diff options
-rw-r--r-- | arch/mips/Kconfig | 15 | ||||
-rw-r--r-- | arch/mips/Makefile | 23 | ||||
-rw-r--r-- | include/asm-mips/page.h | 2 |
3 files changed, 21 insertions, 19 deletions
diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index b09eee2281c5..492f581fe6ba 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig | |||
@@ -1853,21 +1853,6 @@ source "fs/Kconfig.binfmt" | |||
1853 | config TRAD_SIGNALS | 1853 | config TRAD_SIGNALS |
1854 | bool | 1854 | bool |
1855 | 1855 | ||
1856 | config BUILD_ELF64 | ||
1857 | bool "Use 64-bit ELF format for building" | ||
1858 | depends on 64BIT | ||
1859 | help | ||
1860 | A 64-bit kernel is usually built using the 64-bit ELF binary object | ||
1861 | format as it's one that allows arbitrary 64-bit constructs. For | ||
1862 | kernels that are loaded within the KSEG compatibility segments the | ||
1863 | 32-bit ELF format can optionally be used resulting in a somewhat | ||
1864 | smaller binary, but this option is not explicitly supported by the | ||
1865 | toolchain and since binutils 2.14 it does not even work at all. | ||
1866 | |||
1867 | Say Y to use the 64-bit format or N to use the 32-bit one. | ||
1868 | |||
1869 | If unsure say Y. | ||
1870 | |||
1871 | config BINFMT_IRIX | 1856 | config BINFMT_IRIX |
1872 | bool "Include IRIX binary compatibility" | 1857 | bool "Include IRIX binary compatibility" |
1873 | depends on CPU_BIG_ENDIAN && 32BIT && BROKEN | 1858 | depends on CPU_BIG_ENDIAN && 32BIT && BROKEN |
diff --git a/arch/mips/Makefile b/arch/mips/Makefile index d5d5831b6e24..4337c492ed1b 100644 --- a/arch/mips/Makefile +++ b/arch/mips/Makefile | |||
@@ -60,9 +60,6 @@ vmlinux-32 = vmlinux.32 | |||
60 | vmlinux-64 = vmlinux | 60 | vmlinux-64 = vmlinux |
61 | 61 | ||
62 | cflags-y += -mabi=64 | 62 | cflags-y += -mabi=64 |
63 | ifndef CONFIG_BUILD_ELF64 | ||
64 | cflags-y += $(call cc-option,-msym32) | ||
65 | endif | ||
66 | endif | 63 | endif |
67 | 64 | ||
68 | all-$(CONFIG_BOOT_ELF32) := $(vmlinux-32) | 65 | all-$(CONFIG_BOOT_ELF32) := $(vmlinux-32) |
@@ -576,6 +573,26 @@ else | |||
576 | JIFFIES = jiffies_64 | 573 | JIFFIES = jiffies_64 |
577 | endif | 574 | endif |
578 | 575 | ||
576 | # | ||
577 | # Automatically detect the build format. By default we choose | ||
578 | # the elf format according to the load address. | ||
579 | # We can always force a build with a 64-bits symbol format by | ||
580 | # passing 'BUILD_ELF32=no' option to the make's command line. | ||
581 | # | ||
582 | ifdef CONFIG_64BIT | ||
583 | ifndef BUILD_ELF32 | ||
584 | ifeq ($(shell expr $(load-y) \< 0xffffffff80000000), 0) | ||
585 | BUILD_ELF32 = y | ||
586 | endif | ||
587 | endif | ||
588 | |||
589 | ifeq ($(BUILD_ELF32), y) | ||
590 | cflags-y += -msym32 | ||
591 | else | ||
592 | cflags-y += -DCONFIG_BUILD_ELF64 | ||
593 | endif | ||
594 | endif | ||
595 | |||
579 | AFLAGS += $(cflags-y) | 596 | AFLAGS += $(cflags-y) |
580 | CFLAGS += $(cflags-y) \ | 597 | CFLAGS += $(cflags-y) \ |
581 | -D"VMLINUX_LOAD_ADDRESS=$(load-y)" | 598 | -D"VMLINUX_LOAD_ADDRESS=$(load-y)" |
diff --git a/include/asm-mips/page.h b/include/asm-mips/page.h index e3301e54d559..b92dd8c760da 100644 --- a/include/asm-mips/page.h +++ b/include/asm-mips/page.h | |||
@@ -142,7 +142,7 @@ typedef struct { unsigned long pgprot; } pgprot_t; | |||
142 | /* | 142 | /* |
143 | * __pa()/__va() should be used only during mem init. | 143 | * __pa()/__va() should be used only during mem init. |
144 | */ | 144 | */ |
145 | #ifdef CONFIG_64BIT | 145 | #if defined(CONFIG_64BIT) && !defined(CONFIG_BUILD_ELF64) |
146 | #define __pa(x) \ | 146 | #define __pa(x) \ |
147 | ({ \ | 147 | ({ \ |
148 | unsigned long __x = (unsigned long)(x); \ | 148 | unsigned long __x = (unsigned long)(x); \ |