Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/sage/ceph...
[linux-2.6.git] / arch / x86 / Makefile.um
blob36b62bc52638368c750c250a529995cd8cac80cb
1 core-y += arch/x86/crypto/
3 ifeq ($(CONFIG_X86_32),y)
4 START := 0x8048000
6 LDFLAGS                 += -m elf_i386
7 ELF_ARCH                := i386
8 ELF_FORMAT              := elf32-i386
9 CHECKFLAGS      += -D__i386__
11 KBUILD_CFLAGS           += $(call cc-option,-m32)
12 KBUILD_AFLAGS           += $(call cc-option,-m32)
13 LINK-y                  += $(call cc-option,-m32)
15 export LDFLAGS
17 LDS_EXTRA               := -Ui386
18 export LDS_EXTRA
20 # First of all, tune CFLAGS for the specific CPU. This actually sets cflags-y.
21 include $(srctree)/arch/x86/Makefile_32.cpu
23 # prevent gcc from keeping the stack 16 byte aligned. Taken from i386.
24 cflags-y += $(call cc-option,-mpreferred-stack-boundary=2)
26 # Prevent sprintf in nfsd from being converted to strcpy and resulting in
27 # an unresolved reference.
28 cflags-y += -ffreestanding
30 # Disable unit-at-a-time mode on pre-gcc-4.0 compilers, it makes gcc use
31 # a lot more stack due to the lack of sharing of stacklots.  Also, gcc
32 # 4.3.0 needs -funit-at-a-time for extern inline functions.
33 KBUILD_CFLAGS += $(shell if [ $(call cc-version) -lt 0400 ] ; then \
34                         echo $(call cc-option,-fno-unit-at-a-time); \
35                         else echo $(call cc-option,-funit-at-a-time); fi ;)
37 KBUILD_CFLAGS += $(cflags-y)
39 else
41 START := 0x60000000
43 KBUILD_CFLAGS += -fno-builtin -m64 
45 CHECKFLAGS  += -m64 -D__x86_64__
46 KBUILD_AFLAGS += -m64
47 LDFLAGS += -m elf_x86_64
48 KBUILD_CPPFLAGS += -m64
50 ELF_ARCH := i386:x86-64
51 ELF_FORMAT := elf64-x86-64
53 # Not on all 64-bit distros /lib is a symlink to /lib64. PLD is an example.
55 LINK-$(CONFIG_LD_SCRIPT_DYN) += -Wl,-rpath,/lib64
56 LINK-y += -m64
58 # Do unit-at-a-time unconditionally on x86_64, following the host
59 KBUILD_CFLAGS += $(call cc-option,-funit-at-a-time)
60 endif