Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | # |
Sam Ravnborg | 74b469f | 2007-10-25 19:42:04 +0200 | [diff] [blame] | 2 | # x86_64 Makefile |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 | |
Thomas Gleixner | bec2c48 | 2007-10-23 22:37:23 +0200 | [diff] [blame] | 24 | # 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 |
| 27 | BITS := 64 |
| 28 | export BITS |
| 29 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | LDFLAGS := -m elf_x86_64 |
| 31 | OBJCOPYFLAGS := -O binary -R .note -R .comment -S |
Eric W. Biederman | 5ded01e | 2005-06-25 14:57:48 -0700 | [diff] [blame] | 32 | LDFLAGS_vmlinux := |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | CHECKFLAGS += -D__x86_64__ -m64 |
| 34 | |
Sam Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 35 | cflags-y := |
Sergey Vlasov | 409f89e | 2006-06-26 13:59:32 +0200 | [diff] [blame] | 36 | cflags-kernel-y := |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 37 | cflags-$(CONFIG_MK8) += $(call cc-option,-march=k8) |
| 38 | cflags-$(CONFIG_MPSC) += $(call cc-option,-march=nocona) |
Andi Kleen | 7138199 | 2006-12-07 02:14:09 +0100 | [diff] [blame] | 39 | # gcc doesn't support -march=core2 yet as of gcc 4.3, but I hope it |
| 40 | # will eventually. Use -mtune=generic as fallback |
| 41 | cflags-$(CONFIG_MCORE2) += \ |
| 42 | $(call cc-option,-march=core2,$(call cc-option,-mtune=generic)) |
Andi Kleen | dca99a3 | 2006-03-25 16:29:06 +0100 | [diff] [blame] | 43 | cflags-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=generic) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 44 | |
Sam Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 45 | cflags-y += -m64 |
| 46 | cflags-y += -mno-red-zone |
| 47 | cflags-y += -mcmodel=kernel |
| 48 | cflags-y += -pipe |
Sam Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 49 | cflags-y += -Wno-sign-compare |
Sam Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 50 | cflags-y += -fno-asynchronous-unwind-tables |
Jan Beulich | 6e0c47e | 2006-01-11 22:42:05 +0100 | [diff] [blame] | 51 | ifneq ($(CONFIG_DEBUG_INFO),y) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 52 | # -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 Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 54 | #cflags-y += $(call cc-option,-fweb) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 55 | endif |
| 56 | # -funit-at-a-time shrinks the kernel .text considerably |
| 57 | # unfortunately it makes reading oopses harder. |
Sam Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 58 | cflags-y += $(call cc-option,-funit-at-a-time) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 59 | # prevent gcc from generating any FP code by mistake |
Sam Ravnborg | bbd3aff | 2006-04-07 19:50:28 +0200 | [diff] [blame] | 60 | cflags-y += $(call cc-option,-mno-sse -mno-mmx -mno-sse2 -mno-3dnow,) |
Andi Kleen | cdfce1f | 2006-10-21 18:37:01 +0200 | [diff] [blame] | 61 | # this works around some issues with generating unwind tables in older gccs |
| 62 | # newer gccs do it by default |
| 63 | cflags-y += -maccumulate-outgoing-args |
| 64 | |
Andi Kleen | e241491 | 2006-09-26 10:52:30 +0200 | [diff] [blame] | 65 | # do binutils support CFI? |
Andi Kleen | f0f12d8 | 2007-08-15 02:40:37 +0200 | [diff] [blame] | 66 | cflags-y += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,) |
Sam Ravnborg | 222d394 | 2007-10-15 21:59:31 +0200 | [diff] [blame] | 67 | KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 68 | |
Jan Beulich | adf1423 | 2006-09-26 10:52:41 +0200 | [diff] [blame] | 69 | # is .cfi_signal_frame supported too? |
| 70 | cflags-y += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,) |
Sam Ravnborg | 222d394 | 2007-10-15 21:59:31 +0200 | [diff] [blame] | 71 | KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,) |
Jan Beulich | adf1423 | 2006-09-26 10:52:41 +0200 | [diff] [blame] | 72 | |
Ingo Molnar | ccf9ff5 | 2006-11-16 11:49:16 +0100 | [diff] [blame] | 73 | cflags-$(CONFIG_CC_STACKPROTECTOR) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector ) |
| 74 | cflags-$(CONFIG_CC_STACKPROTECTOR_ALL) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector-all ) |
Arjan van de Ven | 4f7fd4d | 2006-09-26 10:52:39 +0200 | [diff] [blame] | 75 | |
Sam Ravnborg | a0f97e0 | 2007-10-14 22:21:35 +0200 | [diff] [blame] | 76 | KBUILD_CFLAGS += $(cflags-y) |
Sergey Vlasov | 409f89e | 2006-06-26 13:59:32 +0200 | [diff] [blame] | 77 | CFLAGS_KERNEL += $(cflags-kernel-y) |
Sam Ravnborg | 222d394 | 2007-10-15 21:59:31 +0200 | [diff] [blame] | 78 | KBUILD_AFLAGS += -m64 |
Andi Kleen | bb33421 | 2006-01-11 22:43:54 +0100 | [diff] [blame] | 79 | |
Hiroshi Shimamoto | 7778887 | 2007-10-19 20:35:02 +0200 | [diff] [blame] | 80 | head-y := arch/x86/kernel/head_64.o arch/x86/kernel/head64.o arch/x86/kernel/init_task.o |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 81 | |
Thomas Gleixner | 185f3d3 | 2007-10-11 11:17:08 +0200 | [diff] [blame] | 82 | libs-y += arch/x86/lib/ |
Thomas Gleixner | 250c227 | 2007-10-11 11:17:24 +0200 | [diff] [blame] | 83 | core-y += arch/x86/kernel/ \ |
Thomas Gleixner | 95119fb | 2007-10-11 11:17:18 +0200 | [diff] [blame] | 84 | arch/x86/mm/ \ |
Thomas Gleixner | 987c75d7 | 2007-10-11 11:17:03 +0200 | [diff] [blame] | 85 | arch/x86/crypto/ \ |
Thomas Gleixner | 7648b13 | 2007-10-11 11:17:10 +0200 | [diff] [blame] | 86 | arch/x86/vdso/ |
Thomas Gleixner | 2db55d3 | 2007-10-11 11:17:21 +0200 | [diff] [blame] | 87 | core-$(CONFIG_IA32_EMULATION) += arch/x86/ia32/ |
Thomas Gleixner | f68c065 | 2007-10-11 11:17:12 +0200 | [diff] [blame] | 88 | drivers-$(CONFIG_PCI) += arch/x86/pci/ |
Thomas Gleixner | ff43956 | 2007-10-11 11:16:55 +0200 | [diff] [blame] | 89 | drivers-$(CONFIG_OPROFILE) += arch/x86/oprofile/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 90 | |
Thomas Gleixner | 2a6c8d5 | 2007-10-11 11:17:16 +0200 | [diff] [blame] | 91 | boot := arch/x86/boot |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 | |
Paul Smith | 4f19336 | 2006-03-05 17:14:10 -0500 | [diff] [blame] | 93 | PHONY += bzImage bzlilo install archmrproper \ |
H. Peter Anvin | 841b8a4 | 2006-03-26 01:36:59 -0800 | [diff] [blame] | 94 | fdimage fdimage144 fdimage288 isoimage archclean |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 95 | |
| 96 | #Default target when executing "make" |
| 97 | all: bzImage |
| 98 | |
Thomas Gleixner | 2a6c8d5 | 2007-10-11 11:17:16 +0200 | [diff] [blame] | 99 | BOOTIMAGE := arch/x86/boot/bzImage |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 100 | KBUILD_IMAGE := $(BOOTIMAGE) |
| 101 | |
| 102 | bzImage: vmlinux |
| 103 | $(Q)$(MAKE) $(build)=$(boot) $(BOOTIMAGE) |
Sam Ravnborg | 3ceba78 | 2007-10-19 20:35:02 +0200 | [diff] [blame] | 104 | $(Q)mkdir -p $(objtree)/arch/x86_64/boot |
| 105 | $(Q)ln -fsn ../../x86/boot/bzImage $(objtree)/arch/x86_64/boot/bzImage |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 106 | |
| 107 | bzlilo: vmlinux |
| 108 | $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zlilo |
| 109 | |
| 110 | bzdisk: vmlinux |
| 111 | $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zdisk |
| 112 | |
H. Peter Anvin | 841b8a4 | 2006-03-26 01:36:59 -0800 | [diff] [blame] | 113 | fdimage fdimage144 fdimage288 isoimage: vmlinux |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 114 | $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@ |
| 115 | |
Roland McGrath | af7e6a7 | 2007-10-17 18:04:32 +0200 | [diff] [blame] | 116 | install: vdso_install |
H. Peter Anvin | 0d20bab | 2006-01-07 17:38:39 -0800 | [diff] [blame] | 117 | $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@ |
| 118 | |
Roland McGrath | af7e6a7 | 2007-10-17 18:04:32 +0200 | [diff] [blame] | 119 | vdso_install: |
| 120 | ifeq ($(CONFIG_IA32_EMULATION),y) |
| 121 | $(Q)$(MAKE) $(build)=arch/x86/ia32 $@ |
| 122 | endif |
Roland McGrath | f79eb83 | 2007-10-17 18:04:32 +0200 | [diff] [blame] | 123 | $(Q)$(MAKE) $(build)=arch/x86/vdso $@ |
Roland McGrath | af7e6a7 | 2007-10-17 18:04:32 +0200 | [diff] [blame] | 124 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 125 | archclean: |
Thomas Gleixner | 2a6c8d5 | 2007-10-11 11:17:16 +0200 | [diff] [blame] | 126 | $(Q)rm -rf $(objtree)/arch/x86_64/boot |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 127 | $(Q)$(MAKE) $(clean)=$(boot) |
| 128 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 129 | define archhelp |
| 130 | echo '* bzImage - Compressed kernel image (arch/$(ARCH)/boot/bzImage)' |
| 131 | echo ' install - Install kernel using' |
H. Peter Anvin | 841b8a4 | 2006-03-26 01:36:59 -0800 | [diff] [blame] | 132 | 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 Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 138 | endef |
| 139 | |
H. Peter Anvin | 841b8a4 | 2006-03-26 01:36:59 -0800 | [diff] [blame] | 140 | CLEAN_FILES += arch/$(ARCH)/boot/fdimage \ |
| 141 | arch/$(ARCH)/boot/image.iso \ |
| 142 | arch/$(ARCH)/boot/mtools.conf |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 143 | |
| 144 | |