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 22:07:57 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2005-04-17 06:20:36 +08:00
|
|
|
#ifndef _LINUX_INIT_H
|
|
|
|
#define _LINUX_INIT_H
|
|
|
|
|
|
|
|
#include <linux/compiler.h>
|
2012-01-13 07:02:18 +08:00
|
|
|
#include <linux/types.h>
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2018-02-01 19:27:20 +08:00
|
|
|
/* Built-in __init functions needn't be compiled with retpoline */
|
2018-02-19 18:50:57 +08:00
|
|
|
#if defined(__noretpoline) && !defined(MODULE)
|
|
|
|
#define __noinitretpoline __noretpoline
|
2018-02-01 19:27:20 +08:00
|
|
|
#else
|
2018-02-19 18:50:57 +08:00
|
|
|
#define __noinitretpoline
|
2018-02-01 19:27:20 +08:00
|
|
|
#endif
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/* These macros are used to mark some functions or
|
|
|
|
* initialized data (doesn't apply to uninitialized data)
|
|
|
|
* as `initialization' functions. The kernel can take this
|
|
|
|
* as hint that the function is used only during the initialization
|
|
|
|
* phase and free up used memory resources after
|
|
|
|
*
|
|
|
|
* Usage:
|
|
|
|
* For functions:
|
|
|
|
*
|
|
|
|
* You should add __init immediately before the function name, like:
|
|
|
|
*
|
|
|
|
* static void __init initme(int x, int y)
|
|
|
|
* {
|
|
|
|
* extern int z; z = x * y;
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* If the function has a prototype somewhere, you can also add
|
|
|
|
* __init between closing brace of the prototype and semicolon:
|
|
|
|
*
|
|
|
|
* extern int initialize_foobar_device(int, int, int) __init;
|
|
|
|
*
|
|
|
|
* For initialized data:
|
2013-11-13 07:10:19 +08:00
|
|
|
* You should insert __initdata or __initconst between the variable name
|
|
|
|
* and equal sign followed by value, e.g.:
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
|
|
|
* static int init_variable __initdata = 0;
|
2009-06-17 06:34:19 +08:00
|
|
|
* static const char linux_logo[] __initconst = { 0x32, 0x36, ... };
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
|
|
|
* Don't forget to initialize data not at file scope, i.e. within a function,
|
|
|
|
* as gcc otherwise puts the data into the bss section and not into the init
|
|
|
|
* section.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* These are for everybody (although not all archs will actually
|
|
|
|
discard it in modules) */
|
add support for Clang CFI
This change adds support for Clang’s forward-edge Control Flow
Integrity (CFI) checking. With CONFIG_CFI_CLANG, the compiler
injects a runtime check before each indirect function call to ensure
the target is a valid function with the correct static type. This
restricts possible call targets and makes it more difficult for
an attacker to exploit bugs that allow the modification of stored
function pointers. For more details, see:
https://clang.llvm.org/docs/ControlFlowIntegrity.html
Clang requires CONFIG_LTO_CLANG to be enabled with CFI to gain
visibility to possible call targets. Kernel modules are supported
with Clang’s cross-DSO CFI mode, which allows checking between
independently compiled components.
With CFI enabled, the compiler injects a __cfi_check() function into
the kernel and each module for validating local call targets. For
cross-module calls that cannot be validated locally, the compiler
calls the global __cfi_slowpath_diag() function, which determines
the target module and calls the correct __cfi_check() function. This
patch includes a slowpath implementation that uses __module_address()
to resolve call targets, and with CONFIG_CFI_CLANG_SHADOW enabled, a
shadow map that speeds up module look-ups by ~3x.
Clang implements indirect call checking using jump tables and
offers two methods of generating them. With canonical jump tables,
the compiler renames each address-taken function to <function>.cfi
and points the original symbol to a jump table entry, which passes
__cfi_check() validation. This isn’t compatible with stand-alone
assembly code, which the compiler doesn’t instrument, and would
result in indirect calls to assembly code to fail. Therefore, we
default to using non-canonical jump tables instead, where the compiler
generates a local jump table entry <function>.cfi_jt for each
address-taken function, and replaces all references to the function
with the address of the jump table entry.
Note that because non-canonical jump table addresses are local
to each component, they break cross-module function address
equality. Specifically, the address of a global function will be
different in each module, as it's replaced with the address of a local
jump table entry. If this address is passed to a different module,
it won’t match the address of the same function taken there. This
may break code that relies on comparing addresses passed from other
components.
CFI checking can be disabled in a function with the __nocfi attribute.
Additionally, CFI can be disabled for an entire compilation unit by
filtering out CC_FLAGS_CFI.
By default, CFI failures result in a kernel panic to stop a potential
exploit. CONFIG_CFI_PERMISSIVE enables a permissive mode, where the
kernel prints out a rate-limited warning instead, and allows execution
to continue. This option is helpful for locating type mismatches, but
should only be enabled during development.
Signed-off-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Kees Cook <keescook@chromium.org>
Tested-by: Nathan Chancellor <nathan@kernel.org>
Signed-off-by: Kees Cook <keescook@chromium.org>
Link: https://lore.kernel.org/r/20210408182843.1754385-2-samitolvanen@google.com
2021-04-09 02:28:26 +08:00
|
|
|
#define __init __section(".init.text") __cold __latent_entropy __noinitretpoline __nocfi
|
2020-10-22 10:36:07 +08:00
|
|
|
#define __initdata __section(".init.data")
|
|
|
|
#define __initconst __section(".init.rodata")
|
|
|
|
#define __exitdata __section(".exit.data")
|
|
|
|
#define __exit_call __used __section(".exitcall.exit")
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2010-08-12 23:43:56 +08:00
|
|
|
/*
|
|
|
|
* modpost check for section mismatches during the kernel build.
|
2007-05-18 02:14:48 +08:00
|
|
|
* A section mismatch happens when there are references from a
|
|
|
|
* code or data section to an init section (both code or data).
|
|
|
|
* The init sections are (for most archs) discarded by the kernel
|
|
|
|
* when early init has completed so all such references are potential bugs.
|
|
|
|
* For exit sections the same issue exists.
|
2010-08-12 23:43:56 +08:00
|
|
|
*
|
2007-05-18 02:14:48 +08:00
|
|
|
* The following markers are used for the cases where the reference to
|
2008-01-29 03:21:15 +08:00
|
|
|
* the *init / *exit section (code or data) is valid and will teach
|
2010-08-12 23:43:56 +08:00
|
|
|
* modpost not to issue a warning. Intended semantics is that a code or
|
|
|
|
* data tagged __ref* can reference code or data from init section without
|
|
|
|
* producing a warning (of course, no warning does not mean code is
|
|
|
|
* correct, so optimally document why the __ref is needed and why it's OK).
|
|
|
|
*
|
|
|
|
* The markers follow same syntax rules as __init / __initdata.
|
|
|
|
*/
|
2020-10-22 10:36:07 +08:00
|
|
|
#define __ref __section(".ref.text") noinline
|
|
|
|
#define __refdata __section(".ref.data")
|
|
|
|
#define __refconst __section(".ref.rodata")
|
2008-01-29 03:21:15 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
#ifdef MODULE
|
2008-01-21 03:07:28 +08:00
|
|
|
#define __exitused
|
2005-04-17 06:20:36 +08:00
|
|
|
#else
|
2008-01-21 03:07:28 +08:00
|
|
|
#define __exitused __used
|
2005-04-17 06:20:36 +08:00
|
|
|
#endif
|
|
|
|
|
2020-10-22 10:36:07 +08:00
|
|
|
#define __exit __section(".exit.text") __exitused __cold notrace
|
2008-01-21 03:07:28 +08:00
|
|
|
|
|
|
|
/* Used for MEMORY_HOTPLUG */
|
2020-10-22 10:36:07 +08:00
|
|
|
#define __meminit __section(".meminit.text") __cold notrace \
|
2016-06-21 02:42:34 +08:00
|
|
|
__latent_entropy
|
2020-10-22 10:36:07 +08:00
|
|
|
#define __meminitdata __section(".meminit.data")
|
|
|
|
#define __meminitconst __section(".meminit.rodata")
|
|
|
|
#define __memexit __section(".memexit.text") __exitused __cold notrace
|
|
|
|
#define __memexitdata __section(".memexit.data")
|
|
|
|
#define __memexitconst __section(".memexit.rodata")
|
2008-01-21 03:07:28 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/* For assembly routines */
|
2009-06-15 04:10:41 +08:00
|
|
|
#define __HEAD .section ".head.text","ax"
|
2005-04-17 06:20:36 +08:00
|
|
|
#define __INIT .section ".init.text","ax"
|
2007-05-03 01:27:05 +08:00
|
|
|
#define __FINIT .previous
|
2008-01-21 03:07:28 +08:00
|
|
|
|
2009-08-19 15:40:48 +08:00
|
|
|
#define __INITDATA .section ".init.data","aw",%progbits
|
|
|
|
#define __INITRODATA .section ".init.rodata","a",%progbits
|
2008-02-07 05:39:45 +08:00
|
|
|
#define __FINITDATA .previous
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2008-01-21 03:07:28 +08:00
|
|
|
#define __MEMINIT .section ".meminit.text", "ax"
|
|
|
|
#define __MEMINITDATA .section ".meminit.data", "aw"
|
2008-10-26 06:02:51 +08:00
|
|
|
#define __MEMINITRODATA .section ".meminit.rodata", "a"
|
2008-01-21 03:07:28 +08:00
|
|
|
|
2008-01-29 03:21:15 +08:00
|
|
|
/* silence warnings when references are OK */
|
|
|
|
#define __REF .section ".ref.text", "ax"
|
|
|
|
#define __REFDATA .section ".ref.data", "aw"
|
2008-10-26 06:02:51 +08:00
|
|
|
#define __REFCONST .section ".ref.rodata", "a"
|
2008-01-29 03:21:15 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
/*
|
|
|
|
* Used for initialization calls..
|
|
|
|
*/
|
|
|
|
typedef int (*initcall_t)(void);
|
|
|
|
typedef void (*exitcall_t)(void);
|
|
|
|
|
2018-08-22 12:56:13 +08:00
|
|
|
#ifdef CONFIG_HAVE_ARCH_PREL32_RELOCATIONS
|
|
|
|
typedef int initcall_entry_t;
|
|
|
|
|
|
|
|
static inline initcall_t initcall_from_entry(initcall_entry_t *entry)
|
|
|
|
{
|
|
|
|
return offset_to_ptr(entry);
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
typedef initcall_t initcall_entry_t;
|
|
|
|
|
|
|
|
static inline initcall_t initcall_from_entry(initcall_entry_t *entry)
|
|
|
|
{
|
|
|
|
return *entry;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
extern initcall_entry_t __con_initcall_start[], __con_initcall_end[];
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-06-18 07:28:03 +08:00
|
|
|
/* Used for contructor calls. */
|
|
|
|
typedef void (*ctor_fn_t)(void);
|
|
|
|
|
2019-05-31 05:48:35 +08:00
|
|
|
struct file_system_type;
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/* Defined in init/main.c */
|
2008-07-31 03:49:02 +08:00
|
|
|
extern int do_one_initcall(initcall_t fn);
|
[PATCH] Dynamic kernel command-line: common
Current implementation stores a static command-line buffer allocated to
COMMAND_LINE_SIZE size. Most architectures stores two copies of this buffer,
one for future reference and one for parameter parsing.
Current kernel command-line size for most architecture is much too small for
module parameters, video settings, initramfs paramters and much more. The
problem is that setting COMMAND_LINE_SIZE to a grater value, allocates static
buffers.
In order to allow a greater command-line size, these buffers should be
dynamically allocated or marked as init disposable buffers, so unused memory
can be released.
This patch renames the static saved_command_line variable into
boot_command_line adding __initdata attribute, so that it can be disposed
after initialization. This rename is required so applications that use
saved_command_line will not be affected by this change.
It reintroduces saved_command_line as dynamically allocated buffer to match
the data in boot_command_line.
It also mark secondary command-line buffer as __initdata, and copies it to
dynamically allocated static_command_line buffer components may hold reference
to it after initialization.
This patch is for linux-2.6.20-rc4-mm1 and is divided to target each
architecture. I could not check this in any architecture so please forgive me
if I got it wrong.
The per-architecture modification is very simple, use boot_command_line in
place of saved_command_line. The common code is the change into dynamic
command-line.
This patch:
1. Rename saved_command_line into boot_command_line, mark as init
disposable.
2. Add dynamic allocated saved_command_line.
3. Add dynamic allocated static_command_line.
4. During startup copy: boot_command_line into saved_command_line. arch
command_line into static_command_line.
5. Parse static_command_line and not arch command_line, so arch
command_line may be freed.
Signed-off-by: Alon Bar-Lev <alon.barlev@gmail.com>
Cc: Andi Kleen <ak@muc.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Richard Henderson <rth@twiddle.net>
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: Russell King <rmk@arm.linux.org.uk>
Cc: Ian Molton <spyro@f2s.com>
Cc: Mikael Starvik <starvik@axis.com>
Cc: David Howells <dhowells@redhat.com>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Hirokazu Takata <takata@linux-m32r.org>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Cc: Richard Curnow <rc@rc0.org.uk>
Cc: William Lee Irwin III <wli@holomorphy.com>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Jeff Dike <jdike@addtoit.com>
Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
Cc: Miles Bader <uclinux-v850@lsi.nec.co.jp>
Cc: Chris Zankel <chris@zankel.net>
Cc: "Luck, Tony" <tony.luck@intel.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Roman Zippel <zippel@linux-m68k.org>
Cc: Greg Ungerer <gerg@uclinux.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-02-12 16:53:52 +08:00
|
|
|
extern char __initdata boot_command_line[];
|
|
|
|
extern char *saved_command_line;
|
2006-09-27 16:50:44 +08:00
|
|
|
extern unsigned int reset_devices;
|
2006-03-25 19:07:39 +08:00
|
|
|
|
|
|
|
/* used by init/main.c */
|
2007-05-08 15:24:47 +08:00
|
|
|
void setup_arch(char **);
|
|
|
|
void prepare_namespace(void);
|
2019-06-02 06:09:44 +08:00
|
|
|
void __init init_rootfs(void);
|
2019-05-31 05:48:35 +08:00
|
|
|
extern struct file_system_type rootfs_fs_type;
|
2006-03-25 19:07:39 +08:00
|
|
|
|
2017-02-07 08:31:58 +08:00
|
|
|
#if defined(CONFIG_STRICT_KERNEL_RWX) || defined(CONFIG_STRICT_MODULE_RWX)
|
2016-11-14 14:15:05 +08:00
|
|
|
extern bool rodata_enabled;
|
|
|
|
#endif
|
2017-02-07 08:31:58 +08:00
|
|
|
#ifdef CONFIG_STRICT_KERNEL_RWX
|
2016-02-18 06:41:12 +08:00
|
|
|
void mark_rodata_ro(void);
|
|
|
|
#endif
|
|
|
|
|
2008-04-29 15:59:18 +08:00
|
|
|
extern void (*late_time_init)(void);
|
|
|
|
|
2012-01-13 07:02:18 +08:00
|
|
|
extern bool initcall_debug;
|
2009-12-14 03:29:01 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef MODULE
|
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
kbuild: allow archs to select link dead code/data elimination
Introduce LD_DEAD_CODE_DATA_ELIMINATION option for architectures to
select to build with -ffunction-sections, -fdata-sections, and link
with --gc-sections. It requires some work (documented) to ensure all
unreferenced entrypoints are live, and requires toolchain and build
verification, so it is made a per-arch option for now.
On a random powerpc64le build, this yelds a significant size saving,
it boots and runs fine, but there is a lot I haven't tested as yet, so
these savings may be reduced if there are bugs in the link.
text data bss dec filename
11169741 1180744 1923176 14273661 vmlinux
10445269 1004127 1919707 13369103 vmlinux.dce
~700K text, ~170K data, 6% removed from kernel image size.
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michal Marek <mmarek@suse.com>
2016-08-24 20:29:20 +08:00
|
|
|
/*
|
|
|
|
* initcalls are now grouped by functionality into separate
|
2005-04-17 06:20:36 +08:00
|
|
|
* subsections. Ordering inside the subsections is determined
|
|
|
|
* by link order.
|
|
|
|
* For backwards compatibility, initcall() puts the call in
|
|
|
|
* the device init subsection.
|
2006-10-28 02:42:37 +08:00
|
|
|
*
|
|
|
|
* The `id' arg to __define_initcall() is needed so that multiple initcalls
|
|
|
|
* can point at the same handler without causing duplicate-symbol build errors.
|
kbuild: allow archs to select link dead code/data elimination
Introduce LD_DEAD_CODE_DATA_ELIMINATION option for architectures to
select to build with -ffunction-sections, -fdata-sections, and link
with --gc-sections. It requires some work (documented) to ensure all
unreferenced entrypoints are live, and requires toolchain and build
verification, so it is made a per-arch option for now.
On a random powerpc64le build, this yelds a significant size saving,
it boots and runs fine, but there is a lot I haven't tested as yet, so
these savings may be reduced if there are bugs in the link.
text data bss dec filename
11169741 1180744 1923176 14273661 vmlinux
10445269 1004127 1919707 13369103 vmlinux.dce
~700K text, ~170K data, 6% removed from kernel image size.
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michal Marek <mmarek@suse.com>
2016-08-24 20:29:20 +08:00
|
|
|
*
|
|
|
|
* Initcalls are run by placing pointers in initcall sections that the
|
|
|
|
* kernel iterates at runtime. The linker can do dead code / data elimination
|
|
|
|
* and remove that completely, so the initcall sections have to be marked
|
|
|
|
* as KEEP() in the linker script.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
|
|
|
|
2020-12-12 02:46:24 +08:00
|
|
|
/* Format: <modname>__<counter>_<line>_<fn> */
|
|
|
|
#define __initcall_id(fn) \
|
|
|
|
__PASTE(__KBUILD_MODNAME, \
|
|
|
|
__PASTE(__, \
|
|
|
|
__PASTE(__COUNTER__, \
|
|
|
|
__PASTE(_, \
|
|
|
|
__PASTE(__LINE__, \
|
|
|
|
__PASTE(_, fn))))))
|
|
|
|
|
|
|
|
/* Format: __<prefix>__<iid><id> */
|
|
|
|
#define __initcall_name(prefix, __iid, id) \
|
|
|
|
__PASTE(__, \
|
|
|
|
__PASTE(prefix, \
|
|
|
|
__PASTE(__, \
|
|
|
|
__PASTE(__iid, id))))
|
|
|
|
|
|
|
|
#ifdef CONFIG_LTO_CLANG
|
|
|
|
/*
|
|
|
|
* With LTO, the compiler doesn't necessarily obey link order for
|
|
|
|
* initcalls. In order to preserve the correct order, we add each
|
|
|
|
* variable into its own section and generate a linker script (in
|
|
|
|
* scripts/link-vmlinux.sh) to specify the order of the sections.
|
|
|
|
*/
|
|
|
|
#define __initcall_section(__sec, __iid) \
|
|
|
|
#__sec ".init.." #__iid
|
2020-12-12 02:46:25 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* With LTO, the compiler can rename static functions to avoid
|
|
|
|
* global naming collisions. We use a global stub function for
|
|
|
|
* initcalls to create a stable symbol name whose address can be
|
|
|
|
* taken in inline assembly when PREL32 relocations are used.
|
|
|
|
*/
|
|
|
|
#define __initcall_stub(fn, __iid, id) \
|
|
|
|
__initcall_name(initstub, __iid, id)
|
|
|
|
|
|
|
|
#define __define_initcall_stub(__stub, fn) \
|
2021-04-09 02:28:27 +08:00
|
|
|
int __init __cficanonical __stub(void); \
|
|
|
|
int __init __cficanonical __stub(void) \
|
2020-12-12 02:46:25 +08:00
|
|
|
{ \
|
|
|
|
return fn(); \
|
|
|
|
} \
|
|
|
|
__ADDRESSABLE(__stub)
|
2020-12-12 02:46:24 +08:00
|
|
|
#else
|
|
|
|
#define __initcall_section(__sec, __iid) \
|
|
|
|
#__sec ".init"
|
2020-12-12 02:46:25 +08:00
|
|
|
|
|
|
|
#define __initcall_stub(fn, __iid, id) fn
|
|
|
|
|
|
|
|
#define __define_initcall_stub(__stub, fn) \
|
|
|
|
__ADDRESSABLE(fn)
|
2020-12-12 02:46:24 +08:00
|
|
|
#endif
|
|
|
|
|
2018-08-22 12:56:13 +08:00
|
|
|
#ifdef CONFIG_HAVE_ARCH_PREL32_RELOCATIONS
|
2020-12-12 02:46:25 +08:00
|
|
|
#define ____define_initcall(fn, __stub, __name, __sec) \
|
|
|
|
__define_initcall_stub(__stub, fn) \
|
2020-12-12 02:46:24 +08:00
|
|
|
asm(".section \"" __sec "\", \"a\" \n" \
|
|
|
|
__stringify(__name) ": \n" \
|
2020-12-12 02:46:25 +08:00
|
|
|
".long " __stringify(__stub) " - . \n" \
|
2021-05-21 15:26:10 +08:00
|
|
|
".previous \n"); \
|
|
|
|
static_assert(__same_type(initcall_t, &fn));
|
2018-08-22 12:56:13 +08:00
|
|
|
#else
|
2020-12-12 02:46:25 +08:00
|
|
|
#define ____define_initcall(fn, __unused, __name, __sec) \
|
2020-12-12 02:46:24 +08:00
|
|
|
static initcall_t __name __used \
|
|
|
|
__attribute__((__section__(__sec))) = fn;
|
2018-08-22 12:56:13 +08:00
|
|
|
#endif
|
|
|
|
|
2020-12-12 02:46:24 +08:00
|
|
|
#define __unique_initcall(fn, id, __sec, __iid) \
|
|
|
|
____define_initcall(fn, \
|
2020-12-12 02:46:25 +08:00
|
|
|
__initcall_stub(fn, __iid, id), \
|
2020-12-12 02:46:24 +08:00
|
|
|
__initcall_name(initcall, __iid, id), \
|
|
|
|
__initcall_section(__sec, __iid))
|
|
|
|
|
|
|
|
#define ___define_initcall(fn, id, __sec) \
|
|
|
|
__unique_initcall(fn, id, __sec, __initcall_id(fn))
|
|
|
|
|
2018-08-22 12:56:13 +08:00
|
|
|
#define __define_initcall(fn, id) ___define_initcall(fn, id, .initcall##id)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2008-07-26 10:45:11 +08:00
|
|
|
/*
|
|
|
|
* Early initcalls run before initializing SMP.
|
|
|
|
*
|
|
|
|
* Only for built-in code, not modules.
|
|
|
|
*/
|
2012-12-18 07:59:32 +08:00
|
|
|
#define early_initcall(fn) __define_initcall(fn, early)
|
2008-07-26 10:45:11 +08:00
|
|
|
|
2006-11-21 03:47:18 +08:00
|
|
|
/*
|
|
|
|
* A "pure" initcall has no dependencies on anything else, and purely
|
|
|
|
* initializes variables that couldn't be statically initialized.
|
|
|
|
*
|
|
|
|
* This only exists for built-in code, not for modules.
|
2012-06-15 06:00:59 +08:00
|
|
|
* Keep main.c:initcall_level_names[] in sync.
|
2006-11-21 03:47:18 +08:00
|
|
|
*/
|
2012-12-18 07:59:32 +08:00
|
|
|
#define pure_initcall(fn) __define_initcall(fn, 0)
|
|
|
|
|
|
|
|
#define core_initcall(fn) __define_initcall(fn, 1)
|
|
|
|
#define core_initcall_sync(fn) __define_initcall(fn, 1s)
|
|
|
|
#define postcore_initcall(fn) __define_initcall(fn, 2)
|
|
|
|
#define postcore_initcall_sync(fn) __define_initcall(fn, 2s)
|
|
|
|
#define arch_initcall(fn) __define_initcall(fn, 3)
|
|
|
|
#define arch_initcall_sync(fn) __define_initcall(fn, 3s)
|
|
|
|
#define subsys_initcall(fn) __define_initcall(fn, 4)
|
|
|
|
#define subsys_initcall_sync(fn) __define_initcall(fn, 4s)
|
|
|
|
#define fs_initcall(fn) __define_initcall(fn, 5)
|
|
|
|
#define fs_initcall_sync(fn) __define_initcall(fn, 5s)
|
|
|
|
#define rootfs_initcall(fn) __define_initcall(fn, rootfs)
|
|
|
|
#define device_initcall(fn) __define_initcall(fn, 6)
|
|
|
|
#define device_initcall_sync(fn) __define_initcall(fn, 6s)
|
|
|
|
#define late_initcall(fn) __define_initcall(fn, 7)
|
|
|
|
#define late_initcall_sync(fn) __define_initcall(fn, 7s)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
#define __initcall(fn) device_initcall(fn)
|
|
|
|
|
kbuild: allow archs to select link dead code/data elimination
Introduce LD_DEAD_CODE_DATA_ELIMINATION option for architectures to
select to build with -ffunction-sections, -fdata-sections, and link
with --gc-sections. It requires some work (documented) to ensure all
unreferenced entrypoints are live, and requires toolchain and build
verification, so it is made a per-arch option for now.
On a random powerpc64le build, this yelds a significant size saving,
it boots and runs fine, but there is a lot I haven't tested as yet, so
these savings may be reduced if there are bugs in the link.
text data bss dec filename
11169741 1180744 1923176 14273661 vmlinux
10445269 1004127 1919707 13369103 vmlinux.dce
~700K text, ~170K data, 6% removed from kernel image size.
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michal Marek <mmarek@suse.com>
2016-08-24 20:29:20 +08:00
|
|
|
#define __exitcall(fn) \
|
2005-04-17 06:20:36 +08:00
|
|
|
static exitcall_t __exitcall_##fn __exit_call = fn
|
|
|
|
|
2020-12-12 02:46:24 +08:00
|
|
|
#define console_initcall(fn) ___define_initcall(fn, con, .con_initcall)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
struct obs_kernel_param {
|
|
|
|
const char *str;
|
|
|
|
int (*setup_func)(char *);
|
|
|
|
int early;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Only for really core code. See moduleparam.h for the normal way.
|
|
|
|
*
|
|
|
|
* Force the alignment so the compiler doesn't space elements of the
|
|
|
|
* obs_kernel_param "array" too far apart in .init.setup.
|
|
|
|
*/
|
|
|
|
#define __setup_param(str, unique_id, fn, early) \
|
2015-03-05 15:28:48 +08:00
|
|
|
static const char __setup_str_##unique_id[] __initconst \
|
|
|
|
__aligned(1) = str; \
|
|
|
|
static struct obs_kernel_param __setup_##unique_id \
|
2020-10-22 10:36:07 +08:00
|
|
|
__used __section(".init.setup") \
|
2020-11-23 18:23:16 +08:00
|
|
|
__aligned(__alignof__(struct obs_kernel_param)) \
|
2005-04-17 06:20:36 +08:00
|
|
|
= { __setup_str_##unique_id, fn, early }
|
|
|
|
|
2022-03-24 07:06:11 +08:00
|
|
|
/*
|
|
|
|
* NOTE: __setup functions return values:
|
|
|
|
* @fn returns 1 (or non-zero) if the option argument is "handled"
|
|
|
|
* and returns 0 if the option argument is "not handled".
|
|
|
|
*/
|
2015-03-05 15:28:48 +08:00
|
|
|
#define __setup(str, fn) \
|
2005-04-17 06:20:36 +08:00
|
|
|
__setup_param(str, fn, fn, 0)
|
|
|
|
|
2015-03-05 15:28:48 +08:00
|
|
|
/*
|
2022-03-24 07:06:11 +08:00
|
|
|
* NOTE: @fn is as per module_param, not __setup!
|
|
|
|
* I.e., @fn returns 0 for no error or non-zero for error
|
|
|
|
* (possibly @fn returns a -errno value, but it does not matter).
|
|
|
|
* Emits warning if @fn returns non-zero.
|
2015-03-05 15:28:48 +08:00
|
|
|
*/
|
|
|
|
#define early_param(str, fn) \
|
2005-04-17 06:20:36 +08:00
|
|
|
__setup_param(str, fn, fn, 1)
|
|
|
|
|
2015-03-05 15:28:48 +08:00
|
|
|
#define early_param_on_off(str_on, str_off, var, config) \
|
|
|
|
\
|
|
|
|
int var = IS_ENABLED(config); \
|
|
|
|
\
|
|
|
|
static int __init parse_##var##_on(char *arg) \
|
|
|
|
{ \
|
|
|
|
var = 1; \
|
|
|
|
return 0; \
|
|
|
|
} \
|
2021-02-26 09:22:15 +08:00
|
|
|
early_param(str_on, parse_##var##_on); \
|
2015-03-05 15:28:48 +08:00
|
|
|
\
|
|
|
|
static int __init parse_##var##_off(char *arg) \
|
|
|
|
{ \
|
|
|
|
var = 0; \
|
|
|
|
return 0; \
|
|
|
|
} \
|
2021-02-26 09:22:15 +08:00
|
|
|
early_param(str_off, parse_##var##_off)
|
2015-03-05 09:24:13 +08:00
|
|
|
|
[PATCH] Dynamic kernel command-line: common
Current implementation stores a static command-line buffer allocated to
COMMAND_LINE_SIZE size. Most architectures stores two copies of this buffer,
one for future reference and one for parameter parsing.
Current kernel command-line size for most architecture is much too small for
module parameters, video settings, initramfs paramters and much more. The
problem is that setting COMMAND_LINE_SIZE to a grater value, allocates static
buffers.
In order to allow a greater command-line size, these buffers should be
dynamically allocated or marked as init disposable buffers, so unused memory
can be released.
This patch renames the static saved_command_line variable into
boot_command_line adding __initdata attribute, so that it can be disposed
after initialization. This rename is required so applications that use
saved_command_line will not be affected by this change.
It reintroduces saved_command_line as dynamically allocated buffer to match
the data in boot_command_line.
It also mark secondary command-line buffer as __initdata, and copies it to
dynamically allocated static_command_line buffer components may hold reference
to it after initialization.
This patch is for linux-2.6.20-rc4-mm1 and is divided to target each
architecture. I could not check this in any architecture so please forgive me
if I got it wrong.
The per-architecture modification is very simple, use boot_command_line in
place of saved_command_line. The common code is the change into dynamic
command-line.
This patch:
1. Rename saved_command_line into boot_command_line, mark as init
disposable.
2. Add dynamic allocated saved_command_line.
3. Add dynamic allocated static_command_line.
4. During startup copy: boot_command_line into saved_command_line. arch
command_line into static_command_line.
5. Parse static_command_line and not arch command_line, so arch
command_line may be freed.
Signed-off-by: Alon Bar-Lev <alon.barlev@gmail.com>
Cc: Andi Kleen <ak@muc.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Richard Henderson <rth@twiddle.net>
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: Russell King <rmk@arm.linux.org.uk>
Cc: Ian Molton <spyro@f2s.com>
Cc: Mikael Starvik <starvik@axis.com>
Cc: David Howells <dhowells@redhat.com>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Hirokazu Takata <takata@linux-m32r.org>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Cc: Richard Curnow <rc@rc0.org.uk>
Cc: William Lee Irwin III <wli@holomorphy.com>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Jeff Dike <jdike@addtoit.com>
Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
Cc: Miles Bader <uclinux-v850@lsi.nec.co.jp>
Cc: Chris Zankel <chris@zankel.net>
Cc: "Luck, Tony" <tony.luck@intel.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Roman Zippel <zippel@linux-m68k.org>
Cc: Greg Ungerer <gerg@uclinux.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-02-12 16:53:52 +08:00
|
|
|
/* Relies on boot_command_line being set */
|
2005-04-17 06:20:36 +08:00
|
|
|
void __init parse_early_param(void);
|
2009-03-31 05:37:25 +08:00
|
|
|
void __init parse_early_options(char *cmdline);
|
2005-04-17 06:20:36 +08:00
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
|
|
|
|
#else /* MODULE */
|
|
|
|
|
|
|
|
#define __setup_param(str, unique_id, fn) /* nothing */
|
|
|
|
#define __setup(str, func) /* nothing */
|
|
|
|
#endif
|
|
|
|
|
2007-05-07 05:50:49 +08:00
|
|
|
/* Data marked not to be saved by software suspend */
|
2020-10-22 10:36:07 +08:00
|
|
|
#define __nosavedata __section(".data..nosave")
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
#ifdef MODULE
|
|
|
|
#define __exit_p(x) x
|
|
|
|
#else
|
|
|
|
#define __exit_p(x) NULL
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _LINUX_INIT_H */
|