aboutsummaryrefslogtreecommitdiffstats
path: root/arch/ppc64/kernel
diff options
context:
space:
mode:
authorMichael Ellerman <michael@ellerman.id.au>2005-09-23 00:59:04 -0400
committerStephen Rothwell <sfr@canb.auug.org.au>2005-09-23 00:59:04 -0400
commit4762713a93fa8706c31b0897c1340e7dc282d8fb (patch)
tree12c28b1b91fa691c17e9d33dcc7a391e7445a473 /arch/ppc64/kernel
parentc0a59491daca7db11d49edad1a1cefaaa7120a9e (diff)
ppc64 iSeries: Call early_setup() on iSeries
Misc steps to incorporate the flat device tree on iSeries. - define iseries_probe() - call build_iSeries_Memory_Map() earlier - return __pa() of the flat device tree from iSeries_early_setup() - actually call early_setup() for iSeries - add iseries_md to machdep_calls - build prom.o for iSeries - enable /proc/device-tree for iSeries Signed-off-by: Michael Ellerman <michael@ellerman.id.au> Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
Diffstat (limited to 'arch/ppc64/kernel')
-rw-r--r--arch/ppc64/kernel/Makefile4
-rw-r--r--arch/ppc64/kernel/head.S1
-rw-r--r--arch/ppc64/kernel/iSeries_setup.c22
-rw-r--r--arch/ppc64/kernel/setup.c9
4 files changed, 22 insertions, 14 deletions
diff --git a/arch/ppc64/kernel/Makefile b/arch/ppc64/kernel/Makefile
index 813718df4f82..afadb6e4a6dc 100644
--- a/arch/ppc64/kernel/Makefile
+++ b/arch/ppc64/kernel/Makefile
@@ -11,7 +11,7 @@ obj-y := setup.o entry.o traps.o irq.o idle.o dma.o \
11 udbg.o binfmt_elf32.o sys_ppc32.o ioctl32.o \ 11 udbg.o binfmt_elf32.o sys_ppc32.o ioctl32.o \
12 ptrace32.o signal32.o rtc.o init_task.o \ 12 ptrace32.o signal32.o rtc.o init_task.o \
13 lmb.o cputable.o cpu_setup_power4.o idle_power4.o \ 13 lmb.o cputable.o cpu_setup_power4.o idle_power4.o \
14 iommu.o sysfs.o vdso.o pmc.o firmware.o 14 iommu.o sysfs.o vdso.o pmc.o firmware.o prom.o
15obj-y += vdso32/ vdso64/ 15obj-y += vdso32/ vdso64/
16 16
17obj-$(CONFIG_PPC_OF) += of_device.o 17obj-$(CONFIG_PPC_OF) += of_device.o
@@ -27,7 +27,7 @@ obj-$(CONFIG_PPC_ISERIES) += HvCall.o HvLpConfig.o LparData.o \
27 mf.o HvLpEvent.o iSeries_proc.o iSeries_htab.o \ 27 mf.o HvLpEvent.o iSeries_proc.o iSeries_htab.o \
28 iSeries_iommu.o 28 iSeries_iommu.o
29 29
30obj-$(CONFIG_PPC_MULTIPLATFORM) += nvram.o i8259.o prom_init.o prom.o 30obj-$(CONFIG_PPC_MULTIPLATFORM) += nvram.o i8259.o prom_init.o
31 31
32obj-$(CONFIG_PPC_PSERIES) += pSeries_pci.o pSeries_lpar.o pSeries_hvCall.o \ 32obj-$(CONFIG_PPC_PSERIES) += pSeries_pci.o pSeries_lpar.o pSeries_hvCall.o \
33 pSeries_nvram.o rtasd.o ras.o pSeries_reconfig.o \ 33 pSeries_nvram.o rtasd.o ras.o pSeries_reconfig.o \
diff --git a/arch/ppc64/kernel/head.S b/arch/ppc64/kernel/head.S
index b1d0edff0c04..eb526c480b6c 100644
--- a/arch/ppc64/kernel/head.S
+++ b/arch/ppc64/kernel/head.S
@@ -1364,6 +1364,7 @@ _STATIC(__start_initialization_iSeries)
1364 addi r2,r2,0x4000 1364 addi r2,r2,0x4000
1365 1365
1366 bl .iSeries_early_setup 1366 bl .iSeries_early_setup
1367 bl .early_setup
1367 1368
1368 /* relocation is on at this point */ 1369 /* relocation is on at this point */
1369 1370
diff --git a/arch/ppc64/kernel/iSeries_setup.c b/arch/ppc64/kernel/iSeries_setup.c
index 99e4307affd6..27faf4f0967a 100644
--- a/arch/ppc64/kernel/iSeries_setup.c
+++ b/arch/ppc64/kernel/iSeries_setup.c
@@ -359,12 +359,6 @@ static void __init iSeries_init_early(void)
359 */ 359 */
360 iommu_init_early_iSeries(); 360 iommu_init_early_iSeries();
361 361
362 /*
363 * Initialize the table which translate Linux physical addresses to
364 * AS/400 absolute addresses
365 */
366 build_iSeries_Memory_Map();
367
368 iSeries_get_cmdline(); 362 iSeries_get_cmdline();
369 363
370 /* Save unparsed command line copy for /proc/cmdline */ 364 /* Save unparsed command line copy for /proc/cmdline */
@@ -894,6 +888,11 @@ static int iseries_dedicated_idle(void)
894void __init iSeries_init_IRQ(void) { } 888void __init iSeries_init_IRQ(void) { }
895#endif 889#endif
896 890
891static int __init iseries_probe(int platform)
892{
893 return PLATFORM_ISERIES_LPAR == platform;
894}
895
897struct machdep_calls __initdata iseries_md = { 896struct machdep_calls __initdata iseries_md = {
898 .setup_arch = iSeries_setup_arch, 897 .setup_arch = iSeries_setup_arch,
899 .get_cpuinfo = iSeries_get_cpuinfo, 898 .get_cpuinfo = iSeries_get_cpuinfo,
@@ -909,6 +908,7 @@ struct machdep_calls __initdata iseries_md = {
909 .get_rtc_time = iSeries_get_rtc_time, 908 .get_rtc_time = iSeries_get_rtc_time,
910 .calibrate_decr = iSeries_calibrate_decr, 909 .calibrate_decr = iSeries_calibrate_decr,
911 .progress = iSeries_progress, 910 .progress = iSeries_progress,
911 .probe = iseries_probe,
912 /* XXX Implement enable_pmcs for iSeries */ 912 /* XXX Implement enable_pmcs for iSeries */
913}; 913};
914 914
@@ -1047,9 +1047,17 @@ void build_flat_dt(struct iseries_flat_dt *dt)
1047 dt_push_u32(dt, OF_DT_END); 1047 dt_push_u32(dt, OF_DT_END);
1048} 1048}
1049 1049
1050void __init iSeries_early_setup(void) 1050void * __init iSeries_early_setup(void)
1051{ 1051{
1052 iSeries_fixup_klimit(); 1052 iSeries_fixup_klimit();
1053 1053
1054 /*
1055 * Initialize the table which translate Linux physical addresses to
1056 * AS/400 absolute addresses
1057 */
1058 build_iSeries_Memory_Map();
1059
1054 build_flat_dt(&iseries_dt); 1060 build_flat_dt(&iseries_dt);
1061
1062 return (void *) __pa(&iseries_dt);
1055} 1063}
diff --git a/arch/ppc64/kernel/setup.c b/arch/ppc64/kernel/setup.c
index acf826043e39..6c1cd3bab28e 100644
--- a/arch/ppc64/kernel/setup.c
+++ b/arch/ppc64/kernel/setup.c
@@ -309,13 +309,11 @@ static void __init setup_cpu_maps(void)
309} 309}
310#endif /* CONFIG_SMP */ 310#endif /* CONFIG_SMP */
311 311
312
313#ifdef CONFIG_PPC_MULTIPLATFORM
314
315extern struct machdep_calls pSeries_md; 312extern struct machdep_calls pSeries_md;
316extern struct machdep_calls pmac_md; 313extern struct machdep_calls pmac_md;
317extern struct machdep_calls maple_md; 314extern struct machdep_calls maple_md;
318extern struct machdep_calls bpa_md; 315extern struct machdep_calls bpa_md;
316extern struct machdep_calls iseries_md;
319 317
320/* Ultimately, stuff them in an elf section like initcalls... */ 318/* Ultimately, stuff them in an elf section like initcalls... */
321static struct machdep_calls __initdata *machines[] = { 319static struct machdep_calls __initdata *machines[] = {
@@ -331,6 +329,9 @@ static struct machdep_calls __initdata *machines[] = {
331#ifdef CONFIG_PPC_BPA 329#ifdef CONFIG_PPC_BPA
332 &bpa_md, 330 &bpa_md,
333#endif 331#endif
332#ifdef CONFIG_PPC_ISERIES
333 &iseries_md,
334#endif
334 NULL 335 NULL
335}; 336};
336 337
@@ -534,8 +535,6 @@ static void __init check_for_initrd(void)
534#endif /* CONFIG_BLK_DEV_INITRD */ 535#endif /* CONFIG_BLK_DEV_INITRD */
535} 536}
536 537
537#endif /* CONFIG_PPC_MULTIPLATFORM */
538
539/* 538/*
540 * Do some initial setup of the system. The parameters are those which 539 * Do some initial setup of the system. The parameters are those which
541 * were passed in from the bootloader. 540 * were passed in from the bootloader.