powerpc: Add 64-bit CPU targets for gcc
Add a menu to select various 64-bit CPU targets for gcc. We default to -mtune=power7 and if gcc doesn't understand that we fallback to -mtune=power4. Signed-off-by: Anton Blanchard <anton@samba.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
This commit is contained in:
committed by
Benjamin Herrenschmidt
parent
894a65c857
commit
d23c6fb4eb
@@ -69,6 +69,16 @@ LDFLAGS_vmlinux := $(LDFLAGS_vmlinux-y)
|
|||||||
|
|
||||||
CFLAGS-$(CONFIG_PPC64) := -mminimal-toc -mtraceback=no -mcall-aixdesc
|
CFLAGS-$(CONFIG_PPC64) := -mminimal-toc -mtraceback=no -mcall-aixdesc
|
||||||
CFLAGS-$(CONFIG_PPC32) := -ffixed-r2 -mmultiple
|
CFLAGS-$(CONFIG_PPC32) := -ffixed-r2 -mmultiple
|
||||||
|
|
||||||
|
CFLAGS-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=power7,-mtune=power4)
|
||||||
|
CFLAGS-$(CONFIG_CELL_CPU) += $(call cc-option,-mcpu=cell)
|
||||||
|
CFLAGS-$(CONFIG_POWER4_CPU) += $(call cc-option,-mcpu=power4)
|
||||||
|
CFLAGS-$(CONFIG_POWER5_CPU) += $(call cc-option,-mcpu=power5)
|
||||||
|
CFLAGS-$(CONFIG_POWER6_CPU) += $(call cc-option,-mcpu=power6)
|
||||||
|
CFLAGS-$(CONFIG_POWER7_CPU) += $(call cc-option,-mcpu=power7)
|
||||||
|
|
||||||
|
CFLAGS-$(CONFIG_TUNE_CELL) += $(call cc-option,-mtune=cell)
|
||||||
|
|
||||||
KBUILD_CPPFLAGS += -Iarch/$(ARCH)
|
KBUILD_CPPFLAGS += -Iarch/$(ARCH)
|
||||||
KBUILD_AFLAGS += -Iarch/$(ARCH)
|
KBUILD_AFLAGS += -Iarch/$(ARCH)
|
||||||
KBUILD_CFLAGS += -msoft-float -pipe -Iarch/$(ARCH) $(CFLAGS-y)
|
KBUILD_CFLAGS += -msoft-float -pipe -Iarch/$(ARCH) $(CFLAGS-y)
|
||||||
@@ -76,22 +86,11 @@ CPP = $(CC) -E $(KBUILD_CFLAGS)
|
|||||||
|
|
||||||
CHECKFLAGS += -m$(CONFIG_WORD_SIZE) -D__powerpc__ -D__powerpc$(CONFIG_WORD_SIZE)__
|
CHECKFLAGS += -m$(CONFIG_WORD_SIZE) -D__powerpc__ -D__powerpc$(CONFIG_WORD_SIZE)__
|
||||||
|
|
||||||
ifeq ($(CONFIG_PPC64),y)
|
|
||||||
ifeq ($(CONFIG_POWER4_ONLY),y)
|
|
||||||
KBUILD_CFLAGS += $(call cc-option,-mcpu=power4)
|
|
||||||
else
|
|
||||||
KBUILD_CFLAGS += $(call cc-option,-mtune=power4)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
KBUILD_LDFLAGS_MODULE += arch/powerpc/lib/crtsavres.o
|
KBUILD_LDFLAGS_MODULE += arch/powerpc/lib/crtsavres.o
|
||||||
|
|
||||||
ifeq ($(CONFIG_TUNE_CELL),y)
|
# No AltiVec or VSX instructions when building kernel
|
||||||
KBUILD_CFLAGS += $(call cc-option,-mtune=cell)
|
|
||||||
endif
|
|
||||||
|
|
||||||
# No AltiVec instruction when building kernel
|
|
||||||
KBUILD_CFLAGS += $(call cc-option,-mno-altivec)
|
KBUILD_CFLAGS += $(call cc-option,-mno-altivec)
|
||||||
|
KBUILD_CFLAGS += $(call cc-option,-mno-vsx)
|
||||||
|
|
||||||
# No SPE instruction when building kernel
|
# No SPE instruction when building kernel
|
||||||
# (We use all available options to help semi-broken compilers)
|
# (We use all available options to help semi-broken compilers)
|
||||||
|
@@ -78,6 +78,36 @@ config PPC_BOOK3E_64
|
|||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
|
choice
|
||||||
|
prompt "CPU selection"
|
||||||
|
depends on PPC64
|
||||||
|
default GENERIC_CPU
|
||||||
|
help
|
||||||
|
This will create a kernel which is optimised for a particular CPU.
|
||||||
|
The resulting kernel may not run on other CPUs, so use this with care.
|
||||||
|
|
||||||
|
If unsure, select Generic.
|
||||||
|
|
||||||
|
config GENERIC_CPU
|
||||||
|
bool "Generic"
|
||||||
|
|
||||||
|
config CELL_CPU
|
||||||
|
bool "Cell Broadband Engine"
|
||||||
|
|
||||||
|
config POWER4_CPU
|
||||||
|
bool "POWER4"
|
||||||
|
|
||||||
|
config POWER5_CPU
|
||||||
|
bool "POWER5"
|
||||||
|
|
||||||
|
config POWER6_CPU
|
||||||
|
bool "POWER6"
|
||||||
|
|
||||||
|
config POWER7_CPU
|
||||||
|
bool "POWER7"
|
||||||
|
|
||||||
|
endchoice
|
||||||
|
|
||||||
config PPC_BOOK3S
|
config PPC_BOOK3S
|
||||||
def_bool y
|
def_bool y
|
||||||
depends on PPC_BOOK3S_32 || PPC_BOOK3S_64
|
depends on PPC_BOOK3S_32 || PPC_BOOK3S_64
|
||||||
|
Reference in New Issue
Block a user