2005-04-17 06:20:36 +08:00
|
|
|
#
|
|
|
|
# parisc/Makefile
|
|
|
|
#
|
|
|
|
# This file is included by the global makefile so that you can add your own
|
2021-10-13 14:36:22 +08:00
|
|
|
# architecture-specific flags and dependencies.
|
2005-04-17 06:20:36 +08:00
|
|
|
#
|
|
|
|
# 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-27 03:55:17 +08:00
|
|
|
|
2021-11-27 05:35:45 +08:00
|
|
|
boot := arch/parisc/boot
|
|
|
|
KBUILD_IMAGE := $(boot)/bzImage
|
2013-06-29 19:31:24 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
NM = sh $(srctree)/arch/parisc/nm
|
2018-05-29 02:27:35 +08:00
|
|
|
CHECKFLAGS += -D__hppa__=1
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
ifdef CONFIG_64BIT
|
|
|
|
UTS_MACHINE := parisc64
|
2018-05-31 04:48:38 +08:00
|
|
|
CHECKFLAGS += -D__LP64__=1
|
2017-08-20 16:52:22 +08:00
|
|
|
LD_BFD := elf64-hppa-linux
|
2007-10-19 04:54:51 +08:00
|
|
|
else # 32-bit
|
2017-08-20 16:52:22 +08:00
|
|
|
LD_BFD := elf32-hppa-linux
|
2005-04-17 06:20:36 +08:00
|
|
|
endif
|
|
|
|
|
2020-03-27 06:31:43 +08:00
|
|
|
# select defconfig based on actual architecture
|
2021-06-10 10:03:31 +08:00
|
|
|
ifeq ($(ARCH),parisc64)
|
2020-03-27 06:31:43 +08:00
|
|
|
KBUILD_DEFCONFIG := generic-64bit_defconfig
|
2021-06-10 10:03:31 +08:00
|
|
|
CC_ARCHES := hppa64
|
2020-03-27 06:31:43 +08:00
|
|
|
else
|
|
|
|
KBUILD_DEFCONFIG := generic-32bit_defconfig
|
2021-06-10 10:03:31 +08:00
|
|
|
CC_ARCHES := hppa hppa2.0 hppa1.1
|
2020-03-27 06:31:43 +08:00
|
|
|
endif
|
|
|
|
|
2017-08-20 16:52:22 +08:00
|
|
|
export LD_BFD
|
|
|
|
|
2021-12-08 18:06:52 +08:00
|
|
|
# Set default 32 bits cross compilers for vdso
|
|
|
|
CC_ARCHES_32 = hppa hppa2.0 hppa1.1
|
2022-03-22 05:02:01 +08:00
|
|
|
CC_SUFFIXES = linux linux-gnu unknown-linux-gnu suse-linux
|
2021-12-08 18:06:52 +08:00
|
|
|
CROSS32_COMPILE := $(call cc-cross-prefix, \
|
|
|
|
$(foreach a,$(CC_ARCHES_32), \
|
|
|
|
$(foreach s,$(CC_SUFFIXES),$(a)-$(s)-)))
|
|
|
|
CROSS32CC := $(CROSS32_COMPILE)gcc
|
|
|
|
export CROSS32CC
|
|
|
|
|
|
|
|
# Set default cross compiler for kernel build
|
2021-05-02 01:24:36 +08:00
|
|
|
ifdef cross_compiling
|
2013-05-12 03:04:09 +08:00
|
|
|
ifeq ($(CROSS_COMPILE),)
|
2022-03-22 05:02:01 +08:00
|
|
|
CC_SUFFIXES = linux linux-gnu unknown-linux-gnu suse-linux
|
2013-05-12 03:04:09 +08:00
|
|
|
CROSS_COMPILE := $(call cc-cross-prefix, \
|
|
|
|
$(foreach a,$(CC_ARCHES), \
|
|
|
|
$(foreach s,$(CC_SUFFIXES),$(a)-$(s)-)))
|
|
|
|
endif
|
2007-10-19 04:54:51 +08:00
|
|
|
endif
|
2005-04-17 06:20:36 +08: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-06 04:32:22 +08:00
|
|
|
ifdef CONFIG_DYNAMIC_FTRACE
|
|
|
|
ifdef CONFIG_64BIT
|
|
|
|
NOP_COUNT := 8
|
|
|
|
else
|
|
|
|
NOP_COUNT := 5
|
|
|
|
endif
|
|
|
|
|
|
|
|
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)))
|
|
|
|
endif
|
|
|
|
|
2005-04-17 06:20:36 +08: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-23 08:54:50 +08:00
|
|
|
cflags-y += -mno-space-regs
|
|
|
|
|
|
|
|
# -mfast-indirect-calls is only relevant for 32-bit kernels.
|
|
|
|
ifndef CONFIG_64BIT
|
|
|
|
cflags-y += -mfast-indirect-calls
|
|
|
|
endif
|
2005-04-17 06:20:36 +08: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-22 10:48:34 +08:00
|
|
|
cflags-y += -mdisable-fpregs
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2013-02-01 05:44:28 +08:00
|
|
|
# Use long jumps instead of long branches (needed if your linker fails to
|
2013-04-24 03:29:03 +08:00
|
|
|
# link a too big vmlinux executable). Not enabled for building modules.
|
|
|
|
ifdef CONFIG_MLONGCALLS
|
|
|
|
KBUILD_CFLAGS_KERNEL += -mlong-calls
|
|
|
|
endif
|
2013-02-01 05:44:28 +08:00
|
|
|
|
2018-11-30 00:05:47 +08: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.
|
|
|
|
ifndef CONFIG_64BIT
|
|
|
|
KBUILD_CFLAGS_MODULE += -ffunction-sections
|
|
|
|
endif
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
# select which processor to optimise for
|
2013-05-29 17:56:58 +08:00
|
|
|
cflags-$(CONFIG_PA7000) += -march=1.1 -mschedule=7100
|
2005-04-17 06:20:36 +08: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-15 04:21:35 +08:00
|
|
|
KBUILD_CFLAGS += $(cflags-y)
|
2020-05-11 04:43:33 +08:00
|
|
|
LIBGCC := $(shell $(CC) -print-libgcc-file-name)
|
|
|
|
export LIBGCC
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2012-06-05 12:54:09 +08:00
|
|
|
libs-y += arch/parisc/lib/ $(LIBGCC)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2017-08-20 16:52:22 +08:00
|
|
|
boot := arch/parisc/boot
|
|
|
|
|
2008-12-08 17:43:08 +08:00
|
|
|
PALO := $(shell if (which palo 2>&1); then : ; \
|
2007-10-19 06:09:59 +08:00
|
|
|
elif [ -x /sbin/palo ]; then echo /sbin/palo; \
|
|
|
|
fi)
|
|
|
|
|
2019-07-06 11:07:11 +08:00
|
|
|
PALOCONF := $(shell if [ -f $(srctree)/palo.conf ]; then echo $(srctree)/palo.conf; \
|
|
|
|
else echo $(objtree)/palo.conf; \
|
2007-10-21 00:31:33 +08:00
|
|
|
fi)
|
|
|
|
|
2013-10-19 03:18:46 +08:00
|
|
|
palo lifimage: vmlinuz
|
2007-10-21 00:31:33 +08:00
|
|
|
@if test ! -x "$(PALO)"; then \
|
2007-10-19 06:09:59 +08: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-21 00:31:33 +08:00
|
|
|
@if test ! -f "$(PALOCONF)"; then \
|
2019-07-06 11:07:11 +08: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-19 06:09:59 +08: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-21 00:31:33 +08:00
|
|
|
$(PALO) -f $(PALOCONF)
|
2007-10-19 06:09:59 +08:00
|
|
|
|
2013-10-19 03:18:46 +08:00
|
|
|
BOOT_TARGETS = zImage Image palo lifimage
|
|
|
|
INSTALL_TARGETS = zinstall install
|
|
|
|
|
|
|
|
PHONY += bzImage $(BOOT_TARGETS) $(INSTALL_TARGETS)
|
|
|
|
|
2018-04-18 13:49:19 +08:00
|
|
|
# Default kernel to build
|
|
|
|
all: bzImage
|
|
|
|
|
2017-08-20 16:52:22 +08:00
|
|
|
zImage: vmlinuz
|
2013-06-29 19:31:24 +08:00
|
|
|
Image: vmlinux
|
|
|
|
|
2017-08-20 16:52:22 +08:00
|
|
|
bzImage: vmlinux
|
|
|
|
$(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
|
|
|
|
|
|
|
|
vmlinuz: bzImage
|
|
|
|
$(OBJCOPY) $(boot)/bzImage $@
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2021-12-08 18:06:52 +08:00
|
|
|
ifeq ($(KBUILD_EXTMOD),)
|
|
|
|
# We need to generate vdso-offsets.h before compiling certain files in kernel/.
|
|
|
|
# In order to do that, we should use the archprepare target, but we can't since
|
|
|
|
# asm-offsets.h is included in some files used to generate vdso-offsets.h, and
|
|
|
|
# asm-offsets.h is built in prepare0, for which archprepare is a dependency.
|
|
|
|
# Therefore we need to generate the header after prepare0 has been made, hence
|
|
|
|
# this hack.
|
|
|
|
prepare: vdso_prepare
|
|
|
|
vdso_prepare: prepare0
|
|
|
|
$(if $(CONFIG_64BIT),$(Q)$(MAKE) \
|
|
|
|
$(build)=arch/parisc/kernel/vdso64 include/generated/vdso64-offsets.h)
|
|
|
|
$(Q)$(MAKE) $(build)=arch/parisc/kernel/vdso32 include/generated/vdso32-offsets.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
PHONY += vdso_install
|
|
|
|
|
|
|
|
vdso_install:
|
|
|
|
$(Q)$(MAKE) $(build)=arch/parisc/kernel/vdso $@
|
|
|
|
$(if $(CONFIG_COMPAT_VDSO), \
|
|
|
|
$(Q)$(MAKE) $(build)=arch/parisc/kernel/vdso32 $@)
|
2013-10-19 03:18:46 +08:00
|
|
|
install:
|
2019-07-06 11:07:11 +08:00
|
|
|
$(CONFIG_SHELL) $(srctree)/arch/parisc/install.sh \
|
2013-10-19 03:18:46 +08:00
|
|
|
$(KERNELRELEASE) vmlinux System.map "$(INSTALL_PATH)"
|
|
|
|
zinstall:
|
2019-07-06 11:07:11 +08:00
|
|
|
$(CONFIG_SHELL) $(srctree)/arch/parisc/install.sh \
|
2013-10-19 03:18:46 +08:00
|
|
|
$(KERNELRELEASE) vmlinuz System.map "$(INSTALL_PATH)"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2005-09-10 02:57:26 +08:00
|
|
|
CLEAN_FILES += lifimage
|
2005-04-17 06:20:36 +08:00
|
|
|
MRPROPER_FILES += palo.conf
|
|
|
|
|
|
|
|
define archhelp
|
|
|
|
@echo '* vmlinux - Uncompressed kernel image (./vmlinux)'
|
2013-06-29 19:31:24 +08:00
|
|
|
@echo ' vmlinuz - Compressed kernel image (./vmlinuz)'
|
2007-10-19 06:09:59 +08:00
|
|
|
@echo ' palo - Bootable image (./lifimage)'
|
2013-10-19 03:18:46 +08:00
|
|
|
@echo ' install - Install uncompressed vmlinux kernel using'
|
2009-07-21 03:37:11 +08:00
|
|
|
@echo ' (your) ~/bin/$(INSTALLKERNEL) or'
|
|
|
|
@echo ' (distribution) /sbin/$(INSTALLKERNEL) or'
|
2005-04-17 06:20:36 +08:00
|
|
|
@echo ' copy to $$(INSTALL_PATH)'
|
2013-10-19 03:18:46 +08:00
|
|
|
@echo ' zinstall - Install compressed vmlinuz kernel'
|
2005-04-17 06:20:36 +08:00
|
|
|
endef
|
2018-11-19 14:34:36 +08:00
|
|
|
|
|
|
|
archheaders:
|
|
|
|
$(Q)$(MAKE) $(build)=arch/parisc/kernel/syscalls all
|