2005-04-16 18:20:36 -04:00
|
|
|
#
|
2007-10-25 13:42:04 -04:00
|
|
|
# x86_64 Makefile
|
2005-04-16 18:20:36 -04:00
|
|
|
#
|
|
|
|
# This file is included by the global makefile so that you can add your own
|
|
|
|
# architecture-specific flags and dependencies. Remember to do have actions
|
|
|
|
# for "archclean" and "archdep" for cleaning up and making dependencies for
|
|
|
|
# this architecture
|
|
|
|
#
|
|
|
|
# This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
# License. See the file "COPYING" in the main directory of this archive
|
|
|
|
# for more details.
|
|
|
|
#
|
|
|
|
# Copyright (C) 1994 by Linus Torvalds
|
|
|
|
#
|
|
|
|
# 19990713 Artur Skawina <skawina@geocities.com>
|
|
|
|
# Added '-march' and '-mpreferred-stack-boundary' support
|
|
|
|
# 20000913 Pavel Machek <pavel@suse.cz>
|
|
|
|
# Converted for x86_64 architecture
|
|
|
|
# 20010105 Andi Kleen, add IA32 compiler.
|
|
|
|
# ....and later removed it again....
|
|
|
|
#
|
|
|
|
# $Id: Makefile,v 1.31 2002/03/22 15:56:07 ak Exp $
|
|
|
|
|
2007-10-23 16:37:23 -04:00
|
|
|
# BITS is used as extension for files which are available in a 32 bit
|
|
|
|
# and a 64 bit version to simplify shared Makefiles.
|
|
|
|
# e.g.: obj-y += foo_$(BITS).o
|
|
|
|
BITS := 64
|
|
|
|
export BITS
|
|
|
|
|
2005-04-16 18:20:36 -04:00
|
|
|
LDFLAGS := -m elf_x86_64
|
|
|
|
OBJCOPYFLAGS := -O binary -R .note -R .comment -S
|
2005-06-25 17:57:48 -04:00
|
|
|
LDFLAGS_vmlinux :=
|
2005-04-16 18:20:36 -04:00
|
|
|
CHECKFLAGS += -D__x86_64__ -m64
|
|
|
|
|
2006-04-07 13:50:28 -04:00
|
|
|
cflags-y :=
|
2006-06-26 07:59:32 -04:00
|
|
|
cflags-kernel-y :=
|
2005-04-16 18:20:36 -04:00
|
|
|
cflags-$(CONFIG_MK8) += $(call cc-option,-march=k8)
|
|
|
|
cflags-$(CONFIG_MPSC) += $(call cc-option,-march=nocona)
|
2006-12-06 20:14:09 -05:00
|
|
|
# gcc doesn't support -march=core2 yet as of gcc 4.3, but I hope it
|
|
|
|
# will eventually. Use -mtune=generic as fallback
|
|
|
|
cflags-$(CONFIG_MCORE2) += \
|
|
|
|
$(call cc-option,-march=core2,$(call cc-option,-mtune=generic))
|
2006-03-25 10:29:06 -05:00
|
|
|
cflags-$(CONFIG_GENERIC_CPU) += $(call cc-option,-mtune=generic)
|
2005-04-16 18:20:36 -04:00
|
|
|
|
2006-04-07 13:50:28 -04:00
|
|
|
cflags-y += -m64
|
|
|
|
cflags-y += -mno-red-zone
|
|
|
|
cflags-y += -mcmodel=kernel
|
|
|
|
cflags-y += -pipe
|
|
|
|
cflags-y += -Wno-sign-compare
|
|
|
|
cflags-y += -fno-asynchronous-unwind-tables
|
2006-01-11 16:42:05 -05:00
|
|
|
ifneq ($(CONFIG_DEBUG_INFO),y)
|
2005-04-16 18:20:36 -04:00
|
|
|
# -fweb shrinks the kernel a bit, but the difference is very small
|
|
|
|
# it also messes up debugging, so don't use it for now.
|
2006-04-07 13:50:28 -04:00
|
|
|
#cflags-y += $(call cc-option,-fweb)
|
2005-04-16 18:20:36 -04:00
|
|
|
endif
|
|
|
|
# -funit-at-a-time shrinks the kernel .text considerably
|
|
|
|
# unfortunately it makes reading oopses harder.
|
2006-04-07 13:50:28 -04:00
|
|
|
cflags-y += $(call cc-option,-funit-at-a-time)
|
2005-04-16 18:20:36 -04:00
|
|
|
# prevent gcc from generating any FP code by mistake
|
2006-04-07 13:50:28 -04:00
|
|
|
cflags-y += $(call cc-option,-mno-sse -mno-mmx -mno-sse2 -mno-3dnow,)
|
2006-10-21 12:37:01 -04:00
|
|
|
# this works around some issues with generating unwind tables in older gccs
|
|
|
|
# newer gccs do it by default
|
|
|
|
cflags-y += -maccumulate-outgoing-args
|
|
|
|
|
2006-09-26 04:52:30 -04:00
|
|
|
# do binutils support CFI?
|
2007-08-14 20:40:37 -04:00
|
|
|
cflags-y += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
|
2007-10-15 15:59:31 -04:00
|
|
|
KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_rel_offset rsp${comma}0\n.cfi_endproc,-DCONFIG_AS_CFI=1,)
|
2005-04-16 18:20:36 -04:00
|
|
|
|
2006-09-26 04:52:41 -04:00
|
|
|
# is .cfi_signal_frame supported too?
|
|
|
|
cflags-y += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
|
2007-10-15 15:59:31 -04:00
|
|
|
KBUILD_AFLAGS += $(call as-instr,.cfi_startproc\n.cfi_signal_frame\n.cfi_endproc,-DCONFIG_AS_CFI_SIGNAL_FRAME=1,)
|
2006-09-26 04:52:41 -04:00
|
|
|
|
2006-11-16 05:49:16 -05:00
|
|
|
cflags-$(CONFIG_CC_STACKPROTECTOR) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector )
|
|
|
|
cflags-$(CONFIG_CC_STACKPROTECTOR_ALL) += $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-x86_64-has-stack-protector.sh "$(CC)" -fstack-protector-all )
|
2006-09-26 04:52:39 -04:00
|
|
|
|
2007-10-14 16:21:35 -04:00
|
|
|
KBUILD_CFLAGS += $(cflags-y)
|
2006-06-26 07:59:32 -04:00
|
|
|
CFLAGS_KERNEL += $(cflags-kernel-y)
|
2007-10-15 15:59:31 -04:00
|
|
|
KBUILD_AFLAGS += -m64
|
2006-01-11 16:43:54 -05:00
|
|
|
|
2007-10-19 14:35:02 -04:00
|
|
|
head-y := arch/x86/kernel/head_64.o arch/x86/kernel/head64.o arch/x86/kernel/init_task.o
|
2005-04-16 18:20:36 -04:00
|
|
|
|
2007-10-11 05:17:08 -04:00
|
|
|
libs-y += arch/x86/lib/
|
2007-10-11 05:17:24 -04:00
|
|
|
core-y += arch/x86/kernel/ \
|
2007-10-11 05:17:18 -04:00
|
|
|
arch/x86/mm/ \
|
2007-10-11 05:17:03 -04:00
|
|
|
arch/x86/crypto/ \
|
2007-10-11 05:17:10 -04:00
|
|
|
arch/x86/vdso/
|
2007-10-11 05:17:21 -04:00
|
|
|
core-$(CONFIG_IA32_EMULATION) += arch/x86/ia32/
|
2007-10-11 05:17:12 -04:00
|
|
|
drivers-$(CONFIG_PCI) += arch/x86/pci/
|
2007-10-11 05:16:55 -04:00
|
|
|
drivers-$(CONFIG_OPROFILE) += arch/x86/oprofile/
|
2005-04-16 18:20:36 -04:00
|
|
|
|
2007-10-11 05:17:16 -04:00
|
|
|
boot := arch/x86/boot
|
2005-04-16 18:20:36 -04:00
|
|
|
|
2006-03-05 17:14:10 -05:00
|
|
|
PHONY += bzImage bzlilo install archmrproper \
|
2006-03-26 04:36:59 -05:00
|
|
|
fdimage fdimage144 fdimage288 isoimage archclean
|
2005-04-16 18:20:36 -04:00
|
|
|
|
|
|
|
#Default target when executing "make"
|
|
|
|
all: bzImage
|
|
|
|
|
2007-10-11 05:17:16 -04:00
|
|
|
BOOTIMAGE := arch/x86/boot/bzImage
|
2005-04-16 18:20:36 -04:00
|
|
|
KBUILD_IMAGE := $(BOOTIMAGE)
|
|
|
|
|
|
|
|
bzImage: vmlinux
|
|
|
|
$(Q)$(MAKE) $(build)=$(boot) $(BOOTIMAGE)
|
2007-10-19 14:35:02 -04:00
|
|
|
$(Q)mkdir -p $(objtree)/arch/x86_64/boot
|
|
|
|
$(Q)ln -fsn ../../x86/boot/bzImage $(objtree)/arch/x86_64/boot/bzImage
|
2005-04-16 18:20:36 -04:00
|
|
|
|
|
|
|
bzlilo: vmlinux
|
|
|
|
$(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zlilo
|
|
|
|
|
|
|
|
bzdisk: vmlinux
|
|
|
|
$(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) zdisk
|
|
|
|
|
2006-03-26 04:36:59 -05:00
|
|
|
fdimage fdimage144 fdimage288 isoimage: vmlinux
|
2005-04-16 18:20:36 -04:00
|
|
|
$(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
|
|
|
|
|
2007-10-17 12:04:32 -04:00
|
|
|
install: vdso_install
|
2006-01-07 20:38:39 -05:00
|
|
|
$(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(BOOTIMAGE) $@
|
|
|
|
|
2007-10-17 12:04:32 -04:00
|
|
|
vdso_install:
|
|
|
|
ifeq ($(CONFIG_IA32_EMULATION),y)
|
|
|
|
$(Q)$(MAKE) $(build)=arch/x86/ia32 $@
|
|
|
|
endif
|
2007-10-17 12:04:32 -04:00
|
|
|
$(Q)$(MAKE) $(build)=arch/x86/vdso $@
|
2007-10-17 12:04:32 -04:00
|
|
|
|
2005-04-16 18:20:36 -04:00
|
|
|
archclean:
|
2008-01-30 07:30:04 -05:00
|
|
|
$(Q)rm -rf $(objtree)/arch/i386
|
|
|
|
$(Q)rm -rf $(objtree)/arch/x86_64
|
2005-04-16 18:20:36 -04:00
|
|
|
$(Q)$(MAKE) $(clean)=$(boot)
|
|
|
|
|
|
|
|
define archhelp
|
2007-11-12 14:14:19 -05:00
|
|
|
echo '* bzImage - Compressed kernel image (arch/x86/boot/bzImage)'
|
2005-04-16 18:20:36 -04:00
|
|
|
echo ' install - Install kernel using'
|
2006-03-26 04:36:59 -05:00
|
|
|
echo ' (your) ~/bin/installkernel or'
|
|
|
|
echo ' (distribution) /sbin/installkernel or'
|
|
|
|
echo ' install to $$(INSTALL_PATH) and run lilo'
|
|
|
|
echo ' bzdisk - Create a boot floppy in /dev/fd0'
|
|
|
|
echo ' fdimage - Create a boot floppy image'
|
|
|
|
echo ' isoimage - Create a boot CD-ROM image'
|
2005-04-16 18:20:36 -04:00
|
|
|
endef
|
|
|
|
|
2007-11-12 14:14:19 -05:00
|
|
|
CLEAN_FILES += arch/x86/boot/fdimage \
|
|
|
|
arch/x86/boot/image.iso \
|
|
|
|
arch/x86/boot/mtools.conf
|
2005-04-16 18:20:36 -04:00
|
|
|
|
|
|
|
|