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
2018-06-27 22:46:14 +03:00
LDFLAGS_vmlinux := --no-undefined -X
2012-04-20 17:45:54 +04:00
CPPFLAGS_vmlinux.lds = -DTEXT_OFFSET= $( TEXT_OFFSET)
GZFLAGS := -9
arm64: prevent regressions in compressed kernel image size when upgrading to binutils 2.27
Upon upgrading to binutils 2.27, we found that our lz4 and gzip
compressed kernel images were significantly larger, resulting is 10ms
boot time regressions.
As noted by Rahul:
"aarch64 binaries uses RELA relocations, where each relocation entry
includes an addend value. This is similar to x86_64. On x86_64, the
addend values are also stored at the relocation offset for relative
relocations. This is an optimization: in the case where code does not
need to be relocated, the loader can simply skip processing relative
relocations. In binutils-2.25, both bfd and gold linkers did this for
x86_64, but only the gold linker did this for aarch64. The kernel build
here is using the bfd linker, which stored zeroes at the relocation
offsets for relative relocations. Since a set of zeroes compresses
better than a set of non-zero addend values, this behavior was resulting
in much better lz4 compression.
The bfd linker in binutils-2.27 is now storing the actual addend values
at the relocation offsets. The behavior is now consistent with what it
does for x86_64 and what gold linker does for both architectures. The
change happened in this upstream commit:
https://sourceware.org/git/?p=binutils-gdb.git;a=commit;h=1f56df9d0d5ad89806c24e71f296576d82344613
Since a bunch of zeroes got replaced by non-zero addend values, we see
the side effect of lz4 compressed image being a bit bigger.
To get the old behavior from the bfd linker, "--no-apply-dynamic-relocs"
flag can be used:
$ LDFLAGS="--no-apply-dynamic-relocs" make
With this flag, the compressed image size is back to what it was with
binutils-2.25.
If the kernel is using ASLR, there aren't additional runtime costs to
--no-apply-dynamic-relocs, as the relocations will need to be applied
again anyway after the kernel is relocated to a random address.
If the kernel is not using ASLR, then presumably the current default
behavior of the linker is better. Since the static linker performed the
dynamic relocs, and the kernel is not moved to a different address at
load time, it can skip applying the relocations all over again."
Some measurements:
$ ld -v
GNU ld (binutils-2.25-f3d35cf6) 2.25.51.20141117
^
$ ls -l vmlinux
-rwxr-x--- 1 ndesaulniers eng 300652760 Oct 26 11:57 vmlinux
$ ls -l Image.lz4-dtb
-rw-r----- 1 ndesaulniers eng 16932627 Oct 26 11:57 Image.lz4-dtb
$ ld -v
GNU ld (binutils-2.27-53dd00a1) 2.27.0.20170315
^
pre patch:
$ ls -l vmlinux
-rwxr-x--- 1 ndesaulniers eng 300376208 Oct 26 11:43 vmlinux
$ ls -l Image.lz4-dtb
-rw-r----- 1 ndesaulniers eng 18159474 Oct 26 11:43 Image.lz4-dtb
post patch:
$ ls -l vmlinux
-rwxr-x--- 1 ndesaulniers eng 300376208 Oct 26 12:06 vmlinux
$ ls -l Image.lz4-dtb
-rw-r----- 1 ndesaulniers eng 16932466 Oct 26 12:06 Image.lz4-dtb
By Siqi's measurement w/ gzip:
binutils 2.27 with this patch (with --no-apply-dynamic-relocs):
Image 41535488
Image.gz 13404067
binutils 2.27 without this patch (without --no-apply-dynamic-relocs):
Image 41535488
Image.gz 14125516
Any compression scheme should be able to get better results from the
longer runs of zeros, not just GZIP and LZ4.
10ms boot time savings isn't anything to get excited about, but users of
arm64+compression+bfd-2.27 should not have to pay a penalty for no
runtime improvement.
Reported-by: Gopinath Elanchezhian <gelanchezhian@google.com>
Reported-by: Sindhuri Pentyala <spentyala@google.com>
Reported-by: Wei Wang <wvw@google.com>
Suggested-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Suggested-by: Rahul Chaudhry <rahulchaudhry@google.com>
Suggested-by: Siqi Lin <siqilin@google.com>
Suggested-by: Stephen Hines <srhines@google.com>
Signed-off-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
[will: added comment to Makefile]
Signed-off-by: Will Deacon <will.deacon@arm.com>
2017-10-27 19:33:41 +03:00
i f e q ( $( CONFIG_RELOCATABLE ) , y )
# Pass --no-apply-dynamic-relocs to restore pre-binutils-2.27 behaviour
# for relative relocs, since this leads to better Image compression
# with the relocation offsets always being zero.
LDFLAGS_vmlinux += -pie -shared -Bsymbolic \
$( call ld-option, --no-apply-dynamic-relocs)
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-12-06 18:27:43 +03:00
KBUILD_AFLAGS += $( lseinstr) $( brokengasinst)
2015-02-03 19:14:13 +03:00
2017-09-18 13:20:20 +03:00
KBUILD_CFLAGS += $( call cc-option,-mabi= lp64)
KBUILD_AFLAGS += $( call cc-option,-mabi= lp64)
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
2018-07-13 18:30:33 +03:00
# Prefer the baremetal ELF build target, but not all toolchains include
# it so fall back to the standard linux version if needed.
2018-08-24 02:20:39 +03:00
KBUILD_LDFLAGS += -EB $( call ld-option, -maarch64elfb, -maarch64linuxb)
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
2018-07-13 18:30:33 +03:00
# Same as above, prefer ELF but fall back to linux target if needed.
2018-08-24 02:20:39 +03:00
KBUILD_LDFLAGS += -EL $( call ld-option, -maarch64elf, -maarch64linux)
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
2018-05-30 23:48:38 +03:00
CHECKFLAGS += -D__aarch64__
2012-04-20 17:45:54 +04:00
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
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
2018-03-01 20:07:12 +03:00
# KASAN_SHADOW_OFFSET = VA_START + (1 << (VA_BITS - KASAN_SHADOW_SCALE_SHIFT))
# - (1 << (64 - KASAN_SHADOW_SCALE_SHIFT))
2015-10-12 18:52:58 +03:00
# in 32-bit arithmetic
2018-03-01 20:07:12 +03:00
KASAN_SHADOW_SCALE_SHIFT := 3
2015-10-12 18:52:58 +03:00
KASAN_SHADOW_OFFSET := $( shell printf "0x%08x00000000\n" $$ ( ( \
2018-03-01 20:07:12 +03:00
( 0xffffffff & ( -1 << ( $( CONFIG_ARM64_VA_BITS) - 32) ) ) \
+ ( 1 << ( $( CONFIG_ARM64_VA_BITS) - 32 - $( KASAN_SHADOW_SCALE_SHIFT) ) ) \
- ( 1 << ( 64 - 32 - $( KASAN_SHADOW_SCALE_SHIFT) ) ) ) ) )
2015-10-12 18:52:58 +03:00
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