avionic design with actual uboot and tooling
submodule of avionic design uboot bootloader and with included tools to get you started , read readme.md and readme-tk1-loader.md
This commit is contained in:
9
u-boot/board/sbc8548/Kconfig
Normal file
9
u-boot/board/sbc8548/Kconfig
Normal file
@@ -0,0 +1,9 @@
|
||||
if TARGET_SBC8548
|
||||
|
||||
config SYS_BOARD
|
||||
default "sbc8548"
|
||||
|
||||
config SYS_CONFIG_NAME
|
||||
default "sbc8548"
|
||||
|
||||
endif
|
||||
10
u-boot/board/sbc8548/MAINTAINERS
Normal file
10
u-boot/board/sbc8548/MAINTAINERS
Normal file
@@ -0,0 +1,10 @@
|
||||
SBC8548 BOARD
|
||||
M: Paul Gortmaker <paul.gortmaker@windriver.com>
|
||||
S: Maintained
|
||||
F: board/sbc8548/
|
||||
F: include/configs/sbc8548.h
|
||||
F: configs/sbc8548_defconfig
|
||||
F: configs/sbc8548_PCI_33_defconfig
|
||||
F: configs/sbc8548_PCI_33_PCIE_defconfig
|
||||
F: configs/sbc8548_PCI_66_defconfig
|
||||
F: configs/sbc8548_PCI_66_PCIE_defconfig
|
||||
14
u-boot/board/sbc8548/Makefile
Normal file
14
u-boot/board/sbc8548/Makefile
Normal file
@@ -0,0 +1,14 @@
|
||||
#
|
||||
# (C) Copyright 2004-2006
|
||||
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||
#
|
||||
# (C) Copyright 2007 Wind River Systems Inc <www.windriver.com>.
|
||||
# Added support for Wind River SBC8548 board
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
obj-y += sbc8548.o
|
||||
obj-y += law.o
|
||||
obj-y += tlb.o
|
||||
obj-$(CONFIG_SYS_FSL_DDR2) += ddr.o
|
||||
269
u-boot/board/sbc8548/README
Normal file
269
u-boot/board/sbc8548/README
Normal file
@@ -0,0 +1,269 @@
|
||||
Intro:
|
||||
======
|
||||
|
||||
The SBC8548 is a stand alone single board computer with a 1GHz
|
||||
MPC8548 CPU, 8MB boot flash, 64MB user flash and, 256MB DDR2 400MHz
|
||||
memory. It also has 128MB SDRAM 100MHz LBC memory, with both a PCI-e,
|
||||
and a PCI-X slot, dual mini-DB9 for UART, and dual RJ-45 for eTSEC
|
||||
ethernet connections.
|
||||
|
||||
U-Boot Configuration:
|
||||
=====================
|
||||
|
||||
The following possible U-Boot configuration targets are available:
|
||||
|
||||
1) sbc8548_config
|
||||
2) sbc8548_PCI_33_config
|
||||
3) sbc8548_PCI_66_config
|
||||
4) sbc8548_PCI_33_PCIE_config
|
||||
5) sbc8548_PCI_66_PCIE_config
|
||||
|
||||
Generally speaking, most people should choose to use #5. Details
|
||||
of each choice are listed below.
|
||||
|
||||
Choice #1 does not enable CONFIG_PCI, and assumes that the PCI slot
|
||||
will be left empty (M66EN high), and so the board will operate with
|
||||
a base clock of 66MHz. Note that you need both PCI enabled in U-Boot
|
||||
and linux in order to have functional PCI under linux.
|
||||
|
||||
The second enables PCI support and builds for a 33MHz clock rate. Note
|
||||
that if a 33MHz 32bit card is inserted in the slot, then the whole board
|
||||
will clock down to a 33MHz base clock instead of the default 66MHz. This
|
||||
will change the baud clocks and mess up your serial console output if you
|
||||
were previously running at 66MHz. If you want to use a 33MHz PCI card,
|
||||
then you should build a U-Boot with a _PCI_33_ config and store this
|
||||
to flash prior to powering down the board and inserting the 33MHz PCI
|
||||
card. [The above discussion assumes that the SW2[1-4] has not been changed
|
||||
to reflect a different CCB:SYSCLK ratio]
|
||||
|
||||
The third option builds PCI support in, and leaves the clocking at the
|
||||
default 66MHz. Options four and five are just repeats of option two
|
||||
and three, but with PCI-e support enabled as well.
|
||||
|
||||
PCI output listing with an intel e1000 PCI-x and a Syskonnect SK-9Exx
|
||||
is shown below for sbc8548_PCI_66_PCIE_config. (Note that PCI-e with
|
||||
a 33MHz PCI configuration is currently untested.)
|
||||
|
||||
=> pci 0
|
||||
Scanning PCI devices on bus 0
|
||||
BusDevFun VendorId DeviceId Device Class Sub-Class
|
||||
_____________________________________________________________
|
||||
00.00.00 0x1057 0x0012 Processor 0x20
|
||||
00.01.00 0x8086 0x1026 Network controller 0x00
|
||||
=> pci 1
|
||||
Scanning PCI devices on bus 1
|
||||
BusDevFun VendorId DeviceId Device Class Sub-Class
|
||||
_____________________________________________________________
|
||||
01.00.00 0x1957 0x0012 Processor 0x20
|
||||
=> pci 2
|
||||
Scanning PCI devices on bus 2
|
||||
BusDevFun VendorId DeviceId Device Class Sub-Class
|
||||
_____________________________________________________________
|
||||
02.00.00 0x1148 0x9e00 Network controller 0x00
|
||||
=>
|
||||
|
||||
Memory Size and using SPD:
|
||||
==========================
|
||||
|
||||
The default configuration uses hard coded memory configuration settings
|
||||
for 256MB of DDR2 @400MHz. It does not by default use the DDR2 SPD
|
||||
EEPROM data to read what memory is installed.
|
||||
|
||||
There is a hardware errata, which causes the older local bus SDRAM
|
||||
SPD EEPROM to land at the same address as the DDR2 SPD EEPROM, so
|
||||
that the SPD data can not be read reliably. You can test if your
|
||||
board has the errata fix by running "i2c probe". If you see 0x53
|
||||
as a valid device, it has been fixed. If you only see 0x50, 0x51
|
||||
then your board does not have the fix.
|
||||
|
||||
You can also visually inspect the board to see if this hardware
|
||||
fix has been applied:
|
||||
|
||||
1) Remove R314 (RES-R0174-033, 1K, 0603). R314 is located on
|
||||
the back of the PCB behind the DDR SDRAM SODIMM connector.
|
||||
2) Solder RES-R0174-033 (1K, 0603) resistor from R314 pin 2 pad
|
||||
to R313 pin 2. Pin 2 for each resistor is the end of the
|
||||
resistor closest to the CPU.
|
||||
|
||||
Boards without the mod will have R314 and R313 in parallel, like "||".
|
||||
After the mod, they will be touching and form an "L" shape.
|
||||
|
||||
If you want to upgrade to larger RAM size, you can simply enable
|
||||
#define CONFIG_SPD_EEPROM
|
||||
#define CONFIG_DDR_SPD
|
||||
in include/configs/sbc8548.h file. (The lines are already there
|
||||
but listed as #undef).
|
||||
|
||||
If you did the i2c test, and your board does not have the errata
|
||||
fix, then you will have to physically remove the LBC 128MB DIMM
|
||||
from the board's socket to resolve the above i2c address overlap
|
||||
issue and allow SPD autodetection of RAM to work.
|
||||
|
||||
|
||||
Updating U-Boot with U-Boot:
|
||||
============================
|
||||
|
||||
Note that versions of U-Boot up to and including 2009.08 had U-Boot stored
|
||||
at 0xfff8_0000 -> 0xffff_ffff (512k). Currently it is being stored from
|
||||
0xfffa_0000 -> 0xffff_ffff (384k). If you use an old macro/script to
|
||||
update U-Boot with U-Boot and it uses the old address, you will render
|
||||
your board inoperable, and you will require JTAG recovery.
|
||||
|
||||
The following steps list how to update with the current address:
|
||||
|
||||
tftp u-boot.bin
|
||||
md 200000 10
|
||||
protect off all
|
||||
erase fffa0000 ffffffff
|
||||
cp.b 200000 fffa0000 60000
|
||||
md fffa0000 10
|
||||
protect on all
|
||||
|
||||
The "md" steps in the above are just a precautionary step that allow
|
||||
you to confirm the U-Boot version that was downloaded, and then confirm
|
||||
that it was copied to flash.
|
||||
|
||||
The above assumes that you are using the default board settings which
|
||||
have U-Boot in the 8MB flash, tied to /CS0.
|
||||
|
||||
If you are running the default 8MB /CS0 settings but want to store an
|
||||
image in the SODIMM that is built with CONFIG_SYS_ALT_BOOT enabled,
|
||||
(as a backup, etc) then the steps will become:
|
||||
|
||||
tftp u-boot.bin
|
||||
md 200000 10
|
||||
protect off all
|
||||
era eff00000 efffffff
|
||||
cp.b 200000 eff00000 100000
|
||||
md eff00000 10
|
||||
protect on all
|
||||
|
||||
Finally, if you are running the alternate 64MB /CS0 settings and want
|
||||
to update the in-use U-Boot image, then (again with CONFIG_SYS_ALT_BOOT
|
||||
enabled) the steps will become:
|
||||
|
||||
tftp u-boot.bin
|
||||
md 200000 10
|
||||
protect off all
|
||||
era fff00000 ffffffff
|
||||
cp.b 200000 fff00000 100000
|
||||
md fff00000 10
|
||||
protect on all
|
||||
|
||||
|
||||
Hardware Reference:
|
||||
===================
|
||||
|
||||
The following contains some summary information on hardware settings
|
||||
that are relevant to U-Boot, based on the board manual. For the
|
||||
most up to date and complete details of the board, please request the
|
||||
reference manual ERG-00327-001.pdf from www.windriver.com
|
||||
|
||||
Boot flash:
|
||||
intel V28F640Jx, 8192x8 (one device) at 0xff80_0000
|
||||
|
||||
Sodimm flash:
|
||||
intel V28F128Jx, 16384x8 (4 devices) at 0xfb80_0000
|
||||
Note that this address reflects the default setting for
|
||||
the JTAG debugging tools, but since the alignment is
|
||||
rather inconvenient, U-Boot puts it at 0xec00_0000.
|
||||
|
||||
|
||||
Jumpers:
|
||||
|
||||
Jumper Name ON OFF
|
||||
----------------------------------------------------------------
|
||||
JP12 CS0/CS6 swap see note[*] see note[*]
|
||||
|
||||
JP13 SODIMM flash write OK writes disabled
|
||||
write prot.
|
||||
|
||||
JP14 HRESET/TRST joined isolated
|
||||
|
||||
JP15 PWR ON when AC pwr use S1 for on/off
|
||||
|
||||
JP16 Demo LEDs lit not lit
|
||||
|
||||
JP19 PCI mode PCI PCI-X
|
||||
|
||||
|
||||
[*]JP12, when jumpered parallel to the SODIMM, puts the boot flash
|
||||
onto /CS0 and the SODIMM flash on /CS6 (default). When JP12
|
||||
is jumpered parallel to the LBC-SDRAM, then /CS0 is for the
|
||||
SODIMM flash and /CS6 is for the boot flash. Note that in this
|
||||
alternate setting, you also need to switch SW2.8 to ON.
|
||||
See the setting CONFIG_SYS_ALT_BOOT if you want to use this setting
|
||||
and boot U-Boot from the 64MB SODIMM
|
||||
|
||||
|
||||
Switches:
|
||||
|
||||
The defaults are marked with a *
|
||||
|
||||
Name Desc. ON OFF
|
||||
------------------------------------------------------------------
|
||||
S1 Pwr toggle n/a n/a
|
||||
|
||||
SW2.1 CFG_SYS_PLL0 1 0*
|
||||
SW2.2 CFG_SYS_PLL1 1* 0
|
||||
SW2.3 CFG_SYS_PLL2 1* 0
|
||||
SW2.4 CFG_SYS_PLL3 1 0*
|
||||
SW2.5 CFG_CORE_PLL0 1* 0
|
||||
SW2.6 CFG_CORE_PLL1 1 0*
|
||||
SW2.7 CFG_CORE_PLL2 1* 0
|
||||
SW2.8 CFG_ROM_LOC1 1 0*
|
||||
|
||||
SW3.1 CFG_HOST_AGT0 1* 0
|
||||
SW3.2 CFG_HOST_AGT1 1* 0
|
||||
SW3.3 CFG_HOST_AGT2 1* 0
|
||||
SW3.4 CFG_IO_PORTS0 1* 0
|
||||
SW3.5 CFG_IO_PORTS0 1 0*
|
||||
SW3.6 CFG_IO_PORTS0 1 0*
|
||||
|
||||
SerDes CLK(MHz) SW5.1 SW5.2
|
||||
----------------------------------------------
|
||||
25 0 0
|
||||
100* 1 0
|
||||
125 0 1
|
||||
200 1 1
|
||||
|
||||
SerDes CLK spread SW5.3 SW5.4
|
||||
----------------------------------------------
|
||||
+/- 0.25% 0 0
|
||||
-0.50% 1 0
|
||||
-0.75% 0 1
|
||||
No Spread* 1 1
|
||||
|
||||
SW4 settings are readable from the EPLD and are currently not used for
|
||||
any hardware settings (i.e. user configuration switches).
|
||||
|
||||
LEDs:
|
||||
|
||||
Name Desc. ON OFF
|
||||
------------------------------------------------------------------
|
||||
D13 PCI/PCI-X PCI-X PCI
|
||||
D14 3.3V PWR 3.3V no power
|
||||
D15 SYSCLK 66MHz 33MHz
|
||||
|
||||
|
||||
Default Memory Map:
|
||||
|
||||
start end CS<n> width Desc.
|
||||
----------------------------------------------------------------------
|
||||
0000_0000 0fff_ffff MCS0,1 64 DDR2 (256MB)
|
||||
f000_0000 f7ff_ffff CS3,4 32 LB SDRAM (128MB)
|
||||
f800_0000 f8b0_1fff CS5 - EPLD
|
||||
fb80_0000 ff7f_ffff CS6 32 SODIMM flash (64MB) [*]
|
||||
ff80_0000 ffff_ffff CS0 8 Boot flash (8MB)
|
||||
|
||||
[*] fb80 represents the default programmed by WR JTAG register files,
|
||||
but U-Boot places the flash at either ec00 or fc00 based on JP12.
|
||||
|
||||
The EPLD on CS5 demuxes the following devices at the following offsets:
|
||||
|
||||
offset size width device
|
||||
--------------------------------------------------------
|
||||
0 1fff 8 7 segment display LED
|
||||
10_0000 1fff 4 user switches
|
||||
30_0000 1fff 4 HW Rev. register
|
||||
b0_0000 1fff 8 8kB EEPROM
|
||||
132
u-boot/board/sbc8548/ddr.c
Normal file
132
u-boot/board/sbc8548/ddr.c
Normal file
@@ -0,0 +1,132 @@
|
||||
/*
|
||||
* Copyright 2008 Freescale Semiconductor, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <i2c.h>
|
||||
|
||||
#include <fsl_ddr_sdram.h>
|
||||
#include <fsl_ddr_dimm_params.h>
|
||||
|
||||
void fsl_ddr_board_options(memctl_options_t *popts,
|
||||
dimm_params_t *pdimm,
|
||||
unsigned int ctrl_num)
|
||||
{
|
||||
/*
|
||||
* Factors to consider for clock adjust:
|
||||
* - number of chips on bus
|
||||
* - position of slot
|
||||
* - DDR1 vs. DDR2?
|
||||
* - ???
|
||||
*
|
||||
* This needs to be determined on a board-by-board basis.
|
||||
* 0110 3/4 cycle late
|
||||
* 0111 7/8 cycle late
|
||||
*/
|
||||
popts->clk_adjust = 7;
|
||||
|
||||
/*
|
||||
* Factors to consider for CPO:
|
||||
* - frequency
|
||||
* - ddr1 vs. ddr2
|
||||
*/
|
||||
popts->cpo_override = 10;
|
||||
|
||||
/*
|
||||
* Factors to consider for write data delay:
|
||||
* - number of DIMMs
|
||||
*
|
||||
* 1 = 1/4 clock delay
|
||||
* 2 = 1/2 clock delay
|
||||
* 3 = 3/4 clock delay
|
||||
* 4 = 1 clock delay
|
||||
* 5 = 5/4 clock delay
|
||||
* 6 = 3/2 clock delay
|
||||
*/
|
||||
popts->write_data_delay = 3;
|
||||
|
||||
/*
|
||||
* Factors to consider for half-strength driver enable:
|
||||
* - number of DIMMs installed
|
||||
*/
|
||||
popts->half_strength_driver_enable = 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_SPD_EEPROM
|
||||
/*
|
||||
* Workaround for hardware errata. An i2c address conflict
|
||||
* existed on earlier boards; the workaround moved the DDR
|
||||
* SPD from 0x51 to 0x53. So we try and read 0x53 1st, and
|
||||
* if that fails, then fall back to reading at 0x51.
|
||||
*/
|
||||
void get_spd(generic_spd_eeprom_t *spd, u8 i2c_address)
|
||||
{
|
||||
int ret;
|
||||
|
||||
#ifdef ALT_SPD_EEPROM_ADDRESS
|
||||
if (i2c_address == SPD_EEPROM_ADDRESS) {
|
||||
ret = i2c_read(ALT_SPD_EEPROM_ADDRESS, 0, 1, (uchar *)spd,
|
||||
sizeof(generic_spd_eeprom_t));
|
||||
if (ret == 0)
|
||||
return; /* Good data at 0x53 */
|
||||
memset(spd, 0, sizeof(generic_spd_eeprom_t));
|
||||
}
|
||||
#endif
|
||||
ret = i2c_read(i2c_address, 0, 1, (uchar *)spd,
|
||||
sizeof(generic_spd_eeprom_t));
|
||||
if (ret) {
|
||||
printf("DDR: failed to read SPD from addr %u\n", i2c_address);
|
||||
memset(spd, 0, sizeof(generic_spd_eeprom_t));
|
||||
}
|
||||
}
|
||||
|
||||
#else
|
||||
/*
|
||||
* fixed_sdram init -- doesn't use serial presence detect.
|
||||
* Assumes 256MB DDR2 SDRAM SODIMM, without ECC, running at DDR400 speed.
|
||||
*/
|
||||
phys_size_t fixed_sdram(void)
|
||||
{
|
||||
struct ccsr_ddr __iomem *ddr =
|
||||
(struct ccsr_ddr __iomem *)(CONFIG_SYS_FSL_DDR_ADDR);
|
||||
|
||||
out_be32(&ddr->cs0_bnds, 0x0000007f);
|
||||
out_be32(&ddr->cs1_bnds, 0x008000ff);
|
||||
out_be32(&ddr->cs2_bnds, 0x00000000);
|
||||
out_be32(&ddr->cs3_bnds, 0x00000000);
|
||||
|
||||
out_be32(&ddr->cs0_config, 0x80010101);
|
||||
out_be32(&ddr->cs1_config, 0x80010101);
|
||||
out_be32(&ddr->cs2_config, 0x00000000);
|
||||
out_be32(&ddr->cs3_config, 0x00000000);
|
||||
|
||||
out_be32(&ddr->timing_cfg_3, 0x00000000);
|
||||
out_be32(&ddr->timing_cfg_0, 0x00220802);
|
||||
out_be32(&ddr->timing_cfg_1, 0x38377322);
|
||||
out_be32(&ddr->timing_cfg_2, 0x0fa044C7);
|
||||
|
||||
out_be32(&ddr->sdram_cfg, 0x4300C000);
|
||||
out_be32(&ddr->sdram_cfg_2, 0x24401000);
|
||||
|
||||
out_be32(&ddr->sdram_mode, 0x23C00542);
|
||||
out_be32(&ddr->sdram_mode_2, 0x00000000);
|
||||
|
||||
out_be32(&ddr->sdram_interval, 0x05080100);
|
||||
out_be32(&ddr->sdram_md_cntl, 0x00000000);
|
||||
out_be32(&ddr->sdram_data_init, 0x00000000);
|
||||
out_be32(&ddr->sdram_clk_cntl, 0x03800000);
|
||||
asm("sync;isync;msync");
|
||||
udelay(500);
|
||||
|
||||
#ifdef CONFIG_DDR_ECC
|
||||
/* Enable ECC checking */
|
||||
out_be32(&ddr->sdram_cfg, CONFIG_SYS_DDR_CONTROL | 0x20000000);
|
||||
#else
|
||||
out_be32(&ddr->sdram_cfg, CONFIG_SYS_DDR_CONTROL);
|
||||
#endif
|
||||
|
||||
return CONFIG_SYS_SDRAM_SIZE * 1024 * 1024;
|
||||
}
|
||||
#endif
|
||||
55
u-boot/board/sbc8548/law.c
Normal file
55
u-boot/board/sbc8548/law.c
Normal file
@@ -0,0 +1,55 @@
|
||||
/*
|
||||
* Copyright 2008 Freescale Semiconductor, Inc.
|
||||
*
|
||||
* (C) Copyright 2000
|
||||
* Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <asm/fsl_law.h>
|
||||
#include <asm/mmu.h>
|
||||
|
||||
/*
|
||||
* LAW(Local Access Window) configuration:
|
||||
*
|
||||
* 0x0000_0000 0x0fff_ffff DDR 256M
|
||||
* 0x8000_0000 0x9fff_ffff PCI1 MEM 512M
|
||||
* 0xa000_0000 0xbfff_ffff PCIe MEM 512M
|
||||
* 0xe000_0000 0xe000_ffff CCSR 1M
|
||||
* 0xe200_0000 0xe27f_ffff PCI1 IO 8M
|
||||
* 0xe280_0000 0xe2ff_ffff PCIe IO 8M
|
||||
* 0xec00_0000 0xefff_ffff FLASH (2nd bank) 64M
|
||||
* 0xf000_0000 0xf7ff_ffff SDRAM 128M
|
||||
* 0xf8b0_0000 0xf80f_ffff EEPROM 1M
|
||||
* 0xff80_0000 0xffff_ffff FLASH (boot bank) 8M
|
||||
*
|
||||
* If swapped CS0/CS6 via JP12+SW2.8:
|
||||
* 0xef80_0000 0xefff_ffff FLASH (2nd bank) 8M
|
||||
* 0xfc00_0000 0xffff_ffff FLASH (boot bank) 64M
|
||||
*
|
||||
* Notes:
|
||||
* CCSRBAR and L2-as-SRAM don't need a configured Local Access Window.
|
||||
* If flash is 8M at default position (last 8M), no LAW needed.
|
||||
*/
|
||||
|
||||
struct law_entry law_table[] = {
|
||||
#ifdef CONFIG_SYS_ALT_BOOT
|
||||
SET_LAW(CONFIG_SYS_ALT_FLASH, LAW_SIZE_8M, LAW_TRGT_IF_LBC),
|
||||
#else
|
||||
SET_LAW(CONFIG_SYS_ALT_FLASH, LAW_SIZE_64M, LAW_TRGT_IF_LBC),
|
||||
#endif
|
||||
#ifndef CONFIG_SPD_EEPROM
|
||||
SET_LAW(CONFIG_SYS_DDR_SDRAM_BASE, LAW_SIZE_256M, LAW_TRGT_IF_DDR),
|
||||
#endif
|
||||
#ifdef CONFIG_SYS_LBC_SDRAM_BASE
|
||||
/* LBC window - maps 256M 0xf0000000 -> 0xffffffff */
|
||||
SET_LAW(CONFIG_SYS_LBC_SDRAM_BASE, LAW_SIZE_256M, LAW_TRGT_IF_LBC),
|
||||
#else
|
||||
/* LBC window - maps 128M 0xf8000000 -> 0xffffffff */
|
||||
SET_LAW(CONFIG_SYS_EPLD_BASE, LAW_SIZE_128M, LAW_TRGT_IF_LBC),
|
||||
#endif
|
||||
};
|
||||
|
||||
int num_law_entries = ARRAY_SIZE(law_table);
|
||||
314
u-boot/board/sbc8548/sbc8548.c
Normal file
314
u-boot/board/sbc8548/sbc8548.c
Normal file
@@ -0,0 +1,314 @@
|
||||
/*
|
||||
* Copyright 2007,2009 Wind River Systems, Inc. <www.windriver.com>
|
||||
*
|
||||
* Copyright 2007 Embedded Specialties, Inc.
|
||||
*
|
||||
* Copyright 2004, 2007 Freescale Semiconductor.
|
||||
*
|
||||
* (C) Copyright 2002 Scott McNutt <smcnutt@artesyncp.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <pci.h>
|
||||
#include <asm/processor.h>
|
||||
#include <asm/immap_85xx.h>
|
||||
#include <asm/fsl_pci.h>
|
||||
#include <fsl_ddr_sdram.h>
|
||||
#include <asm/fsl_serdes.h>
|
||||
#include <spd_sdram.h>
|
||||
#include <netdev.h>
|
||||
#include <tsec.h>
|
||||
#include <miiphy.h>
|
||||
#include <libfdt.h>
|
||||
#include <fdt_support.h>
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
void local_bus_init(void);
|
||||
|
||||
int board_early_init_f (void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
int checkboard (void)
|
||||
{
|
||||
volatile ccsr_local_ecm_t *ecm = (void *)(CONFIG_SYS_MPC85xx_ECM_ADDR);
|
||||
volatile u_char *rev= (void *)CONFIG_SYS_BD_REV;
|
||||
|
||||
printf ("Board: Wind River SBC8548 Rev. 0x%01x\n",
|
||||
in_8(rev) >> 4);
|
||||
|
||||
/*
|
||||
* Initialize local bus.
|
||||
*/
|
||||
local_bus_init ();
|
||||
|
||||
out_be32(&ecm->eedr, 0xffffffff); /* clear ecm errors */
|
||||
out_be32(&ecm->eeer, 0xffffffff); /* enable ecm errors */
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Initialize Local Bus
|
||||
*/
|
||||
void
|
||||
local_bus_init(void)
|
||||
{
|
||||
volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
|
||||
volatile fsl_lbc_t *lbc = LBC_BASE_ADDR;
|
||||
|
||||
uint clkdiv, lbc_mhz, lcrr = CONFIG_SYS_LBC_LCRR;
|
||||
sys_info_t sysinfo;
|
||||
|
||||
get_sys_info(&sysinfo);
|
||||
|
||||
lbc_mhz = sysinfo.freq_localbus / 1000000;
|
||||
clkdiv = sysinfo.freq_systembus / sysinfo.freq_localbus;
|
||||
|
||||
debug("LCRR=0x%x, CD=%d, MHz=%d\n", lcrr, clkdiv, lbc_mhz);
|
||||
|
||||
out_be32(&gur->lbiuiplldcr1, 0x00078080);
|
||||
if (clkdiv == 16) {
|
||||
out_be32(&gur->lbiuiplldcr0, 0x7c0f1bf0);
|
||||
} else if (clkdiv == 8) {
|
||||
out_be32(&gur->lbiuiplldcr0, 0x6c0f1bf0);
|
||||
} else if (clkdiv == 4) {
|
||||
out_be32(&gur->lbiuiplldcr0, 0x5c0f1bf0);
|
||||
}
|
||||
|
||||
/*
|
||||
* Local Bus Clock > 83.3 MHz. According to timing
|
||||
* specifications set LCRR[EADC] to 2 delay cycles.
|
||||
*/
|
||||
if (lbc_mhz > 83) {
|
||||
lcrr &= ~LCRR_EADC;
|
||||
lcrr |= LCRR_EADC_2;
|
||||
}
|
||||
|
||||
/*
|
||||
* According to MPC8548ERMAD Rev. 1.3, 13.3.1.16, 13-30
|
||||
* disable PLL bypass for Local Bus Clock > 83 MHz.
|
||||
*/
|
||||
if (lbc_mhz >= 66)
|
||||
lcrr &= (~LCRR_DBYP); /* DLL Enabled */
|
||||
|
||||
else
|
||||
lcrr |= LCRR_DBYP; /* DLL Bypass */
|
||||
|
||||
out_be32(&lbc->lcrr, lcrr);
|
||||
asm("sync;isync;msync");
|
||||
|
||||
/*
|
||||
* According to MPC8548ERMAD Rev.1.3 read back LCRR
|
||||
* and terminate with isync
|
||||
*/
|
||||
lcrr = in_be32(&lbc->lcrr);
|
||||
asm ("isync;");
|
||||
|
||||
/* let DLL stabilize */
|
||||
udelay(500);
|
||||
|
||||
out_be32(&lbc->ltesr, 0xffffffff); /* Clear LBC error IRQs */
|
||||
out_be32(&lbc->lteir, 0xffffffff); /* Enable LBC error IRQs */
|
||||
}
|
||||
|
||||
/*
|
||||
* Initialize SDRAM memory on the Local Bus.
|
||||
*/
|
||||
void lbc_sdram_init(void)
|
||||
{
|
||||
#if defined(CONFIG_SYS_LBC_SDRAM_SIZE)
|
||||
|
||||
uint idx;
|
||||
const unsigned long size = CONFIG_SYS_LBC_SDRAM_SIZE * 1024 * 1024;
|
||||
volatile fsl_lbc_t *lbc = LBC_BASE_ADDR;
|
||||
uint *sdram_addr = (uint *)CONFIG_SYS_LBC_SDRAM_BASE;
|
||||
uint *sdram_addr2 = (uint *)(CONFIG_SYS_LBC_SDRAM_BASE + size/2);
|
||||
|
||||
puts(" SDRAM: ");
|
||||
|
||||
print_size(size, "\n");
|
||||
|
||||
/*
|
||||
* Setup SDRAM Base and Option Registers
|
||||
*/
|
||||
set_lbc_or(3, CONFIG_SYS_OR3_PRELIM);
|
||||
set_lbc_br(3, CONFIG_SYS_BR3_PRELIM);
|
||||
set_lbc_or(4, CONFIG_SYS_OR4_PRELIM);
|
||||
set_lbc_br(4, CONFIG_SYS_BR4_PRELIM);
|
||||
|
||||
out_be32(&lbc->lbcr, CONFIG_SYS_LBC_LBCR);
|
||||
asm("msync");
|
||||
|
||||
out_be32(&lbc->lsrt, CONFIG_SYS_LBC_LSRT);
|
||||
out_be32(&lbc->mrtpr, CONFIG_SYS_LBC_MRTPR);
|
||||
asm("msync");
|
||||
|
||||
/*
|
||||
* Issue PRECHARGE ALL command.
|
||||
*/
|
||||
out_be32(&lbc->lsdmr, CONFIG_SYS_LBC_LSDMR_PCHALL);
|
||||
asm("sync;msync");
|
||||
*sdram_addr = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr);
|
||||
*sdram_addr2 = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr2);
|
||||
udelay(100);
|
||||
|
||||
/*
|
||||
* Issue 8 AUTO REFRESH commands.
|
||||
*/
|
||||
for (idx = 0; idx < 8; idx++) {
|
||||
out_be32(&lbc->lsdmr, CONFIG_SYS_LBC_LSDMR_ARFRSH);
|
||||
asm("sync;msync");
|
||||
*sdram_addr = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr);
|
||||
*sdram_addr2 = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr2);
|
||||
udelay(100);
|
||||
}
|
||||
|
||||
/*
|
||||
* Issue 8 MODE-set command.
|
||||
*/
|
||||
out_be32(&lbc->lsdmr, CONFIG_SYS_LBC_LSDMR_MRW);
|
||||
asm("sync;msync");
|
||||
*sdram_addr = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr);
|
||||
*sdram_addr2 = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr2);
|
||||
udelay(100);
|
||||
|
||||
/*
|
||||
* Issue RFEN command.
|
||||
*/
|
||||
out_be32(&lbc->lsdmr, CONFIG_SYS_LBC_LSDMR_RFEN);
|
||||
asm("sync;msync");
|
||||
*sdram_addr = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr);
|
||||
*sdram_addr2 = 0xff;
|
||||
ppcDcbf((unsigned long) sdram_addr2);
|
||||
udelay(200); /* Overkill. Must wait > 200 bus cycles */
|
||||
|
||||
#endif /* enable SDRAM init */
|
||||
}
|
||||
|
||||
#if defined(CONFIG_SYS_DRAM_TEST)
|
||||
int
|
||||
testdram(void)
|
||||
{
|
||||
uint *pstart = (uint *) CONFIG_SYS_MEMTEST_START;
|
||||
uint *pend = (uint *) CONFIG_SYS_MEMTEST_END;
|
||||
uint *p;
|
||||
|
||||
printf("Testing DRAM from 0x%08x to 0x%08x\n",
|
||||
CONFIG_SYS_MEMTEST_START,
|
||||
CONFIG_SYS_MEMTEST_END);
|
||||
|
||||
printf("DRAM test phase 1:\n");
|
||||
for (p = pstart; p < pend; p++)
|
||||
*p = 0xaaaaaaaa;
|
||||
|
||||
for (p = pstart; p < pend; p++) {
|
||||
if (*p != 0xaaaaaaaa) {
|
||||
printf ("DRAM test fails at: %08x\n", (uint) p);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
|
||||
printf("DRAM test phase 2:\n");
|
||||
for (p = pstart; p < pend; p++)
|
||||
*p = 0x55555555;
|
||||
|
||||
for (p = pstart; p < pend; p++) {
|
||||
if (*p != 0x55555555) {
|
||||
printf ("DRAM test fails at: %08x\n", (uint) p);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
|
||||
printf("DRAM test passed.\n");
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_PCI1
|
||||
static struct pci_controller pci1_hose;
|
||||
#endif /* CONFIG_PCI1 */
|
||||
|
||||
#ifdef CONFIG_PCI
|
||||
void
|
||||
pci_init_board(void)
|
||||
{
|
||||
volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
|
||||
int first_free_busno = 0;
|
||||
|
||||
#ifdef CONFIG_PCI1
|
||||
struct fsl_pci_info pci_info;
|
||||
u32 devdisr = in_be32(&gur->devdisr);
|
||||
u32 pordevsr = in_be32(&gur->pordevsr);
|
||||
u32 porpllsr = in_be32(&gur->porpllsr);
|
||||
|
||||
if (!(devdisr & MPC85xx_DEVDISR_PCI1)) {
|
||||
uint pci_32 = pordevsr & MPC85xx_PORDEVSR_PCI1_PCI32;
|
||||
uint pci_arb = pordevsr & MPC85xx_PORDEVSR_PCI1_ARB;
|
||||
uint pci_clk_sel = porpllsr & MPC85xx_PORDEVSR_PCI1_SPD;
|
||||
uint pci_speed = CONFIG_SYS_CLK_FREQ; /* get_clock_freq() */
|
||||
|
||||
printf("PCI: Host, %d bit, %s MHz, %s, %s\n",
|
||||
(pci_32) ? 32 : 64,
|
||||
(pci_speed == 33000000) ? "33" :
|
||||
(pci_speed == 66000000) ? "66" : "unknown",
|
||||
pci_clk_sel ? "sync" : "async",
|
||||
pci_arb ? "arbiter" : "external-arbiter");
|
||||
|
||||
SET_STD_PCI_INFO(pci_info, 1);
|
||||
set_next_law(pci_info.mem_phys,
|
||||
law_size_bits(pci_info.mem_size), pci_info.law);
|
||||
set_next_law(pci_info.io_phys,
|
||||
law_size_bits(pci_info.io_size), pci_info.law);
|
||||
|
||||
first_free_busno = fsl_pci_init_port(&pci_info,
|
||||
&pci1_hose, first_free_busno);
|
||||
} else {
|
||||
printf("PCI: disabled\n");
|
||||
}
|
||||
|
||||
puts("\n");
|
||||
#else
|
||||
setbits_be32(&gur->devdisr, MPC85xx_DEVDISR_PCI1); /* disable */
|
||||
#endif
|
||||
|
||||
setbits_be32(&gur->devdisr, MPC85xx_DEVDISR_PCI2); /* disable PCI2 */
|
||||
|
||||
fsl_pcie_init_board(first_free_busno);
|
||||
}
|
||||
#endif
|
||||
|
||||
int board_eth_init(bd_t *bis)
|
||||
{
|
||||
tsec_standard_init(bis);
|
||||
pci_eth_init(bis);
|
||||
return 0; /* otherwise cpu_eth_init gets run */
|
||||
}
|
||||
|
||||
int last_stage_init(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_OF_BOARD_SETUP)
|
||||
int ft_board_setup(void *blob, bd_t *bd)
|
||||
{
|
||||
ft_cpu_setup(blob, bd);
|
||||
|
||||
#ifdef CONFIG_FSL_PCI_INIT
|
||||
FT_FSL_PCI_SETUP;
|
||||
#endif
|
||||
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
122
u-boot/board/sbc8548/tlb.c
Normal file
122
u-boot/board/sbc8548/tlb.c
Normal file
@@ -0,0 +1,122 @@
|
||||
/*
|
||||
* Copyright 2008 Freescale Semiconductor, Inc.
|
||||
*
|
||||
* (C) Copyright 2000
|
||||
* Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <asm/mmu.h>
|
||||
|
||||
struct fsl_e_tlb_entry tlb_table[] = {
|
||||
/* TLB 0 - for temp stack in cache */
|
||||
SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR, CONFIG_SYS_INIT_RAM_ADDR,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, 0,
|
||||
0, 0, BOOKE_PAGESZ_4K, 0),
|
||||
SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 4 * 1024,
|
||||
CONFIG_SYS_INIT_RAM_ADDR + 4 * 1024,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, 0,
|
||||
0, 0, BOOKE_PAGESZ_4K, 0),
|
||||
SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 8 * 1024,
|
||||
CONFIG_SYS_INIT_RAM_ADDR + 8 * 1024,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, 0,
|
||||
0, 0, BOOKE_PAGESZ_4K, 0),
|
||||
SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 12 * 1024,
|
||||
CONFIG_SYS_INIT_RAM_ADDR + 12 * 1024,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, 0,
|
||||
0, 0, BOOKE_PAGESZ_4K, 0),
|
||||
|
||||
/*
|
||||
* TLB 0: 64M Non-cacheable, guarded
|
||||
* 0xfc000000 56M unused
|
||||
* 0xff800000 8M boot FLASH
|
||||
* .... or ....
|
||||
* 0xfc000000 64M user flash
|
||||
*
|
||||
* Out of reset this entry is only 4K.
|
||||
*/
|
||||
SET_TLB_ENTRY(1, 0xfc000000, 0xfc000000,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 0, BOOKE_PAGESZ_64M, 1),
|
||||
|
||||
/*
|
||||
* TLB 1: 1G Non-cacheable, guarded
|
||||
* 0x80000000 512M PCI1 MEM
|
||||
* 0xa0000000 512M PCIe MEM
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_PCI1_MEM_VIRT, CONFIG_SYS_PCI1_MEM_PHYS,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 1, BOOKE_PAGESZ_1G, 1),
|
||||
|
||||
/*
|
||||
* TLB 2: 64M Non-cacheable, guarded
|
||||
* 0xe0000000 1M CCSRBAR
|
||||
* 0xe2000000 8M PCI1 IO
|
||||
* 0xe2800000 8M PCIe IO
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_CCSRBAR, CONFIG_SYS_CCSRBAR_PHYS,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 2, BOOKE_PAGESZ_64M, 1),
|
||||
|
||||
#ifdef CONFIG_SYS_LBC_SDRAM_BASE
|
||||
/*
|
||||
* TLB 3: 64M Cacheable, non-guarded
|
||||
* 0xf0000000 64M LBC SDRAM First half
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_LBC_SDRAM_BASE, CONFIG_SYS_LBC_SDRAM_BASE,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, 0,
|
||||
0, 3, BOOKE_PAGESZ_64M, 1),
|
||||
|
||||
/*
|
||||
* TLB 4: 64M Cacheable, non-guarded
|
||||
* 0xf4000000 64M LBC SDRAM Second half
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_LBC_SDRAM_BASE + 0x4000000,
|
||||
CONFIG_SYS_LBC_SDRAM_BASE + 0x4000000,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, 0,
|
||||
0, 4, BOOKE_PAGESZ_64M, 1),
|
||||
#endif
|
||||
|
||||
/*
|
||||
* TLB 5: 16M Cacheable, non-guarded
|
||||
* 0xf8000000 1M 7-segment LED display
|
||||
* 0xf8100000 1M User switches
|
||||
* 0xf8300000 1M Board revision
|
||||
* 0xf8b00000 1M EEPROM
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_EPLD_BASE, CONFIG_SYS_EPLD_BASE,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 5, BOOKE_PAGESZ_16M, 1),
|
||||
|
||||
#ifndef CONFIG_SYS_ALT_BOOT
|
||||
/*
|
||||
* TLB 6: 64M Non-cacheable, guarded
|
||||
* 0xec000000 64M 64MB user FLASH
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_ALT_FLASH, CONFIG_SYS_ALT_FLASH,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 6, BOOKE_PAGESZ_64M, 1),
|
||||
#else
|
||||
/*
|
||||
* TLB 6: 4M Non-cacheable, guarded
|
||||
* 0xef800000 4M 1st 1/2 8MB soldered FLASH
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_ALT_FLASH, CONFIG_SYS_ALT_FLASH,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 6, BOOKE_PAGESZ_4M, 1),
|
||||
|
||||
/*
|
||||
* TLB 7: 4M Non-cacheable, guarded
|
||||
* 0xefc00000 4M 2nd half 8MB soldered FLASH
|
||||
*/
|
||||
SET_TLB_ENTRY(1, CONFIG_SYS_ALT_FLASH + 0x400000,
|
||||
CONFIG_SYS_ALT_FLASH + 0x400000,
|
||||
MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,
|
||||
0, 7, BOOKE_PAGESZ_4M, 1),
|
||||
#endif
|
||||
|
||||
};
|
||||
|
||||
int num_tlb_entries = ARRAY_SIZE(tlb_table);
|
||||
Reference in New Issue
Block a user