blob: 0cf86ed2b7c17fdf20d7dcfa55ae9495b1296c2b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# parisc/Makefile
3#
4# This file is included by the global makefile so that you can add your own
5# architecture-specific flags and dependencies. Remember to do have actions
6# for "archclean" and "archdep" for cleaning up and making dependencies for
7# this architecture
8#
9# This file is subject to the terms and conditions of the GNU General Public
10# License. See the file "COPYING" in the main directory of this archive
11# for more details.
12#
13# Copyright (C) 1994 by Linus Torvalds
14# Portions Copyright (C) 1999 The Puffin Group
15#
16# Modified for PA-RISC Linux by Paul Lahaie, Alex deVries,
17# Mike Shaver, Helge Deller and Martin K. Petersen
18#
Adrian Bunkc04f7ae2008-02-26 21:55:17 +020019
Helge Dellerc27a5482021-11-26 22:35:45 +010020ifdef CONFIG_PARISC_SELF_EXTRACT
21boot := arch/parisc/boot
22KBUILD_IMAGE := $(boot)/bzImage
23else
Helge Deller594174d2013-06-29 13:31:24 +020024KBUILD_IMAGE := vmlinuz
Helge Dellerc27a5482021-11-26 22:35:45 +010025endif
Helge Deller594174d2013-06-29 13:31:24 +020026
Linus Torvalds1da177e2005-04-16 15:20:36 -070027NM = sh $(srctree)/arch/parisc/nm
Luc Van Oostenryck145167652018-05-28 20:27:35 +020028CHECKFLAGS += -D__hppa__=1
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
30ifdef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -070031UTS_MACHINE := parisc64
Luc Van Oostenryck1f2f01b2018-05-30 22:48:38 +020032CHECKFLAGS += -D__LP64__=1
Helge Deller6880b012013-05-11 19:04:09 +000033CC_ARCHES = hppa64
Helge Dellerb6adc162017-08-20 10:52:22 +020034LD_BFD := elf64-hppa-linux
Kyle McMartin991b7d62007-10-18 13:54:51 -070035else # 32-bit
Helge Deller6880b012013-05-11 19:04:09 +000036CC_ARCHES = hppa hppa2.0 hppa1.1
Helge Dellerb6adc162017-08-20 10:52:22 +020037LD_BFD := elf32-hppa-linux
Linus Torvalds1da177e2005-04-16 15:20:36 -070038endif
39
Helge Dellerededa082020-03-26 23:31:43 +010040# select defconfig based on actual architecture
41ifeq ($(shell uname -m),parisc64)
42 KBUILD_DEFCONFIG := generic-64bit_defconfig
43else
44 KBUILD_DEFCONFIG := generic-32bit_defconfig
45endif
46
Helge Dellerb6adc162017-08-20 10:52:22 +020047export LD_BFD
48
Helge Deller6880b012013-05-11 19:04:09 +000049ifneq ($(SUBARCH),$(UTS_MACHINE))
50 ifeq ($(CROSS_COMPILE),)
51 CC_SUFFIXES = linux linux-gnu unknown-linux-gnu
52 CROSS_COMPILE := $(call cc-cross-prefix, \
53 $(foreach a,$(CC_ARCHES), \
54 $(foreach s,$(CC_SUFFIXES),$(a)-$(s)-)))
55 endif
Kyle McMartin991b7d62007-10-18 13:54:51 -070056endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070057
Sven Schnelle6ca63662019-06-05 22:32:22 +020058ifdef CONFIG_DYNAMIC_FTRACE
59ifdef CONFIG_64BIT
60NOP_COUNT := 8
61else
62NOP_COUNT := 5
63endif
64
65export CC_USING_RECORD_MCOUNT:=1
66export CC_USING_PATCHABLE_FUNCTION_ENTRY:=1
67
68KBUILD_AFLAGS += -DCC_USING_PATCHABLE_FUNCTION_ENTRY=1
69KBUILD_CFLAGS += -DCC_USING_PATCHABLE_FUNCTION_ENTRY=1 \
70 -DFTRACE_PATCHABLE_FUNCTION_SIZE=$(NOP_COUNT)
71
72CC_FLAGS_FTRACE := -fpatchable-function-entry=$(NOP_COUNT),$(shell echo $$(($(NOP_COUNT)-1)))
Sven Schnelle6ca63662019-06-05 22:32:22 +020073endif
74
Linus Torvalds1da177e2005-04-16 15:20:36 -070075OBJCOPY_FLAGS =-O binary -R .note -R .comment -S
76
77cflags-y := -pipe
78
79# These flags should be implied by an hppa-linux configuration, but they
80# are not in gcc 3.2.
John David Anglind26a7732014-09-22 20:54:50 -040081cflags-y += -mno-space-regs
82
83# -mfast-indirect-calls is only relevant for 32-bit kernels.
84ifndef CONFIG_64BIT
85cflags-y += -mfast-indirect-calls
86endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070087
88# Currently we save and restore fpregs on all kernel entry/interruption paths.
89# If that gets optimized, we might need to disable the use of fpregs in the
90# kernel.
Randolph Chungfa681a12005-10-21 22:48:34 -040091cflags-y += -mdisable-fpregs
Linus Torvalds1da177e2005-04-16 15:20:36 -070092
Helge Dellerec758f92013-01-31 21:44:28 +000093# Use long jumps instead of long branches (needed if your linker fails to
Helge Dellercf711302013-04-23 21:29:03 +020094# link a too big vmlinux executable). Not enabled for building modules.
95ifdef CONFIG_MLONGCALLS
96KBUILD_CFLAGS_KERNEL += -mlong-calls
97endif
Helge Dellerec758f92013-01-31 21:44:28 +000098
Helge Deller1e8249b2018-11-29 17:05:47 +010099# Without this, "ld -r" results in .text sections that are too big (> 0x40000)
100# for branches to reach stubs. And multiple .text sections trigger a warning
101# when creating the sysfs module information section.
102ifndef CONFIG_64BIT
103KBUILD_CFLAGS_MODULE += -ffunction-sections
104endif
105
Linus Torvalds1da177e2005-04-16 15:20:36 -0700106# select which processor to optimise for
Paul Bolle76603902013-05-29 09:56:58 +0000107cflags-$(CONFIG_PA7000) += -march=1.1 -mschedule=7100
Linus Torvalds1da177e2005-04-16 15:20:36 -0700108cflags-$(CONFIG_PA7200) += -march=1.1 -mschedule=7200
109cflags-$(CONFIG_PA7100LC) += -march=1.1 -mschedule=7100LC
110cflags-$(CONFIG_PA7300LC) += -march=1.1 -mschedule=7300
111cflags-$(CONFIG_PA8X00) += -march=2.0 -mschedule=8000
112
113head-y := arch/parisc/kernel/head.o
114
Sam Ravnborga0f97e02007-10-14 22:21:35 +0200115KBUILD_CFLAGS += $(cflags-y)
Helge Deller0d341e02020-05-10 22:43:33 +0200116LIBGCC := $(shell $(CC) -print-libgcc-file-name)
117export LIBGCC
Linus Torvalds1da177e2005-04-16 15:20:36 -0700118
Thomas Gleixner481f93b2012-05-07 11:28:13 +0200119kernel-y := mm/ kernel/ math-emu/
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120
121core-y += $(addprefix arch/parisc/, $(kernel-y))
James Bottomley4c01acc2012-06-05 13:54:09 +0900122libs-y += arch/parisc/lib/ $(LIBGCC)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700123
124drivers-$(CONFIG_OPROFILE) += arch/parisc/oprofile/
125
Helge Dellerb6adc162017-08-20 10:52:22 +0200126boot := arch/parisc/boot
127
Kyle McMartin6525ee52008-12-08 09:43:08 +0000128PALO := $(shell if (which palo 2>&1); then : ; \
Kyle McMartin5feb4f32007-10-18 15:09:59 -0700129 elif [ -x /sbin/palo ]; then echo /sbin/palo; \
130 fi)
131
Masahiro Yamada75dd4742019-07-06 12:07:11 +0900132PALOCONF := $(shell if [ -f $(srctree)/palo.conf ]; then echo $(srctree)/palo.conf; \
133 else echo $(objtree)/palo.conf; \
Kyle McMartinf67d4032007-10-20 09:31:33 -0700134 fi)
135
Helge Dellerb0756b52013-10-18 21:18:46 +0200136palo lifimage: vmlinuz
Kyle McMartinf67d4032007-10-20 09:31:33 -0700137 @if test ! -x "$(PALO)"; then \
Kyle McMartin5feb4f32007-10-18 15:09:59 -0700138 echo 'ERROR: Please install palo first (apt-get install palo)';\
139 echo 'or build it from source and install it somewhere in your $$PATH';\
140 false; \
141 fi
Kyle McMartinf67d4032007-10-20 09:31:33 -0700142 @if test ! -f "$(PALOCONF)"; then \
Masahiro Yamada75dd4742019-07-06 12:07:11 +0900143 cp $(srctree)/arch/parisc/defpalo.conf $(objtree)/palo.conf; \
144 echo 'A generic palo config file ($(objree)/palo.conf) has been created for you.'; \
Kyle McMartin5feb4f32007-10-18 15:09:59 -0700145 echo 'You should check it and re-run "make palo".'; \
146 echo 'WARNING: the "lifimage" file is now placed in this directory by default!'; \
147 false; \
148 fi
Kyle McMartinf67d4032007-10-20 09:31:33 -0700149 $(PALO) -f $(PALOCONF)
Kyle McMartin5feb4f32007-10-18 15:09:59 -0700150
Helge Dellerb0756b52013-10-18 21:18:46 +0200151BOOT_TARGETS = zImage Image palo lifimage
152INSTALL_TARGETS = zinstall install
153
154PHONY += bzImage $(BOOT_TARGETS) $(INSTALL_TARGETS)
155
Helge Deller89e050c2018-04-18 07:49:19 +0200156# Default kernel to build
157all: bzImage
158
Helge Dellerb6adc162017-08-20 10:52:22 +0200159zImage: vmlinuz
Helge Deller594174d2013-06-29 13:31:24 +0200160Image: vmlinux
Linus Torvalds1da177e2005-04-16 15:20:36 -0700161
Helge Dellerb6adc162017-08-20 10:52:22 +0200162bzImage: vmlinux
163 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
164
Helge Delleraf21b012017-09-22 22:24:02 +0200165ifdef CONFIG_PARISC_SELF_EXTRACT
Helge Dellerb6adc162017-08-20 10:52:22 +0200166vmlinuz: bzImage
167 $(OBJCOPY) $(boot)/bzImage $@
Helge Delleraf21b012017-09-22 22:24:02 +0200168else
169vmlinuz: vmlinux
Denis Efremove4a42c82020-06-08 12:59:44 +0300170 @$(KGZIP) -cf -9 $< > $@
Helge Delleraf21b012017-09-22 22:24:02 +0200171endif
Helge Deller594174d2013-06-29 13:31:24 +0200172
Helge Dellerb0756b52013-10-18 21:18:46 +0200173install:
Masahiro Yamada75dd4742019-07-06 12:07:11 +0900174 $(CONFIG_SHELL) $(srctree)/arch/parisc/install.sh \
Helge Dellerb0756b52013-10-18 21:18:46 +0200175 $(KERNELRELEASE) vmlinux System.map "$(INSTALL_PATH)"
176zinstall:
Masahiro Yamada75dd4742019-07-06 12:07:11 +0900177 $(CONFIG_SHELL) $(srctree)/arch/parisc/install.sh \
Helge Dellerb0756b52013-10-18 21:18:46 +0200178 $(KERNELRELEASE) vmlinuz System.map "$(INSTALL_PATH)"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700179
Sam Ravnborg0013a852005-09-09 20:57:26 +0200180CLEAN_FILES += lifimage
Linus Torvalds1da177e2005-04-16 15:20:36 -0700181MRPROPER_FILES += palo.conf
182
183define archhelp
184 @echo '* vmlinux - Uncompressed kernel image (./vmlinux)'
Helge Deller594174d2013-06-29 13:31:24 +0200185 @echo ' vmlinuz - Compressed kernel image (./vmlinuz)'
Kyle McMartin5feb4f32007-10-18 15:09:59 -0700186 @echo ' palo - Bootable image (./lifimage)'
Helge Dellerb0756b52013-10-18 21:18:46 +0200187 @echo ' install - Install uncompressed vmlinux kernel using'
Sam Ravnborgcaa27b62009-07-20 21:37:11 +0200188 @echo ' (your) ~/bin/$(INSTALLKERNEL) or'
189 @echo ' (distribution) /sbin/$(INSTALLKERNEL) or'
Linus Torvalds1da177e2005-04-16 15:20:36 -0700190 @echo ' copy to $$(INSTALL_PATH)'
Helge Dellerb0756b52013-10-18 21:18:46 +0200191 @echo ' zinstall - Install compressed vmlinuz kernel'
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192endef
Firoz Khan575afc42018-11-19 12:04:36 +0530193
James Bottomleyf2c5ed02019-08-01 13:47:03 +0200194archclean:
195 $(Q)$(MAKE) $(clean)=$(boot)
196
Firoz Khan575afc42018-11-19 12:04:36 +0530197archheaders:
198 $(Q)$(MAKE) $(build)=arch/parisc/kernel/syscalls all