2012-04-20 17:45:54 +04:00
#
# arch/arm64/Makefile
#
# This file is included by the global makefile so that you can add your own
# architecture-specific flags and dependencies.
#
# 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) 1995-2001 by Russell King
LDFLAGS_vmlinux := -p --no-undefined -X
CPPFLAGS_vmlinux.lds = -DTEXT_OFFSET= $( TEXT_OFFSET)
GZFLAGS := -9
2016-01-26 11:13:44 +03:00
i f n e q ( $( CONFIG_RELOCATABLE ) , )
2016-10-20 13:12:57 +03:00
LDFLAGS_vmlinux += -pie -shared -Bsymbolic
2016-01-26 11:13:44 +03:00
e n d i f
2016-08-22 13:58:36 +03:00
i f e q ( $( CONFIG_ARM 64_ERRATUM_ 843419) , y )
ifeq ( $( call ld-option, --fix-cortex-a53-843419) ,)
$( warning ld does not support --fix -cortex -a 53-843419; kernel may be susceptible to erratum )
else
LDFLAGS_vmlinux += --fix-cortex-a53-843419
endif
e n d i f
2012-04-20 17:45:54 +04:00
KBUILD_DEFCONFIG := defconfig
2015-02-03 19:14:13 +03:00
# Check for binutils support for specific extensions
lseinstr := $( call as-instr,.arch_extension lse,-DCONFIG_AS_LSE= 1)
i f e q ( $( CONFIG_ARM 64_LSE_ATOMICS ) , y )
ifeq ( $( lseinstr) ,)
$( warning LSE atomics not supported by binutils )
endif
e n d i f
2017-04-11 19:32:30 +03:00
i f e q ( $( CONFIG_ARM 64) , y )
2016-12-06 18:27:43 +03:00
brokengasinst := $( call as-instr,1:\n .inst 0\n .rept . - 1b\n \n nop\n .endr\n ,,-DCONFIG_BROKEN_GAS_INST= 1)
2017-04-11 19:32:30 +03:00
ifneq ( $( brokengasinst) ,)
2016-12-06 18:27:43 +03:00
$( warning Detected assembler with broken .inst ; disassembly will be unreliable )
2017-04-11 19:32:30 +03:00
endif
2016-12-06 18:27:43 +03:00
e n d i f
KBUILD_CFLAGS += -mgeneral-regs-only $( lseinstr) $( brokengasinst)
2016-01-22 06:56:26 +03:00
KBUILD_CFLAGS += -fno-asynchronous-unwind-tables
2016-01-26 02:52:16 +03:00
KBUILD_CFLAGS += $( call cc-option, -mpc-relative-literal-loads)
2016-12-06 18:27:43 +03:00
KBUILD_AFLAGS += $( lseinstr) $( brokengasinst)
2015-02-03 19:14:13 +03:00
2013-10-11 17:52:08 +04:00
i f e q ( $( CONFIG_CPU_BIG_ENDIAN ) , y )
KBUILD_CPPFLAGS += -mbig-endian
2017-06-24 18:42:11 +03:00
CHECKFLAGS += -D__AARCH64EB__
2013-10-11 17:52:08 +04:00
AS += -EB
LD += -EB
2016-08-30 11:31:35 +03:00
UTS_MACHINE := aarch64_be
2013-10-11 17:52:08 +04:00
e l s e
2012-04-20 17:45:54 +04:00
KBUILD_CPPFLAGS += -mlittle-endian
2017-06-24 18:42:11 +03:00
CHECKFLAGS += -D__AARCH64EL__
2012-04-20 17:45:54 +04:00
AS += -EL
LD += -EL
2016-08-30 11:31:35 +03:00
UTS_MACHINE := aarch64
2013-10-11 17:52:08 +04:00
e n d i f
2012-04-20 17:45:54 +04:00
2017-06-20 15:24:43 +03:00
CHECKFLAGS += -D__aarch64__ -m64
2012-04-20 17:45:54 +04:00
2015-11-24 14:37:35 +03:00
i f e q ( $( CONFIG_ARM 64_MODULE_CMODEL_LARGE ) , y )
2015-10-08 13:11:17 +03:00
KBUILD_CFLAGS_MODULE += -mcmodel= large
2015-03-17 15:15:02 +03:00
e n d i f
2015-11-24 14:37:35 +03:00
i f e q ( $( CONFIG_ARM 64_MODULE_PLTS ) , y )
KBUILD_LDFLAGS_MODULE += -T $( srctree) /arch/arm64/kernel/module.lds
2017-06-06 20:00:22 +03:00
i f e q ( $( CONFIG_DYNAMIC_FTRACE ) , y )
KBUILD_LDFLAGS_MODULE += $( objtree) /arch/arm64/kernel/ftrace-mod.o
e n d i f
2015-11-24 14:37:35 +03:00
e n d i f
2012-04-20 17:45:54 +04:00
# Default value
head-y := arch/arm64/kernel/head.o
# The byte offset of the kernel image in RAM from the start of RAM.
2014-06-24 19:51:37 +04:00
i f e q ( $( CONFIG_ARM 64_RANDOMIZE_TEXT_OFFSET ) , y )
2016-05-31 17:58:00 +03:00
TEXT_OFFSET := $( shell awk " BEGIN {srand(); printf \"0x%06x\n\", \
int( 2 * 1024 * 1024 / ( 2 ^ $( CONFIG_ARM64_PAGE_SHIFT) ) * \
rand( ) ) * ( 2 ^ $( CONFIG_ARM64_PAGE_SHIFT) ) } " )
2014-06-24 19:51:37 +04:00
e l s e
2012-04-20 17:45:54 +04:00
TEXT_OFFSET := 0x00080000
2014-06-24 19:51:37 +04:00
e n d i f
2012-04-20 17:45:54 +04:00
2015-10-12 18:52:58 +03:00
# KASAN_SHADOW_OFFSET = VA_START + (1 << (VA_BITS - 3)) - (1 << 61)
# in 32-bit arithmetic
KASAN_SHADOW_OFFSET := $( shell printf "0x%08x00000000\n" $$ ( ( \
( 0xffffffff & ( -1 << ( $( CONFIG_ARM64_VA_BITS) - 32) ) ) \
+ ( 1 << ( $( CONFIG_ARM64_VA_BITS) - 32 - 3) ) \
- ( 1 << ( 64 - 32 - 3) ) ) ) )
2012-04-20 17:45:54 +04:00
export TEXT_OFFSET GZFLAGS
core-y += arch/arm64/kernel/ arch/arm64/mm/
2014-08-27 08:15:30 +04:00
core-$(CONFIG_NET) += arch/arm64/net/
2012-12-10 20:41:44 +04:00
core-$(CONFIG_KVM) += arch/arm64/kvm/
2013-06-12 19:48:38 +04:00
core-$(CONFIG_XEN) += arch/arm64/xen/
2014-03-06 12:23:33 +04:00
core-$(CONFIG_CRYPTO) += arch/arm64/crypto/
2012-04-20 17:45:54 +04:00
libs-y := arch/arm64/lib/ $( libs-y)
2015-03-16 12:30:39 +03:00
core-$(CONFIG_EFI_STUB) += $( objtree) /drivers/firmware/efi/libstub/lib.a
2012-04-20 17:45:54 +04:00
# Default target when executing plain make
2016-11-23 00:34:29 +03:00
boot := arch/arm64/boot
KBUILD_IMAGE := $( boot) /Image.gz
2012-12-04 03:17:21 +04:00
KBUILD_DTBS := dtbs
2012-04-20 17:45:54 +04:00
2016-11-23 00:34:29 +03:00
all : Image .gz $( KBUILD_DTBS )
2012-04-20 17:45:54 +04:00
2015-07-16 23:26:16 +03:00
Image : vmlinux
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2016-06-21 04:44:00 +03:00
Image.% : Image
2012-12-04 03:17:21 +04:00
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2012-04-20 17:45:54 +04:00
2016-02-19 09:05:50 +03:00
zinstall install :
2012-12-04 03:17:21 +04:00
$( Q) $( MAKE) $( build) = $( boot) $@
2012-04-20 17:45:54 +04:00
2012-12-04 03:17:21 +04:00
%.dtb : scripts
$( Q) $( MAKE) $( build) = $( boot) /dts $( boot) /dts/$@
2014-08-29 16:17:02 +04:00
PHONY += dtbs dtbs_install
2014-09-03 17:29:24 +04:00
dtbs : prepare scripts
2014-09-03 17:54:55 +04:00
$( Q) $( MAKE) $( build) = $( boot) /dts
2012-04-20 17:45:54 +04:00
2014-09-03 17:29:24 +04:00
dtbs_install :
$( Q) $( MAKE) $( dtbinst) = $( boot) /dts
2013-06-16 23:32:44 +04:00
PHONY += vdso_install
vdso_install :
$( Q) $( MAKE) $( build) = arch/arm64/kernel/vdso $@
2012-04-20 17:45:54 +04:00
# We use MRPROPER_FILES and CLEAN_FILES now
archclean :
$( Q) $( MAKE) $( clean) = $( boot)
2015-01-19 17:57:00 +03:00
$( Q) $( MAKE) $( clean) = $( boot) /dts
2012-04-20 17:45:54 +04:00
arm64: fix vdso-offsets.h dependency
arm64/kernel/{vdso,signal}.c include vdso-offsets.h, as well as any
file that includes asm/vdso.h. Therefore, vdso-offsets.h must be
generated before these files are compiled.
The current rules in arm64/kernel/Makefile do not actually enforce
this, because even though $(obj)/vdso is listed as a prerequisite for
vdso-offsets.h, this does not result in the intended effect of
building the vdso subdirectory (before all the other objects). As a
consequence, depending on the order in which the rules are followed,
vdso-offsets.h is updated or not before arm64/kernel/{vdso,signal}.o
are built. The current rules also impose an unnecessary dependency on
vdso-offsets.h for all arm64/kernel/*.o, resulting in unnecessary
rebuilds. This is made obvious when using make -j:
touch arch/arm64/kernel/vdso/gettimeofday.S && make -j$NCPUS arch/arm64/kernel
will sometimes result in none of arm64/kernel/*.o being
rebuilt, sometimes all of them, or even just some of them.
It is quite difficult to ensure that a header is generated before it
is used with recursive Makefiles by using normal rules. Instead,
arch-specific generated headers are normally built in the archprepare
recipe in the arch Makefile (see for instance arch/ia64/Makefile).
Unfortunately, asm-offsets.h is included in gettimeofday.S, and must
therefore be generated before vdso-offsets.h, which is not the case if
archprepare is used. For this reason, a rule run after archprepare has
to be used.
This commit adds rules in arm64/Makefile to build vdso-offsets.h
during the prepare step, ensuring that vdso-offsets.h is generated
before building anything. It also removes the now-unnecessary
dependencies on vdso-offsets.h in arm64/kernel/Makefile. Finally, it
removes the duplication of asm-offsets.h between arm64/kernel/vdso/
and include/generated/ and makes include/generated/vdso-offsets.h a
target in arm64/kernel/vdso/Makefile.
Cc: Will Deacon <will.deacon@arm.com>
Cc: Michal Marek <mmarek@suse.com>
Signed-off-by: Kevin Brodsky <kevin.brodsky@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2016-05-12 19:39:15 +03:00
# 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 : prepare 0
$( Q) $( MAKE) $( build) = arch/arm64/kernel/vdso include/generated/vdso-offsets.h
2012-04-20 17:45:54 +04:00
d e f i n e a r c h h e l p
echo '* Image.gz - Compressed kernel image (arch/$(ARCH)/boot/Image.gz)'
echo ' Image - Uncompressed kernel image (arch/$(ARCH)/boot/Image)'
2012-12-04 03:17:21 +04:00
echo '* dtbs - Build device tree blobs for enabled boards'
2014-08-29 16:17:02 +04:00
echo ' dtbs_install - Install dtbs to $(INSTALL_DTBS_PATH)'
2012-04-20 17:45:54 +04:00
echo ' install - Install uncompressed kernel'
echo ' zinstall - Install compressed kernel'
echo ' Install using (your) ~/bin/installkernel or'
echo ' (distribution) /sbin/installkernel or'
echo ' install to $$(INSTALL_PATH) and run lilo'
e n d e f