diff options
author | Kumar Gala <galak@kernel.crashing.org> | 2008-01-24 17:04:58 -0500 |
---|---|---|
committer | Kumar Gala <galak@kernel.crashing.org> | 2008-01-27 15:10:36 -0500 |
commit | 7858f7477e3d9311240b93d4f320a8d57faa3c70 (patch) | |
tree | 092e3e1c8195ed51f45d1707ca9575ae565526d5 /arch | |
parent | b3bea15d29799797d1486aeddf883404a2e05c81 (diff) |
[POWERPC] Add a cuboot wrapper for 85xx with CPM2
The bd info struct changes if we have CPM2 enabled in u-boot.
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/powerpc/boot/Makefile | 5 | ||||
-rw-r--r-- | arch/powerpc/boot/cuboot-85xx-cpm2.c | 66 |
2 files changed, 70 insertions, 1 deletions
diff --git a/arch/powerpc/boot/Makefile b/arch/powerpc/boot/Makefile index b36f9113ad1f..7f6b07c30d69 100644 --- a/arch/powerpc/boot/Makefile +++ b/arch/powerpc/boot/Makefile | |||
@@ -63,7 +63,7 @@ src-plat := of.c cuboot-52xx.c cuboot-824x.c cuboot-83xx.c cuboot-85xx.c holly.c | |||
63 | cuboot-pq2.c cuboot-sequoia.c treeboot-walnut.c cuboot-bamboo.c \ | 63 | cuboot-pq2.c cuboot-sequoia.c treeboot-walnut.c cuboot-bamboo.c \ |
64 | fixed-head.S ep88xc.c cuboot-hpc2.c ep405.c cuboot-taishan.c \ | 64 | fixed-head.S ep88xc.c cuboot-hpc2.c ep405.c cuboot-taishan.c \ |
65 | cuboot-katmai.c cuboot-rainier.c redboot-8xx.c ep8248e.c \ | 65 | cuboot-katmai.c cuboot-rainier.c redboot-8xx.c ep8248e.c \ |
66 | cuboot-warp.c | 66 | cuboot-warp.c cuboot-85xx-cpm2.c |
67 | src-boot := $(src-wlib) $(src-plat) empty.c | 67 | src-boot := $(src-wlib) $(src-plat) empty.c |
68 | 68 | ||
69 | src-boot := $(addprefix $(obj)/, $(src-boot)) | 69 | src-boot := $(addprefix $(obj)/, $(src-boot)) |
@@ -201,6 +201,9 @@ image-$(CONFIG_PPC_MPC52xx) += cuImage.52xx | |||
201 | image-$(CONFIG_STORCENTER) += cuImage.824x | 201 | image-$(CONFIG_STORCENTER) += cuImage.824x |
202 | image-$(CONFIG_PPC_83xx) += cuImage.83xx | 202 | image-$(CONFIG_PPC_83xx) += cuImage.83xx |
203 | image-$(CONFIG_PPC_85xx) += cuImage.85xx | 203 | image-$(CONFIG_PPC_85xx) += cuImage.85xx |
204 | ifeq ($(CONFIG_CPM2),y) | ||
205 | image-$(CONFIG_PPC_85xx) += cuImage.85xx-cpm2 | ||
206 | endif | ||
204 | image-$(CONFIG_MPC7448HPC2) += cuImage.hpc2 | 207 | image-$(CONFIG_MPC7448HPC2) += cuImage.hpc2 |
205 | image-$(CONFIG_EBONY) += treeImage.ebony cuImage.ebony | 208 | image-$(CONFIG_EBONY) += treeImage.ebony cuImage.ebony |
206 | image-$(CONFIG_BAMBOO) += treeImage.bamboo cuImage.bamboo | 209 | image-$(CONFIG_BAMBOO) += treeImage.bamboo cuImage.bamboo |
diff --git a/arch/powerpc/boot/cuboot-85xx-cpm2.c b/arch/powerpc/boot/cuboot-85xx-cpm2.c new file mode 100644 index 000000000000..723872ddd447 --- /dev/null +++ b/arch/powerpc/boot/cuboot-85xx-cpm2.c | |||
@@ -0,0 +1,66 @@ | |||
1 | /* | ||
2 | * Old U-boot compatibility for 85xx | ||
3 | * | ||
4 | * Author: Scott Wood <scottwood@freescale.com> | ||
5 | * | ||
6 | * Copyright (c) 2007 Freescale Semiconductor, Inc. | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify it | ||
9 | * under the terms of the GNU General Public License version 2 as published | ||
10 | * by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include "ops.h" | ||
14 | #include "stdio.h" | ||
15 | #include "cuboot.h" | ||
16 | |||
17 | #define TARGET_85xx | ||
18 | #define TARGET_CPM2 | ||
19 | #include "ppcboot.h" | ||
20 | |||
21 | static bd_t bd; | ||
22 | |||
23 | static void platform_fixups(void) | ||
24 | { | ||
25 | void *devp; | ||
26 | |||
27 | dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); | ||
28 | dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr); | ||
29 | dt_fixup_mac_address_by_alias("ethernet1", bd.bi_enet1addr); | ||
30 | dt_fixup_mac_address_by_alias("ethernet2", bd.bi_enet2addr); | ||
31 | dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 8, bd.bi_busfreq); | ||
32 | |||
33 | /* Unfortunately, the specific model number is encoded in the | ||
34 | * soc node name in existing dts files -- once that is fixed, | ||
35 | * this can do a simple path lookup. | ||
36 | */ | ||
37 | devp = find_node_by_devtype(NULL, "soc"); | ||
38 | if (devp) { | ||
39 | void *serial = NULL; | ||
40 | |||
41 | setprop(devp, "bus-frequency", &bd.bi_busfreq, | ||
42 | sizeof(bd.bi_busfreq)); | ||
43 | |||
44 | while ((serial = find_node_by_devtype(serial, "serial"))) { | ||
45 | if (get_parent(serial) != devp) | ||
46 | continue; | ||
47 | |||
48 | setprop(serial, "clock-frequency", &bd.bi_busfreq, | ||
49 | sizeof(bd.bi_busfreq)); | ||
50 | } | ||
51 | } | ||
52 | |||
53 | devp = find_node_by_compatible(NULL, "fsl,cpm2-brg"); | ||
54 | if (devp) | ||
55 | setprop(devp, "clock-frequency", &bd.bi_brgfreq, | ||
56 | sizeof(bd.bi_brgfreq)); | ||
57 | } | ||
58 | |||
59 | void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, | ||
60 | unsigned long r6, unsigned long r7) | ||
61 | { | ||
62 | CUBOOT_INIT(); | ||
63 | fdt_init(_dtb_start); | ||
64 | serial_console_init(); | ||
65 | platform_ops.fixups = platform_fixups; | ||
66 | } | ||