blob: 45f59808b8429e2abe7c0ffc4c895c6de03474bf [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# ia64/Makefile
3#
Paul Smith4f193362006-03-05 17:14:10 -05004# This file is included by the global makefile so that you can add your own
5# architecture-specific flags and dependencies.
6#
Linus Torvalds1da177e2005-04-16 15:20:36 -07007# 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 Bunk022f92682008-02-26 21:54:46 +020014KBUILD_DEFCONFIG := generic_defconfig
15
Linus Torvalds1da177e2005-04-16 15:20:36 -070016NM := $(CROSS_COMPILE)nm -B
17READELF := $(CROSS_COMPILE)readelf
18
19export AWK
20
Luc Van Oostenryck1f2f01b2018-05-30 22:48:38 +020021CHECKFLAGS += -D__ia64=1 -D__ia64__=1 -D_LP64 -D__LP64__
Linus Torvalds1da177e2005-04-16 15:20:36 -070022
23OBJCOPYFLAGS := --strip-all
24LDFLAGS_vmlinux := -static
Sam Ravnborg65881692010-07-28 17:33:09 +020025KBUILD_LDFLAGS_MODULE += -T $(srctree)/arch/ia64/module.lds
Sam Ravnborg80c00ba2010-07-28 19:11:27 +020026KBUILD_AFLAGS_KERNEL := -mconstant-gp
Linus Torvalds1da177e2005-04-16 15:20:36 -070027EXTRA :=
28
29cflags-y := -pipe $(EXTRA) -ffixed-r13 -mfixed-range=f12-f15,f32-f127 \
30 -falign-functions=32 -frename-registers -fno-optimize-sibling-calls
Sam Ravnborg80c00ba2010-07-28 19:11:27 +020031KBUILD_CFLAGS_KERNEL := -mconstant-gp
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
Linus Torvalds1da177e2005-04-16 15:20:36 -070033GAS_STATUS = $(shell $(srctree)/arch/ia64/scripts/check-gas "$(CC)" "$(OBJDUMP)")
Sam Ravnborg06c50402007-10-15 22:17:25 +020034KBUILD_CPPFLAGS += $(shell $(srctree)/arch/ia64/scripts/toolchain-flags "$(CC)" "$(OBJDUMP)" "$(READELF)")
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
36ifeq ($(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)
42endif
43
Sam Ravnborga0f97e02007-10-14 22:21:35 +020044KBUILD_CFLAGS += $(cflags-y)
David Howells05008712018-01-02 15:12:01 +000045head-y := arch/ia64/kernel/head.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070046
47libs-y += arch/ia64/lib/
48core-y += arch/ia64/kernel/ arch/ia64/mm/
Linus Torvalds1da177e2005-04-16 15:20:36 -070049core-$(CONFIG_IA64_DIG) += arch/ia64/dig/
Fenghua Yu62fdd762008-10-17 12:14:13 -070050core-$(CONFIG_IA64_DIG_VTD) += arch/ia64/dig/
Linus Torvalds1da177e2005-04-16 15:20:36 -070051core-$(CONFIG_IA64_GENERIC) += arch/ia64/dig/
52core-$(CONFIG_IA64_HP_ZX1) += arch/ia64/dig/
53core-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/dig/
54core-$(CONFIG_IA64_SGI_SN2) += arch/ia64/sn/
Jack Steiner732a6752008-06-14 07:57:25 -050055core-$(CONFIG_IA64_SGI_UV) += arch/ia64/uv/
Linus Torvalds1da177e2005-04-16 15:20:36 -070056
57drivers-$(CONFIG_PCI) += arch/ia64/pci/
58drivers-$(CONFIG_IA64_HP_SIM) += arch/ia64/hp/sim/
59drivers-$(CONFIG_IA64_HP_ZX1) += arch/ia64/hp/common/ arch/ia64/hp/zx1/
60drivers-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/hp/common/ arch/ia64/hp/zx1/
Jack Steiner22246612008-05-06 15:18:57 -050061drivers-$(CONFIG_IA64_GENERIC) += arch/ia64/hp/common/ arch/ia64/hp/zx1/ arch/ia64/hp/sim/ arch/ia64/sn/ arch/ia64/uv/
Linus Torvalds1da177e2005-04-16 15:20:36 -070062drivers-$(CONFIG_OPROFILE) += arch/ia64/oprofile/
63
64boot := arch/ia64/hp/sim/boot
65
Paul Smith4f193362006-03-05 17:14:10 -050066PHONY += boot compressed check
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
68all: compressed unwcheck
69
70compressed: vmlinux.gz
71
Alex Williamson120b2862006-06-06 10:23:34 -060072vmlinuz: vmlinux.gz
73
Linus Torvalds1da177e2005-04-16 15:20:36 -070074vmlinux.gz: vmlinux
75 $(Q)$(MAKE) $(build)=$(boot) $@
76
77unwcheck: vmlinux
Masahiro Yamada011bf122014-07-18 13:40:11 +090078 -$(Q)READELF=$(READELF) $(PYTHON) $(srctree)/arch/ia64/scripts/unwcheck.py $<
Linus Torvalds1da177e2005-04-16 15:20:36 -070079
80archclean:
81 $(Q)$(MAKE) $(clean)=$(boot)
82
Tony Luck82f1b072005-09-13 08:50:39 -070083CLEAN_FILES += vmlinux.gz bootloader
Sam Ravnborg39e01cb2005-09-09 22:03:13 +020084
Linus Torvalds1da177e2005-04-16 15:20:36 -070085boot: lib/lib.a vmlinux
86 $(Q)$(MAKE) $(build)=$(boot) $@
87
88install: vmlinux.gz
89 sh $(srctree)/arch/ia64/install.sh $(KERNELRELEASE) $< System.map "$(INSTALL_PATH)"
90
91define archhelp
92 echo '* compressed - Build compressed kernel image'
93 echo ' install - Install compressed kernel image'
94 echo ' boot - Build vmlinux and bootloader for Ski simulator'
95 echo '* unwcheck - Check vmlinux for invalid unwind info'
96endef
Isaku Yamahata213060a2008-05-19 22:13:40 +090097
Masahiro Yamada2e8d6962016-03-13 09:13:55 +090098archprepare: make_nr_irqs_h
Masahiro Yamada1c44b282016-04-08 11:16:10 +090099PHONY += make_nr_irqs_h
Isaku Yamahata213060a2008-05-19 22:13:40 +0900100
Masahiro Yamada2e8d6962016-03-13 09:13:55 +0900101make_nr_irqs_h:
Sam Ravnborg4929d292009-04-20 19:35:54 +0200102 $(Q)$(MAKE) $(build)=arch/ia64/kernel include/generated/nr-irqs.h