mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-03-15 22:36:58 +00:00
Merge branch 'mpc86xx'
This commit is contained in:
commit
bdee35d0e0
3 changed files with 243 additions and 12 deletions
|
@ -30,7 +30,7 @@
|
|||
i-cache-line-size = <20>; // 32 bytes
|
||||
d-cache-size = <8000>; // L1, 32K
|
||||
i-cache-size = <8000>; // L1, 32K
|
||||
timebase-frequency = <0>; // 33 MHz, from uboot
|
||||
timebase-frequency = <0>; // 33 MHz, from uboot
|
||||
bus-frequency = <0>; // From uboot
|
||||
clock-frequency = <0>; // From uboot
|
||||
32-bit;
|
||||
|
@ -44,7 +44,7 @@
|
|||
i-cache-line-size = <20>; // 32 bytes
|
||||
d-cache-size = <8000>; // L1, 32K
|
||||
i-cache-size = <8000>; // L1, 32K
|
||||
timebase-frequency = <0>; // 33 MHz, from uboot
|
||||
timebase-frequency = <0>; // 33 MHz, from uboot
|
||||
bus-frequency = <0>; // From uboot
|
||||
clock-frequency = <0>; // From uboot
|
||||
32-bit;
|
||||
|
@ -55,7 +55,7 @@
|
|||
memory {
|
||||
device_type = "memory";
|
||||
linux,phandle = <300>;
|
||||
reg = <00000000 40000000>; // 1G at 0x0, replaced by uboot
|
||||
reg = <00000000 40000000>; // 1G at 0x0
|
||||
};
|
||||
|
||||
soc8641@f8000000 {
|
||||
|
@ -95,28 +95,28 @@
|
|||
ethernet-phy@0 {
|
||||
linux,phandle = <2452000>;
|
||||
interrupt-parent = <40000>;
|
||||
interrupts = <a 0>;
|
||||
interrupts = <3a 0>;
|
||||
reg = <0>;
|
||||
device_type = "ethernet-phy";
|
||||
};
|
||||
ethernet-phy@1 {
|
||||
linux,phandle = <2452001>;
|
||||
interrupt-parent = <40000>;
|
||||
interrupts = <a 0>;
|
||||
interrupts = <3a 0>;
|
||||
reg = <1>;
|
||||
device_type = "ethernet-phy";
|
||||
};
|
||||
ethernet-phy@2 {
|
||||
linux,phandle = <2452002>;
|
||||
interrupt-parent = <40000>;
|
||||
interrupts = <a 0>;
|
||||
interrupts = <3a 0>;
|
||||
reg = <2>;
|
||||
device_type = "ethernet-phy";
|
||||
};
|
||||
ethernet-phy@3 {
|
||||
linux,phandle = <2452003>;
|
||||
interrupt-parent = <40000>;
|
||||
interrupts = <a 0>;
|
||||
interrupts = <3a 0>;
|
||||
reg = <3>;
|
||||
device_type = "ethernet-phy";
|
||||
};
|
||||
|
@ -176,8 +176,8 @@
|
|||
serial@4500 {
|
||||
device_type = "serial";
|
||||
compatible = "ns16550";
|
||||
reg = <4500 100>; // reg base, size
|
||||
clock-frequency = <0>; // should we fill in in uboot?
|
||||
reg = <4500 100>;
|
||||
clock-frequency = <0>;
|
||||
interrupts = <2a 3>;
|
||||
interrupt-parent = <40000>;
|
||||
};
|
||||
|
@ -185,12 +185,120 @@
|
|||
serial@4600 {
|
||||
device_type = "serial";
|
||||
compatible = "ns16550";
|
||||
reg = <4600 100>; // reg base, size
|
||||
clock-frequency = <0>; // should we fill in in uboot?
|
||||
reg = <4600 100>;
|
||||
clock-frequency = <0>;
|
||||
interrupts = <2a 3>;
|
||||
interrupt-parent = <40000>;
|
||||
};
|
||||
|
||||
pci@8000 {
|
||||
compatible = "86xx";
|
||||
device_type = "pci";
|
||||
linux,phandle = <8000>;
|
||||
#interrupt-cells = <1>;
|
||||
#size-cells = <2>;
|
||||
#address-cells = <3>;
|
||||
reg = <8000 1000>;
|
||||
bus-range = <0 fe>;
|
||||
ranges = <02000000 0 80000000 80000000 0 20000000
|
||||
01000000 0 00000000 e2000000 0 00100000>;
|
||||
clock-frequency = <1fca055>;
|
||||
interrupt-parent = <40000>;
|
||||
interrupts = <8 0>;
|
||||
interrupt-map-mask = <f800 0 0 7>;
|
||||
interrupt-map = <
|
||||
/* IDSEL 0x11 */
|
||||
8800 0 0 1 40000 3 0
|
||||
8800 0 0 2 40000 4 0
|
||||
8800 0 0 3 40000 5 0
|
||||
8800 0 0 4 40000 6 0
|
||||
|
||||
/* IDSEL 0x12 */
|
||||
9000 0 0 1 40000 4 0
|
||||
9000 0 0 2 40000 5 0
|
||||
9000 0 0 3 40000 6 0
|
||||
9000 0 0 4 40000 3 0
|
||||
|
||||
/* IDSEL 0x13 */
|
||||
9800 0 0 1 40000 5 0
|
||||
9800 0 0 2 40000 6 0
|
||||
9800 0 0 3 40000 3 0
|
||||
9800 0 0 4 40000 4 0
|
||||
|
||||
/* IDSEL 0x14 */
|
||||
a000 0 0 1 40000 6 0
|
||||
a000 0 0 2 40000 3 0
|
||||
a000 0 0 3 40000 4 0
|
||||
a000 0 0 4 40000 5 0
|
||||
|
||||
/* IDSEL 0x15 */
|
||||
a800 0 0 1 40000 0 0
|
||||
a800 0 0 2 40000 0 0
|
||||
a800 0 0 3 40000 0 0
|
||||
a800 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x16 */
|
||||
b000 0 0 1 40000 0 0
|
||||
b000 0 0 2 40000 0 0
|
||||
b000 0 0 3 40000 0 0
|
||||
b000 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x17 */
|
||||
b800 0 0 1 40000 0 0
|
||||
b800 0 0 2 40000 0 0
|
||||
b800 0 0 3 40000 0 0
|
||||
b800 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x18 */
|
||||
c000 0 0 1 40000 0 0
|
||||
c000 0 0 2 40000 0 0
|
||||
c000 0 0 3 40000 0 0
|
||||
c000 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x19 */
|
||||
c800 0 0 1 40000 0 0
|
||||
c800 0 0 2 40000 0 0
|
||||
c800 0 0 3 40000 0 0
|
||||
c800 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x1a */
|
||||
d000 0 0 1 40000 0 0
|
||||
d000 0 0 2 40000 0 0
|
||||
d000 0 0 3 40000 0 0
|
||||
d000 0 0 4 40000 0 0
|
||||
|
||||
|
||||
/* IDSEL 0x1b */
|
||||
d800 0 0 1 40000 0 0
|
||||
d800 0 0 2 40000 0 0
|
||||
d800 0 0 3 40000 0 0
|
||||
d800 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x1c */
|
||||
e000 0 0 1 40000 0 0
|
||||
e000 0 0 2 40000 0 0
|
||||
e000 0 0 3 40000 0 0
|
||||
e000 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x1d */
|
||||
e800 0 0 1 40000 0 0
|
||||
e800 0 0 2 40000 0 0
|
||||
e800 0 0 3 40000 0 0
|
||||
e800 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x1e */
|
||||
f000 0 0 1 40000 0 0
|
||||
f000 0 0 2 40000 0 0
|
||||
f000 0 0 3 40000 0 0
|
||||
f000 0 0 4 40000 0 0
|
||||
|
||||
/* IDSEL 0x1f */
|
||||
f800 0 0 1 40000 6 0
|
||||
f800 0 0 2 40000 6 0
|
||||
f800 0 0 3 40000 6 0
|
||||
f800 0 0 4 40000 6 0
|
||||
>;
|
||||
};
|
||||
pic@40000 {
|
||||
linux,phandle = <40000>;
|
||||
clock-frequency = <0>;
|
||||
|
|
|
@ -83,7 +83,7 @@ U_BOOT_CMD(
|
|||
extern int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
|
||||
|
||||
U_BOOT_CMD(
|
||||
reset, 1, 0, do_reset,
|
||||
reset, CFG_MAXARGS, 1, do_reset,
|
||||
"reset - Perform RESET of the CPU\n",
|
||||
NULL
|
||||
);
|
||||
|
|
123
doc/README.mpc8641hpcn
Normal file
123
doc/README.mpc8641hpcn
Normal file
|
@ -0,0 +1,123 @@
|
|||
Freescale MPC8641HPCN board
|
||||
===========================
|
||||
|
||||
Created 05/24/2006 Haiying Wang
|
||||
-------------------------------
|
||||
|
||||
1. Building U-Boot
|
||||
------------------
|
||||
The 86xx HPCN code base is known to compile using:
|
||||
Binutils 2.15, Gcc 3.4.3, Glibc 2.3.3
|
||||
|
||||
$ make MPC8641HPCN_config
|
||||
Configuring for MPC8641HPCN board...
|
||||
|
||||
$ make
|
||||
|
||||
|
||||
2. Switch and Jumper Setting
|
||||
----------------------------
|
||||
Jumpers:
|
||||
J14 Pins 1-2 (near plcc32 socket)
|
||||
|
||||
Switches:
|
||||
SW1(1-5) = 01100 CFG_COREPLL = 01000 :: CORE = 2:1
|
||||
01100 :: CORE = 2.5:1
|
||||
10000 :: CORE = 3:1
|
||||
11100 :: CORE = 3.5:1
|
||||
10100 :: CORE = 4:1
|
||||
01110 :: CORE = 4.5:1
|
||||
SW1(6-8) = 001 CFG_SYSCLK = 000 :: SYSCLK = 33MHz
|
||||
001 :: SYSCLK = 40MHz
|
||||
|
||||
SW2(1-4) = 1100 CFG_CCBPLL = 0010 :: 2X
|
||||
0100 :: 4X
|
||||
0110 :: 6X
|
||||
1000 :: 8X
|
||||
1010 :: 10X
|
||||
1100 :: 12X
|
||||
1110 :: 14X
|
||||
0000 :: 16X
|
||||
SW2(5-8) = 1110 CFG_BOOTLOC = 1110 :: boot 16-bit localbus
|
||||
|
||||
SW3(1-7) = 0011000 CFG_VID = 0011000 :: VCORE = 1.2V
|
||||
0100000 :: VCORE = 1.11V
|
||||
SW3(8) = 0 VCC_PLAT = 0 :: VCC_PLAT = 1.2V
|
||||
1 :: VCC_PLAT = 1.0V
|
||||
|
||||
SW4(1-2) = 11 CFG_HOSTMODE = 11 :: both prots host/root
|
||||
SW4(3-4) = 11 CFG_BOOTSEQ = 11 :: no boot seq
|
||||
SW4(5-8) = 0011 CFG_IOPORT = 0011 :: both PEX
|
||||
|
||||
SW5(1) = 1 CFG_FLASHMAP = 1 :: boot from flash
|
||||
0 :: boot from PromJet
|
||||
SW5(2) = 1 CFG_FLASHBANK = 1 :: swap upper/lower
|
||||
halves (virtual banks)
|
||||
0 :: normal
|
||||
SW5(3) = 0 CFG_FLASHWP = 0 :: not protected
|
||||
SW5(4) = 0 CFG_PORTDIV = 1 :: 2:1 for PD4
|
||||
1:1 for PD6
|
||||
SW5(5-6) = 11 CFG_PIXISOPT = 11 :: s/w determined
|
||||
SW5(7-8) = 11 CFG_LADOPT = 11 :: s/w determined
|
||||
|
||||
SW6(1) = 1 CFG_CPUBOOT = 1 :: no boot holdoff
|
||||
SW6(2) = 1 CFG_BOOTADDR = 1 :: no traslation
|
||||
SW6(3-5) = 000 CFG_REFCLKSEL = 000 :: 100MHZ
|
||||
SW6(6) = 1 CFG_SERROM_ADDR= 1 ::
|
||||
SW6(7) = 1 CFG_MEMDEBUG = 1 ::
|
||||
SW6(8) = 1 CFG_DDRDEBUG = 1 ::
|
||||
|
||||
SW8(1) = 1 ACZ_SYNC = 1 :: 48MHz on TP49
|
||||
SW8(2) = 1 ACB_SYNC = 1 :: THRMTRIP disabled
|
||||
SW8(3) = 1 ACZ_SDOUT = 1 :: p4 mode
|
||||
SW8(4) = 1 ACB_SDOUT = 1 :: PATA freq. = 133MHz
|
||||
SW8(5) = 0 SUSLED = 0 :: SouthBridge Mode
|
||||
SW8(6) = 0 SPREAD = 0 :: REFCLK SSCG Disabled
|
||||
SW8(7) = 1 ACPWR = 1 :: non-battery
|
||||
SW8(8) = 0 CFG_IDWP = 0 :: write enable
|
||||
|
||||
|
||||
3. Flash U-Boot
|
||||
---------------
|
||||
The flash range 0xFF800000 to 0xFFFFFFFF can be divided into 2 halves.
|
||||
It is possible to use either half to boot using u-boot. Switch 5 bit 2
|
||||
is used for this purpose.
|
||||
|
||||
0xFF800000 to 0xFFBFFFFF - 4MB
|
||||
0xFFC00000 to 0xFFFFFFFF - 4MB
|
||||
When this bit is 0, U-Boot is at 0xFFF00000.
|
||||
When this bit is 1, U-Boot is at 0xFFB00000.
|
||||
|
||||
Use the above mentioned flash commands to program the other half, and
|
||||
use switch 5, bit 2 to alternate between the halves. Note: The booting
|
||||
version of U-Boot will always be at 0xFFF00000.
|
||||
|
||||
To Flash U-Boot into the booting bank (0xFFC00000 - 0xFFFFFFFF):
|
||||
|
||||
tftp 1000000 u-boot.bin
|
||||
protect off all
|
||||
erase fff00000 ffffffff
|
||||
cp.b 1000000 fff00100 80000
|
||||
|
||||
To Flash U-boot into the alternative bank (0xFF800000 - 0xFFBFFFFF):
|
||||
|
||||
tftp 1000000 u-boot.bin
|
||||
erase ffb00000 ffbfffff
|
||||
cp.b 1000000 ffb00100 80000
|
||||
|
||||
|
||||
4. Memory Map
|
||||
-------------
|
||||
|
||||
Memory Range Device Size
|
||||
------------ ------ ----
|
||||
0x0000_0000 0x7fff_ffff DDR 2G
|
||||
0x8000_0000 0x9fff_ffff PCI1/PEX1 MEM 512M
|
||||
0xa000_0000 0xafff_ffff PCI2/PEX2 MEM 512M
|
||||
0xf800_0000 0xf80f_ffff CCSR 1M
|
||||
0xf810_0000 0xf81f_ffff PIXIS 1M
|
||||
0xf840_0000 0xf840_3fff Stack space 32K
|
||||
0xe200_0000 0xe2ff_ffff PCI1/PEX1 IO 512M
|
||||
0xe300_0000 0xe3ff_ffff PCI2/PEX2 IO 512M
|
||||
0xfe00_0000 0xfeff_ffff Flash(alternate)16M
|
||||
0xff00_0000 0xffff_ffff Flash(boot bank)16M
|
Loading…
Add table
Reference in a new issue