2005-04-16 15:20:36 -07:00
#
# parisc/Makefile
#
# This file is included by the global makefile so that you can add your own
# architecture-specific flags and dependencies. Remember to do have actions
# for "archclean" and "archdep" for cleaning up and making dependencies for
# this architecture
#
# This file is subject to the terms and conditions of the GNU General Public
# License. See the file "COPYING" in the main directory of this archive
# for more details.
#
# Copyright (C) 1994 by Linus Torvalds
# Portions Copyright (C) 1999 The Puffin Group
#
# Modified for PA-RISC Linux by Paul Lahaie, Alex deVries,
# Mike Shaver, Helge Deller and Martin K. Petersen
#
2008-02-26 21:55:17 +02:00
2013-06-29 13:31:24 +02:00
KBUILD_IMAGE := vmlinuz
2005-04-16 15:20:36 -07:00
NM = sh $( srctree) /arch/parisc/nm
2018-05-28 20:27:35 +02:00
CHECKFLAGS += -D__hppa__= 1
2012-06-05 13:54:09 +09:00
LIBGCC = $( shell $( CC) $( KBUILD_CFLAGS) -print-libgcc-file-name)
2017-08-20 10:52:22 +02:00
export LIBGCC
2005-04-16 15:20:36 -07:00
i f d e f C O N F I G _ 6 4 B I T
UTS_MACHINE := parisc64
2018-05-30 22:48:38 +02:00
CHECKFLAGS += -D__LP64__= 1
2013-05-11 19:04:09 +00:00
CC_ARCHES = hppa64
2017-08-20 10:52:22 +02:00
LD_BFD := elf64-hppa-linux
2007-10-18 13:54:51 -07:00
e l s e # 32-bit
2013-05-11 19:04:09 +00:00
CC_ARCHES = hppa hppa2.0 hppa1.1
2017-08-20 10:52:22 +02:00
LD_BFD := elf32-hppa-linux
2005-04-16 15:20:36 -07:00
e n d i f
2017-08-20 10:52:22 +02:00
export LD_BFD
2013-05-11 19:04:09 +00:00
i f n e q ( $( SUBARCH ) , $( UTS_MACHINE ) )
ifeq ( $( CROSS_COMPILE) ,)
CC_SUFFIXES = linux linux-gnu unknown-linux-gnu
CROSS_COMPILE := $( call cc-cross-prefix, \
$( foreach a,$( CC_ARCHES) , \
$( foreach s,$( CC_SUFFIXES) ,$( a) -$( s) -) ) )
endif
2007-10-18 13:54:51 -07:00
e n d i f
2005-04-16 15:20:36 -07:00
parisc: add dynamic ftrace
This patch implements dynamic ftrace for PA-RISC. The required mcount
call sequences can get pretty long, so instead of patching the
whole call sequence out of the functions, we are using
-fpatchable-function-entry from gcc. This puts a configurable amount of
NOPS before/at the start of the function. Taking do_sys_open() as example,
which would look like this when the call is patched out:
1036b248: 08 00 02 40 nop
1036b24c: 08 00 02 40 nop
1036b250: 08 00 02 40 nop
1036b254: 08 00 02 40 nop
1036b258 <do_sys_open>:
1036b258: 08 00 02 40 nop
1036b25c: 08 03 02 41 copy r3,r1
1036b260: 6b c2 3f d9 stw rp,-14(sp)
1036b264: 08 1e 02 43 copy sp,r3
1036b268: 6f c1 01 00 stw,ma r1,80(sp)
When ftrace gets enabled for this function the kernel will patch these
NOPs to:
1036b248: 10 19 57 20 <address of ftrace>
1036b24c: 6f c1 00 80 stw,ma r1,40(sp)
1036b250: 48 21 3f d1 ldw -18(r1),r1
1036b254: e8 20 c0 02 bv,n r0(r1)
1036b258 <do_sys_open>:
1036b258: e8 3f 1f df b,l,n .-c,r1
1036b25c: 08 03 02 41 copy r3,r1
1036b260: 6b c2 3f d9 stw rp,-14(sp)
1036b264: 08 1e 02 43 copy sp,r3
1036b268: 6f c1 01 00 stw,ma r1,80(sp)
So the first NOP in do_sys_open() will be patched to jump backwards into
some minimal trampoline code which pushes a stackframe, saves r1 which
holds the return address, loads the address of the real ftrace function,
and branches to that location. For 64 Bit things are getting a bit more
complicated (and longer) because we must make sure that the address of
ftrace location is 8 byte aligned, and the offset passed to ldd for
fetching the address is 8 byte aligned as well.
Note that gcc has a bug which misplaces the function label, and needs a
patch to make dynamic ftrace work. See
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=90751 for details.
Signed-off-by: Sven Schnelle <svens@stackframe.org>
Signed-off-by: Helge Deller <deller@gmx.de>
2019-06-05 22:32:22 +02:00
i f d e f C O N F I G _ D Y N A M I C _ F T R A C E
i f d e f C O N F I G _ 6 4 B I T
NOP_COUNT := 8
e l s e
NOP_COUNT := 5
e n d i f
export CC_USING_RECORD_MCOUNT := 1
export CC_USING_PATCHABLE_FUNCTION_ENTRY := 1
KBUILD_AFLAGS += -DCC_USING_PATCHABLE_FUNCTION_ENTRY= 1
KBUILD_CFLAGS += -DCC_USING_PATCHABLE_FUNCTION_ENTRY= 1 \
-DFTRACE_PATCHABLE_FUNCTION_SIZE= $( NOP_COUNT)
CC_FLAGS_FTRACE := -fpatchable-function-entry= $( NOP_COUNT) ,$( shell echo $$ ( ( $( NOP_COUNT) -1) ) )
KBUILD_LDFLAGS_MODULE += -T $( srctree) /arch/parisc/kernel/module.lds
e n d i f
2005-04-16 15:20:36 -07:00
OBJCOPY_FLAGS = -O binary -R .note -R .comment -S
cflags-y := -pipe
# These flags should be implied by an hppa-linux configuration, but they
# are not in gcc 3.2.
2014-09-22 20:54:50 -04:00
cflags-y += -mno-space-regs
# -mfast-indirect-calls is only relevant for 32-bit kernels.
i f n d e f C O N F I G _ 6 4 B I T
cflags-y += -mfast-indirect-calls
e n d i f
2005-04-16 15:20:36 -07:00
# Currently we save and restore fpregs on all kernel entry/interruption paths.
# If that gets optimized, we might need to disable the use of fpregs in the
# kernel.
2005-10-21 22:48:34 -04:00
cflags-y += -mdisable-fpregs
2005-04-16 15:20:36 -07:00
2013-01-31 21:44:28 +00:00
# Use long jumps instead of long branches (needed if your linker fails to
2013-04-23 21:29:03 +02:00
# link a too big vmlinux executable). Not enabled for building modules.
i f d e f C O N F I G _ M L O N G C A L L S
KBUILD_CFLAGS_KERNEL += -mlong-calls
e n d i f
2013-01-31 21:44:28 +00:00
2018-11-29 17:05:47 +01:00
# Without this, "ld -r" results in .text sections that are too big (> 0x40000)
# for branches to reach stubs. And multiple .text sections trigger a warning
# when creating the sysfs module information section.
i f n d e f C O N F I G _ 6 4 B I T
KBUILD_CFLAGS_MODULE += -ffunction-sections
e n d i f
2005-04-16 15:20:36 -07:00
# select which processor to optimise for
2013-05-29 09:56:58 +00:00
cflags-$(CONFIG_PA7000) += -march= 1.1 -mschedule= 7100
2005-04-16 15:20:36 -07:00
cflags-$(CONFIG_PA7200) += -march= 1.1 -mschedule= 7200
cflags-$(CONFIG_PA7100LC) += -march= 1.1 -mschedule= 7100LC
cflags-$(CONFIG_PA7300LC) += -march= 1.1 -mschedule= 7300
cflags-$(CONFIG_PA8X00) += -march= 2.0 -mschedule= 8000
head-y := arch/parisc/kernel/head.o
2007-10-14 22:21:35 +02:00
KBUILD_CFLAGS += $( cflags-y)
2005-04-16 15:20:36 -07:00
2012-05-07 11:28:13 +02:00
kernel-y := mm/ kernel/ math-emu/
2005-04-16 15:20:36 -07:00
core-y += $( addprefix arch/parisc/, $( kernel-y) )
2012-06-05 13:54:09 +09:00
libs-y += arch/parisc/lib/ $( LIBGCC)
2005-04-16 15:20:36 -07:00
drivers-$(CONFIG_OPROFILE) += arch/parisc/oprofile/
2017-08-20 10:52:22 +02:00
boot := arch/parisc/boot
2008-12-08 09:43:08 +00:00
PALO := $( shell if ( which palo 2>& 1) ; then : ; \
2007-10-18 15:09:59 -07:00
elif [ -x /sbin/palo ] ; then echo /sbin/palo; \
fi )
2019-07-06 12:07:11 +09:00
PALOCONF := $( shell if [ -f $( srctree) /palo.conf ] ; then echo $( srctree) /palo.conf; \
else echo $( objtree) /palo.conf; \
2007-10-20 09:31:33 -07:00
fi )
2013-10-18 21:18:46 +02:00
palo lifimage : vmlinuz
2007-10-20 09:31:33 -07:00
@if test ! -x " $( PALO) " ; then \
2007-10-18 15:09:59 -07:00
echo 'ERROR: Please install palo first (apt-get install palo)' ; \
echo 'or build it from source and install it somewhere in your $$PATH' ; \
false; \
fi
2007-10-20 09:31:33 -07:00
@if test ! -f " $( PALOCONF) " ; then \
2019-07-06 12:07:11 +09:00
cp $( srctree) /arch/parisc/defpalo.conf $( objtree) /palo.conf; \
echo 'A generic palo config file ($(objree)/palo.conf) has been created for you.' ; \
2007-10-18 15:09:59 -07:00
echo 'You should check it and re-run "make palo".' ; \
echo 'WARNING: the "lifimage" file is now placed in this directory by default!' ; \
false; \
fi
2007-10-20 09:31:33 -07:00
$( PALO) -f $( PALOCONF)
2007-10-18 15:09:59 -07:00
2013-10-18 21:18:46 +02:00
BOOT_TARGETS = zImage Image palo lifimage
INSTALL_TARGETS = zinstall install
PHONY += bzImage $( BOOT_TARGETS) $( INSTALL_TARGETS)
2018-04-18 07:49:19 +02:00
# Default kernel to build
all : bzImage
2017-08-20 10:52:22 +02:00
zImage : vmlinuz
2013-06-29 13:31:24 +02:00
Image : vmlinux
2017-08-20 10:52:22 +02:00
bzImage : vmlinux
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2017-09-22 22:24:02 +02:00
i f d e f C O N F I G _ P A R I S C _ S E L F _ E X T R A C T
2017-08-20 10:52:22 +02:00
vmlinuz : bzImage
$( OBJCOPY) $( boot) /bzImage $@
2017-09-22 22:24:02 +02:00
e l s e
vmlinuz : vmlinux
@gzip -cf -9 $< > $@
e n d i f
2005-04-16 15:20:36 -07:00
2013-10-18 21:18:46 +02:00
install :
2019-07-06 12:07:11 +09:00
$( CONFIG_SHELL) $( srctree) /arch/parisc/install.sh \
2013-10-18 21:18:46 +02:00
$( KERNELRELEASE) vmlinux System.map " $( INSTALL_PATH) "
zinstall :
2019-07-06 12:07:11 +09:00
$( CONFIG_SHELL) $( srctree) /arch/parisc/install.sh \
2013-10-18 21:18:46 +02:00
$( KERNELRELEASE) vmlinuz System.map " $( INSTALL_PATH) "
2005-04-16 15:20:36 -07:00
2005-09-09 20:57:26 +02:00
CLEAN_FILES += lifimage
2005-04-16 15:20:36 -07:00
MRPROPER_FILES += palo.conf
d e f i n e a r c h h e l p
@echo '* vmlinux - Uncompressed kernel image (./vmlinux)'
2013-06-29 13:31:24 +02:00
@echo ' vmlinuz - Compressed kernel image (./vmlinuz)'
2007-10-18 15:09:59 -07:00
@echo ' palo - Bootable image (./lifimage)'
2013-10-18 21:18:46 +02:00
@echo ' install - Install uncompressed vmlinux kernel using'
2009-07-20 21:37:11 +02:00
@echo ' (your) ~/bin/$(INSTALLKERNEL) or'
@echo ' (distribution) /sbin/$(INSTALLKERNEL) or'
2005-04-16 15:20:36 -07:00
@echo ' copy to $$(INSTALL_PATH)'
2013-10-18 21:18:46 +02:00
@echo ' zinstall - Install compressed vmlinuz kernel'
2005-04-16 15:20:36 -07:00
e n d e f
2018-11-19 12:04:36 +05:30
archheaders :
$( Q) $( MAKE) $( build) = arch/parisc/kernel/syscalls all