diff options
| author | Ard Biesheuvel <ard.biesheuvel@linaro.org> | 2018-08-22 00:56:13 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-08-22 13:52:47 -0400 |
| commit | 1b1eeca7e4c19fa76d409d4c7b338dba21f2df45 (patch) | |
| tree | 6443f1ee2cdc661123076f02bda70dc25852045e /kernel | |
| parent | 7290d58095712a89f845e1bca05334796dd49ed2 (diff) | |
init: allow initcall tables to be emitted using relative references
Allow the initcall tables to be emitted using relative references that
are only half the size on 64-bit architectures and don't require fixups
at runtime on relocatable kernels.
Link: http://lkml.kernel.org/r/20180704083651.24360-5-ard.biesheuvel@linaro.org
Acked-by: James Morris <james.morris@microsoft.com>
Acked-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Acked-by: Petr Mladek <pmladek@suse.com>
Acked-by: Michael Ellerman <mpe@ellerman.id.au>
Acked-by: Ingo Molnar <mingo@kernel.org>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: James Morris <jmorris@namei.org>
Cc: Jessica Yu <jeyu@kernel.org>
Cc: Josh Poimboeuf <jpoimboe@redhat.com>
Cc: Kees Cook <keescook@chromium.org>
Cc: Nicolas Pitre <nico@linaro.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Russell King <linux@armlinux.org.uk>
Cc: "Serge E. Hallyn" <serge@hallyn.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Thomas Garnier <thgarnie@google.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Will Deacon <will.deacon@arm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/printk/printk.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c index 90b6ab01db59..918f386b2f6e 100644 --- a/kernel/printk/printk.c +++ b/kernel/printk/printk.c | |||
| @@ -2788,7 +2788,8 @@ EXPORT_SYMBOL(unregister_console); | |||
| 2788 | void __init console_init(void) | 2788 | void __init console_init(void) |
| 2789 | { | 2789 | { |
| 2790 | int ret; | 2790 | int ret; |
| 2791 | initcall_t *call; | 2791 | initcall_t call; |
| 2792 | initcall_entry_t *ce; | ||
| 2792 | 2793 | ||
| 2793 | /* Setup the default TTY line discipline. */ | 2794 | /* Setup the default TTY line discipline. */ |
| 2794 | n_tty_init(); | 2795 | n_tty_init(); |
| @@ -2797,13 +2798,14 @@ void __init console_init(void) | |||
| 2797 | * set up the console device so that later boot sequences can | 2798 | * set up the console device so that later boot sequences can |
| 2798 | * inform about problems etc.. | 2799 | * inform about problems etc.. |
| 2799 | */ | 2800 | */ |
| 2800 | call = __con_initcall_start; | 2801 | ce = __con_initcall_start; |
| 2801 | trace_initcall_level("console"); | 2802 | trace_initcall_level("console"); |
| 2802 | while (call < __con_initcall_end) { | 2803 | while (ce < __con_initcall_end) { |
| 2803 | trace_initcall_start((*call)); | 2804 | call = initcall_from_entry(ce); |
| 2804 | ret = (*call)(); | 2805 | trace_initcall_start(call); |
| 2805 | trace_initcall_finish((*call), ret); | 2806 | ret = call(); |
| 2806 | call++; | 2807 | trace_initcall_finish(call, ret); |
| 2808 | ce++; | ||
| 2807 | } | 2809 | } |
| 2808 | } | 2810 | } |
| 2809 | 2811 | ||
