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 | |
Luc Van Oostenryck | 1f2f01b | 2018-05-30 22:48:38 +0200 | [diff] [blame] | 19 | CHECKFLAGS += -D__ia64=1 -D__ia64__=1 -D_LP64 -D__LP64__ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | |
| 21 | OBJCOPYFLAGS := --strip-all |
| 22 | LDFLAGS_vmlinux := -static |
Masahiro Yamada | 10df063 | 2019-08-15 01:06:22 +0900 | [diff] [blame] | 23 | KBUILD_LDS_MODULE += $(srctree)/arch/ia64/module.lds |
Sam Ravnborg | 80c00ba | 2010-07-28 19:11:27 +0200 | [diff] [blame] | 24 | KBUILD_AFLAGS_KERNEL := -mconstant-gp |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | EXTRA := |
| 26 | |
| 27 | cflags-y := -pipe $(EXTRA) -ffixed-r13 -mfixed-range=f12-f15,f32-f127 \ |
| 28 | -falign-functions=32 -frename-registers -fno-optimize-sibling-calls |
Sam Ravnborg | 80c00ba | 2010-07-28 19:11:27 +0200 | [diff] [blame] | 29 | KBUILD_CFLAGS_KERNEL := -mconstant-gp |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | GAS_STATUS = $(shell $(srctree)/arch/ia64/scripts/check-gas "$(CC)" "$(OBJDUMP)") |
Sam Ravnborg | 06c5040 | 2007-10-15 22:17:25 +0200 | [diff] [blame] | 32 | KBUILD_CPPFLAGS += $(shell $(srctree)/arch/ia64/scripts/toolchain-flags "$(CC)" "$(OBJDUMP)" "$(READELF)") |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | |
| 34 | ifeq ($(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) |
| 40 | endif |
| 41 | |
Christoph Hellwig | fc5bad0 | 2019-08-13 09:25:03 +0200 | [diff] [blame] | 42 | quiet_cmd_gzip = GZIP $@ |
Denis Efremov | e4a42c8 | 2020-06-08 12:59:44 +0300 | [diff] [blame] | 43 | cmd_gzip = cat $(real-prereqs) | $(KGZIP) -n -f -9 > $@ |
Christoph Hellwig | fc5bad0 | 2019-08-13 09:25:03 +0200 | [diff] [blame] | 44 | |
| 45 | quiet_cmd_objcopy = OBJCOPY $@ |
| 46 | cmd_objcopy = $(OBJCOPY) $(OBJCOPYFLAGS) $(OBJCOPYFLAGS_$(@F)) $< $@ |
| 47 | |
Sam Ravnborg | a0f97e0 | 2007-10-14 22:21:35 +0200 | [diff] [blame] | 48 | KBUILD_CFLAGS += $(cflags-y) |
David Howells | 0500871 | 2018-01-02 15:12:01 +0000 | [diff] [blame] | 49 | head-y := arch/ia64/kernel/head.o |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 50 | |
| 51 | libs-y += arch/ia64/lib/ |
| 52 | core-y += arch/ia64/kernel/ arch/ia64/mm/ |
Jack Steiner | 732a675 | 2008-06-14 07:57:25 -0500 | [diff] [blame] | 53 | core-$(CONFIG_IA64_SGI_UV) += arch/ia64/uv/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 | |
Christoph Hellwig | df41017 | 2019-08-13 09:25:12 +0200 | [diff] [blame] | 55 | drivers-y += arch/ia64/pci/ arch/ia64/hp/common/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | drivers-$(CONFIG_OPROFILE) += arch/ia64/oprofile/ |
| 57 | |
Christoph Hellwig | fc5bad0 | 2019-08-13 09:25:03 +0200 | [diff] [blame] | 58 | PHONY += compressed check |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 59 | |
| 60 | all: compressed unwcheck |
| 61 | |
| 62 | compressed: vmlinux.gz |
| 63 | |
Alex Williamson | 120b286 | 2006-06-06 10:23:34 -0600 | [diff] [blame] | 64 | vmlinuz: vmlinux.gz |
| 65 | |
Christoph Hellwig | fc5bad0 | 2019-08-13 09:25:03 +0200 | [diff] [blame] | 66 | vmlinux.gz: vmlinux.bin FORCE |
| 67 | $(call if_changed,gzip) |
| 68 | |
| 69 | vmlinux.bin: vmlinux FORCE |
| 70 | $(call if_changed,objcopy) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 71 | |
| 72 | unwcheck: vmlinux |
Masahiro Yamada | 011bf12 | 2014-07-18 13:40:11 +0900 | [diff] [blame] | 73 | -$(Q)READELF=$(READELF) $(PYTHON) $(srctree)/arch/ia64/scripts/unwcheck.py $< |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 74 | |
| 75 | archclean: |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 76 | |
Firoz Khan | c518362 | 2018-11-13 12:27:45 +0530 | [diff] [blame] | 77 | archheaders: |
| 78 | $(Q)$(MAKE) $(build)=arch/ia64/kernel/syscalls all |
| 79 | |
Christoph Hellwig | fc5bad0 | 2019-08-13 09:25:03 +0200 | [diff] [blame] | 80 | CLEAN_FILES += vmlinux.gz |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 81 | |
| 82 | install: vmlinux.gz |
| 83 | sh $(srctree)/arch/ia64/install.sh $(KERNELRELEASE) $< System.map "$(INSTALL_PATH)" |
| 84 | |
| 85 | define archhelp |
| 86 | echo '* compressed - Build compressed kernel image' |
| 87 | echo ' install - Install compressed kernel image' |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 | echo '* unwcheck - Check vmlinux for invalid unwind info' |
| 89 | endef |
Isaku Yamahata | 213060a | 2008-05-19 22:13:40 +0900 | [diff] [blame] | 90 | |
Masahiro Yamada | 2e8d696 | 2016-03-13 09:13:55 +0900 | [diff] [blame] | 91 | archprepare: make_nr_irqs_h |
Masahiro Yamada | 1c44b28 | 2016-04-08 11:16:10 +0900 | [diff] [blame] | 92 | PHONY += make_nr_irqs_h |
Isaku Yamahata | 213060a | 2008-05-19 22:13:40 +0900 | [diff] [blame] | 93 | |
Masahiro Yamada | 2e8d696 | 2016-03-13 09:13:55 +0900 | [diff] [blame] | 94 | make_nr_irqs_h: |
Sam Ravnborg | 4929d29 | 2009-04-20 19:35:54 +0200 | [diff] [blame] | 95 | $(Q)$(MAKE) $(build)=arch/ia64/kernel include/generated/nr-irqs.h |