kbuild: enable 'make CFLAGS=...' to add additional options to CC
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / arch / x86_64 / Makefile
CommitLineData
1da177e4
LT
1#
2# x86_64/Makefile
3#
4# This file is included by the global makefile so that you can add your own
5# architecture-specific flags and dependencies. Remember to do have actions
6# for "archclean" and "archdep" for cleaning up and making dependencies for
7# this architecture
8#
9# This file is subject to the terms and conditions of the GNU General Public
10# License. See the file "COPYING" in the main directory of this archive
11# for more details.
12#
13# Copyright (C) 1994 by Linus Torvalds
14#
15# 19990713 Artur Skawina <skawina@geocities.com>
16# Added '-march' and '-mpreferred-stack-boundary' support
17# 20000913 Pavel Machek <pavel@suse.cz>
18# Converted for x86_64 architecture
19# 20010105 Andi Kleen, add IA32 compiler.
20# ....and later removed it again....
21#
22# $Id: Makefile,v 1.31 2002/03/22 15:56:07 ak Exp $
23
250c2277
TG
24# Fill in SRCARCH
25SRCARCH := x86
26
1da177e4
LT
27LDFLAGS := -m elf_x86_64
28OBJCOPYFLAGS := -O binary -R .note -R .comment -S
5ded01e8 29LDFLAGS_vmlinux :=
1da177e4
LT
30CHECKFLAGS += -D__x86_64__ -m64
31
bbd3aff8 32cflags-y :=
409f89e0 33cflags-kernel-y :=
1da177e4
LT
34cflags-$(CONFIG_MK8) += $(call cc-option,-march=k8)
35cflags-$(CONFIG_MPSC) += $(call cc-option,-march=nocona)
71381998
AK
36# gcc doesn't support -march=core2 yet as of gcc 4.3, but I hope it
37# will eventually. Use -mtune=generic as fallback
38cflags-$(CONFIG_MCORE2) += \
39 $(call cc-option,-march=core2,$(call cc-option,-mtune=generic))
dca99a38 40cflags-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=generic)
1da177e4 41
bbd3aff8
SR
42cflags-y += -m64
43cflags-y += -mno-red-zone
44cflags-y += -mcmodel=kernel
45cflags-y += -pipe
bbd3aff8 46cflags-y += -Wno-sign-compare
bbd3aff8 47cflags-y += -fno-asynchronous-unwind-tables
6e0c47ed 48ifneq ($(CONFIG_DEBUG_INFO),y)
1da177e4
LT
49# -fweb shrinks the kernel a bit, but the difference is very small
50# it also messes up debugging, so don't use it for now.
bbd3aff8 51#cflags-y += $(call cc-option,-fweb)
1da177e4
LT
52endif
53# -funit-at-a-time shrinks the kernel .text considerably
54# unfortunately it makes reading oopses harder.
bbd3aff8 55cflags-y += $(call cc-option,-funit-at-a-time)
1da177e4 56# prevent gcc from generating any FP code by mistake
bbd3aff8 57cflags-y += $(call cc-option,-mno-sse -mno-mmx -mno-sse2 -mno-3dnow,)
cdfce1f5
AK
58# this works around some issues with generating unwind tables in older gccs
59# newer gccs do it by default
60cflags-y += -maccumulate-outgoing-args
61
e2414910 62# do binutils support CFI?
f0f12d85
AK
63cflags-y += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
64AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
1da177e4 65
adf14236
JB
66# is .cfi_signal_frame supported too?
67cflags-y += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
68AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
69
ccf9ff52
IM
70cflags-$(CONFIG_CC_STACKPROTECTOR) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector )
71cflags-$(CONFIG_CC_STACKPROTECTOR_ALL) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector-all )
4f7fd4d7 72
a0f97e06 73KBUILD_CFLAGS += $(cflags-y)
409f89e0 74CFLAGS_KERNEL += $(cflags-kernel-y)
bb33421d
AK
75AFLAGS += -m64
76
250c2277 77head-y := arch/x86/kernel/head_64.o arch/x86/kernel/head64.o arch/x86/kernel/init_task_64.o
1da177e4 78
185f3d38 79libs-y += arch/x86/lib/
250c2277 80core-y += arch/x86/kernel/ \
95119fbd 81 arch/x86/mm/ \
987c75d7 82 arch/x86/crypto/ \
7648b133 83 arch/x86/vdso/
2db55d34 84core-$(CONFIG_IA32_EMULATION) += arch/x86/ia32/
f68c0654 85drivers-$(CONFIG_PCI) += arch/x86/pci/
ff439565 86drivers-$(CONFIG_OPROFILE) += arch/x86/oprofile/
1da177e4 87
2a6c8d5a 88boot := arch/x86/boot
1da177e4 89
4f193362 90PHONY += bzImage bzlilo install archmrproper \
841b8a46 91 fdimage fdimage144 fdimage288 isoimage archclean
1da177e4
LT
92
93#Default target when executing "make"
94all: bzImage
95
2a6c8d5a 96BOOTIMAGE := arch/x86/boot/bzImage
1da177e4
LT
97KBUILD_IMAGE := $(BOOTIMAGE)
98
99bzImage: vmlinux
2a6c8d5a
TG
100 $(Q)mkdir -p $(objtree)/arch/x86_64/boot
101 $(Q)ln -fsn $(objtree)/arch/x86/boot/bzImage $(objtree)/arch/x86_64/boot/bzImage
1da177e4
LT
102 $(Q)$(MAKE) $(build)=$(boot) $(BOOTIMAGE)
103
104bzlilo: vmlinux
105 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zlilo
106
107bzdisk: vmlinux
108 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zdisk
109
841b8a46 110fdimage fdimage144 fdimage288 isoimage: vmlinux
1da177e4
LT
111 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
112
0d20babd
PA
113install:
114 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
115
1da177e4 116archclean:
2a6c8d5a 117 $(Q)rm -rf $(objtree)/arch/x86_64/boot
1da177e4
LT
118 $(Q)$(MAKE) $(clean)=$(boot)
119
1da177e4
LT
120define archhelp
121 echo '* bzImage - Compressed kernel image (arch/$(ARCH)/boot/bzImage)'
122 echo ' install - Install kernel using'
841b8a46
PA
123 echo ' (your) ~/bin/installkernel or'
124 echo ' (distribution) /sbin/installkernel or'
125 echo ' install to $$(INSTALL_PATH) and run lilo'
126 echo ' bzdisk - Create a boot floppy in /dev/fd0'
127 echo ' fdimage - Create a boot floppy image'
128 echo ' isoimage - Create a boot CD-ROM image'
1da177e4
LT
129endef
130
841b8a46
PA
131CLEAN_FILES += arch/$(ARCH)/boot/fdimage \
132 arch/$(ARCH)/boot/image.iso \
133 arch/$(ARCH)/boot/mtools.conf
1da177e4
LT
134
135