blob: 32240000dc0c85844675b428df5bfe564ff8669c [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
Luc Van Oostenryck1f2f01b2018-05-30 22:48:38 +020019CHECKFLAGS += -D__ia64=1 -D__ia64__=1 -D_LP64 -D__LP64__
Linus Torvalds1da177e2005-04-16 15:20:36 -070020
21OBJCOPYFLAGS := --strip-all
22LDFLAGS_vmlinux := -static
Masahiro Yamada10df0632019-08-15 01:06:22 +090023KBUILD_LDS_MODULE += $(srctree)/arch/ia64/module.lds
Sam Ravnborg80c00ba2010-07-28 19:11:27 +020024KBUILD_AFLAGS_KERNEL := -mconstant-gp
Linus Torvalds1da177e2005-04-16 15:20:36 -070025EXTRA :=
26
27cflags-y := -pipe $(EXTRA) -ffixed-r13 -mfixed-range=f12-f15,f32-f127 \
28 -falign-functions=32 -frename-registers -fno-optimize-sibling-calls
Sam Ravnborg80c00ba2010-07-28 19:11:27 +020029KBUILD_CFLAGS_KERNEL := -mconstant-gp
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
Linus Torvalds1da177e2005-04-16 15:20:36 -070031GAS_STATUS = $(shell $(srctree)/arch/ia64/scripts/check-gas "$(CC)" "$(OBJDUMP)")
Sam Ravnborg06c50402007-10-15 22:17:25 +020032KBUILD_CPPFLAGS += $(shell $(srctree)/arch/ia64/scripts/toolchain-flags "$(CC)" "$(OBJDUMP)" "$(READELF)")
Linus Torvalds1da177e2005-04-16 15:20:36 -070033
34ifeq ($(GAS_STATUS),buggy)
35$(error Sorry, you need a newer version of the assember, one that is built from \
36 a source-tree that post-dates 18-Dec-2002. You can find a pre-compiled \
37 static binary of such an assembler at: \
38 \
39 ftp://ftp.hpl.hp.com/pub/linux-ia64/gas-030124.tar.gz)
40endif
41
Christoph Hellwigfc5bad02019-08-13 09:25:03 +020042quiet_cmd_gzip = GZIP $@
43cmd_gzip = cat $(real-prereqs) | gzip -n -f -9 > $@
44
45quiet_cmd_objcopy = OBJCOPY $@
46cmd_objcopy = $(OBJCOPY) $(OBJCOPYFLAGS) $(OBJCOPYFLAGS_$(@F)) $< $@
47
Sam Ravnborga0f97e02007-10-14 22:21:35 +020048KBUILD_CFLAGS += $(cflags-y)
David Howells05008712018-01-02 15:12:01 +000049head-y := arch/ia64/kernel/head.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
51libs-y += arch/ia64/lib/
52core-y += arch/ia64/kernel/ arch/ia64/mm/
Jack Steiner732a6752008-06-14 07:57:25 -050053core-$(CONFIG_IA64_SGI_UV) += arch/ia64/uv/
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
Christoph Hellwigdf410172019-08-13 09:25:12 +020055drivers-y += arch/ia64/pci/ arch/ia64/hp/common/
Linus Torvalds1da177e2005-04-16 15:20:36 -070056drivers-$(CONFIG_OPROFILE) += arch/ia64/oprofile/
57
Christoph Hellwigfc5bad02019-08-13 09:25:03 +020058PHONY += compressed check
Linus Torvalds1da177e2005-04-16 15:20:36 -070059
60all: compressed unwcheck
61
62compressed: vmlinux.gz
63
Alex Williamson120b2862006-06-06 10:23:34 -060064vmlinuz: vmlinux.gz
65
Christoph Hellwigfc5bad02019-08-13 09:25:03 +020066vmlinux.gz: vmlinux.bin FORCE
67 $(call if_changed,gzip)
68
69vmlinux.bin: vmlinux FORCE
70 $(call if_changed,objcopy)
Linus Torvalds1da177e2005-04-16 15:20:36 -070071
72unwcheck: vmlinux
Masahiro Yamada011bf122014-07-18 13:40:11 +090073 -$(Q)READELF=$(READELF) $(PYTHON) $(srctree)/arch/ia64/scripts/unwcheck.py $<
Linus Torvalds1da177e2005-04-16 15:20:36 -070074
75archclean:
Linus Torvalds1da177e2005-04-16 15:20:36 -070076
Firoz Khanc5183622018-11-13 12:27:45 +053077archheaders:
78 $(Q)$(MAKE) $(build)=arch/ia64/kernel/syscalls all
79
Christoph Hellwigfc5bad02019-08-13 09:25:03 +020080CLEAN_FILES += vmlinux.gz
Linus Torvalds1da177e2005-04-16 15:20:36 -070081
82install: vmlinux.gz
83 sh $(srctree)/arch/ia64/install.sh $(KERNELRELEASE) $< System.map "$(INSTALL_PATH)"
84
85define archhelp
86 echo '* compressed - Build compressed kernel image'
87 echo ' install - Install compressed kernel image'
Linus Torvalds1da177e2005-04-16 15:20:36 -070088 echo '* unwcheck - Check vmlinux for invalid unwind info'
89endef
Isaku Yamahata213060a2008-05-19 22:13:40 +090090
Masahiro Yamada2e8d6962016-03-13 09:13:55 +090091archprepare: make_nr_irqs_h
Masahiro Yamada1c44b282016-04-08 11:16:10 +090092PHONY += make_nr_irqs_h
Isaku Yamahata213060a2008-05-19 22:13:40 +090093
Masahiro Yamada2e8d6962016-03-13 09:13:55 +090094make_nr_irqs_h:
Sam Ravnborg4929d292009-04-20 19:35:54 +020095 $(Q)$(MAKE) $(build)=arch/ia64/kernel include/generated/nr-irqs.h