Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | # |
| 2 | # ia64/Makefile |
| 3 | # |
Paul Smith | 4f19336 | 2006-03-05 17:14:10 -0500 | [diff] [blame] | 4 | # This file is included by the global makefile so that you can add your own |
| 5 | # architecture-specific flags and dependencies. |
| 6 | # |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | # This file is subject to the terms and conditions of the GNU General Public |
| 8 | # License. See the file "COPYING" in the main directory of this archive |
| 9 | # for more details. |
| 10 | # |
| 11 | # Copyright (C) 1998-2004 by David Mosberger-Tang <davidm@hpl.hp.com> |
| 12 | # |
| 13 | |
Adrian Bunk | 022f9268 | 2008-02-26 21:54:46 +0200 | [diff] [blame] | 14 | KBUILD_DEFCONFIG := generic_defconfig |
| 15 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 | NM := $(CROSS_COMPILE)nm -B |
| 17 | READELF := $(CROSS_COMPILE)readelf |
| 18 | |
| 19 | export AWK |
| 20 | |
| 21 | CHECKFLAGS += -m64 -D__ia64=1 -D__ia64__=1 -D_LP64 -D__LP64__ |
| 22 | |
| 23 | OBJCOPYFLAGS := --strip-all |
| 24 | LDFLAGS_vmlinux := -static |
| 25 | LDFLAGS_MODULE += -T $(srctree)/arch/ia64/module.lds |
| 26 | AFLAGS_KERNEL := -mconstant-gp |
| 27 | EXTRA := |
| 28 | |
| 29 | cflags-y := -pipe $(EXTRA) -ffixed-r13 -mfixed-range=f12-f15,f32-f127 \ |
| 30 | -falign-functions=32 -frename-registers -fno-optimize-sibling-calls |
| 31 | CFLAGS_KERNEL := -mconstant-gp |
| 32 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | GAS_STATUS = $(shell $(srctree)/arch/ia64/scripts/check-gas "$(CC)" "$(OBJDUMP)") |
Sam Ravnborg | 06c5040 | 2007-10-15 22:17:25 +0200 | [diff] [blame] | 34 | KBUILD_CPPFLAGS += $(shell $(srctree)/arch/ia64/scripts/toolchain-flags "$(CC)" "$(OBJDUMP)" "$(READELF)") |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | |
| 36 | ifeq ($(GAS_STATUS),buggy) |
| 37 | $(error Sorry, you need a newer version of the assember, one that is built from \ |
| 38 | a source-tree that post-dates 18-Dec-2002. You can find a pre-compiled \ |
| 39 | static binary of such an assembler at: \ |
| 40 | \ |
| 41 | ftp://ftp.hpl.hp.com/pub/linux-ia64/gas-030124.tar.gz) |
| 42 | endif |
| 43 | |
Sam Ravnborg | ad14336 | 2006-01-08 19:58:51 +0100 | [diff] [blame] | 44 | ifeq ($(call cc-version),0304) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 | cflags-$(CONFIG_ITANIUM) += -mtune=merced |
| 46 | cflags-$(CONFIG_MCKINLEY) += -mtune=mckinley |
| 47 | endif |
| 48 | |
Sam Ravnborg | a0f97e0 | 2007-10-14 22:21:35 +0200 | [diff] [blame] | 49 | KBUILD_CFLAGS += $(cflags-y) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 50 | head-y := arch/ia64/kernel/head.o arch/ia64/kernel/init_task.o |
| 51 | |
| 52 | libs-y += arch/ia64/lib/ |
| 53 | core-y += arch/ia64/kernel/ arch/ia64/mm/ |
| 54 | core-$(CONFIG_IA32_SUPPORT) += arch/ia64/ia32/ |
| 55 | core-$(CONFIG_IA64_DIG) += arch/ia64/dig/ |
Fenghua Yu | 62fdd76 | 2008-10-17 12:14:13 -0700 | [diff] [blame^] | 56 | core-$(CONFIG_IA64_DIG_VTD) += arch/ia64/dig/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 | core-$(CONFIG_IA64_GENERIC) += arch/ia64/dig/ |
| 58 | core-$(CONFIG_IA64_HP_ZX1) += arch/ia64/dig/ |
| 59 | core-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/dig/ |
| 60 | core-$(CONFIG_IA64_SGI_SN2) += arch/ia64/sn/ |
Jack Steiner | 732a675 | 2008-06-14 07:57:25 -0500 | [diff] [blame] | 61 | core-$(CONFIG_IA64_SGI_UV) += arch/ia64/uv/ |
Xiantao Zhang | b693919 | 2008-03-28 14:58:47 +0800 | [diff] [blame] | 62 | core-$(CONFIG_KVM) += arch/ia64/kvm/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 63 | |
| 64 | drivers-$(CONFIG_PCI) += arch/ia64/pci/ |
| 65 | drivers-$(CONFIG_IA64_HP_SIM) += arch/ia64/hp/sim/ |
| 66 | drivers-$(CONFIG_IA64_HP_ZX1) += arch/ia64/hp/common/ arch/ia64/hp/zx1/ |
| 67 | drivers-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/hp/common/ arch/ia64/hp/zx1/ |
Jack Steiner | 2224661 | 2008-05-06 15:18:57 -0500 | [diff] [blame] | 68 | drivers-$(CONFIG_IA64_GENERIC) += arch/ia64/hp/common/ arch/ia64/hp/zx1/ arch/ia64/hp/sim/ arch/ia64/sn/ arch/ia64/uv/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 69 | drivers-$(CONFIG_OPROFILE) += arch/ia64/oprofile/ |
| 70 | |
| 71 | boot := arch/ia64/hp/sim/boot |
| 72 | |
Paul Smith | 4f19336 | 2006-03-05 17:14:10 -0500 | [diff] [blame] | 73 | PHONY += boot compressed check |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 74 | |
| 75 | all: compressed unwcheck |
| 76 | |
| 77 | compressed: vmlinux.gz |
| 78 | |
Alex Williamson | 120b286 | 2006-06-06 10:23:34 -0600 | [diff] [blame] | 79 | vmlinuz: vmlinux.gz |
| 80 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 81 | vmlinux.gz: vmlinux |
| 82 | $(Q)$(MAKE) $(build)=$(boot) $@ |
| 83 | |
| 84 | unwcheck: vmlinux |
Andrew Morton | ff08e65 | 2007-12-07 14:42:08 -0800 | [diff] [blame] | 85 | -$(Q)READELF=$(READELF) python $(srctree)/arch/ia64/scripts/unwcheck.py $< |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 86 | |
| 87 | archclean: |
| 88 | $(Q)$(MAKE) $(clean)=$(boot) |
| 89 | |
Tony Luck | 82f1b07 | 2005-09-13 08:50:39 -0700 | [diff] [blame] | 90 | CLEAN_FILES += vmlinux.gz bootloader |
Sam Ravnborg | 39e01cb | 2005-09-09 22:03:13 +0200 | [diff] [blame] | 91 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 | boot: lib/lib.a vmlinux |
| 93 | $(Q)$(MAKE) $(build)=$(boot) $@ |
| 94 | |
| 95 | install: vmlinux.gz |
| 96 | sh $(srctree)/arch/ia64/install.sh $(KERNELRELEASE) $< System.map "$(INSTALL_PATH)" |
| 97 | |
| 98 | define archhelp |
| 99 | echo '* compressed - Build compressed kernel image' |
| 100 | echo ' install - Install compressed kernel image' |
| 101 | echo ' boot - Build vmlinux and bootloader for Ski simulator' |
| 102 | echo '* unwcheck - Check vmlinux for invalid unwind info' |
| 103 | endef |
Isaku Yamahata | 213060a | 2008-05-19 22:13:40 +0900 | [diff] [blame] | 104 | |
| 105 | archprepare: make_nr_irqs_h FORCE |
| 106 | PHONY += make_nr_irqs_h FORCE |
| 107 | |
| 108 | make_nr_irqs_h: FORCE |
| 109 | $(Q)$(MAKE) $(build)=arch/ia64/kernel include/asm-ia64/nr-irqs.h |