aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Rothwell <sfr@canb.auug.org.au>2007-09-20 20:16:20 -0400
committerPaul Mackerras <paulus@samba.org>2007-10-02 19:12:02 -0400
commit2578bfae84a78bd46fdbc0d2f9d39e9fbc9c8a3f (patch)
tree9dad1abf1dd5fa31cc1d507d559baa7e52d6a836
parent75918a4b5998c93ee1ab131fbe64b97b5d0d2315 (diff)
[POWERPC] Create and use CONFIG_WORD_SIZE
Linus made this suggestion for the x86 merge and this starts the process for powerpc. We assume that CONFIG_PPC64 implies CONFIG_PPC_MERGE and CONFIG_PPC_STD_MMU_32 implies CONFIG_PPC_STD_MMU. Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Paul Mackerras <paulus@samba.org>
-rw-r--r--arch/powerpc/Kconfig5
-rw-r--r--arch/powerpc/Makefile21
-rw-r--r--arch/powerpc/kernel/Makefile30
-rw-r--r--arch/powerpc/lib/Makefile7
-rw-r--r--arch/powerpc/mm/Makefile13
-rw-r--r--arch/ppc/Kconfig4
6 files changed, 46 insertions, 34 deletions
diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig
index 26126d27d756..45e86c751f11 100644
--- a/arch/powerpc/Kconfig
+++ b/arch/powerpc/Kconfig
@@ -14,6 +14,11 @@ config 64BIT
14 bool 14 bool
15 default y if PPC64 15 default y if PPC64
16 16
17config WORD_SIZE
18 int
19 default 64 if PPC64
20 default 32 if !PPC64
21
17config PPC_MERGE 22config PPC_MERGE
18 def_bool y 23 def_bool y
19 24
diff --git a/arch/powerpc/Makefile b/arch/powerpc/Makefile
index 87aff5372d6e..71632b20b81d 100644
--- a/arch/powerpc/Makefile
+++ b/arch/powerpc/Makefile
@@ -39,7 +39,6 @@ KBUILD_DEFCONFIG := $(shell uname -m)_defconfig
39 39
40ifeq ($(CONFIG_PPC64),y) 40ifeq ($(CONFIG_PPC64),y)
41OLDARCH := ppc64 41OLDARCH := ppc64
42SZ := 64
43 42
44new_nm := $(shell if $(NM) --help 2>&1 | grep -- '--synthetic' > /dev/null; then echo y; else echo n; fi) 43new_nm := $(shell if $(NM) --help 2>&1 | grep -- '--synthetic' > /dev/null; then echo y; else echo n; fi)
45 44
@@ -49,16 +48,21 @@ endif
49 48
50else 49else
51OLDARCH := ppc 50OLDARCH := ppc
52SZ := 32 51endif
52
53# It seems there are times we use this Makefile without
54# including the config file, but this replicates the old behaviour
55ifeq ($(CONFIG_WORD_SIZE),)
56CONFIG_WORD_SIZE := 32
53endif 57endif
54 58
55UTS_MACHINE := $(OLDARCH) 59UTS_MACHINE := $(OLDARCH)
56 60
57ifeq ($(HAS_BIARCH),y) 61ifeq ($(HAS_BIARCH),y)
58override AS += -a$(SZ) 62override AS += -a$(CONFIG_WORD_SIZE)
59override LD += -m elf$(SZ)ppc 63override LD += -m elf$(CONFIG_WORD_SIZE)ppc
60override CC += -m$(SZ) 64override CC += -m$(CONFIG_WORD_SIZE)
61override AR := GNUTARGET=elf$(SZ)-powerpc $(AR) 65override AR := GNUTARGET=elf$(CONFIG_WORD_SIZE)-powerpc $(AR)
62endif 66endif
63 67
64LDFLAGS_vmlinux := -Bstatic 68LDFLAGS_vmlinux := -Bstatic
@@ -72,7 +76,7 @@ AFLAGS += $(AFLAGS-y)
72CFLAGS += -msoft-float -pipe $(CFLAGS-y) 76CFLAGS += -msoft-float -pipe $(CFLAGS-y)
73CPP = $(CC) -E $(CFLAGS) 77CPP = $(CC) -E $(CFLAGS)
74 78
75CHECKFLAGS += -m$(SZ) -D__powerpc__ -D__powerpc$(SZ)__ 79CHECKFLAGS += -m$(CONFIG_WORD_SIZE) -D__powerpc__ -D__powerpc$(CONFIG_WORD_SIZE)__
76 80
77ifeq ($(CONFIG_PPC64),y) 81ifeq ($(CONFIG_PPC64),y)
78GCC_BROKEN_VEC := $(shell if [ $(call cc-version) -lt 0400 ] ; then echo "y"; fi) 82GCC_BROKEN_VEC := $(shell if [ $(call cc-version) -lt 0400 ] ; then echo "y"; fi)
@@ -120,8 +124,7 @@ cpu-as-$(CONFIG_E200) += -Wa,-me200
120AFLAGS += $(cpu-as-y) 124AFLAGS += $(cpu-as-y)
121CFLAGS += $(cpu-as-y) 125CFLAGS += $(cpu-as-y)
122 126
123head-y := arch/powerpc/kernel/head_32.o 127head-y := arch/powerpc/kernel/head_$(CONFIG_WORD_SIZE).o
124head-$(CONFIG_PPC64) := arch/powerpc/kernel/head_64.o
125head-$(CONFIG_8xx) := arch/powerpc/kernel/head_8xx.o 128head-$(CONFIG_8xx) := arch/powerpc/kernel/head_8xx.o
126head-$(CONFIG_40x) := arch/powerpc/kernel/head_40x.o 129head-$(CONFIG_40x) := arch/powerpc/kernel/head_40x.o
127head-$(CONFIG_44x) := arch/powerpc/kernel/head_44x.o 130head-$(CONFIG_44x) := arch/powerpc/kernel/head_44x.o
diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile
index b37165effb65..fb33a7e71941 100644
--- a/arch/powerpc/kernel/Makefile
+++ b/arch/powerpc/kernel/Makefile
@@ -38,10 +38,10 @@ obj-$(CONFIG_GENERIC_TBSYNC) += smp-tbsync.o
38obj-$(CONFIG_CRASH_DUMP) += crash_dump.o 38obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
39obj-$(CONFIG_6xx) += idle_6xx.o l2cr_6xx.o cpu_setup_6xx.o 39obj-$(CONFIG_6xx) += idle_6xx.o l2cr_6xx.o cpu_setup_6xx.o
40obj-$(CONFIG_TAU) += tau_6xx.o 40obj-$(CONFIG_TAU) += tau_6xx.o
41obj-$(CONFIG_HIBERNATION) += swsusp.o suspend.o 41obj-$(CONFIG_HIBERNATION) += swsusp.o suspend.o \
42obj32-$(CONFIG_HIBERNATION) += swsusp_32.o 42 swsusp_$(CONFIG_WORD_SIZE).o
43obj64-$(CONFIG_HIBERNATION) += swsusp_64.o swsusp_asm64.o 43obj64-$(CONFIG_HIBERNATION) += swsusp_asm64.o
44obj32-$(CONFIG_MODULES) += module_32.o 44obj-$(CONFIG_MODULES) += module_$(CONFIG_WORD_SIZE).o
45 45
46ifeq ($(CONFIG_PPC_MERGE),y) 46ifeq ($(CONFIG_PPC_MERGE),y)
47 47
@@ -54,9 +54,10 @@ extra-$(CONFIG_8xx) := head_8xx.o
54extra-y += vmlinux.lds 54extra-y += vmlinux.lds
55 55
56obj-y += time.o prom.o traps.o setup-common.o \ 56obj-y += time.o prom.o traps.o setup-common.o \
57 udbg.o misc.o io.o 57 udbg.o misc.o io.o \
58obj-$(CONFIG_PPC32) += entry_32.o setup_32.o misc_32.o 58 misc_$(CONFIG_WORD_SIZE).o
59obj-$(CONFIG_PPC64) += misc_64.o dma_64.o iommu.o 59obj-$(CONFIG_PPC32) += entry_32.o setup_32.o
60obj-$(CONFIG_PPC64) += dma_64.o iommu.o
60obj-$(CONFIG_PPC_MULTIPLATFORM) += prom_init.o 61obj-$(CONFIG_PPC_MULTIPLATFORM) += prom_init.o
61obj-$(CONFIG_MODULES) += ppc_ksyms.o 62obj-$(CONFIG_MODULES) += ppc_ksyms.o
62obj-$(CONFIG_BOOTX_TEXT) += btext.o 63obj-$(CONFIG_BOOTX_TEXT) += btext.o
@@ -64,16 +65,12 @@ obj-$(CONFIG_SMP) += smp.o
64obj-$(CONFIG_KPROBES) += kprobes.o 65obj-$(CONFIG_KPROBES) += kprobes.o
65obj-$(CONFIG_PPC_UDBG_16550) += legacy_serial.o udbg_16550.o 66obj-$(CONFIG_PPC_UDBG_16550) += legacy_serial.o udbg_16550.o
66 67
67module-$(CONFIG_PPC64) += module_64.o 68pci64-$(CONFIG_PPC64) += pci_dn.o isa-bridge.o
68obj-$(CONFIG_MODULES) += $(module-y) 69obj-$(CONFIG_PCI) += pci_$(CONFIG_WORD_SIZE).o $(pci64-y) \
69 70 pci-common.o
70pci64-$(CONFIG_PPC64) += pci_64.o pci_dn.o isa-bridge.o
71pci32-$(CONFIG_PPC32) := pci_32.o
72obj-$(CONFIG_PCI) += $(pci64-y) $(pci32-y) pci-common.o
73obj-$(CONFIG_PCI_MSI) += msi.o 71obj-$(CONFIG_PCI_MSI) += msi.o
74kexec-$(CONFIG_PPC64) := machine_kexec_64.o 72obj-$(CONFIG_KEXEC) += machine_kexec.o crash.o \
75kexec-$(CONFIG_PPC32) := machine_kexec_32.o 73 machine_kexec_$(CONFIG_WORD_SIZE).o
76obj-$(CONFIG_KEXEC) += machine_kexec.o crash.o $(kexec-y)
77obj-$(CONFIG_AUDIT) += audit.o 74obj-$(CONFIG_AUDIT) += audit.o
78obj64-$(CONFIG_AUDIT) += compat_audit.o 75obj64-$(CONFIG_AUDIT) += compat_audit.o
79 76
@@ -87,7 +84,6 @@ smpobj-$(CONFIG_SMP) += smp.o
87 84
88endif 85endif
89 86
90obj-$(CONFIG_PPC32) += $(obj32-y)
91obj-$(CONFIG_PPC64) += $(obj64-y) 87obj-$(CONFIG_PPC64) += $(obj64-y)
92 88
93extra-$(CONFIG_PPC_FPU) += fpu.o 89extra-$(CONFIG_PPC_FPU) += fpu.o
diff --git a/arch/powerpc/lib/Makefile b/arch/powerpc/lib/Makefile
index 23bbb1ea7f9f..65d492e316a6 100644
--- a/arch/powerpc/lib/Makefile
+++ b/arch/powerpc/lib/Makefile
@@ -7,11 +7,12 @@ EXTRA_CFLAGS += -mno-minimal-toc
7endif 7endif
8 8
9ifeq ($(CONFIG_PPC_MERGE),y) 9ifeq ($(CONFIG_PPC_MERGE),y)
10obj-y := string.o alloc.o 10obj-y := string.o alloc.o \
11obj-$(CONFIG_PPC32) += div64.o copy_32.o checksum_32.o 11 checksum_$(CONFIG_WORD_SIZE).o
12obj-$(CONFIG_PPC32) += div64.o copy_32.o
12endif 13endif
13 14
14obj-$(CONFIG_PPC64) += checksum_64.o copypage_64.o copyuser_64.o \ 15obj-$(CONFIG_PPC64) += copypage_64.o copyuser_64.o \
15 memcpy_64.o usercopy_64.o mem_64.o string.o 16 memcpy_64.o usercopy_64.o mem_64.o string.o
16obj-$(CONFIG_QUICC_ENGINE) += rheap.o 17obj-$(CONFIG_QUICC_ENGINE) += rheap.o
17obj-$(CONFIG_XMON) += sstep.o 18obj-$(CONFIG_XMON) += sstep.o
diff --git a/arch/powerpc/mm/Makefile b/arch/powerpc/mm/Makefile
index bf20fa688809..20629ae95c50 100644
--- a/arch/powerpc/mm/Makefile
+++ b/arch/powerpc/mm/Makefile
@@ -6,13 +6,16 @@ ifeq ($(CONFIG_PPC64),y)
6EXTRA_CFLAGS += -mno-minimal-toc 6EXTRA_CFLAGS += -mno-minimal-toc
7endif 7endif
8 8
9obj-y := fault.o mem.o lmb.o 9obj-y := fault.o mem.o lmb.o \
10obj-$(CONFIG_PPC32) += init_32.o pgtable_32.o mmu_context_32.o 10 init_$(CONFIG_WORD_SIZE).o \
11 pgtable_$(CONFIG_WORD_SIZE).o \
12 mmu_context_$(CONFIG_WORD_SIZE).o
11hash-$(CONFIG_PPC_NATIVE) := hash_native_64.o 13hash-$(CONFIG_PPC_NATIVE) := hash_native_64.o
12obj-$(CONFIG_PPC64) += init_64.o pgtable_64.o mmu_context_64.o \ 14obj-$(CONFIG_PPC64) += hash_utils_64.o \
13 hash_utils_64.o hash_low_64.o tlb_64.o \
14 slb_low.o slb.o stab.o mmap.o $(hash-y) 15 slb_low.o slb.o stab.o mmap.o $(hash-y)
15obj-$(CONFIG_PPC_STD_MMU_32) += ppc_mmu_32.o hash_low_32.o tlb_32.o 16obj-$(CONFIG_PPC_STD_MMU_32) += ppc_mmu_32.o
17obj-$(CONFIG_PPC_STD_MMU) += hash_low_$(CONFIG_WORD_SIZE).o \
18 tlb_$(CONFIG_WORD_SIZE).o
16obj-$(CONFIG_40x) += 40x_mmu.o 19obj-$(CONFIG_40x) += 40x_mmu.o
17obj-$(CONFIG_44x) += 44x_mmu.o 20obj-$(CONFIG_44x) += 44x_mmu.o
18obj-$(CONFIG_FSL_BOOKE) += fsl_booke_mmu.o 21obj-$(CONFIG_FSL_BOOKE) += fsl_booke_mmu.o
diff --git a/arch/ppc/Kconfig b/arch/ppc/Kconfig
index c1b34eb383cf..c2087f645ad3 100644
--- a/arch/ppc/Kconfig
+++ b/arch/ppc/Kconfig
@@ -4,6 +4,10 @@
4 4
5mainmenu "Linux/PowerPC Kernel Configuration" 5mainmenu "Linux/PowerPC Kernel Configuration"
6 6
7config WORD_SIZE
8 int
9 default 32
10
7config MMU 11config MMU
8 bool 12 bool
9 default y 13 default y