201 lines
6.4 KiB
Plaintext
201 lines
6.4 KiB
Plaintext
|
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
|
||
|
=>
|
||
|
|
||
|
|
||
|
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.
|
||
|
|
||
|
|
||
|
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
|
||
|
|
||
|
|
||
|
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. Currently
|
||
|
u-boot doesn't support booting off the SODIMM in this alternate
|
||
|
setting without manually altering BR0/OR0 and BR6/OR6 in the
|
||
|
board config file appropriately.
|
||
|
|
||
|
|
||
|
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)
|
||
|
|
||
|
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
|