blob: 57e714a47af7aff0e78512860c9a004db49c1d5f [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
Sam Ravnborg74b469f2007-10-25 19:42:04 +02002# x86_64 Makefile
Linus Torvalds1da177e2005-04-16 15:20:36 -07003#
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
Thomas Gleixnerbec2c482007-10-23 22:37:23 +020024# BITS is used as extension for files which are available in a 32 bit
25# and a 64 bit version to simplify shared Makefiles.
26# e.g.: obj-y += foo_$(BITS).o
27BITS := 64
28export BITS
29
Linus Torvalds1da177e2005-04-16 15:20:36 -070030LDFLAGS := -m elf_x86_64
31OBJCOPYFLAGS := -O binary -R .note -R .comment -S
Eric W. Biederman5ded01e2005-06-25 14:57:48 -070032LDFLAGS_vmlinux :=
Linus Torvalds1da177e2005-04-16 15:20:36 -070033CHECKFLAGS += -D__x86_64__ -m64
34
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020035cflags-y :=
Sergey Vlasov409f89e2006-06-26 13:59:32 +020036cflags-kernel-y :=
Linus Torvalds1da177e2005-04-16 15:20:36 -070037cflags-$(CONFIG_MK8) += $(call cc-option,-march=k8)
38cflags-$(CONFIG_MPSC) += $(call cc-option,-march=nocona)
Andi Kleen71381992006-12-07 02:14:09 +010039# gcc doesn't support -march=core2 yet as of gcc 4.3, but I hope it
40# will eventually. Use -mtune=generic as fallback
41cflags-$(CONFIG_MCORE2) += \
42 $(call cc-option,-march=core2,$(call cc-option,-mtune=generic))
Andi Kleendca99a32006-03-25 16:29:06 +010043cflags-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=generic)
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020045cflags-y += -m64
46cflags-y += -mno-red-zone
47cflags-y += -mcmodel=kernel
48cflags-y += -pipe
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020049cflags-y += -Wno-sign-compare
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020050cflags-y += -fno-asynchronous-unwind-tables
Jan Beulich6e0c47e2006-01-11 22:42:05 +010051ifneq ($(CONFIG_DEBUG_INFO),y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070052# -fweb shrinks the kernel a bit, but the difference is very small
53# it also messes up debugging, so don't use it for now.
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020054#cflags-y += $(call cc-option,-fweb)
Linus Torvalds1da177e2005-04-16 15:20:36 -070055endif
56# -funit-at-a-time shrinks the kernel .text considerably
57# unfortunately it makes reading oopses harder.
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020058cflags-y += $(call cc-option,-funit-at-a-time)
Linus Torvalds1da177e2005-04-16 15:20:36 -070059# prevent gcc from generating any FP code by mistake
Sam Ravnborgbbd3aff2006-04-07 19:50:28 +020060cflags-y += $(call cc-option,-mno-sse -mno-mmx -mno-sse2 -mno-3dnow,)
Andi Kleencdfce1f2006-10-21 18:37:01 +020061# this works around some issues with generating unwind tables in older gccs
62# newer gccs do it by default
63cflags-y += -maccumulate-outgoing-args
64
Andi Kleene2414912006-09-26 10:52:30 +020065# do binutils support CFI?
Andi Kleenf0f12d82007-08-15 02:40:37 +020066cflags-y += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
Sam Ravnborg222d3942007-10-15 21:59:31 +020067KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
Linus Torvalds1da177e2005-04-16 15:20:36 -070068
Jan Beulichadf14232006-09-26 10:52:41 +020069# is .cfi_signal_frame supported too?
70cflags-y += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
Sam Ravnborg222d3942007-10-15 21:59:31 +020071KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
Jan Beulichadf14232006-09-26 10:52:41 +020072
Ingo Molnarccf9ff52006-11-16 11:49:16 +010073cflags-$(CONFIG_CC_STACKPROTECTOR) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector )
74cflags-$(CONFIG_CC_STACKPROTECTOR_ALL) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector-all )
Arjan van de Ven4f7fd4d2006-09-26 10:52:39 +020075
Sam Ravnborga0f97e02007-10-14 22:21:35 +020076KBUILD_CFLAGS += $(cflags-y)
Sergey Vlasov409f89e2006-06-26 13:59:32 +020077CFLAGS_KERNEL += $(cflags-kernel-y)
Sam Ravnborg222d3942007-10-15 21:59:31 +020078KBUILD_AFLAGS += -m64
Andi Kleenbb334212006-01-11 22:43:54 +010079
Hiroshi Shimamoto77788872007-10-19 20:35:02 +020080head-y := arch/x86/kernel/head_64.o arch/x86/kernel/head64.o arch/x86/kernel/init_task.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070081
Thomas Gleixner185f3d32007-10-11 11:17:08 +020082libs-y += arch/x86/lib/
Thomas Gleixner250c2272007-10-11 11:17:24 +020083core-y += arch/x86/kernel/ \
Thomas Gleixner95119fb2007-10-11 11:17:18 +020084 arch/x86/mm/ \
Thomas Gleixner987c75d72007-10-11 11:17:03 +020085 arch/x86/crypto/ \
Thomas Gleixner7648b132007-10-11 11:17:10 +020086 arch/x86/vdso/
Thomas Gleixner2db55d32007-10-11 11:17:21 +020087core-$(CONFIG_IA32_EMULATION) += arch/x86/ia32/
Thomas Gleixnerf68c0652007-10-11 11:17:12 +020088drivers-$(CONFIG_PCI) += arch/x86/pci/
Thomas Gleixnerff439562007-10-11 11:16:55 +020089drivers-$(CONFIG_OPROFILE) += arch/x86/oprofile/
Linus Torvalds1da177e2005-04-16 15:20:36 -070090
Thomas Gleixner2a6c8d52007-10-11 11:17:16 +020091boot := arch/x86/boot
Linus Torvalds1da177e2005-04-16 15:20:36 -070092
Paul Smith4f193362006-03-05 17:14:10 -050093PHONY += bzImage bzlilo install archmrproper \
H. Peter Anvin841b8a42006-03-26 01:36:59 -080094 fdimage fdimage144 fdimage288 isoimage archclean
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
96#Default target when executing "make"
97all: bzImage
98
Thomas Gleixner2a6c8d52007-10-11 11:17:16 +020099BOOTIMAGE := arch/x86/boot/bzImage
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100KBUILD_IMAGE := $(BOOTIMAGE)
101
102bzImage: vmlinux
103 $(Q)$(MAKE) $(build)=$(boot) $(BOOTIMAGE)
Sam Ravnborg3ceba782007-10-19 20:35:02 +0200104 $(Q)mkdir -p $(objtree)/arch/x86_64/boot
105 $(Q)ln -fsn ../../x86/boot/bzImage $(objtree)/arch/x86_64/boot/bzImage
Linus Torvalds1da177e2005-04-16 15:20:36 -0700106
107bzlilo: vmlinux
108 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zlilo
109
110bzdisk: vmlinux
111 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zdisk
112
H. Peter Anvin841b8a42006-03-26 01:36:59 -0800113fdimage fdimage144 fdimage288 isoimage: vmlinux
Linus Torvalds1da177e2005-04-16 15:20:36 -0700114 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
115
Roland McGrathaf7e6a72007-10-17 18:04:32 +0200116install: vdso_install
H. Peter Anvin0d20bab2006-01-07 17:38:39 -0800117 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
118
Roland McGrathaf7e6a72007-10-17 18:04:32 +0200119vdso_install:
120ifeq ($(CONFIG_IA32_EMULATION),y)
121 $(Q)$(MAKE) $(build)=arch/x86/ia32 $@
122endif
Roland McGrathf79eb832007-10-17 18:04:32 +0200123 $(Q)$(MAKE) $(build)=arch/x86/vdso $@
Roland McGrathaf7e6a72007-10-17 18:04:32 +0200124
Linus Torvalds1da177e2005-04-16 15:20:36 -0700125archclean:
Thomas Gleixner2a6c8d52007-10-11 11:17:16 +0200126 $(Q)rm -rf $(objtree)/arch/x86_64/boot
Linus Torvalds1da177e2005-04-16 15:20:36 -0700127 $(Q)$(MAKE) $(clean)=$(boot)
128
Linus Torvalds1da177e2005-04-16 15:20:36 -0700129define archhelp
130 echo '* bzImage - Compressed kernel image (arch/$(ARCH)/boot/bzImage)'
131 echo ' install - Install kernel using'
H. Peter Anvin841b8a42006-03-26 01:36:59 -0800132 echo ' (your) ~/bin/installkernel or'
133 echo ' (distribution) /sbin/installkernel or'
134 echo ' install to $$(INSTALL_PATH) and run lilo'
135 echo ' bzdisk - Create a boot floppy in /dev/fd0'
136 echo ' fdimage - Create a boot floppy image'
137 echo ' isoimage - Create a boot CD-ROM image'
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138endef
139
H. Peter Anvin841b8a42006-03-26 01:36:59 -0800140CLEAN_FILES += arch/$(ARCH)/boot/fdimage \
141 arch/$(ARCH)/boot/image.iso \
142 arch/$(ARCH)/boot/mtools.conf
Linus Torvalds1da177e2005-04-16 15:20:36 -0700143
144