mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-13 23:02:59 +00:00
14aa71e660
The following boards share a common design but with minor variations between them: P1020MSBG-PC P1020RDB-PC P1020UTM-PC P1021RDB-PC P1024RDB P1025RDB P2020RDB-PC The P1020RDB-PC shares its roots in the existing P1020RDB board design, however uses DDR3 instead of DDR2. P2020RDB-PC differs from the P102x RDB-PC with 64-bit DDR and 100Mhz SYSCLK. Key features on these boards include: * DDR3 * NOR flash * NAND flash (on RDB's only) * SPI flash (on RDB's only) * SDHC/MMC card slot * VSC7385 Ethernet switch (on P1020MBG, P1020RDB, & P1021RDB) * PCIE slot and mini-PCIE slots As these boards use soldered DDR chips not regular DIMMs, an on-board EEPROM is used to store SPD data. In case of absent or corrupted SPD, falling back to timing data embedded in the source code will be used. Raw timing data is extracted from DDR chip datasheet. Different speeds of DDR are supported with this approach. ODT option is forced to fit this set of boards, again because they don't have regular DIMMs. CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS is defined as 5ms to meet specification for writing timing. VSC firmware Address is defined by default in config file for eTSEC1. SD width is based off DIP switch. DIP switch is detected on the board by reading i2c bus and setting the appropriate mux values. Some boards have QE module in the silicon (P1021 and P1025). QE and eLBC have pins multiplexing. QE function needs to be disabled to access Nor Flash and CPLD. QE-UEC and QE-UART can be enabled for linux kernel by setting "qe" in hwconfig. In addition, QE-UEC and QE-TDM also have pins multiplexing, to enable QE-TDM for linux kernel, set "qe;tdm" in hwconfig. Syntax is as below 'setenv hwconfig qe' to enable QE UEC/UART and disable Nor-Flash/CPLD. 'setenv hwconfig 'qe;tdm'' to enalbe QE TDM and disable Nor-Flash/CPLD. Signed-off-by: York Sun <yorksun@freescale.com> Signed-off-by: Li Yang <leoli@freescale.com> Signed-off-by: Zhao Chenhui <b26998@freescale.com> Signed-off-by: Matthew McClintock <msm@freescale.com> Signed-off-by: Poonam Aggrwal <poonam.aggrwal@freescale.com> Signed-off-by: Priyanka Jain <Priyanka.Jain@freescale.com> Signed-off-by: Tang Yuantian <b29983@freescale.com> Signed-off-by: ramneek.mehresh <ramneek.mehresh@freescale.com> Signed-off-by: Prabhakar Kushwaha <prabhakar@freescale.com> Signed-off-by: Matthew McClintock <msm@freescale.com> Signed-off-by: Xie Xiaobo <X.Xie@freescale.com> Signed-off-by: Kumar Gala <galak@kernel.crashing.org> Signed-off-by: Jerry Huang <Chang-Ming.Huang@freescale.com> Signed-off-by: Akhil Goyal <akhil.goyal@freescale.com> |
||
---|---|---|
.. | ||
uImage.FIT | ||
feature-removal-schedule.txt | ||
I2C_Edge_Conditions | ||
mkimage.1 | ||
README-integrator | ||
README.440-DDR-performance | ||
README.alaska8220 | ||
README.AMCC-eval-boards-cleanup | ||
README.amigaone | ||
README.arm-caches | ||
README.ARM-memory-map | ||
README.arm-relocation | ||
README.ARM-SoC | ||
README.at91 | ||
README.at91-soc | ||
README.atmel_mci | ||
README.autoboot | ||
README.AVR32 | ||
README.AVR32-port-muxing | ||
README.bamboo | ||
README.bedbug | ||
README.bitbangMII | ||
README.blackfin | ||
README.bus_vcxk | ||
README.cfi | ||
README.cmi | ||
README.COBRA5272 | ||
README.commands | ||
README.commands.itest | ||
README.console | ||
README.davinci | ||
README.db64360 | ||
README.db64460 | ||
README.designware_eth | ||
README.dnp5370 | ||
README.dns | ||
README.drivers.eth | ||
README.ebony | ||
README.enetaddr | ||
README.EVB-64260-750CX | ||
README.evb64260 | ||
README.fads | ||
README.fsl-ddr | ||
README.fsl-hwconfig | ||
README.generic_usb_ohci | ||
README.hawkboard | ||
README.hwconfig | ||
README.IceCube | ||
README.idma2intr | ||
README.imx5 | ||
README.imx31 | ||
README.imximage | ||
README.INCA-IP | ||
README.iomux | ||
README.IPHASE4539 | ||
README.JFFS2 | ||
README.JFFS2_NAND | ||
README.kmeter1 | ||
README.korat | ||
README.kwbimage | ||
README.LED | ||
README.LED_display | ||
README.Lite5200B_low_power | ||
README.lynxkdi | ||
README.m68k | ||
README.m5253evbe | ||
README.m5373evb | ||
README.m5475evb | ||
README.m52277evb | ||
README.m53017evb | ||
README.m54455evb | ||
README.marubun-pcmcia | ||
README.MBX | ||
README.mergerbox | ||
README.mflash | ||
README.mips | ||
README.Modem | ||
README.mpc5xx | ||
README.mpc74xx | ||
README.mpc83xx.ddrecc | ||
README.mpc83xxads | ||
README.mpc85xxads | ||
README.mpc85xxcds | ||
README.mpc832xemds | ||
README.mpc837xemds | ||
README.mpc837xerdb | ||
README.MPC866 | ||
README.mpc7448hpc2 | ||
README.mpc8313erdb | ||
README.mpc8315erdb | ||
README.mpc8323erdb | ||
README.mpc8349itx | ||
README.mpc8360emds | ||
README.mpc8536ds | ||
README.mpc8544ds | ||
README.mpc8569mds | ||
README.mpc8572ds | ||
README.mpc8610hpcd | ||
README.mpc8641hpcn | ||
README.mvbc_p | ||
README.mvblm7 | ||
README.mvsmr | ||
README.mx35pdk | ||
README.nand | ||
README.nand-boot-ppc440 | ||
README.ne2000 | ||
README.NetConsole | ||
README.nhk8815 | ||
README.ns9750dev | ||
README.ocotea | ||
README.ocotea-PIBS-to-U-Boot | ||
README.OFT | ||
README.omap3 | ||
README.omap730p2 | ||
README.OXC | ||
README.p1_p2_rdb_pc | ||
README.p1022ds | ||
README.p1023rds | ||
README.p2020rdb | ||
README.p2041rdb | ||
README.p4080ds | ||
README.phytec.pcm030 | ||
README.PIP405 | ||
README.PlanetCore | ||
README.POST | ||
README.ppc440 | ||
README.PXA_CF | ||
README.qemu_mips | ||
README.RPXClassic | ||
README.RPXlite | ||
README.s5pc1xx | ||
README.Sandpoint8240 | ||
README.sata | ||
README.sbc8349 | ||
README.sbc8548 | ||
README.SBC8560 | ||
README.sbc8641d | ||
README.sched | ||
README.scrapyard | ||
README.serial_multi | ||
README.sh | ||
README.sh7757lcr | ||
README.sh7785lcr | ||
README.sha1 | ||
README.silent | ||
README.simpc8313 | ||
README.SNTP | ||
README.spear | ||
README.SPL | ||
README.standalone | ||
README.stxxtc | ||
README.timll | ||
README.TQM8260 | ||
README.ubi | ||
README.ublimage | ||
README.update | ||
README.usb | ||
README.video | ||
README.VLAN | ||
README.xpedite1k | ||
README.zeus |
Storage of the board specific values (ethaddr...) ------------------------------------------------- The board specific environment variables that should be unique for each individual board, can be stored in the I2C EEPROM. This will be done from offset 0x80 with the length of 0x80 bytes. The following command can be used to store the values here: => setdef de:20:6a:ed:e2:72 de:20:6a:ed:e2:73 AB0001 ethaddr eth1addr serial# Now those 3 values are stored into the I2C EEPROM. A CRC is added to make sure that the values get not corrupted. SW-Reset Pushbutton handling: ----------------------------- The SW-reset push button is connected to a GPIO input too. This way U-Boot can "see" how long the SW-reset was pressed, and a specific action can be taken. Two different actions are supported: a) Release after more than 5 seconds and less then 10 seconds: -> Run POST Please note, that the POST test will take a while (approx. 1 min on the 128MByte board). This is mainly due to the system memory test. b) Release after more than 10 seconds: -> Restore factory default settings The factory default values are restored. The default environment variables are restored (ipaddr, serverip...) and the board specific values (ethaddr, eth1addr and serial#) are restored to the environment from the I2C EEPROM. Also a bootline parameter is added to the Linux bootline to signal the Linux kernel upon the next startup, that the factory defaults should be restored. The command to check this sw-reset status and act accordingly is => chkreset This command is added to the default "bootcmd", so that it is called automatically upon startup. Also, the 2 LED's are used to indicate the current status of this command (time passed since pushing the button). When the POST test will be run, the green LED will be switched off, and when the factory restore will be initiated, the reg LED will be switched off. Loggin of POST results: ----------------------- The results of the POST tests are logged in a logbuffer located at the end of the onboard memory. It can be accessed with the U-Boot command "log": => log show <4>POST memory PASSED <4>POST cache PASSED <4>POST cpu PASSED <4>POST uart PASSED <4>POST ethernet PASSED The DENX Linux kernel tree has support for this log buffer included. Exactly this buffer is used for logging of all kernel messages too. By enabling the compile time option "CONFIG_LOGBUFFER" this support is enabled. This way you can access the U-Boot log messages from Linux too. 2007-08-10, Stefan Roese <sr@denx.de>