111c45ebdSJoe Hamman /* 211c45ebdSJoe Hamman * Copyright 2007 Wind River Systemes, Inc. <www.windriver.com> 311c45ebdSJoe Hamman * Copyright 2007 Embedded Specialties, Inc. 411c45ebdSJoe Hamman * 511c45ebdSJoe Hamman * Copyright 2004, 2007 Freescale Semiconductor. 611c45ebdSJoe Hamman * 711c45ebdSJoe Hamman * (C) Copyright 2002 Scott McNutt <smcnutt@artesyncp.com> 811c45ebdSJoe Hamman * 911c45ebdSJoe Hamman * See file CREDITS for list of people who contributed to this 1011c45ebdSJoe Hamman * project. 1111c45ebdSJoe Hamman * 1211c45ebdSJoe Hamman * This program is free software; you can redistribute it and/or 1311c45ebdSJoe Hamman * modify it under the terms of the GNU General Public License as 1411c45ebdSJoe Hamman * published by the Free Software Foundation; either version 2 of 1511c45ebdSJoe Hamman * the License, or (at your option) any later version. 1611c45ebdSJoe Hamman * 1711c45ebdSJoe Hamman * This program is distributed in the hope that it will be useful, 1811c45ebdSJoe Hamman * but WITHOUT ANY WARRANTY; without even the implied warranty of 1911c45ebdSJoe Hamman * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 2011c45ebdSJoe Hamman * GNU General Public License for more details. 2111c45ebdSJoe Hamman * 2211c45ebdSJoe Hamman * You should have received a copy of the GNU General Public License 2311c45ebdSJoe Hamman * along with this program; if not, write to the Free Software 2411c45ebdSJoe Hamman * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 2511c45ebdSJoe Hamman * MA 02111-1307 USA 2611c45ebdSJoe Hamman */ 2711c45ebdSJoe Hamman 2811c45ebdSJoe Hamman #include <common.h> 2911c45ebdSJoe Hamman #include <pci.h> 3011c45ebdSJoe Hamman #include <asm/processor.h> 3111c45ebdSJoe Hamman #include <asm/immap_85xx.h> 32c8514622SKumar Gala #include <asm/fsl_pci.h> 3333b9079bSKumar Gala #include <asm/fsl_ddr_sdram.h> 34a30a549aSJon Loeliger #include <spd_sdram.h> 3511c45ebdSJoe Hamman #include <miiphy.h> 3611c45ebdSJoe Hamman #include <libfdt.h> 3711c45ebdSJoe Hamman #include <fdt_support.h> 3811c45ebdSJoe Hamman 3911c45ebdSJoe Hamman DECLARE_GLOBAL_DATA_PTR; 4011c45ebdSJoe Hamman 4111c45ebdSJoe Hamman void local_bus_init(void); 4211c45ebdSJoe Hamman void sdram_init(void); 4311c45ebdSJoe Hamman long int fixed_sdram (void); 4411c45ebdSJoe Hamman 4511c45ebdSJoe Hamman int board_early_init_f (void) 4611c45ebdSJoe Hamman { 4711c45ebdSJoe Hamman return 0; 4811c45ebdSJoe Hamman } 4911c45ebdSJoe Hamman 5011c45ebdSJoe Hamman int checkboard (void) 5111c45ebdSJoe Hamman { 526d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_local_ecm_t *ecm = (void *)(CONFIG_SYS_MPC85xx_ECM_ADDR); 546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile u_char *rev= (void *)CONFIG_SYS_BD_REV; 5511c45ebdSJoe Hamman 5611c45ebdSJoe Hamman printf ("Board: Wind River SBC8548 Rev. 0x%01x\n", 57347b7938SJean-Christophe PLAGNIOL-VILLARD (*rev) >> 4); 5811c45ebdSJoe Hamman 5911c45ebdSJoe Hamman /* 6011c45ebdSJoe Hamman * Initialize local bus. 6111c45ebdSJoe Hamman */ 6211c45ebdSJoe Hamman local_bus_init (); 6311c45ebdSJoe Hamman 6411c45ebdSJoe Hamman /* 6511c45ebdSJoe Hamman * Hack TSEC 3 and 4 IO voltages. 6611c45ebdSJoe Hamman */ 6711c45ebdSJoe Hamman gur->tsec34ioovcr = 0xe7e0; /* 1110 0111 1110 0xxx */ 6811c45ebdSJoe Hamman 6911c45ebdSJoe Hamman ecm->eedr = 0xffffffff; /* clear ecm errors */ 7011c45ebdSJoe Hamman ecm->eeer = 0xffffffff; /* enable ecm errors */ 7111c45ebdSJoe Hamman return 0; 7211c45ebdSJoe Hamman } 7311c45ebdSJoe Hamman 749973e3c6SBecky Bruce phys_size_t 7511c45ebdSJoe Hamman initdram(int board_type) 7611c45ebdSJoe Hamman { 7711c45ebdSJoe Hamman long dram_size = 0; 7811c45ebdSJoe Hamman 7911c45ebdSJoe Hamman puts("Initializing\n"); 8011c45ebdSJoe Hamman 8111c45ebdSJoe Hamman #if defined(CONFIG_DDR_DLL) 8211c45ebdSJoe Hamman { 8311c45ebdSJoe Hamman /* 8411c45ebdSJoe Hamman * Work around to stabilize DDR DLL MSYNC_IN. 8511c45ebdSJoe Hamman * Errata DDR9 seems to have been fixed. 8611c45ebdSJoe Hamman * This is now the workaround for Errata DDR11: 8711c45ebdSJoe Hamman * Override DLL = 1, Course Adj = 1, Tap Select = 0 8811c45ebdSJoe Hamman */ 8911c45ebdSJoe Hamman 906d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 9111c45ebdSJoe Hamman 9211c45ebdSJoe Hamman gur->ddrdllcr = 0x81000000; 9311c45ebdSJoe Hamman asm("sync;isync;msync"); 9411c45ebdSJoe Hamman udelay(200); 9511c45ebdSJoe Hamman } 9611c45ebdSJoe Hamman #endif 9711c45ebdSJoe Hamman 9811c45ebdSJoe Hamman #if defined(CONFIG_SPD_EEPROM) 9933b9079bSKumar Gala dram_size = fsl_ddr_sdram(); 10033b9079bSKumar Gala dram_size = setup_ddr_tlbs(dram_size / 0x100000); 10133b9079bSKumar Gala dram_size *= 0x100000; 10211c45ebdSJoe Hamman #else 10311c45ebdSJoe Hamman dram_size = fixed_sdram (); 10411c45ebdSJoe Hamman #endif 10511c45ebdSJoe Hamman 10611c45ebdSJoe Hamman /* 10711c45ebdSJoe Hamman * SDRAM Initialization 10811c45ebdSJoe Hamman */ 10911c45ebdSJoe Hamman sdram_init(); 11011c45ebdSJoe Hamman 11111c45ebdSJoe Hamman puts(" DDR: "); 11211c45ebdSJoe Hamman return dram_size; 11311c45ebdSJoe Hamman } 11411c45ebdSJoe Hamman 11511c45ebdSJoe Hamman /* 11611c45ebdSJoe Hamman * Initialize Local Bus 11711c45ebdSJoe Hamman */ 11811c45ebdSJoe Hamman void 11911c45ebdSJoe Hamman local_bus_init(void) 12011c45ebdSJoe Hamman { 1216d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 1226d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_lbc_t *lbc = (void *)(CONFIG_SYS_MPC85xx_LBC_ADDR); 12311c45ebdSJoe Hamman 12411c45ebdSJoe Hamman uint clkdiv; 12511c45ebdSJoe Hamman uint lbc_hz; 12611c45ebdSJoe Hamman sys_info_t sysinfo; 12711c45ebdSJoe Hamman 12811c45ebdSJoe Hamman get_sys_info(&sysinfo); 129a5d212a2STrent Piepho clkdiv = (lbc->lcrr & LCRR_CLKDIV) * 2; 13011c45ebdSJoe Hamman lbc_hz = sysinfo.freqSystemBus / 1000000 / clkdiv; 13111c45ebdSJoe Hamman 13211c45ebdSJoe Hamman gur->lbiuiplldcr1 = 0x00078080; 13311c45ebdSJoe Hamman if (clkdiv == 16) { 13411c45ebdSJoe Hamman gur->lbiuiplldcr0 = 0x7c0f1bf0; 13511c45ebdSJoe Hamman } else if (clkdiv == 8) { 13611c45ebdSJoe Hamman gur->lbiuiplldcr0 = 0x6c0f1bf0; 13711c45ebdSJoe Hamman } else if (clkdiv == 4) { 13811c45ebdSJoe Hamman gur->lbiuiplldcr0 = 0x5c0f1bf0; 13911c45ebdSJoe Hamman } 14011c45ebdSJoe Hamman 14111c45ebdSJoe Hamman lbc->lcrr |= 0x00030000; 14211c45ebdSJoe Hamman 14311c45ebdSJoe Hamman asm("sync;isync;msync"); 14411c45ebdSJoe Hamman 14511c45ebdSJoe Hamman lbc->ltesr = 0xffffffff; /* Clear LBC error interrupts */ 14611c45ebdSJoe Hamman lbc->lteir = 0xffffffff; /* Enable LBC error interrupts */ 14711c45ebdSJoe Hamman } 14811c45ebdSJoe Hamman 14911c45ebdSJoe Hamman /* 15011c45ebdSJoe Hamman * Initialize SDRAM memory on the Local Bus. 15111c45ebdSJoe Hamman */ 15211c45ebdSJoe Hamman void 15311c45ebdSJoe Hamman sdram_init(void) 15411c45ebdSJoe Hamman { 1556d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_OR3_PRELIM) && defined(CONFIG_SYS_BR3_PRELIM) 15611c45ebdSJoe Hamman 15711c45ebdSJoe Hamman uint idx; 1586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_lbc_t *lbc = (void *)(CONFIG_SYS_MPC85xx_LBC_ADDR); 1596d0f6bcfSJean-Christophe PLAGNIOL-VILLARD uint *sdram_addr = (uint *)CONFIG_SYS_LBC_SDRAM_BASE; 16011c45ebdSJoe Hamman uint lsdmr_common; 16111c45ebdSJoe Hamman 16211c45ebdSJoe Hamman puts(" SDRAM: "); 16311c45ebdSJoe Hamman 1646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD print_size (CONFIG_SYS_LBC_SDRAM_SIZE * 1024 * 1024, "\n"); 16511c45ebdSJoe Hamman 16611c45ebdSJoe Hamman /* 16711c45ebdSJoe Hamman * Setup SDRAM Base and Option Registers 16811c45ebdSJoe Hamman */ 1696d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->or3 = CONFIG_SYS_OR3_PRELIM; 17011c45ebdSJoe Hamman asm("msync"); 17111c45ebdSJoe Hamman 1726d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->br3 = CONFIG_SYS_BR3_PRELIM; 17311c45ebdSJoe Hamman asm("msync"); 17411c45ebdSJoe Hamman 1756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lbcr = CONFIG_SYS_LBC_LBCR; 17611c45ebdSJoe Hamman asm("msync"); 17711c45ebdSJoe Hamman 17811c45ebdSJoe Hamman 1796d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lsrt = CONFIG_SYS_LBC_LSRT; 1806d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->mrtpr = CONFIG_SYS_LBC_MRTPR; 18111c45ebdSJoe Hamman asm("msync"); 18211c45ebdSJoe Hamman 18311c45ebdSJoe Hamman /* 18411c45ebdSJoe Hamman * MPC8548 uses "new" 15-16 style addressing. 18511c45ebdSJoe Hamman */ 1866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lsdmr_common = CONFIG_SYS_LBC_LSDMR_COMMON; 187b0fe93edSKumar Gala lsdmr_common |= LSDMR_BSMA1516; 18811c45ebdSJoe Hamman 18911c45ebdSJoe Hamman /* 19011c45ebdSJoe Hamman * Issue PRECHARGE ALL command. 19111c45ebdSJoe Hamman */ 192b0fe93edSKumar Gala lbc->lsdmr = lsdmr_common | LSDMR_OP_PCHALL; 19311c45ebdSJoe Hamman asm("sync;msync"); 19411c45ebdSJoe Hamman *sdram_addr = 0xff; 19511c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 19611c45ebdSJoe Hamman udelay(100); 19711c45ebdSJoe Hamman 19811c45ebdSJoe Hamman /* 19911c45ebdSJoe Hamman * Issue 8 AUTO REFRESH commands. 20011c45ebdSJoe Hamman */ 20111c45ebdSJoe Hamman for (idx = 0; idx < 8; idx++) { 202b0fe93edSKumar Gala lbc->lsdmr = lsdmr_common | LSDMR_OP_ARFRSH; 20311c45ebdSJoe Hamman asm("sync;msync"); 20411c45ebdSJoe Hamman *sdram_addr = 0xff; 20511c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 20611c45ebdSJoe Hamman udelay(100); 20711c45ebdSJoe Hamman } 20811c45ebdSJoe Hamman 20911c45ebdSJoe Hamman /* 21011c45ebdSJoe Hamman * Issue 8 MODE-set command. 21111c45ebdSJoe Hamman */ 212b0fe93edSKumar Gala lbc->lsdmr = lsdmr_common | LSDMR_OP_MRW; 21311c45ebdSJoe Hamman asm("sync;msync"); 21411c45ebdSJoe Hamman *sdram_addr = 0xff; 21511c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 21611c45ebdSJoe Hamman udelay(100); 21711c45ebdSJoe Hamman 21811c45ebdSJoe Hamman /* 21911c45ebdSJoe Hamman * Issue NORMAL OP command. 22011c45ebdSJoe Hamman */ 221b0fe93edSKumar Gala lbc->lsdmr = lsdmr_common | LSDMR_OP_NORMAL; 22211c45ebdSJoe Hamman asm("sync;msync"); 22311c45ebdSJoe Hamman *sdram_addr = 0xff; 22411c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 22511c45ebdSJoe Hamman udelay(200); /* Overkill. Must wait > 200 bus cycles */ 22611c45ebdSJoe Hamman 22711c45ebdSJoe Hamman #endif /* enable SDRAM init */ 22811c45ebdSJoe Hamman } 22911c45ebdSJoe Hamman 2306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_DRAM_TEST) 23111c45ebdSJoe Hamman int 23211c45ebdSJoe Hamman testdram(void) 23311c45ebdSJoe Hamman { 2346d0f6bcfSJean-Christophe PLAGNIOL-VILLARD uint *pstart = (uint *) CONFIG_SYS_MEMTEST_START; 2356d0f6bcfSJean-Christophe PLAGNIOL-VILLARD uint *pend = (uint *) CONFIG_SYS_MEMTEST_END; 23611c45ebdSJoe Hamman uint *p; 23711c45ebdSJoe Hamman 23811c45ebdSJoe Hamman printf("Testing DRAM from 0x%08x to 0x%08x\n", 2396d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_MEMTEST_START, 2406d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_MEMTEST_END); 24111c45ebdSJoe Hamman 24211c45ebdSJoe Hamman printf("DRAM test phase 1:\n"); 24311c45ebdSJoe Hamman for (p = pstart; p < pend; p++) 24411c45ebdSJoe Hamman *p = 0xaaaaaaaa; 24511c45ebdSJoe Hamman 24611c45ebdSJoe Hamman for (p = pstart; p < pend; p++) { 24711c45ebdSJoe Hamman if (*p != 0xaaaaaaaa) { 24811c45ebdSJoe Hamman printf ("DRAM test fails at: %08x\n", (uint) p); 24911c45ebdSJoe Hamman return 1; 25011c45ebdSJoe Hamman } 25111c45ebdSJoe Hamman } 25211c45ebdSJoe Hamman 25311c45ebdSJoe Hamman printf("DRAM test phase 2:\n"); 25411c45ebdSJoe Hamman for (p = pstart; p < pend; p++) 25511c45ebdSJoe Hamman *p = 0x55555555; 25611c45ebdSJoe Hamman 25711c45ebdSJoe Hamman for (p = pstart; p < pend; p++) { 25811c45ebdSJoe Hamman if (*p != 0x55555555) { 25911c45ebdSJoe Hamman printf ("DRAM test fails at: %08x\n", (uint) p); 26011c45ebdSJoe Hamman return 1; 26111c45ebdSJoe Hamman } 26211c45ebdSJoe Hamman } 26311c45ebdSJoe Hamman 26411c45ebdSJoe Hamman printf("DRAM test passed.\n"); 26511c45ebdSJoe Hamman return 0; 26611c45ebdSJoe Hamman } 26711c45ebdSJoe Hamman #endif 26811c45ebdSJoe Hamman 26911c45ebdSJoe Hamman #if !defined(CONFIG_SPD_EEPROM) 27011c45ebdSJoe Hamman /************************************************************************* 27111c45ebdSJoe Hamman * fixed_sdram init -- doesn't use serial presence detect. 27211c45ebdSJoe Hamman * assumes 256MB DDR2 SDRAM SODIMM, without ECC, running at DDR400 speed. 27311c45ebdSJoe Hamman ************************************************************************/ 27411c45ebdSJoe Hamman long int fixed_sdram (void) 27511c45ebdSJoe Hamman { 2766d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_CONTROL 0xc300c000 27711c45ebdSJoe Hamman 2786d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_ddr_t *ddr = (void *)(CONFIG_SYS_MPC85xx_DDR_ADDR); 27911c45ebdSJoe Hamman 28011c45ebdSJoe Hamman ddr->cs0_bnds = 0x0000007f; 28111c45ebdSJoe Hamman ddr->cs1_bnds = 0x008000ff; 28211c45ebdSJoe Hamman ddr->cs2_bnds = 0x00000000; 28311c45ebdSJoe Hamman ddr->cs3_bnds = 0x00000000; 28411c45ebdSJoe Hamman ddr->cs0_config = 0x80010101; 28511c45ebdSJoe Hamman ddr->cs1_config = 0x80010101; 28611c45ebdSJoe Hamman ddr->cs2_config = 0x00000000; 28711c45ebdSJoe Hamman ddr->cs3_config = 0x00000000; 28845239cf4SKumar Gala ddr->timing_cfg_3 = 0x00000000; 28911c45ebdSJoe Hamman ddr->timing_cfg_0 = 0x00220802; 29011c45ebdSJoe Hamman ddr->timing_cfg_1 = 0x38377322; 29111c45ebdSJoe Hamman ddr->timing_cfg_2 = 0x0fa044C7; 29211c45ebdSJoe Hamman ddr->sdram_cfg = 0x4300C000; 29311c45ebdSJoe Hamman ddr->sdram_cfg_2 = 0x24401000; 29411c45ebdSJoe Hamman ddr->sdram_mode = 0x23C00542; 29511c45ebdSJoe Hamman ddr->sdram_mode_2 = 0x00000000; 29611c45ebdSJoe Hamman ddr->sdram_interval = 0x05080100; 29711c45ebdSJoe Hamman ddr->sdram_md_cntl = 0x00000000; 29811c45ebdSJoe Hamman ddr->sdram_data_init = 0x00000000; 29911c45ebdSJoe Hamman ddr->sdram_clk_cntl = 0x03800000; 30011c45ebdSJoe Hamman asm("sync;isync;msync"); 30111c45ebdSJoe Hamman udelay(500); 30211c45ebdSJoe Hamman 30311c45ebdSJoe Hamman #if defined (CONFIG_DDR_ECC) 30411c45ebdSJoe Hamman /* Enable ECC checking */ 3056d0f6bcfSJean-Christophe PLAGNIOL-VILLARD ddr->sdram_cfg = (CONFIG_SYS_DDR_CONTROL | 0x20000000); 30611c45ebdSJoe Hamman #else 3076d0f6bcfSJean-Christophe PLAGNIOL-VILLARD ddr->sdram_cfg = CONFIG_SYS_DDR_CONTROL; 30811c45ebdSJoe Hamman #endif 30911c45ebdSJoe Hamman 3106d0f6bcfSJean-Christophe PLAGNIOL-VILLARD return CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; 31111c45ebdSJoe Hamman } 31211c45ebdSJoe Hamman #endif 31311c45ebdSJoe Hamman 31411c45ebdSJoe Hamman #if defined(CONFIG_PCI) || defined(CONFIG_PCI1) 31511c45ebdSJoe Hamman /* For some reason the Tundra PCI bridge shows up on itself as a 31611c45ebdSJoe Hamman * different device. Work around that by refusing to configure it. 31711c45ebdSJoe Hamman */ 31811c45ebdSJoe Hamman void dummy_func(struct pci_controller* hose, pci_dev_t dev, struct pci_config_table *tab) { } 31911c45ebdSJoe Hamman 32011c45ebdSJoe Hamman static struct pci_config_table pci_sbc8548_config_table[] = { 32111c45ebdSJoe Hamman {0x10e3, 0x0513, PCI_ANY_ID, 1, 3, PCI_ANY_ID, dummy_func, {0,0,0}}, 32211c45ebdSJoe Hamman {0x1106, 0x0686, PCI_ANY_ID, 1, VIA_ID, 0, mpc85xx_config_via, {0,0,0}}, 32311c45ebdSJoe Hamman {0x1106, 0x0571, PCI_ANY_ID, 1, VIA_ID, 1, 32411c45ebdSJoe Hamman mpc85xx_config_via_usbide, {0,0,0}}, 32511c45ebdSJoe Hamman {0x1105, 0x3038, PCI_ANY_ID, 1, VIA_ID, 2, 32611c45ebdSJoe Hamman mpc85xx_config_via_usb, {0,0,0}}, 32711c45ebdSJoe Hamman {0x1106, 0x3038, PCI_ANY_ID, 1, VIA_ID, 3, 32811c45ebdSJoe Hamman mpc85xx_config_via_usb2, {0,0,0}}, 32911c45ebdSJoe Hamman {0x1106, 0x3058, PCI_ANY_ID, 1, VIA_ID, 5, 33011c45ebdSJoe Hamman mpc85xx_config_via_power, {0,0,0}}, 33111c45ebdSJoe Hamman {0x1106, 0x3068, PCI_ANY_ID, 1, VIA_ID, 6, 33211c45ebdSJoe Hamman mpc85xx_config_via_ac97, {0,0,0}}, 33311c45ebdSJoe Hamman {}, 33411c45ebdSJoe Hamman }; 33511c45ebdSJoe Hamman 33611c45ebdSJoe Hamman static struct pci_controller pci1_hose = { 33711c45ebdSJoe Hamman config_table: pci_sbc8548_config_table}; 33811c45ebdSJoe Hamman #endif /* CONFIG_PCI */ 33911c45ebdSJoe Hamman 34011c45ebdSJoe Hamman #ifdef CONFIG_PCI2 34111c45ebdSJoe Hamman static struct pci_controller pci2_hose; 34211c45ebdSJoe Hamman #endif /* CONFIG_PCI2 */ 34311c45ebdSJoe Hamman 34411c45ebdSJoe Hamman #ifdef CONFIG_PCIE1 34511c45ebdSJoe Hamman static struct pci_controller pcie1_hose; 34611c45ebdSJoe Hamman #endif /* CONFIG_PCIE1 */ 34711c45ebdSJoe Hamman 34811c45ebdSJoe Hamman int first_free_busno=0; 34911c45ebdSJoe Hamman 35011c45ebdSJoe Hamman void 35111c45ebdSJoe Hamman pci_init_board(void) 35211c45ebdSJoe Hamman { 3536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 35411c45ebdSJoe Hamman 35511c45ebdSJoe Hamman #ifdef CONFIG_PCI1 35611c45ebdSJoe Hamman { 3576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_fsl_pci_t *pci = (ccsr_fsl_pci_t *) CONFIG_SYS_PCI1_ADDR; 35811c45ebdSJoe Hamman struct pci_controller *hose = &pci1_hose; 35911c45ebdSJoe Hamman struct pci_config_table *table; 3602dba0deaSKumar Gala struct pci_region *r = hose->regions; 36111c45ebdSJoe Hamman 36211c45ebdSJoe Hamman uint pci_32 = gur->pordevsr & MPC85xx_PORDEVSR_PCI1_PCI32; /* PORDEVSR[15] */ 36311c45ebdSJoe Hamman uint pci_arb = gur->pordevsr & MPC85xx_PORDEVSR_PCI1_ARB; /* PORDEVSR[14] */ 36411c45ebdSJoe Hamman uint pci_clk_sel = gur->porpllsr & MPC85xx_PORDEVSR_PCI1_SPD; /* PORPLLSR[16] */ 36511c45ebdSJoe Hamman 366*3e7b6c1fSKumar Gala uint pci_agent = is_fsl_pci_agent(LAW_TRGT_IF_PCI_1, host_agent); 36711c45ebdSJoe Hamman 36811c45ebdSJoe Hamman uint pci_speed = get_clock_freq (); /* PCI PSPEED in [4:5] */ 36911c45ebdSJoe Hamman 37011c45ebdSJoe Hamman if (!(gur->devdisr & MPC85xx_DEVDISR_PCI1)) { 37111c45ebdSJoe Hamman printf (" PCI: %d bit, %s MHz, %s, %s, %s\n", 37211c45ebdSJoe Hamman (pci_32) ? 32 : 64, 37311c45ebdSJoe Hamman (pci_speed == 33333000) ? "33" : 37411c45ebdSJoe Hamman (pci_speed == 66666000) ? "66" : "unknown", 37511c45ebdSJoe Hamman pci_clk_sel ? "sync" : "async", 37611c45ebdSJoe Hamman pci_agent ? "agent" : "host", 37711c45ebdSJoe Hamman pci_arb ? "arbiter" : "external-arbiter" 37811c45ebdSJoe Hamman ); 37911c45ebdSJoe Hamman 38011c45ebdSJoe Hamman /* outbound memory */ 3812dba0deaSKumar Gala pci_set_region(r++, 3826d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_MEM_BASE, 3836d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_MEM_PHYS, 3846d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_MEM_SIZE, 38511c45ebdSJoe Hamman PCI_REGION_MEM); 38611c45ebdSJoe Hamman 38711c45ebdSJoe Hamman /* outbound io */ 3882dba0deaSKumar Gala pci_set_region(r++, 3896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_IO_BASE, 3906d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_IO_PHYS, 3916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_IO_SIZE, 39211c45ebdSJoe Hamman PCI_REGION_IO); 3932dba0deaSKumar Gala hose->region_count = r - hose->regions; 39411c45ebdSJoe Hamman 39511c45ebdSJoe Hamman /* relocate config table pointers */ 39611c45ebdSJoe Hamman hose->config_table = \ 39711c45ebdSJoe Hamman (struct pci_config_table *)((uint)hose->config_table + gd->reloc_off); 39811c45ebdSJoe Hamman for (table = hose->config_table; table && table->vendor; table++) 39911c45ebdSJoe Hamman table->config_device += gd->reloc_off; 40011c45ebdSJoe Hamman 40111c45ebdSJoe Hamman hose->first_busno=first_free_busno; 40211c45ebdSJoe Hamman 403fb3143b3SKumar Gala fsl_pci_init(hose, (u32)&pci->cfg_addr, (u32)&pci->cfg_data); 40411c45ebdSJoe Hamman first_free_busno=hose->last_busno+1; 40511c45ebdSJoe Hamman printf ("PCI on bus %02x - %02x\n",hose->first_busno,hose->last_busno); 40611c45ebdSJoe Hamman #ifdef CONFIG_PCIX_CHECK 4079427ccdeSPeter Tyser if (!(gur->pordevsr & MPC85xx_PORDEVSR_PCI1)) { 40811c45ebdSJoe Hamman /* PCI-X init */ 40911c45ebdSJoe Hamman if (CONFIG_SYS_CLK_FREQ < 66000000) 41011c45ebdSJoe Hamman printf("PCI-X will only work at 66 MHz\n"); 41111c45ebdSJoe Hamman 41211c45ebdSJoe Hamman reg16 = PCI_X_CMD_MAX_SPLIT | PCI_X_CMD_MAX_READ 41311c45ebdSJoe Hamman | PCI_X_CMD_ERO | PCI_X_CMD_DPERR_E; 41411c45ebdSJoe Hamman pci_hose_write_config_word(hose, bus, PCIX_COMMAND, reg16); 41511c45ebdSJoe Hamman } 41611c45ebdSJoe Hamman #endif 41711c45ebdSJoe Hamman } else { 41811c45ebdSJoe Hamman printf (" PCI: disabled\n"); 41911c45ebdSJoe Hamman } 42011c45ebdSJoe Hamman } 42111c45ebdSJoe Hamman #else 42211c45ebdSJoe Hamman gur->devdisr |= MPC85xx_DEVDISR_PCI1; /* disable */ 42311c45ebdSJoe Hamman #endif 42411c45ebdSJoe Hamman 42511c45ebdSJoe Hamman #ifdef CONFIG_PCI2 42611c45ebdSJoe Hamman { 42711c45ebdSJoe Hamman uint pci2_clk_sel = gur->porpllsr & 0x4000; /* PORPLLSR[17] */ 42811c45ebdSJoe Hamman uint pci_dual = get_pci_dual (); /* PCI DUAL in CM_PCI[3] */ 42911c45ebdSJoe Hamman if (pci_dual) { 43011c45ebdSJoe Hamman printf (" PCI2: 32 bit, 66 MHz, %s\n", 43111c45ebdSJoe Hamman pci2_clk_sel ? "sync" : "async"); 43211c45ebdSJoe Hamman } else { 43311c45ebdSJoe Hamman printf (" PCI2: disabled\n"); 43411c45ebdSJoe Hamman } 43511c45ebdSJoe Hamman } 43611c45ebdSJoe Hamman #else 43711c45ebdSJoe Hamman gur->devdisr |= MPC85xx_DEVDISR_PCI2; /* disable */ 43811c45ebdSJoe Hamman #endif /* CONFIG_PCI2 */ 43911c45ebdSJoe Hamman 44011c45ebdSJoe Hamman #ifdef CONFIG_PCIE1 44111c45ebdSJoe Hamman { 4426d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_fsl_pci_t *pci = (ccsr_fsl_pci_t *) CONFIG_SYS_PCIE1_ADDR; 44311c45ebdSJoe Hamman struct pci_controller *hose = &pcie1_hose; 444*3e7b6c1fSKumar Gala int pcie_ep = is_fsl_pci_agent(LAW_TRGT_IF_PCIE_1, host_agent); 4452dba0deaSKumar Gala struct pci_region *r = hose->regions; 44611c45ebdSJoe Hamman 447*3e7b6c1fSKumar Gala int pcie_configured = is_fsl_pci_cfg(LAW_TRGT_IF_PCIE_1, io_sel); 44811c45ebdSJoe Hamman 44911c45ebdSJoe Hamman if (pcie_configured && !(gur->devdisr & MPC85xx_DEVDISR_PCIE)){ 45011c45ebdSJoe Hamman printf ("\n PCIE connected to slot as %s (base address %x)", 45111c45ebdSJoe Hamman pcie_ep ? "End Point" : "Root Complex", 45211c45ebdSJoe Hamman (uint)pci); 45311c45ebdSJoe Hamman 45411c45ebdSJoe Hamman if (pci->pme_msg_det) { 45511c45ebdSJoe Hamman pci->pme_msg_det = 0xffffffff; 45611c45ebdSJoe Hamman debug (" with errors. Clearing. Now 0x%08x",pci->pme_msg_det); 45711c45ebdSJoe Hamman } 45811c45ebdSJoe Hamman printf ("\n"); 45911c45ebdSJoe Hamman 46011c45ebdSJoe Hamman /* outbound memory */ 4612dba0deaSKumar Gala pci_set_region(r++, 4626d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_MEM_BASE, 4636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_MEM_PHYS, 4646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_MEM_SIZE, 46511c45ebdSJoe Hamman PCI_REGION_MEM); 46611c45ebdSJoe Hamman 46711c45ebdSJoe Hamman /* outbound io */ 4682dba0deaSKumar Gala pci_set_region(r++, 4696d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_IO_BASE, 4706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_IO_PHYS, 4716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_IO_SIZE, 47211c45ebdSJoe Hamman PCI_REGION_IO); 47311c45ebdSJoe Hamman 4742dba0deaSKumar Gala hose->region_count = r - hose->regions; 47511c45ebdSJoe Hamman 47611c45ebdSJoe Hamman hose->first_busno=first_free_busno; 47711c45ebdSJoe Hamman 478fb3143b3SKumar Gala fsl_pci_init(hose, (u32)&pci->cfg_addr, (u32)&pci->cfg_data); 47911c45ebdSJoe Hamman printf ("PCIE on bus %d - %d\n",hose->first_busno,hose->last_busno); 48011c45ebdSJoe Hamman 48111c45ebdSJoe Hamman first_free_busno=hose->last_busno+1; 48211c45ebdSJoe Hamman 48311c45ebdSJoe Hamman } else { 48411c45ebdSJoe Hamman printf (" PCIE: disabled\n"); 48511c45ebdSJoe Hamman } 48611c45ebdSJoe Hamman } 48711c45ebdSJoe Hamman #else 48811c45ebdSJoe Hamman gur->devdisr |= MPC85xx_DEVDISR_PCIE; /* disable */ 48911c45ebdSJoe Hamman #endif 49011c45ebdSJoe Hamman 49111c45ebdSJoe Hamman } 49211c45ebdSJoe Hamman 49311c45ebdSJoe Hamman int last_stage_init(void) 49411c45ebdSJoe Hamman { 49511c45ebdSJoe Hamman return 0; 49611c45ebdSJoe Hamman } 49711c45ebdSJoe Hamman 49811c45ebdSJoe Hamman #if defined(CONFIG_OF_BOARD_SETUP) 4992dba0deaSKumar Gala void ft_board_setup(void *blob, bd_t *bd) 50011c45ebdSJoe Hamman { 50111c45ebdSJoe Hamman ft_cpu_setup(blob, bd); 5022dba0deaSKumar Gala #ifdef CONFIG_PCI1 5032dba0deaSKumar Gala ft_fsl_pci_setup(blob, "pci0", &pci1_hose); 5042dba0deaSKumar Gala #endif 5052dba0deaSKumar Gala #ifdef CONFIG_PCIE1 5062dba0deaSKumar Gala ft_fsl_pci_setup(blob, "pci1", &pcie1_hose); 50711c45ebdSJoe Hamman #endif 50811c45ebdSJoe Hamman } 50911c45ebdSJoe Hamman #endif 510