aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86_64/Makefile
diff options
context:
space:
mode:
authorSam Ravnborg <sam@ravnborg.org>2007-10-25 13:42:04 -0400
committerSam Ravnborg <sam@ravnborg.org>2007-10-25 16:27:34 -0400
commit74b469f2e6b1589118b6ac05c7256add01e572d2 (patch)
treed963009bef4f36ae610dd56ca69961e0de9ee29c /arch/x86_64/Makefile
parentc9927c2bf4f45bb85e8b502ab3fb79ad6483c244 (diff)
x86: move i386 and x86_64 Makefiles to arch/x86
Moving the ARCH specific Makefiles for i386 and x86_64 required a litle bit tweaking in the top-lvel Makefile. SRCARCH is now set in the top-level Makefile because we need this info to include the correct arch Makefile. Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Diffstat (limited to 'arch/x86_64/Makefile')
-rw-r--r--arch/x86_64/Makefile147
1 files changed, 0 insertions, 147 deletions
diff --git a/arch/x86_64/Makefile b/arch/x86_64/Makefile
deleted file mode 100644
index 20eb69bd5a6d..000000000000
--- a/arch/x86_64/Makefile
+++ /dev/null
@@ -1,147 +0,0 @@
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
24# Fill in SRCARCH
25SRCARCH := x86
26
27# BITS is used as extension for files which are available in a 32 bit
28# and a 64 bit version to simplify shared Makefiles.
29# e.g.: obj-y += foo_$(BITS).o
30BITS := 64
31export BITS
32
33LDFLAGS := -m elf_x86_64
34OBJCOPYFLAGS := -O binary -R .note -R .comment -S
35LDFLAGS_vmlinux :=
36CHECKFLAGS += -D__x86_64__ -m64
37
38cflags-y :=
39cflags-kernel-y :=
40cflags-$(CONFIG_MK8) += $(call cc-option,-march=k8)
41cflags-$(CONFIG_MPSC) += $(call cc-option,-march=nocona)
42# gcc doesn't support -march=core2 yet as of gcc 4.3, but I hope it
43# will eventually. Use -mtune=generic as fallback
44cflags-$(CONFIG_MCORE2) += \
45 $(call cc-option,-march=core2,$(call cc-option,-mtune=generic))
46cflags-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=generic)
47
48cflags-y += -m64
49cflags-y += -mno-red-zone
50cflags-y += -mcmodel=kernel
51cflags-y += -pipe
52cflags-y += -Wno-sign-compare
53cflags-y += -fno-asynchronous-unwind-tables
54ifneq ($(CONFIG_DEBUG_INFO),y)
55# -fweb shrinks the kernel a bit, but the difference is very small
56# it also messes up debugging, so don't use it for now.
57#cflags-y += $(call cc-option,-fweb)
58endif
59# -funit-at-a-time shrinks the kernel .text considerably
60# unfortunately it makes reading oopses harder.
61cflags-y += $(call cc-option,-funit-at-a-time)
62# prevent gcc from generating any FP code by mistake
63cflags-y += $(call cc-option,-mno-sse -mno-mmx -mno-sse2 -mno-3dnow,)
64# this works around some issues with generating unwind tables in older gccs
65# newer gccs do it by default
66cflags-y += -maccumulate-outgoing-args
67
68# do binutils support CFI?
69cflags-y += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
70KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
71
72# is .cfi_signal_frame supported too?
73cflags-y += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
74KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
75
76cflags-$(CONFIG_CC_STACKPROTECTOR) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector )
77cflags-$(CONFIG_CC_STACKPROTECTOR_ALL) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector-all )
78
79KBUILD_CFLAGS += $(cflags-y)
80CFLAGS_KERNEL += $(cflags-kernel-y)
81KBUILD_AFLAGS += -m64
82
83head-y := arch/x86/kernel/head_64.o arch/x86/kernel/head64.o arch/x86/kernel/init_task.o
84
85libs-y += arch/x86/lib/
86core-y += arch/x86/kernel/ \
87 arch/x86/mm/ \
88 arch/x86/crypto/ \
89 arch/x86/vdso/
90core-$(CONFIG_IA32_EMULATION) += arch/x86/ia32/
91drivers-$(CONFIG_PCI) += arch/x86/pci/
92drivers-$(CONFIG_OPROFILE) += arch/x86/oprofile/
93
94boot := arch/x86/boot
95
96PHONY += bzImage bzlilo install archmrproper \
97 fdimage fdimage144 fdimage288 isoimage archclean
98
99#Default target when executing "make"
100all: bzImage
101
102BOOTIMAGE := arch/x86/boot/bzImage
103KBUILD_IMAGE := $(BOOTIMAGE)
104
105bzImage: vmlinux
106 $(Q)$(MAKE) $(build)=$(boot) $(BOOTIMAGE)
107 $(Q)mkdir -p $(objtree)/arch/x86_64/boot
108 $(Q)ln -fsn ../../x86/boot/bzImage $(objtree)/arch/x86_64/boot/bzImage
109
110bzlilo: vmlinux
111 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zlilo
112
113bzdisk: vmlinux
114 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zdisk
115
116fdimage fdimage144 fdimage288 isoimage: vmlinux
117 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
118
119install: vdso_install
120 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
121
122vdso_install:
123ifeq ($(CONFIG_IA32_EMULATION),y)
124 $(Q)$(MAKE) $(build)=arch/x86/ia32 $@
125endif
126 $(Q)$(MAKE) $(build)=arch/x86/vdso $@
127
128archclean:
129 $(Q)rm -rf $(objtree)/arch/x86_64/boot
130 $(Q)$(MAKE) $(clean)=$(boot)
131
132define archhelp
133 echo '* bzImage - Compressed kernel image (arch/$(ARCH)/boot/bzImage)'
134 echo ' install - Install kernel using'
135 echo ' (your) ~/bin/installkernel or'
136 echo ' (distribution) /sbin/installkernel or'
137 echo ' install to $$(INSTALL_PATH) and run lilo'
138 echo ' bzdisk - Create a boot floppy in /dev/fd0'
139 echo ' fdimage - Create a boot floppy image'
140 echo ' isoimage - Create a boot CD-ROM image'
141endef
142
143CLEAN_FILES += arch/$(ARCH)/boot/fdimage \
144 arch/$(ARCH)/boot/image.iso \
145 arch/$(ARCH)/boot/mtools.conf
146
147