aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorArd Biesheuvel <ard.biesheuvel@linaro.org>2018-08-22 00:56:13 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2018-08-22 13:52:47 -0400
commit1b1eeca7e4c19fa76d409d4c7b338dba21f2df45 (patch)
tree6443f1ee2cdc661123076f02bda70dc25852045e /kernel
parent7290d58095712a89f845e1bca05334796dd49ed2 (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.c16
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);
2788void __init console_init(void) 2788void __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