]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - arch/x86_64/Makefile
[PATCH] x86_64: Basic reorder infrastructure
[mirror_ubuntu-bionic-kernel.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
1da177e4
LT
24LDFLAGS := -m elf_x86_64
25OBJCOPYFLAGS := -O binary -R .note -R .comment -S
5ded01e8 26LDFLAGS_vmlinux :=
1da177e4
LT
27
28CHECKFLAGS += -D__x86_64__ -m64
29
30cflags-$(CONFIG_MK8) += $(call cc-option,-march=k8)
31cflags-$(CONFIG_MPSC) += $(call cc-option,-march=nocona)
dca99a38 32cflags-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=generic)
1da177e4
LT
33CFLAGS += $(cflags-y)
34
bb33421d 35CFLAGS += -m64
1da177e4
LT
36CFLAGS += -mno-red-zone
37CFLAGS += -mcmodel=kernel
38CFLAGS += -pipe
4bdc3b7f 39cflags-$(CONFIG_REORDER) += -ffunction-sections
1da177e4
LT
40# this makes reading assembly source easier, but produces worse code
41# actually it makes the kernel smaller too.
42CFLAGS += -fno-reorder-blocks
43CFLAGS += -Wno-sign-compare
6e0c47ed 44ifneq ($(CONFIG_UNWIND_INFO),y)
1da177e4 45CFLAGS += -fno-asynchronous-unwind-tables
6e0c47ed
JB
46endif
47ifneq ($(CONFIG_DEBUG_INFO),y)
1da177e4
LT
48# -fweb shrinks the kernel a bit, but the difference is very small
49# it also messes up debugging, so don't use it for now.
50#CFLAGS += $(call cc-option,-fweb)
51endif
52# -funit-at-a-time shrinks the kernel .text considerably
53# unfortunately it makes reading oopses harder.
54CFLAGS += $(call cc-option,-funit-at-a-time)
55# prevent gcc from generating any FP code by mistake
56CFLAGS += $(call cc-option,-mno-sse -mno-mmx -mno-sse2 -mno-3dnow,)
57
bb33421d
AK
58AFLAGS += -m64
59
1da177e4
LT
60head-y := arch/x86_64/kernel/head.o arch/x86_64/kernel/head64.o arch/x86_64/kernel/init_task.o
61
62libs-y += arch/x86_64/lib/
a2a892a2
AS
63core-y += arch/x86_64/kernel/ \
64 arch/x86_64/mm/ \
65 arch/x86_64/crypto/
1da177e4
LT
66core-$(CONFIG_IA32_EMULATION) += arch/x86_64/ia32/
67drivers-$(CONFIG_PCI) += arch/x86_64/pci/
68drivers-$(CONFIG_OPROFILE) += arch/x86_64/oprofile/
69
70boot := arch/x86_64/boot
71
4f193362
PS
72PHONY += bzImage bzlilo install archmrproper \
73 fdimage fdimage144 fdimage288 archclean
1da177e4
LT
74
75#Default target when executing "make"
76all: bzImage
77
78BOOTIMAGE := arch/x86_64/boot/bzImage
79KBUILD_IMAGE := $(BOOTIMAGE)
80
81bzImage: vmlinux
82 $(Q)$(MAKE) $(build)=$(boot) $(BOOTIMAGE)
83
84bzlilo: vmlinux
85 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zlilo
86
87bzdisk: vmlinux
88 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zdisk
89
0d20babd 90fdimage fdimage144 fdimage288: vmlinux
1da177e4
LT
91 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
92
0d20babd
PA
93install:
94 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
95
1da177e4
LT
96archclean:
97 $(Q)$(MAKE) $(clean)=$(boot)
98
1da177e4
LT
99define archhelp
100 echo '* bzImage - Compressed kernel image (arch/$(ARCH)/boot/bzImage)'
101 echo ' install - Install kernel using'
102 echo ' (your) ~/bin/installkernel or'
103 echo ' (distribution) /sbin/installkernel or'
104 echo ' install to $$(INSTALL_PATH) and run lilo'
105endef
106
107CLEAN_FILES += arch/$(ARCH)/boot/fdimage arch/$(ARCH)/boot/mtools.conf
108
109