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