License cleanup: add SPDX GPL-2.0 license identifier to files with no license
Many source files in the tree are missing licensing information, which
makes it harder for compliance tools to determine the correct license.
By default all files without license information are under the default
license of the kernel, which is GPL version 2.
Update the files which contain no license information with the 'GPL-2.0'
SPDX license identifier. The SPDX identifier is a legally binding
shorthand, which can be used instead of the full boiler plate text.
This patch is based on work done by Thomas Gleixner and Kate Stewart and
Philippe Ombredanne.
How this work was done:
Patches were generated and checked against linux-4.14-rc6 for a subset of
the use cases:
- file had no licensing information it it.
- file was a */uapi/* one with no licensing information in it,
- file was a */uapi/* one with existing licensing information,
Further patches will be generated in subsequent months to fix up cases
where non-standard license headers were used, and references to license
had to be inferred by heuristics based on keywords.
The analysis to determine which SPDX License Identifier to be applied to
a file was done in a spreadsheet of side by side results from of the
output of two independent scanners (ScanCode & Windriver) producing SPDX
tag:value files created by Philippe Ombredanne. Philippe prepared the
base worksheet, and did an initial spot review of a few 1000 files.
The 4.13 kernel was the starting point of the analysis with 60,537 files
assessed. Kate Stewart did a file by file comparison of the scanner
results in the spreadsheet to determine which SPDX license identifier(s)
to be applied to the file. She confirmed any determination that was not
immediately clear with lawyers working with the Linux Foundation.
Criteria used to select files for SPDX license identifier tagging was:
- Files considered eligible had to be source code files.
- Make and config files were included as candidates if they contained >5
lines of source
- File already had some variant of a license header in it (even if <5
lines).
All documentation files were explicitly excluded.
The following heuristics were used to determine which SPDX license
identifiers to apply.
- when both scanners couldn't find any license traces, file was
considered to have no license information in it, and the top level
COPYING file license applied.
For non */uapi/* files that summary was:
SPDX license identifier # files
---------------------------------------------------|-------
GPL-2.0 11139
and resulted in the first patch in this series.
If that file was a */uapi/* path one, it was "GPL-2.0 WITH
Linux-syscall-note" otherwise it was "GPL-2.0". Results of that was:
SPDX license identifier # files
---------------------------------------------------|-------
GPL-2.0 WITH Linux-syscall-note 930
and resulted in the second patch in this series.
- if a file had some form of licensing information in it, and was one
of the */uapi/* ones, it was denoted with the Linux-syscall-note if
any GPL family license was found in the file or had no licensing in
it (per prior point). Results summary:
SPDX license identifier # files
---------------------------------------------------|------
GPL-2.0 WITH Linux-syscall-note 270
GPL-2.0+ WITH Linux-syscall-note 169
((GPL-2.0 WITH Linux-syscall-note) OR BSD-2-Clause) 21
((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) 17
LGPL-2.1+ WITH Linux-syscall-note 15
GPL-1.0+ WITH Linux-syscall-note 14
((GPL-2.0+ WITH Linux-syscall-note) OR BSD-3-Clause) 5
LGPL-2.0+ WITH Linux-syscall-note 4
LGPL-2.1 WITH Linux-syscall-note 3
((GPL-2.0 WITH Linux-syscall-note) OR MIT) 3
((GPL-2.0 WITH Linux-syscall-note) AND MIT) 1
and that resulted in the third patch in this series.
- when the two scanners agreed on the detected license(s), that became
the concluded license(s).
- when there was disagreement between the two scanners (one detected a
license but the other didn't, or they both detected different
licenses) a manual inspection of the file occurred.
- In most cases a manual inspection of the information in the file
resulted in a clear resolution of the license that should apply (and
which scanner probably needed to revisit its heuristics).
- When it was not immediately clear, the license identifier was
confirmed with lawyers working with the Linux Foundation.
- If there was any question as to the appropriate license identifier,
the file was flagged for further research and to be revisited later
in time.
In total, over 70 hours of logged manual review was done on the
spreadsheet to determine the SPDX license identifiers to apply to the
source files by Kate, Philippe, Thomas and, in some cases, confirmation
by lawyers working with the Linux Foundation.
Kate also obtained a third independent scan of the 4.13 code base from
FOSSology, and compared selected files where the other two scanners
disagreed against that SPDX file, to see if there was new insights. The
Windriver scanner is based on an older version of FOSSology in part, so
they are related.
Thomas did random spot checks in about 500 files from the spreadsheets
for the uapi headers and agreed with SPDX license identifier in the
files he inspected. For the non-uapi files Thomas did random spot checks
in about 15000 files.
In initial set of patches against 4.14-rc6, 3 files were found to have
copy/paste license identifier errors, and have been fixed to reflect the
correct identifier.
Additionally Philippe spent 10 hours this week doing a detailed manual
inspection and review of the 12,461 patched files from the initial patch
version early this week with:
- a full scancode scan run, collecting the matched texts, detected
license ids and scores
- reviewing anything where there was a license detected (about 500+
files) to ensure that the applied SPDX license was correct
- reviewing anything where there was no detection but the patch license
was not GPL-2.0 WITH Linux-syscall-note to ensure that the applied
SPDX license was correct
This produced a worksheet with 20 files needing minor correction. This
worksheet was then exported into 3 different .csv files for the
different types of files to be modified.
These .csv files were then reviewed by Greg. Thomas wrote a script to
parse the csv files and add the proper SPDX tag to the file, in the
format that the file expected. This script was further refined by Greg
based on the output to detect more types of files automatically and to
distinguish between header and source .c files (which need different
comment types.) Finally Greg ran the script using the .csv files to
generate the patches.
Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org>
Reviewed-by: Philippe Ombredanne <pombredanne@nexb.com>
Reviewed-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2017-11-01 17:07:57 +03:00
/* SPDX-License-Identifier: GPL-2.0 */
2012-04-20 17:45:54 +04:00
/ *
* ld s c r i p t t o m a k e A R M L i n u x k e r n e l
* taken f r o m t h e i 3 8 6 v e r s i o n b y R u s s e l l K i n g
* Written b y M a r t i n M a r e s < m j @atrey.karlin.mff.cuni.cz>
* /
# include < a s m - g e n e r i c / v m l i n u x . l d s . h >
2015-12-01 15:20:40 +03:00
# include < a s m / c a c h e . h >
2015-10-19 16:19:27 +03:00
# include < a s m / k e r n e l - p g t a b l e . h >
2012-04-20 17:45:54 +04:00
# include < a s m / t h r e a d _ i n f o . h >
# include < a s m / m e m o r y . h >
# include < a s m / p a g e . h >
2015-01-22 04:36:06 +03:00
# include < a s m / p g t a b l e . h >
2012-04-20 17:45:54 +04:00
arm64: Update the Image header
Currently the kernel Image is stripped of everything past the initial
stack, and at runtime the memory is initialised and used by the kernel.
This makes the effective minimum memory footprint of the kernel larger
than the size of the loaded binary, though bootloaders have no mechanism
to identify how large this minimum memory footprint is. This makes it
difficult to choose safe locations to place both the kernel and other
binaries required at boot (DTB, initrd, etc), such that the kernel won't
clobber said binaries or other reserved memory during initialisation.
Additionally when big endian support was added the image load offset was
overlooked, and is currently of an arbitrary endianness, which makes it
difficult for bootloaders to make use of it. It seems that bootloaders
aren't respecting the image load offset at present anyway, and are
assuming that offset 0x80000 will always be correct.
This patch adds an effective image size to the kernel header which
describes the amount of memory from the start of the kernel Image binary
which the kernel expects to use before detecting memory and handling any
memory reservations. This can be used by bootloaders to choose suitable
locations to load the kernel and/or other binaries such that the kernel
will not clobber any memory unexpectedly. As before, memory reservations
are required to prevent the kernel from clobbering these locations
later.
Both the image load offset and the effective image size are forced to be
little-endian regardless of the native endianness of the kernel to
enable bootloaders to load a kernel of arbitrary endianness. Bootloaders
which wish to make use of the load offset can inspect the effective
image size field for a non-zero value to determine if the offset is of a
known endianness. To enable software to determine the endinanness of the
kernel as may be required for certain use-cases, a new flags field (also
little-endian) is added to the kernel header to export this information.
The documentation is updated to clarify these details. To discourage
future assumptions regarding the value of text_offset, the value at this
point in time is removed from the main flow of the documentation (though
kept as a compatibility note). Some minor formatting issues in the
documentation are also corrected.
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Acked-by: Tom Rini <trini@ti.com>
Cc: Geoff Levand <geoff@infradead.org>
Cc: Kevin Hilman <kevin.hilman@linaro.org>
Acked-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2014-06-24 19:51:36 +04:00
# include " i m a g e . h "
2014-11-25 18:26:13 +03:00
/* .exit.text needed in case of alternative patching */
# define A R M _ E X I T _ K E E P ( x ) x
# define A R M _ E X I T _ D I S C A R D ( x )
2012-04-20 17:45:54 +04:00
OUTPUT_ A R C H ( a a r c h64 )
2014-05-16 21:26:01 +04:00
ENTRY( _ t e x t )
2012-04-20 17:45:54 +04:00
jiffies = j i f f i e s _ 6 4 ;
2012-12-07 22:40:43 +04:00
# define H Y P E R V I S O R _ T E X T \
/ * \
ARM, arm64: kvm: get rid of the bounce page
The HYP init bounce page is a runtime construct that ensures that the
HYP init code does not cross a page boundary. However, this is something
we can do perfectly well at build time, by aligning the code appropriately.
For arm64, we just align to 4 KB, and enforce that the code size is less
than 4 KB, regardless of the chosen page size.
For ARM, the whole code is less than 256 bytes, so we tweak the linker
script to align at a power of 2 upper bound of the code size
Note that this also fixes a benign off-by-one error in the original bounce
page code, where a bounce page would be allocated unnecessarily if the code
was exactly 1 page in size.
On ARM, it also fixes an issue with very large kernels reported by Arnd
Bergmann, where stub sections with linker emitted veneers could erroneously
trigger the size/alignment ASSERT() in the linker script.
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2015-03-19 19:42:26 +03:00
* Align t o 4 K B s o t h a t \
* a) t h e H Y P v e c t o r t a b l e i s a t i t s m i n i m u m \
* alignment o f 2 0 4 8 b y t e s \
* b) t h e H Y P i n i t c o d e w i l l n o t c r o s s a p a g e \
* boundary i f i t s s i z e d o e s n o t e x c e e d \
* 4 KB ( s e e r e l a t e d A S S E R T ( ) b e l o w ) \
2012-12-07 22:40:43 +04:00
* / \
ARM, arm64: kvm: get rid of the bounce page
The HYP init bounce page is a runtime construct that ensures that the
HYP init code does not cross a page boundary. However, this is something
we can do perfectly well at build time, by aligning the code appropriately.
For arm64, we just align to 4 KB, and enforce that the code size is less
than 4 KB, regardless of the chosen page size.
For ARM, the whole code is less than 256 bytes, so we tweak the linker
script to align at a power of 2 upper bound of the code size
Note that this also fixes a benign off-by-one error in the original bounce
page code, where a bounce page would be allocated unnecessarily if the code
was exactly 1 page in size.
On ARM, it also fixes an issue with very large kernels reported by Arnd
Bergmann, where stub sections with linker emitted veneers could erroneously
trigger the size/alignment ASSERT() in the linker script.
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2015-03-19 19:42:26 +03:00
. = ALIGN( S Z _ 4 K ) ; \
2012-12-07 22:40:43 +04:00
VMLINUX_ S Y M B O L ( _ _ h y p _ i d m a p _ t e x t _ s t a r t ) = . ; \
* ( .hyp .idmap .text ) \
VMLINUX_ S Y M B O L ( _ _ h y p _ i d m a p _ t e x t _ e n d ) = . ; \
VMLINUX_ S Y M B O L ( _ _ h y p _ t e x t _ s t a r t ) = . ; \
* ( .hyp .text ) \
VMLINUX_ S Y M B O L ( _ _ h y p _ t e x t _ e n d ) = . ;
2015-06-01 14:40:33 +03:00
# define I D M A P _ T E X T \
. = ALIGN( S Z _ 4 K ) ; \
VMLINUX_ S Y M B O L ( _ _ i d m a p _ t e x t _ s t a r t ) = . ; \
* ( .idmap .text ) \
VMLINUX_ S Y M B O L ( _ _ i d m a p _ t e x t _ e n d ) = . ;
2016-04-27 19:47:12 +03:00
# ifdef C O N F I G _ H I B E R N A T I O N
# define H I B E R N A T E _ T E X T \
. = ALIGN( S Z _ 4 K ) ; \
VMLINUX_ S Y M B O L ( _ _ h i b e r n a t e _ e x i t _ t e x t _ s t a r t ) = . ;\
* ( .hibernate_exit .text ) \
VMLINUX_ S Y M B O L ( _ _ h i b e r n a t e _ e x i t _ t e x t _ e n d ) = . ;
# else
# define H I B E R N A T E _ T E X T
# endif
2017-11-14 17:07:40 +03:00
# ifdef C O N F I G _ U N M A P _ K E R N E L _ A T _ E L 0
# define T R A M P _ T E X T \
. = ALIGN( P A G E _ S I Z E ) ; \
VMLINUX_ S Y M B O L ( _ _ e n t r y _ t r a m p _ t e x t _ s t a r t ) = . ; \
* ( .entry .tramp .text ) \
. = ALIGN( P A G E _ S I Z E ) ; \
VMLINUX_ S Y M B O L ( _ _ e n t r y _ t r a m p _ t e x t _ e n d ) = . ;
# else
# define T R A M P _ T E X T
# endif
2014-10-10 20:42:55 +04:00
/ *
* The s i z e o f t h e P E / C O F F s e c t i o n t h a t c o v e r s t h e k e r n e l i m a g e , w h i c h
* runs f r o m s t e x t t o _ e d a t a , m u s t b e a r o u n d m u l t i p l e o f t h e P E / C O F F
* FileAlignment, w h i c h w e s e t t o i t s m i n i m u m v a l u e o f 0 x20 0 . ' s t e x t '
* itself i s 4 K B a l i g n e d , s o p a d d i n g o u t _ e d a t a t o a 0 x20 0 a l i g n e d
* boundary s h o u l d b e s u f f i c i e n t .
* /
PECOFF_ F I L E _ A L I G N M E N T = 0 x20 0 ;
# ifdef C O N F I G _ E F I
# define P E C O F F _ E D A T A _ P A D D I N G \
.pecoff_edata_padding : { BYTE( 0 ) ; . = ALIGN(PECOFF_FILE_ALIGNMENT); }
# else
# define P E C O F F _ E D A T A _ P A D D I N G
# endif
2012-04-20 17:45:54 +04:00
SECTIONS
{
/ *
* XXX : The l i n k e r d o e s n o t d e f i n e h o w o u t p u t s e c t i o n s a r e
* assigned t o i n p u t s e c t i o n s w h e n t h e r e a r e m u l t i p l e s t a t e m e n t s
* matching t h e s a m e i n p u t s e c t i o n n a m e . T h e r e i s n o d o c u m e n t e d
* order o f m a t c h i n g .
* /
/ DISCARD/ : {
ARM_ E X I T _ D I S C A R D ( E X I T _ T E X T )
ARM_ E X I T _ D I S C A R D ( E X I T _ D A T A )
EXIT_ C A L L
* ( .discard )
* ( .discard . * )
2016-01-26 11:13:44 +03:00
* ( .interp .dynamic )
arm64: relocatable: suppress R_AARCH64_ABS64 relocations in vmlinux
The linker routines that we rely on to produce a relocatable PIE binary
treat it as a shared ELF object in some ways, i.e., it emits symbol based
R_AARCH64_ABS64 relocations into the final binary since doing so would be
appropriate when linking a shared library that is subject to symbol
preemption. (This means that an executable can override certain symbols
that are exported by a shared library it is linked with, and that the
shared library *must* update all its internal references as well, and point
them to the version provided by the executable.)
Symbol preemption does not occur for OS hosted PIE executables, let alone
for vmlinux, and so we would prefer to get rid of these symbol based
relocations. This would allow us to simplify the relocation routines, and
to strip the .dynsym, .dynstr and .hash sections from the binary. (Note
that these are tiny, and are placed in the .init segment, but they clutter
up the vmlinux binary.)
Note that these R_AARCH64_ABS64 relocations are only emitted for absolute
references to symbols defined in the linker script, all other relocatable
quantities are covered by anonymous R_AARCH64_RELATIVE relocations that
simply list the offsets to all 64-bit values in the binary that need to be
fixed up based on the offset between the link time and run time addresses.
Fortunately, GNU ld has a -Bsymbolic option, which is intended for shared
libraries to allow them to ignore symbol preemption, and unconditionally
bind all internal symbol references to its own definitions. So set it for
our PIE binary as well, and get rid of the asoociated sections and the
relocation code that processes them.
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
[will: fixed conflict with __dynsym_offset linker script entry]
Signed-off-by: Will Deacon <will.deacon@arm.com>
2016-07-24 15:00:13 +03:00
* ( .dynsym .dynstr .hash )
2012-04-20 17:45:54 +04:00
}
2016-02-16 15:52:36 +03:00
. = KIMAGE_ V A D D R + T E X T _ O F F S E T ;
2012-04-20 17:45:54 +04:00
.head .text : {
_ text = . ;
HEAD_ T E X T
}
.text : { /* Real text segment */
_ stext = . ; /* Text and read-only data */
_ _ exception_ t e x t _ s t a r t = . ;
* ( .exception .text )
_ _ exception_ t e x t _ e n d = . ;
IRQENTRY_ T E X T
2016-03-26 00:22:05 +03:00
SOFTIRQENTRY_ T E X T
2016-07-08 19:35:50 +03:00
ENTRY_ T E X T
2012-04-20 17:45:54 +04:00
TEXT_ T E X T
SCHED_ T E X T
2016-10-08 03:02:55 +03:00
CPUIDLE_ T E X T
2012-04-20 17:45:54 +04:00
LOCK_ T E X T
arm64: Kprobes with single stepping support
Add support for basic kernel probes(kprobes) and jump probes
(jprobes) for ARM64.
Kprobes utilizes software breakpoint and single step debug
exceptions supported on ARM v8.
A software breakpoint is placed at the probe address to trap the
kernel execution into the kprobe handler.
ARM v8 supports enabling single stepping before the break exception
return (ERET), with next PC in exception return address (ELR_EL1). The
kprobe handler prepares an executable memory slot for out-of-line
execution with a copy of the original instruction being probed, and
enables single stepping. The PC is set to the out-of-line slot address
before the ERET. With this scheme, the instruction is executed with the
exact same register context except for the PC (and DAIF) registers.
Debug mask (PSTATE.D) is enabled only when single stepping a recursive
kprobe, e.g.: during kprobes reenter so that probed instruction can be
single stepped within the kprobe handler -exception- context.
The recursion depth of kprobe is always 2, i.e. upon probe re-entry,
any further re-entry is prevented by not calling handlers and the case
counted as a missed kprobe).
Single stepping from the x-o-l slot has a drawback for PC-relative accesses
like branching and symbolic literals access as the offset from the new PC
(slot address) may not be ensured to fit in the immediate value of
the opcode. Such instructions need simulation, so reject
probing them.
Instructions generating exceptions or cpu mode change are rejected
for probing.
Exclusive load/store instructions are rejected too. Additionally, the
code is checked to see if it is inside an exclusive load/store sequence
(code from Pratyush).
System instructions are mostly enabled for stepping, except MSR/MRS
accesses to "DAIF" flags in PSTATE, which are not safe for
probing.
This also changes arch/arm64/include/asm/ptrace.h to use
include/asm-generic/ptrace.h.
Thanks to Steve Capper and Pratyush Anand for several suggested
Changes.
Signed-off-by: Sandeepa Prabhu <sandeepa.s.prabhu@gmail.com>
Signed-off-by: David A. Long <dave.long@linaro.org>
Signed-off-by: Pratyush Anand <panand@redhat.com>
Acked-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2016-07-08 19:35:48 +03:00
KPROBES_ T E X T
2012-12-07 22:40:43 +04:00
HYPERVISOR_ T E X T
2015-06-01 14:40:33 +03:00
IDMAP_ T E X T
2016-04-27 19:47:12 +03:00
HIBERNATE_ T E X T
2017-11-14 17:07:40 +03:00
TRAMP_ T E X T
2012-04-20 17:45:54 +04:00
* ( .fixup )
* ( .gnu .warning )
. = ALIGN( 1 6 ) ;
* ( .got ) /* Global offset table */
}
arm64: simplify kernel segment mapping granularity
The mapping of the kernel consist of four segments, each of which is mapped
with different permission attributes and/or lifetimes. To optimize the TLB
and translation table footprint, we define various opaque constants in the
linker script that resolve to different aligment values depending on the
page size and whether CONFIG_DEBUG_ALIGN_RODATA is set.
Considering that
- a 4 KB granule kernel benefits from a 64 KB segment alignment (due to
the fact that it allows the use of the contiguous bit),
- the minimum alignment of the .data segment is THREAD_SIZE already, not
PAGE_SIZE (i.e., we already have padding between _data and the start of
the .data payload in many cases),
- 2 MB is a suitable alignment value on all granule sizes, either for
mapping directly (level 2 on 4 KB), or via the contiguous bit (level 3 on
16 KB and 64 KB),
- anything beyond 2 MB exceeds the minimum alignment mandated by the boot
protocol, and can only be mapped efficiently if the physical alignment
happens to be the same,
we can simplify this by standardizing on 64 KB (or 2 MB) explicitly, i.e.,
regardless of granule size, all segments are aligned either to 64 KB, or to
2 MB if CONFIG_DEBUG_ALIGN_RODATA=y. This also means we can drop the Kconfig
dependency of CONFIG_DEBUG_ALIGN_RODATA on CONFIG_ARM64_4K_PAGES.
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2016-03-30 18:43:09 +03:00
. = ALIGN( S E G M E N T _ A L I G N ) ;
arm64: mm: fix location of _etext
As Kees Cook notes in the ARM counterpart of this patch [0]:
The _etext position is defined to be the end of the kernel text code,
and should not include any part of the data segments. This interferes
with things that might check memory ranges and expect executable code
up to _etext.
In particular, Kees is referring to the HARDENED_USERCOPY patch set [1],
which rejects attempts to call copy_to_user() on kernel ranges containing
executable code, but does allow access to the .rodata segment. Regardless
of whether one may or may not agree with the distinction, it makes sense
for _etext to have the same meaning across architectures.
So let's put _etext where it belongs, between .text and .rodata, and fix
up existing references to use __init_begin instead, which unlike _end_rodata
includes the exception and notes sections as well.
The _etext references in kaslr.c are left untouched, since its references
to [_stext, _etext) are meant to capture potential jump instruction targets,
and so disregarding .rodata is actually an improvement here.
[0] http://article.gmane.org/gmane.linux.kernel/2245084
[1] http://thread.gmane.org/gmane.linux.kernel.hardened.devel/2502
Reported-by: Kees Cook <keescook@chromium.org>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2016-06-23 16:53:17 +03:00
_ etext = . ; /* End of text section */
RO_ D A T A ( P A G E _ S I Z E ) / * e v e r y t h i n g f r o m t h i s p o i n t t o * /
EXCEPTION_ T A B L E ( 8 ) / * _ _ i n i t _ b e g i n w i l l b e m a r k e d R O N X * /
2013-08-23 19:16:42 +04:00
NOTES
2012-04-20 17:45:54 +04:00
arm64: simplify kernel segment mapping granularity
The mapping of the kernel consist of four segments, each of which is mapped
with different permission attributes and/or lifetimes. To optimize the TLB
and translation table footprint, we define various opaque constants in the
linker script that resolve to different aligment values depending on the
page size and whether CONFIG_DEBUG_ALIGN_RODATA is set.
Considering that
- a 4 KB granule kernel benefits from a 64 KB segment alignment (due to
the fact that it allows the use of the contiguous bit),
- the minimum alignment of the .data segment is THREAD_SIZE already, not
PAGE_SIZE (i.e., we already have padding between _data and the start of
the .data payload in many cases),
- 2 MB is a suitable alignment value on all granule sizes, either for
mapping directly (level 2 on 4 KB), or via the contiguous bit (level 3 on
16 KB and 64 KB),
- anything beyond 2 MB exceeds the minimum alignment mandated by the boot
protocol, and can only be mapped efficiently if the physical alignment
happens to be the same,
we can simplify this by standardizing on 64 KB (or 2 MB) explicitly, i.e.,
regardless of granule size, all segments are aligned either to 64 KB, or to
2 MB if CONFIG_DEBUG_ALIGN_RODATA=y. This also means we can drop the Kconfig
dependency of CONFIG_DEBUG_ALIGN_RODATA on CONFIG_ARM64_4K_PAGES.
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2016-03-30 18:43:09 +03:00
. = ALIGN( S E G M E N T _ A L I G N ) ;
2012-04-20 17:45:54 +04:00
_ _ init_ b e g i n = . ;
2017-03-09 23:52:03 +03:00
_ _ inittext_ b e g i n = . ;
2012-04-20 17:45:54 +04:00
INIT_ T E X T _ S E C T I O N ( 8 )
.exit .text : {
ARM_ E X I T _ K E E P ( E X I T _ T E X T )
}
2015-01-22 04:36:06 +03:00
2017-03-09 23:52:03 +03:00
. = ALIGN( 4 ) ;
.altinstructions : {
_ _ alt_ i n s t r u c t i o n s = . ;
* ( .altinstructions )
_ _ alt_ i n s t r u c t i o n s _ e n d = . ;
}
.altinstr_replacement : {
* ( .altinstr_replacement )
}
. = ALIGN( P A G E _ S I Z E ) ;
_ _ inittext_ e n d = . ;
_ _ initdata_ b e g i n = . ;
2012-04-20 17:45:54 +04:00
.init .data : {
INIT_ D A T A
INIT_ S E T U P ( 1 6 )
INIT_ C A L L S
CON_ I N I T C A L L
SECURITY_ I N I T C A L L
INIT_ R A M _ F S
2016-02-17 15:35:58 +03:00
* ( .init .rodata . * .init .bss ) /* from the EFI stub */
2012-04-20 17:45:54 +04:00
}
.exit .data : {
ARM_ E X I T _ K E E P ( E X I T _ D A T A )
}
2015-12-01 15:20:40 +03:00
PERCPU_ S E C T I O N ( L 1 _ C A C H E _ B Y T E S )
2012-04-20 17:45:54 +04:00
2016-01-26 11:13:44 +03:00
.rela : ALIGN( 8 ) {
* ( .rela .rela * )
}
2014-11-14 18:54:08 +03:00
2016-07-28 17:15:14 +03:00
_ _ rela_ o f f s e t = A B S O L U T E ( A D D R ( . r e l a ) - K I M A G E _ V A D D R ) ;
2016-04-18 18:09:43 +03:00
_ _ rela_ s i z e = S I Z E O F ( . r e l a ) ;
arm64: simplify kernel segment mapping granularity
The mapping of the kernel consist of four segments, each of which is mapped
with different permission attributes and/or lifetimes. To optimize the TLB
and translation table footprint, we define various opaque constants in the
linker script that resolve to different aligment values depending on the
page size and whether CONFIG_DEBUG_ALIGN_RODATA is set.
Considering that
- a 4 KB granule kernel benefits from a 64 KB segment alignment (due to
the fact that it allows the use of the contiguous bit),
- the minimum alignment of the .data segment is THREAD_SIZE already, not
PAGE_SIZE (i.e., we already have padding between _data and the start of
the .data payload in many cases),
- 2 MB is a suitable alignment value on all granule sizes, either for
mapping directly (level 2 on 4 KB), or via the contiguous bit (level 3 on
16 KB and 64 KB),
- anything beyond 2 MB exceeds the minimum alignment mandated by the boot
protocol, and can only be mapped efficiently if the physical alignment
happens to be the same,
we can simplify this by standardizing on 64 KB (or 2 MB) explicitly, i.e.,
regardless of granule size, all segments are aligned either to 64 KB, or to
2 MB if CONFIG_DEBUG_ALIGN_RODATA=y. This also means we can drop the Kconfig
dependency of CONFIG_DEBUG_ALIGN_RODATA on CONFIG_ARM64_4K_PAGES.
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2016-03-30 18:43:09 +03:00
. = ALIGN( S E G M E N T _ A L I G N ) ;
2017-03-09 23:52:03 +03:00
_ _ initdata_ e n d = . ;
2015-12-09 15:44:38 +03:00
_ _ init_ e n d = . ;
2013-11-04 20:38:47 +04:00
_ data = . ;
_ sdata = . ;
2017-07-21 16:25:33 +03:00
RW_ D A T A _ S E C T I O N ( L 1 _ C A C H E _ B Y T E S , P A G E _ S I Z E , T H R E A D _ A L I G N )
2016-08-24 20:27:29 +03:00
/ *
* Data w r i t t e n w i t h t h e M M U o f f b u t r e a d w i t h t h e M M U o n r e q u i r e s
* cache l i n e s t o b e i n v a l i d a t e d , d i s c a r d i n g u p t o a C a c h e W r i t e b a c k
* Granule ( C W G ) o f d a t a f r o m t h e c a c h e . K e e p t h e s e c t i o n t h a t
* requires t h i s t y p e o f m a i n t e n a n c e t o b e i n i t s o w n C a c h e W r i t e b a c k
* Granule ( C W G ) a r e a s o t h e c a c h e m a i n t e n a n c e o p e r a t i o n s d o n ' t
* interfere w i t h a d j a c e n t d a t a .
* /
.mmuoff .data .write : ALIGN( S Z _ 2 K ) {
_ _ mmuoff_ d a t a _ s t a r t = . ;
* ( .mmuoff .data .write )
}
. = ALIGN( S Z _ 2 K ) ;
.mmuoff .data .read : {
* ( .mmuoff .data .read )
_ _ mmuoff_ d a t a _ e n d = . ;
}
2014-10-10 20:42:55 +04:00
PECOFF_ E D A T A _ P A D D I N G
2017-03-23 22:00:51 +03:00
_ _ pecoff_ d a t a _ r a w s i z e = A B S O L U T E ( . - _ _ i n i t d a t a _ b e g i n ) ;
2013-11-04 20:38:47 +04:00
_ edata = . ;
2012-04-20 17:45:54 +04:00
BSS_ S E C T I O N ( 0 , 0 , 0 )
2014-06-24 19:51:35 +04:00
. = ALIGN( P A G E _ S I Z E ) ;
idmap_ p g _ d i r = . ;
. + = IDMAP_ D I R _ S I Z E ;
2018-01-11 13:11:58 +03:00
# ifdef C O N F I G _ U N M A P _ K E R N E L _ A T _ E L 0
tramp_ p g _ d i r = . ;
. + = PAGE_ S I Z E ;
# endif
2016-07-01 18:53:00 +03:00
# ifdef C O N F I G _ A R M 6 4 _ S W _ T T B R 0 _ P A N
reserved_ t t b r0 = . ;
. + = RESERVED_ T T B R 0 _ S I Z E ;
# endif
2018-01-11 13:11:57 +03:00
swapper_ p g _ d i r = . ;
. + = SWAPPER_ D I R _ S I Z E ;
2018-01-11 13:11:59 +03:00
swapper_ p g _ e n d = . ;
2016-07-01 18:53:00 +03:00
2017-03-23 22:00:51 +03:00
_ _ pecoff_ d a t a _ s i z e = A B S O L U T E ( . - _ _ i n i t d a t a _ b e g i n ) ;
2012-04-20 17:45:54 +04:00
_ end = . ;
STABS_ D E B U G
arm64: Update the Image header
Currently the kernel Image is stripped of everything past the initial
stack, and at runtime the memory is initialised and used by the kernel.
This makes the effective minimum memory footprint of the kernel larger
than the size of the loaded binary, though bootloaders have no mechanism
to identify how large this minimum memory footprint is. This makes it
difficult to choose safe locations to place both the kernel and other
binaries required at boot (DTB, initrd, etc), such that the kernel won't
clobber said binaries or other reserved memory during initialisation.
Additionally when big endian support was added the image load offset was
overlooked, and is currently of an arbitrary endianness, which makes it
difficult for bootloaders to make use of it. It seems that bootloaders
aren't respecting the image load offset at present anyway, and are
assuming that offset 0x80000 will always be correct.
This patch adds an effective image size to the kernel header which
describes the amount of memory from the start of the kernel Image binary
which the kernel expects to use before detecting memory and handling any
memory reservations. This can be used by bootloaders to choose suitable
locations to load the kernel and/or other binaries such that the kernel
will not clobber any memory unexpectedly. As before, memory reservations
are required to prevent the kernel from clobbering these locations
later.
Both the image load offset and the effective image size are forced to be
little-endian regardless of the native endianness of the kernel to
enable bootloaders to load a kernel of arbitrary endianness. Bootloaders
which wish to make use of the load offset can inspect the effective
image size field for a non-zero value to determine if the offset is of a
known endianness. To enable software to determine the endinanness of the
kernel as may be required for certain use-cases, a new flags field (also
little-endian) is added to the kernel header to export this information.
The documentation is updated to clarify these details. To discourage
future assumptions regarding the value of text_offset, the value at this
point in time is removed from the main flow of the documentation (though
kept as a compatibility note). Some minor formatting issues in the
documentation are also corrected.
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Acked-by: Tom Rini <trini@ti.com>
Cc: Geoff Levand <geoff@infradead.org>
Cc: Kevin Hilman <kevin.hilman@linaro.org>
Acked-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2014-06-24 19:51:36 +04:00
HEAD_ S Y M B O L S
2012-04-20 17:45:54 +04:00
}
2012-12-07 22:40:43 +04:00
/ *
2015-06-01 14:40:33 +03:00
* The H Y P i n i t c o d e a n d I D m a p t e x t c a n ' t b e l o n g e r t h a n a p a g e e a c h ,
ARM, arm64: kvm: get rid of the bounce page
The HYP init bounce page is a runtime construct that ensures that the
HYP init code does not cross a page boundary. However, this is something
we can do perfectly well at build time, by aligning the code appropriately.
For arm64, we just align to 4 KB, and enforce that the code size is less
than 4 KB, regardless of the chosen page size.
For ARM, the whole code is less than 256 bytes, so we tweak the linker
script to align at a power of 2 upper bound of the code size
Note that this also fixes a benign off-by-one error in the original bounce
page code, where a bounce page would be allocated unnecessarily if the code
was exactly 1 page in size.
On ARM, it also fixes an issue with very large kernels reported by Arnd
Bergmann, where stub sections with linker emitted veneers could erroneously
trigger the size/alignment ASSERT() in the linker script.
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2015-03-19 19:42:26 +03:00
* and s h o u l d n o t c r o s s a p a g e b o u n d a r y .
2012-12-07 22:40:43 +04:00
* /
ARM, arm64: kvm: get rid of the bounce page
The HYP init bounce page is a runtime construct that ensures that the
HYP init code does not cross a page boundary. However, this is something
we can do perfectly well at build time, by aligning the code appropriately.
For arm64, we just align to 4 KB, and enforce that the code size is less
than 4 KB, regardless of the chosen page size.
For ARM, the whole code is less than 256 bytes, so we tweak the linker
script to align at a power of 2 upper bound of the code size
Note that this also fixes a benign off-by-one error in the original bounce
page code, where a bounce page would be allocated unnecessarily if the code
was exactly 1 page in size.
On ARM, it also fixes an issue with very large kernels reported by Arnd
Bergmann, where stub sections with linker emitted veneers could erroneously
trigger the size/alignment ASSERT() in the linker script.
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2015-03-19 19:42:26 +03:00
ASSERT( _ _ h y p _ i d m a p _ t e x t _ e n d - ( _ _ h y p _ i d m a p _ t e x t _ s t a r t & ~ ( S Z _ 4 K - 1 ) ) < = S Z _ 4 K ,
" HYP i n i t c o d e t o o b i g o r m i s a l i g n e d " )
2015-06-01 14:40:33 +03:00
ASSERT( _ _ i d m a p _ t e x t _ e n d - ( _ _ i d m a p _ t e x t _ s t a r t & ~ ( S Z _ 4 K - 1 ) ) < = S Z _ 4 K ,
" ID m a p t e x t t o o b i g o r m i s a l i g n e d " )
2016-04-27 19:47:12 +03:00
# ifdef C O N F I G _ H I B E R N A T I O N
ASSERT( _ _ h i b e r n a t e _ e x i t _ t e x t _ e n d - ( _ _ h i b e r n a t e _ e x i t _ t e x t _ s t a r t & ~ ( S Z _ 4 K - 1 ) )
< = SZ_ 4 K , " H i b e r n a t e e x i t t e x t t o o b i g o r m i s a l i g n e d " )
# endif
2017-12-06 14:24:02 +03:00
# ifdef C O N F I G _ U N M A P _ K E R N E L _ A T _ E L 0
ASSERT( ( _ _ e n t r y _ t r a m p _ t e x t _ e n d - _ _ e n t r y _ t r a m p _ t e x t _ s t a r t ) = = P A G E _ S I Z E ,
" Entry t r a m p o l i n e t e x t t o o b i g " )
# endif
2014-06-24 19:51:37 +04:00
/ *
* If p a d d i n g i s a p p l i e d b e f o r e . h e a d . t e x t , v i r t < - > p h y s c o n v e r s i o n s w i l l f a i l .
* /
2016-02-16 15:52:36 +03:00
ASSERT( _ t e x t = = ( K I M A G E _ V A D D R + T E X T _ O F F S E T ) , " H E A D i s m i s a l i g n e d " )