Motorola MPC85xxCDS boards -------------------------- The CDS family of boards consists of a PCI backplane called the "Arcadia", a PCI-form-factor carrier card that plugs into a PCI slot, and a CPU daughter card that bolts onto the daughter card. Much of the content of the README.mpc85xxads for the 85xx ADS boards applies to the 85xx CDS boards as well. In particular the toolchain, the switch nomenclature, and the basis for the memory map. There are some differences, though. Building U-Boot --------------- The Binutils in current ELDK toolchain will not support MPC85xx chip. You need to use binutils-2.14.tar.bz2 (or newer) from http://ftp.gnu.org/gnu/binutils. The 85xx CDS code base is known to compile using: gcc (GCC) 3.2.2 20030217 (Yellow Dog Linux 3.0 3.2.2-2a) Memory Map ---------- The memory map for U-Boot and linux has been extended w.r.t. the ADS platform to allow for utilization of all 85xx CDS devices. The memory map is setup for linux to operate properly. The linux source when configured for MPC85xx CDS has been updated to reflect the new memory map. The mapping is: 0x0000_0000 0x7fff_ffff DDR 2G 0x8000_0000 0x9fff_ffff PCI1 MEM 512M 0xa000_0000 0xbfff_ffff PCI2 MEM 512M 0xe000_0000 0xe00f_ffff CCSR 1M 0xe200_0000 0xe2ff_ffff PCI1 IO 16M 0xe300_0000 0xe3ff_ffff PCI2 IO 16M 0xf000_0000 0xf7ff_ffff SDRAM 128M 0xf800_0000 0xf80f_ffff NVRAM/CADMUS (*) 1M 0xff00_0000 0xff7f_ffff FLASH (2nd bank) 8M 0xff80_0000 0xffff_ffff FLASH (boot bank) 8M (*) The system control registers (CADMUS) start at offset 0xfdb0_4000 within the NVRAM/CADMUS region of memory. Using Flash ----------- The CDS board has two flash banks, each 8MB in size (2^23 = 0x00800000). There is a switch which allows the boot-bank to be selected. The switch settings for updating flash are given below. The U-Boot commands for copying the boot-bank into the secondary bank are as follows: erase ff780000 ff7fffff cp.b fff80000 ff780000 80000 U-Boot/kermit commands for downloading an image, then copying it into the secondary bank: loadb [Drop to kermit: ^\c send c ] erase ff780000 ff7fffff cp.b $loadaddr ff780000 80000 U-Boot commands for downloading an image via tftp and flashing it into the second bank: tftp 10000 erase ff780000 ff7fffff cp.b 10000 ff780000 80000 After copying the image into the second bank of flash, be sure to toggle SW2[2] on the carrier card before resetting the board in order to set the secondary bank as the boot-bank. Carrier Board Switches ---------------------- As a reminder, you should read the README.mpc85xxads too. Most switches on the carrier board should not be changed. The only user-settable switches on the carrier board are used to configure the flash banks and determining the PCI slot. The first two bits of SW2 control how flash is used on the board: 12345678 -------- SW2=00XXXXXX FLASH: Boot bank 1, bank 2 available. 01XXXXXX FLASH: Boot bank 2, bank 1 available (swapped). 10XXXXXX FLASH: Boot promjet, bank 1 available 11XXXXXX FLASH: Boot promjet, bank 2 available The boot bank is always mapped to FF80_0000 and listed first by the "flinfo" command. The secondary bank is always FF00_0000. When using PCI, linux needs to know to which slot the CDS carrier is connected.. By convention, the user-specific bits of SW2 are used to convey this information: 12345678 -------- SW2=xxxxxx00 PCI SLOT INFORM: The CDS carrier is in slot0 of the Arcadia xxxxxx01 PCI SLOT INFORM: The CDS carrier is in slot1 of the Arcadia xxxxxx10 PCI SLOT INFORM: The CDS carrier is in slot2 of the Arcadia xxxxxx11 PCI SLOT INFORM: The CDS carrier is in slot3 of the Arcadia These are cleverly, er, clearly silkscreened as Slot 1 through 4, respectively, on the Arcadia near the support posts. The default setting of all switches on the carrier board is: 12345678 -------- SW1=01101100 SW2=0x1111yy x=Flash bank, yy=PCI slot SW3=11101111 SW4=10001000 8555/41 CPU Card Switches ------------------------- Most switches on the CPU Card should not be changed. However, the frequency can be changed by setting SW3: 12345678 -------- SW3=XX00XXXX == CORE:CCB 2:1 XX01XXXX == CORE:CCB 5:2 XX10XXXX == CORE:CCB 3:1 XX11XXXX == CORE:CCB 7:2 XXXX1000 == CCB:SYSCLK 8:1 XXXX1010 == CCB:SYSCLK 10:1 A safe default setting for all switches on the CPU board is: 12345678 -------- SW1=10001111 SW2=01000111 SW3=00001000 SW4=11111110 8548 CPU Card Switches ---------------------- And, just to be confusing, in this set of switches: ON = 1 OFF = 0 Default SW1=11111101 SW2=10011111 SW3=11001000 (8X) (2:1) SW4=11110011 SW3=X000XXXX == CORE:CCB 4:1 X001XXXX == CORE:CCB 9:2 X010XXXX == CORE:CCB 1:1 X011XXXX == CORE:CCB 3:2 X100XXXX == CORE:CCB 2:1 X101XXXX == CORE:CCB 5:2 X110XXXX == CORE:CCB 3:1 X111XXXX == CORE:CCB 7:2 XXXX0000 == CCB:SYSCLK 16:1 XXXX0001 == RESERVED XXXX0010 == CCB:SYSCLK 2:1 XXXX0011 == CCB:SYSCLK 3:1 XXXX0100 == CCB:SYSCLK 4:1 XXXX0101 == CCB:SYSCLK 5:1 XXXX0110 == CCB:SYSCLK 6:1 XXXX0111 == RESERVED XXXX1000 == CCB:SYSCLK 8:1 XXXX1001 == CCB:SYSCLK 9:1 XXXX1010 == CCB:SYSCLK 10:1 XXXX1011 == RESERVED XXXX1100 == CCB:SYSCLK 12:1 XXXX1101 == CCB:SYSCLK 20:1 XXXX1110 == RESERVED XXXX1111 == RESERVED eDINK Info ---------- One bank of flash may contain an eDINK image. Memory Map: CCSRBAR @ 0xe0000000 Flash Bank 1 @ 0xfe000000 Flash Bank 2 @ 0xff000000 Ram @ 0 Commands for downloading a U-Boot image to memory from edink: env -c time -s 4/8/2004 4:30p dl -k -b -o 100000 [Drop to kermit: ^\c transmit /binary c ] fu -l 100000 fe780000 80000