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> 3211c45ebdSJoe Hamman #include <asm/immap_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 #if defined(CONFIG_DDR_ECC) && !defined(CONFIG_ECC_INIT_VIA_DDRCONTROLLER) 4011c45ebdSJoe Hamman extern void ddr_enable_ecc(unsigned int dram_size); 4111c45ebdSJoe Hamman #endif 4211c45ebdSJoe Hamman 4311c45ebdSJoe Hamman DECLARE_GLOBAL_DATA_PTR; 4411c45ebdSJoe Hamman 4511c45ebdSJoe Hamman void local_bus_init(void); 4611c45ebdSJoe Hamman void sdram_init(void); 4711c45ebdSJoe Hamman long int fixed_sdram (void); 4811c45ebdSJoe Hamman 4911c45ebdSJoe Hamman int board_early_init_f (void) 5011c45ebdSJoe Hamman { 5111c45ebdSJoe Hamman return 0; 5211c45ebdSJoe Hamman } 5311c45ebdSJoe Hamman 5411c45ebdSJoe Hamman int checkboard (void) 5511c45ebdSJoe Hamman { 566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_local_ecm_t *ecm = (void *)(CONFIG_SYS_MPC85xx_ECM_ADDR); 586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile u_char *rev= (void *)CONFIG_SYS_BD_REV; 5911c45ebdSJoe Hamman 6011c45ebdSJoe Hamman printf ("Board: Wind River SBC8548 Rev. 0x%01x\n", 61347b7938SJean-Christophe PLAGNIOL-VILLARD (*rev) >> 4); 6211c45ebdSJoe Hamman 6311c45ebdSJoe Hamman /* 6411c45ebdSJoe Hamman * Initialize local bus. 6511c45ebdSJoe Hamman */ 6611c45ebdSJoe Hamman local_bus_init (); 6711c45ebdSJoe Hamman 6811c45ebdSJoe Hamman /* 6911c45ebdSJoe Hamman * Fix CPU2 errata: A core hang possible while executing a 7011c45ebdSJoe Hamman * msync instruction and a snoopable transaction from an I/O 7111c45ebdSJoe Hamman * master tagged to make quick forward progress is present. 7211c45ebdSJoe Hamman */ 7311c45ebdSJoe Hamman ecm->eebpcr |= (1 << 16); 7411c45ebdSJoe Hamman 7511c45ebdSJoe Hamman /* 7611c45ebdSJoe Hamman * Hack TSEC 3 and 4 IO voltages. 7711c45ebdSJoe Hamman */ 7811c45ebdSJoe Hamman gur->tsec34ioovcr = 0xe7e0; /* 1110 0111 1110 0xxx */ 7911c45ebdSJoe Hamman 8011c45ebdSJoe Hamman ecm->eedr = 0xffffffff; /* clear ecm errors */ 8111c45ebdSJoe Hamman ecm->eeer = 0xffffffff; /* enable ecm errors */ 8211c45ebdSJoe Hamman return 0; 8311c45ebdSJoe Hamman } 8411c45ebdSJoe Hamman 859973e3c6SBecky Bruce phys_size_t 8611c45ebdSJoe Hamman initdram(int board_type) 8711c45ebdSJoe Hamman { 8811c45ebdSJoe Hamman long dram_size = 0; 8911c45ebdSJoe Hamman 9011c45ebdSJoe Hamman puts("Initializing\n"); 9111c45ebdSJoe Hamman 9211c45ebdSJoe Hamman #if defined(CONFIG_DDR_DLL) 9311c45ebdSJoe Hamman { 9411c45ebdSJoe Hamman /* 9511c45ebdSJoe Hamman * Work around to stabilize DDR DLL MSYNC_IN. 9611c45ebdSJoe Hamman * Errata DDR9 seems to have been fixed. 9711c45ebdSJoe Hamman * This is now the workaround for Errata DDR11: 9811c45ebdSJoe Hamman * Override DLL = 1, Course Adj = 1, Tap Select = 0 9911c45ebdSJoe Hamman */ 10011c45ebdSJoe Hamman 1016d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 10211c45ebdSJoe Hamman 10311c45ebdSJoe Hamman gur->ddrdllcr = 0x81000000; 10411c45ebdSJoe Hamman asm("sync;isync;msync"); 10511c45ebdSJoe Hamman udelay(200); 10611c45ebdSJoe Hamman } 10711c45ebdSJoe Hamman #endif 10811c45ebdSJoe Hamman 10911c45ebdSJoe Hamman #if defined(CONFIG_SPD_EEPROM) 11033b9079bSKumar Gala dram_size = fsl_ddr_sdram(); 11133b9079bSKumar Gala dram_size = setup_ddr_tlbs(dram_size / 0x100000); 11233b9079bSKumar Gala dram_size *= 0x100000; 11311c45ebdSJoe Hamman #else 11411c45ebdSJoe Hamman dram_size = fixed_sdram (); 11511c45ebdSJoe Hamman #endif 11611c45ebdSJoe Hamman 11711c45ebdSJoe Hamman #if defined(CONFIG_DDR_ECC) && !defined(CONFIG_ECC_INIT_VIA_DDRCONTROLLER) 11811c45ebdSJoe Hamman /* 11911c45ebdSJoe Hamman * Initialize and enable DDR ECC. 12011c45ebdSJoe Hamman */ 12111c45ebdSJoe Hamman ddr_enable_ecc(dram_size); 12211c45ebdSJoe Hamman #endif 12311c45ebdSJoe Hamman /* 12411c45ebdSJoe Hamman * SDRAM Initialization 12511c45ebdSJoe Hamman */ 12611c45ebdSJoe Hamman sdram_init(); 12711c45ebdSJoe Hamman 12811c45ebdSJoe Hamman puts(" DDR: "); 12911c45ebdSJoe Hamman return dram_size; 13011c45ebdSJoe Hamman } 13111c45ebdSJoe Hamman 13211c45ebdSJoe Hamman /* 13311c45ebdSJoe Hamman * Initialize Local Bus 13411c45ebdSJoe Hamman */ 13511c45ebdSJoe Hamman void 13611c45ebdSJoe Hamman local_bus_init(void) 13711c45ebdSJoe Hamman { 1386d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 1396d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_lbc_t *lbc = (void *)(CONFIG_SYS_MPC85xx_LBC_ADDR); 14011c45ebdSJoe Hamman 14111c45ebdSJoe Hamman uint clkdiv; 14211c45ebdSJoe Hamman uint lbc_hz; 14311c45ebdSJoe Hamman sys_info_t sysinfo; 14411c45ebdSJoe Hamman 14511c45ebdSJoe Hamman get_sys_info(&sysinfo); 14611c45ebdSJoe Hamman clkdiv = (lbc->lcrr & 0x0f) * 2; 14711c45ebdSJoe Hamman lbc_hz = sysinfo.freqSystemBus / 1000000 / clkdiv; 14811c45ebdSJoe Hamman 14911c45ebdSJoe Hamman gur->lbiuiplldcr1 = 0x00078080; 15011c45ebdSJoe Hamman if (clkdiv == 16) { 15111c45ebdSJoe Hamman gur->lbiuiplldcr0 = 0x7c0f1bf0; 15211c45ebdSJoe Hamman } else if (clkdiv == 8) { 15311c45ebdSJoe Hamman gur->lbiuiplldcr0 = 0x6c0f1bf0; 15411c45ebdSJoe Hamman } else if (clkdiv == 4) { 15511c45ebdSJoe Hamman gur->lbiuiplldcr0 = 0x5c0f1bf0; 15611c45ebdSJoe Hamman } 15711c45ebdSJoe Hamman 15811c45ebdSJoe Hamman lbc->lcrr |= 0x00030000; 15911c45ebdSJoe Hamman 16011c45ebdSJoe Hamman asm("sync;isync;msync"); 16111c45ebdSJoe Hamman 16211c45ebdSJoe Hamman lbc->ltesr = 0xffffffff; /* Clear LBC error interrupts */ 16311c45ebdSJoe Hamman lbc->lteir = 0xffffffff; /* Enable LBC error interrupts */ 16411c45ebdSJoe Hamman } 16511c45ebdSJoe Hamman 16611c45ebdSJoe Hamman /* 16711c45ebdSJoe Hamman * Initialize SDRAM memory on the Local Bus. 16811c45ebdSJoe Hamman */ 16911c45ebdSJoe Hamman void 17011c45ebdSJoe Hamman sdram_init(void) 17111c45ebdSJoe Hamman { 1726d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_OR3_PRELIM) && defined(CONFIG_SYS_BR3_PRELIM) 17311c45ebdSJoe Hamman 17411c45ebdSJoe Hamman uint idx; 1756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_lbc_t *lbc = (void *)(CONFIG_SYS_MPC85xx_LBC_ADDR); 1766d0f6bcfSJean-Christophe PLAGNIOL-VILLARD uint *sdram_addr = (uint *)CONFIG_SYS_LBC_SDRAM_BASE; 17711c45ebdSJoe Hamman uint lsdmr_common; 17811c45ebdSJoe Hamman 17911c45ebdSJoe Hamman puts(" SDRAM: "); 18011c45ebdSJoe Hamman 1816d0f6bcfSJean-Christophe PLAGNIOL-VILLARD print_size (CONFIG_SYS_LBC_SDRAM_SIZE * 1024 * 1024, "\n"); 18211c45ebdSJoe Hamman 18311c45ebdSJoe Hamman /* 18411c45ebdSJoe Hamman * Setup SDRAM Base and Option Registers 18511c45ebdSJoe Hamman */ 1866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->or3 = CONFIG_SYS_OR3_PRELIM; 18711c45ebdSJoe Hamman asm("msync"); 18811c45ebdSJoe Hamman 1896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->br3 = CONFIG_SYS_BR3_PRELIM; 19011c45ebdSJoe Hamman asm("msync"); 19111c45ebdSJoe Hamman 1926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lbcr = CONFIG_SYS_LBC_LBCR; 19311c45ebdSJoe Hamman asm("msync"); 19411c45ebdSJoe Hamman 19511c45ebdSJoe Hamman 1966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lsrt = CONFIG_SYS_LBC_LSRT; 1976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->mrtpr = CONFIG_SYS_LBC_MRTPR; 19811c45ebdSJoe Hamman asm("msync"); 19911c45ebdSJoe Hamman 20011c45ebdSJoe Hamman /* 20111c45ebdSJoe Hamman * MPC8548 uses "new" 15-16 style addressing. 20211c45ebdSJoe Hamman */ 2036d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lsdmr_common = CONFIG_SYS_LBC_LSDMR_COMMON; 2046d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lsdmr_common |= CONFIG_SYS_LBC_LSDMR_BSMA1516; 20511c45ebdSJoe Hamman 20611c45ebdSJoe Hamman /* 20711c45ebdSJoe Hamman * Issue PRECHARGE ALL command. 20811c45ebdSJoe Hamman */ 2096d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lsdmr = lsdmr_common | CONFIG_SYS_LBC_LSDMR_OP_PCHALL; 21011c45ebdSJoe Hamman asm("sync;msync"); 21111c45ebdSJoe Hamman *sdram_addr = 0xff; 21211c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 21311c45ebdSJoe Hamman udelay(100); 21411c45ebdSJoe Hamman 21511c45ebdSJoe Hamman /* 21611c45ebdSJoe Hamman * Issue 8 AUTO REFRESH commands. 21711c45ebdSJoe Hamman */ 21811c45ebdSJoe Hamman for (idx = 0; idx < 8; idx++) { 2196d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lsdmr = lsdmr_common | CONFIG_SYS_LBC_LSDMR_OP_ARFRSH; 22011c45ebdSJoe Hamman asm("sync;msync"); 22111c45ebdSJoe Hamman *sdram_addr = 0xff; 22211c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 22311c45ebdSJoe Hamman udelay(100); 22411c45ebdSJoe Hamman } 22511c45ebdSJoe Hamman 22611c45ebdSJoe Hamman /* 22711c45ebdSJoe Hamman * Issue 8 MODE-set command. 22811c45ebdSJoe Hamman */ 2296d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lsdmr = lsdmr_common | CONFIG_SYS_LBC_LSDMR_OP_MRW; 23011c45ebdSJoe Hamman asm("sync;msync"); 23111c45ebdSJoe Hamman *sdram_addr = 0xff; 23211c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 23311c45ebdSJoe Hamman udelay(100); 23411c45ebdSJoe Hamman 23511c45ebdSJoe Hamman /* 23611c45ebdSJoe Hamman * Issue NORMAL OP command. 23711c45ebdSJoe Hamman */ 2386d0f6bcfSJean-Christophe PLAGNIOL-VILLARD lbc->lsdmr = lsdmr_common | CONFIG_SYS_LBC_LSDMR_OP_NORMAL; 23911c45ebdSJoe Hamman asm("sync;msync"); 24011c45ebdSJoe Hamman *sdram_addr = 0xff; 24111c45ebdSJoe Hamman ppcDcbf((unsigned long) sdram_addr); 24211c45ebdSJoe Hamman udelay(200); /* Overkill. Must wait > 200 bus cycles */ 24311c45ebdSJoe Hamman 24411c45ebdSJoe Hamman #endif /* enable SDRAM init */ 24511c45ebdSJoe Hamman } 24611c45ebdSJoe Hamman 2476d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_DRAM_TEST) 24811c45ebdSJoe Hamman int 24911c45ebdSJoe Hamman testdram(void) 25011c45ebdSJoe Hamman { 2516d0f6bcfSJean-Christophe PLAGNIOL-VILLARD uint *pstart = (uint *) CONFIG_SYS_MEMTEST_START; 2526d0f6bcfSJean-Christophe PLAGNIOL-VILLARD uint *pend = (uint *) CONFIG_SYS_MEMTEST_END; 25311c45ebdSJoe Hamman uint *p; 25411c45ebdSJoe Hamman 25511c45ebdSJoe Hamman printf("Testing DRAM from 0x%08x to 0x%08x\n", 2566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_MEMTEST_START, 2576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_MEMTEST_END); 25811c45ebdSJoe Hamman 25911c45ebdSJoe Hamman printf("DRAM test phase 1:\n"); 26011c45ebdSJoe Hamman for (p = pstart; p < pend; p++) 26111c45ebdSJoe Hamman *p = 0xaaaaaaaa; 26211c45ebdSJoe Hamman 26311c45ebdSJoe Hamman for (p = pstart; p < pend; p++) { 26411c45ebdSJoe Hamman if (*p != 0xaaaaaaaa) { 26511c45ebdSJoe Hamman printf ("DRAM test fails at: %08x\n", (uint) p); 26611c45ebdSJoe Hamman return 1; 26711c45ebdSJoe Hamman } 26811c45ebdSJoe Hamman } 26911c45ebdSJoe Hamman 27011c45ebdSJoe Hamman printf("DRAM test phase 2:\n"); 27111c45ebdSJoe Hamman for (p = pstart; p < pend; p++) 27211c45ebdSJoe Hamman *p = 0x55555555; 27311c45ebdSJoe Hamman 27411c45ebdSJoe Hamman for (p = pstart; p < pend; p++) { 27511c45ebdSJoe Hamman if (*p != 0x55555555) { 27611c45ebdSJoe Hamman printf ("DRAM test fails at: %08x\n", (uint) p); 27711c45ebdSJoe Hamman return 1; 27811c45ebdSJoe Hamman } 27911c45ebdSJoe Hamman } 28011c45ebdSJoe Hamman 28111c45ebdSJoe Hamman printf("DRAM test passed.\n"); 28211c45ebdSJoe Hamman return 0; 28311c45ebdSJoe Hamman } 28411c45ebdSJoe Hamman #endif 28511c45ebdSJoe Hamman 28611c45ebdSJoe Hamman #if !defined(CONFIG_SPD_EEPROM) 28711c45ebdSJoe Hamman /************************************************************************* 28811c45ebdSJoe Hamman * fixed_sdram init -- doesn't use serial presence detect. 28911c45ebdSJoe Hamman * assumes 256MB DDR2 SDRAM SODIMM, without ECC, running at DDR400 speed. 29011c45ebdSJoe Hamman ************************************************************************/ 29111c45ebdSJoe Hamman long int fixed_sdram (void) 29211c45ebdSJoe Hamman { 2936d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_CONTROL 0xc300c000 29411c45ebdSJoe Hamman 2956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_ddr_t *ddr = (void *)(CONFIG_SYS_MPC85xx_DDR_ADDR); 29611c45ebdSJoe Hamman 29711c45ebdSJoe Hamman ddr->cs0_bnds = 0x0000007f; 29811c45ebdSJoe Hamman ddr->cs1_bnds = 0x008000ff; 29911c45ebdSJoe Hamman ddr->cs2_bnds = 0x00000000; 30011c45ebdSJoe Hamman ddr->cs3_bnds = 0x00000000; 30111c45ebdSJoe Hamman ddr->cs0_config = 0x80010101; 30211c45ebdSJoe Hamman ddr->cs1_config = 0x80010101; 30311c45ebdSJoe Hamman ddr->cs2_config = 0x00000000; 30411c45ebdSJoe Hamman ddr->cs3_config = 0x00000000; 30545239cf4SKumar Gala ddr->timing_cfg_3 = 0x00000000; 30611c45ebdSJoe Hamman ddr->timing_cfg_0 = 0x00220802; 30711c45ebdSJoe Hamman ddr->timing_cfg_1 = 0x38377322; 30811c45ebdSJoe Hamman ddr->timing_cfg_2 = 0x0fa044C7; 30911c45ebdSJoe Hamman ddr->sdram_cfg = 0x4300C000; 31011c45ebdSJoe Hamman ddr->sdram_cfg_2 = 0x24401000; 31111c45ebdSJoe Hamman ddr->sdram_mode = 0x23C00542; 31211c45ebdSJoe Hamman ddr->sdram_mode_2 = 0x00000000; 31311c45ebdSJoe Hamman ddr->sdram_interval = 0x05080100; 31411c45ebdSJoe Hamman ddr->sdram_md_cntl = 0x00000000; 31511c45ebdSJoe Hamman ddr->sdram_data_init = 0x00000000; 31611c45ebdSJoe Hamman ddr->sdram_clk_cntl = 0x03800000; 31711c45ebdSJoe Hamman asm("sync;isync;msync"); 31811c45ebdSJoe Hamman udelay(500); 31911c45ebdSJoe Hamman 32011c45ebdSJoe Hamman #if defined (CONFIG_DDR_ECC) 32111c45ebdSJoe Hamman /* Enable ECC checking */ 3226d0f6bcfSJean-Christophe PLAGNIOL-VILLARD ddr->sdram_cfg = (CONFIG_SYS_DDR_CONTROL | 0x20000000); 32311c45ebdSJoe Hamman #else 3246d0f6bcfSJean-Christophe PLAGNIOL-VILLARD ddr->sdram_cfg = CONFIG_SYS_DDR_CONTROL; 32511c45ebdSJoe Hamman #endif 32611c45ebdSJoe Hamman 3276d0f6bcfSJean-Christophe PLAGNIOL-VILLARD return CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; 32811c45ebdSJoe Hamman } 32911c45ebdSJoe Hamman #endif 33011c45ebdSJoe Hamman 33111c45ebdSJoe Hamman #if defined(CONFIG_PCI) || defined(CONFIG_PCI1) 33211c45ebdSJoe Hamman /* For some reason the Tundra PCI bridge shows up on itself as a 33311c45ebdSJoe Hamman * different device. Work around that by refusing to configure it. 33411c45ebdSJoe Hamman */ 33511c45ebdSJoe Hamman void dummy_func(struct pci_controller* hose, pci_dev_t dev, struct pci_config_table *tab) { } 33611c45ebdSJoe Hamman 33711c45ebdSJoe Hamman static struct pci_config_table pci_sbc8548_config_table[] = { 33811c45ebdSJoe Hamman {0x10e3, 0x0513, PCI_ANY_ID, 1, 3, PCI_ANY_ID, dummy_func, {0,0,0}}, 33911c45ebdSJoe Hamman {0x1106, 0x0686, PCI_ANY_ID, 1, VIA_ID, 0, mpc85xx_config_via, {0,0,0}}, 34011c45ebdSJoe Hamman {0x1106, 0x0571, PCI_ANY_ID, 1, VIA_ID, 1, 34111c45ebdSJoe Hamman mpc85xx_config_via_usbide, {0,0,0}}, 34211c45ebdSJoe Hamman {0x1105, 0x3038, PCI_ANY_ID, 1, VIA_ID, 2, 34311c45ebdSJoe Hamman mpc85xx_config_via_usb, {0,0,0}}, 34411c45ebdSJoe Hamman {0x1106, 0x3038, PCI_ANY_ID, 1, VIA_ID, 3, 34511c45ebdSJoe Hamman mpc85xx_config_via_usb2, {0,0,0}}, 34611c45ebdSJoe Hamman {0x1106, 0x3058, PCI_ANY_ID, 1, VIA_ID, 5, 34711c45ebdSJoe Hamman mpc85xx_config_via_power, {0,0,0}}, 34811c45ebdSJoe Hamman {0x1106, 0x3068, PCI_ANY_ID, 1, VIA_ID, 6, 34911c45ebdSJoe Hamman mpc85xx_config_via_ac97, {0,0,0}}, 35011c45ebdSJoe Hamman {}, 35111c45ebdSJoe Hamman }; 35211c45ebdSJoe Hamman 35311c45ebdSJoe Hamman static struct pci_controller pci1_hose = { 35411c45ebdSJoe Hamman config_table: pci_sbc8548_config_table}; 35511c45ebdSJoe Hamman #endif /* CONFIG_PCI */ 35611c45ebdSJoe Hamman 35711c45ebdSJoe Hamman #ifdef CONFIG_PCI2 35811c45ebdSJoe Hamman static struct pci_controller pci2_hose; 35911c45ebdSJoe Hamman #endif /* CONFIG_PCI2 */ 36011c45ebdSJoe Hamman 36111c45ebdSJoe Hamman #ifdef CONFIG_PCIE1 36211c45ebdSJoe Hamman static struct pci_controller pcie1_hose; 36311c45ebdSJoe Hamman #endif /* CONFIG_PCIE1 */ 36411c45ebdSJoe Hamman 36511c45ebdSJoe Hamman int first_free_busno=0; 36611c45ebdSJoe Hamman 367*2dba0deaSKumar Gala extern int fsl_pci_setup_inbound_windows(struct pci_region *r); 368*2dba0deaSKumar Gala extern void fsl_pci_init(struct pci_controller *hose); 369*2dba0deaSKumar Gala 37011c45ebdSJoe Hamman void 37111c45ebdSJoe Hamman pci_init_board(void) 37211c45ebdSJoe Hamman { 3736d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); 37411c45ebdSJoe Hamman 37511c45ebdSJoe Hamman #ifdef CONFIG_PCI1 37611c45ebdSJoe Hamman { 3776d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_fsl_pci_t *pci = (ccsr_fsl_pci_t *) CONFIG_SYS_PCI1_ADDR; 37811c45ebdSJoe Hamman struct pci_controller *hose = &pci1_hose; 37911c45ebdSJoe Hamman struct pci_config_table *table; 380*2dba0deaSKumar Gala struct pci_region *r = hose->regions; 38111c45ebdSJoe Hamman 38211c45ebdSJoe Hamman uint pci_32 = gur->pordevsr & MPC85xx_PORDEVSR_PCI1_PCI32; /* PORDEVSR[15] */ 38311c45ebdSJoe Hamman uint pci_arb = gur->pordevsr & MPC85xx_PORDEVSR_PCI1_ARB; /* PORDEVSR[14] */ 38411c45ebdSJoe Hamman uint pci_clk_sel = gur->porpllsr & MPC85xx_PORDEVSR_PCI1_SPD; /* PORPLLSR[16] */ 38511c45ebdSJoe Hamman 38611c45ebdSJoe Hamman uint pci_agent = (host_agent == 3) || (host_agent == 4 ) || (host_agent == 6); 38711c45ebdSJoe Hamman 38811c45ebdSJoe Hamman uint pci_speed = get_clock_freq (); /* PCI PSPEED in [4:5] */ 38911c45ebdSJoe Hamman 39011c45ebdSJoe Hamman if (!(gur->devdisr & MPC85xx_DEVDISR_PCI1)) { 39111c45ebdSJoe Hamman printf (" PCI: %d bit, %s MHz, %s, %s, %s\n", 39211c45ebdSJoe Hamman (pci_32) ? 32 : 64, 39311c45ebdSJoe Hamman (pci_speed == 33333000) ? "33" : 39411c45ebdSJoe Hamman (pci_speed == 66666000) ? "66" : "unknown", 39511c45ebdSJoe Hamman pci_clk_sel ? "sync" : "async", 39611c45ebdSJoe Hamman pci_agent ? "agent" : "host", 39711c45ebdSJoe Hamman pci_arb ? "arbiter" : "external-arbiter" 39811c45ebdSJoe Hamman ); 39911c45ebdSJoe Hamman 40011c45ebdSJoe Hamman 40111c45ebdSJoe Hamman /* inbound */ 402*2dba0deaSKumar Gala r += fsl_pci_setup_inbound_windows(r); 40311c45ebdSJoe Hamman 40411c45ebdSJoe Hamman /* outbound memory */ 405*2dba0deaSKumar Gala pci_set_region(r++, 4066d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_MEM_BASE, 4076d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_MEM_PHYS, 4086d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_MEM_SIZE, 40911c45ebdSJoe Hamman PCI_REGION_MEM); 41011c45ebdSJoe Hamman 41111c45ebdSJoe Hamman /* outbound io */ 412*2dba0deaSKumar Gala pci_set_region(r++, 4136d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_IO_BASE, 4146d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_IO_PHYS, 4156d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI1_IO_SIZE, 41611c45ebdSJoe Hamman PCI_REGION_IO); 417*2dba0deaSKumar Gala hose->region_count = r - hose->regions; 41811c45ebdSJoe Hamman 41911c45ebdSJoe Hamman /* relocate config table pointers */ 42011c45ebdSJoe Hamman hose->config_table = \ 42111c45ebdSJoe Hamman (struct pci_config_table *)((uint)hose->config_table + gd->reloc_off); 42211c45ebdSJoe Hamman for (table = hose->config_table; table && table->vendor; table++) 42311c45ebdSJoe Hamman table->config_device += gd->reloc_off; 42411c45ebdSJoe Hamman 42511c45ebdSJoe Hamman hose->first_busno=first_free_busno; 42611c45ebdSJoe Hamman pci_setup_indirect(hose, (int) &pci->cfg_addr, (int) &pci->cfg_data); 42711c45ebdSJoe Hamman 42811c45ebdSJoe Hamman fsl_pci_init(hose); 42911c45ebdSJoe Hamman first_free_busno=hose->last_busno+1; 43011c45ebdSJoe Hamman printf ("PCI on bus %02x - %02x\n",hose->first_busno,hose->last_busno); 43111c45ebdSJoe Hamman #ifdef CONFIG_PCIX_CHECK 43211c45ebdSJoe Hamman if (!(gur->pordevsr & PORDEVSR_PCI)) { 43311c45ebdSJoe Hamman /* PCI-X init */ 43411c45ebdSJoe Hamman if (CONFIG_SYS_CLK_FREQ < 66000000) 43511c45ebdSJoe Hamman printf("PCI-X will only work at 66 MHz\n"); 43611c45ebdSJoe Hamman 43711c45ebdSJoe Hamman reg16 = PCI_X_CMD_MAX_SPLIT | PCI_X_CMD_MAX_READ 43811c45ebdSJoe Hamman | PCI_X_CMD_ERO | PCI_X_CMD_DPERR_E; 43911c45ebdSJoe Hamman pci_hose_write_config_word(hose, bus, PCIX_COMMAND, reg16); 44011c45ebdSJoe Hamman } 44111c45ebdSJoe Hamman #endif 44211c45ebdSJoe Hamman } else { 44311c45ebdSJoe Hamman printf (" PCI: disabled\n"); 44411c45ebdSJoe Hamman } 44511c45ebdSJoe Hamman } 44611c45ebdSJoe Hamman #else 44711c45ebdSJoe Hamman gur->devdisr |= MPC85xx_DEVDISR_PCI1; /* disable */ 44811c45ebdSJoe Hamman #endif 44911c45ebdSJoe Hamman 45011c45ebdSJoe Hamman #ifdef CONFIG_PCI2 45111c45ebdSJoe Hamman { 45211c45ebdSJoe Hamman uint pci2_clk_sel = gur->porpllsr & 0x4000; /* PORPLLSR[17] */ 45311c45ebdSJoe Hamman uint pci_dual = get_pci_dual (); /* PCI DUAL in CM_PCI[3] */ 45411c45ebdSJoe Hamman if (pci_dual) { 45511c45ebdSJoe Hamman printf (" PCI2: 32 bit, 66 MHz, %s\n", 45611c45ebdSJoe Hamman pci2_clk_sel ? "sync" : "async"); 45711c45ebdSJoe Hamman } else { 45811c45ebdSJoe Hamman printf (" PCI2: disabled\n"); 45911c45ebdSJoe Hamman } 46011c45ebdSJoe Hamman } 46111c45ebdSJoe Hamman #else 46211c45ebdSJoe Hamman gur->devdisr |= MPC85xx_DEVDISR_PCI2; /* disable */ 46311c45ebdSJoe Hamman #endif /* CONFIG_PCI2 */ 46411c45ebdSJoe Hamman 46511c45ebdSJoe Hamman #ifdef CONFIG_PCIE1 46611c45ebdSJoe Hamman { 4676d0f6bcfSJean-Christophe PLAGNIOL-VILLARD volatile ccsr_fsl_pci_t *pci = (ccsr_fsl_pci_t *) CONFIG_SYS_PCIE1_ADDR; 46811c45ebdSJoe Hamman struct pci_controller *hose = &pcie1_hose; 46911c45ebdSJoe Hamman int pcie_ep = (host_agent == 0) || (host_agent == 2 ) || (host_agent == 3); 470*2dba0deaSKumar Gala struct pci_region *r = hose->regions; 47111c45ebdSJoe Hamman 47211c45ebdSJoe Hamman int pcie_configured = io_sel >= 1; 47311c45ebdSJoe Hamman 47411c45ebdSJoe Hamman if (pcie_configured && !(gur->devdisr & MPC85xx_DEVDISR_PCIE)){ 47511c45ebdSJoe Hamman printf ("\n PCIE connected to slot as %s (base address %x)", 47611c45ebdSJoe Hamman pcie_ep ? "End Point" : "Root Complex", 47711c45ebdSJoe Hamman (uint)pci); 47811c45ebdSJoe Hamman 47911c45ebdSJoe Hamman if (pci->pme_msg_det) { 48011c45ebdSJoe Hamman pci->pme_msg_det = 0xffffffff; 48111c45ebdSJoe Hamman debug (" with errors. Clearing. Now 0x%08x",pci->pme_msg_det); 48211c45ebdSJoe Hamman } 48311c45ebdSJoe Hamman printf ("\n"); 48411c45ebdSJoe Hamman 48511c45ebdSJoe Hamman /* inbound */ 486*2dba0deaSKumar Gala pci_set_region(r++, 4876d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI_MEMORY_BUS, 4886d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI_MEMORY_PHYS, 4896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCI_MEMORY_SIZE, 49011c45ebdSJoe Hamman PCI_REGION_MEM | PCI_REGION_MEMORY); 49111c45ebdSJoe Hamman 49211c45ebdSJoe Hamman /* outbound memory */ 493*2dba0deaSKumar Gala pci_set_region(r++, 4946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_MEM_BASE, 4956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_MEM_PHYS, 4966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_MEM_SIZE, 49711c45ebdSJoe Hamman PCI_REGION_MEM); 49811c45ebdSJoe Hamman 49911c45ebdSJoe Hamman /* outbound io */ 500*2dba0deaSKumar Gala pci_set_region(r++, 5016d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_IO_BASE, 5026d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_IO_PHYS, 5036d0f6bcfSJean-Christophe PLAGNIOL-VILLARD CONFIG_SYS_PCIE1_IO_SIZE, 50411c45ebdSJoe Hamman PCI_REGION_IO); 50511c45ebdSJoe Hamman 506*2dba0deaSKumar Gala hose->region_count = r - hose->regions; 50711c45ebdSJoe Hamman 50811c45ebdSJoe Hamman hose->first_busno=first_free_busno; 50911c45ebdSJoe Hamman pci_setup_indirect(hose, (int) &pci->cfg_addr, (int) &pci->cfg_data); 51011c45ebdSJoe Hamman 51111c45ebdSJoe Hamman fsl_pci_init(hose); 51211c45ebdSJoe Hamman printf ("PCIE on bus %d - %d\n",hose->first_busno,hose->last_busno); 51311c45ebdSJoe Hamman 51411c45ebdSJoe Hamman first_free_busno=hose->last_busno+1; 51511c45ebdSJoe Hamman 51611c45ebdSJoe Hamman } else { 51711c45ebdSJoe Hamman printf (" PCIE: disabled\n"); 51811c45ebdSJoe Hamman } 51911c45ebdSJoe Hamman } 52011c45ebdSJoe Hamman #else 52111c45ebdSJoe Hamman gur->devdisr |= MPC85xx_DEVDISR_PCIE; /* disable */ 52211c45ebdSJoe Hamman #endif 52311c45ebdSJoe Hamman 52411c45ebdSJoe Hamman } 52511c45ebdSJoe Hamman 52611c45ebdSJoe Hamman int last_stage_init(void) 52711c45ebdSJoe Hamman { 52811c45ebdSJoe Hamman return 0; 52911c45ebdSJoe Hamman } 53011c45ebdSJoe Hamman 53111c45ebdSJoe Hamman #if defined(CONFIG_OF_BOARD_SETUP) 532*2dba0deaSKumar Gala extern void ft_fsl_pci_setup(void *blob, const char *pci_alias, 533*2dba0deaSKumar Gala struct pci_controller *hose); 53411c45ebdSJoe Hamman 535*2dba0deaSKumar Gala void ft_board_setup(void *blob, bd_t *bd) 53611c45ebdSJoe Hamman { 53711c45ebdSJoe Hamman ft_cpu_setup(blob, bd); 538*2dba0deaSKumar Gala #ifdef CONFIG_PCI1 539*2dba0deaSKumar Gala ft_fsl_pci_setup(blob, "pci0", &pci1_hose); 540*2dba0deaSKumar Gala #endif 541*2dba0deaSKumar Gala #ifdef CONFIG_PCIE1 542*2dba0deaSKumar Gala ft_fsl_pci_setup(blob, "pci1", &pcie1_hose); 54311c45ebdSJoe Hamman #endif 54411c45ebdSJoe Hamman } 54511c45ebdSJoe Hamman #endif 546