|
@@ -17,17 +17,18 @@ HAS_BIARCH := $(call cc-option-yn, -m32)
|
|
|
# Set default 32 bits cross compilers for vdso and boot wrapper
|
|
|
CROSS32_COMPILE ?=
|
|
|
|
|
|
-CROSS32CC := $(CROSS32_COMPILE)gcc
|
|
|
-CROSS32AR := $(CROSS32_COMPILE)ar
|
|
|
-
|
|
|
ifeq ($(HAS_BIARCH),y)
|
|
|
ifeq ($(CROSS32_COMPILE),)
|
|
|
-CROSS32CC := $(CC) -m32
|
|
|
-KBUILD_ARFLAGS += --target=elf32-powerpc
|
|
|
+ifdef CONFIG_PPC32
|
|
|
+# These options will be overridden by any -mcpu option that the CPU
|
|
|
+# or platform code sets later on the command line, but they are needed
|
|
|
+# to set a sane 32-bit cpu target for the 64-bit cross compiler which
|
|
|
+# may default to the wrong ISA.
|
|
|
+KBUILD_CFLAGS += -mcpu=powerpc
|
|
|
+KBUILD_AFLAGS += -mcpu=powerpc
|
|
|
+endif
|
|
|
endif
|
|
|
endif
|
|
|
-
|
|
|
-export CROSS32CC CROSS32AR
|
|
|
|
|
|
ifeq ($(CROSS_COMPILE),)
|
|
|
KBUILD_DEFCONFIG := $(shell uname -m)_defconfig
|
|
@@ -74,13 +75,15 @@ endif
|
|
|
endif
|
|
|
|
|
|
ifeq ($(CONFIG_CPU_LITTLE_ENDIAN),y)
|
|
|
-override LD += -EL
|
|
|
+KBUILD_CFLAGS += -mlittle-endian
|
|
|
+LDFLAGS += -EL
|
|
|
LDEMULATION := lppc
|
|
|
GNUTARGET := powerpcle
|
|
|
MULTIPLEWORD := -mno-multiple
|
|
|
KBUILD_CFLAGS_MODULE += $(call cc-option,-mno-save-toc-indirect)
|
|
|
else
|
|
|
-override LD += -EB
|
|
|
+KBUILD_CFLAGS += $(call cc-option,-mbig-endian)
|
|
|
+LDFLAGS += -EB
|
|
|
LDEMULATION := ppc
|
|
|
GNUTARGET := powerpc
|
|
|
MULTIPLEWORD := -mmultiple
|
|
@@ -93,19 +96,19 @@ aflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mabi=elfv1)
|
|
|
aflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mabi=elfv2
|
|
|
endif
|
|
|
|
|
|
-cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mlittle-endian
|
|
|
-cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mbig-endian)
|
|
|
ifneq ($(cc-name),clang)
|
|
|
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mno-strict-align
|
|
|
endif
|
|
|
|
|
|
+cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mbig-endian)
|
|
|
+cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mlittle-endian
|
|
|
aflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mbig-endian)
|
|
|
aflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mlittle-endian
|
|
|
|
|
|
ifeq ($(HAS_BIARCH),y)
|
|
|
-override AS += -a$(BITS)
|
|
|
-override LD += -m elf$(BITS)$(LDEMULATION)
|
|
|
-override CC += -m$(BITS)
|
|
|
+KBUILD_CFLAGS += -m$(BITS)
|
|
|
+KBUILD_AFLAGS += -m$(BITS) -Wl,-a$(BITS)
|
|
|
+LDFLAGS += -m elf$(BITS)$(LDEMULATION)
|
|
|
KBUILD_ARFLAGS += --target=elf$(BITS)-$(GNUTARGET)
|
|
|
endif
|
|
|
|