]> Git Repo - linux.git/commitdiff
init, tracing: instrument security and console initcall trace events
authorAbderrahmane Benbachir <[email protected]>
Fri, 23 Mar 2018 00:33:28 +0000 (20:33 -0400)
committerSteven Rostedt (VMware) <[email protected]>
Fri, 6 Apr 2018 12:56:55 +0000 (08:56 -0400)
Trace events have been added around the initcall functions defined in
init/main.c. But console and security have their own initcalls. This adds
the trace events associated for those initcall functions.

Link: http://lkml.kernel.org/r/[email protected]
Cc: Ingo Molnar <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Signed-off-by: Abderrahmane Benbachir <[email protected]>
Signed-off-by: Steven Rostedt (VMware) <[email protected]>
kernel/printk/printk.c
security/security.c

index f274fbef821d1bee0c457da42417f4b8153444cf..cb5b35341d698352d4ce30ba148b5ba53f33e83b 100644 (file)
@@ -52,6 +52,7 @@
 #include <linux/uaccess.h>
 #include <asm/sections.h>
 
+#include <trace/events/initcall.h>
 #define CREATE_TRACE_POINTS
 #include <trace/events/printk.h>
 
@@ -2781,6 +2782,7 @@ EXPORT_SYMBOL(unregister_console);
  */
 void __init console_init(void)
 {
+       int ret;
        initcall_t *call;
 
        /* Setup the default TTY line discipline. */
@@ -2791,8 +2793,11 @@ void __init console_init(void)
         * inform about problems etc..
         */
        call = __con_initcall_start;
+       trace_initcall_level("console");
        while (call < __con_initcall_end) {
-               (*call)();
+               trace_initcall_start((*call));
+               ret = (*call)();
+               trace_initcall_finish((*call), ret);
                call++;
        }
 }
index 1cd8526cb0b775647fe567a6910cc7b811cff21a..987afe3d464c5f818d937eef264751279d09a7cf 100644 (file)
@@ -30,6 +30,8 @@
 #include <linux/string.h>
 #include <net/flow.h>
 
+#include <trace/events/initcall.h>
+
 #define MAX_LSM_EVM_XATTR      2
 
 /* Maximum number of letters for an LSM name string */
@@ -45,10 +47,14 @@ static __initdata char chosen_lsm[SECURITY_NAME_MAX + 1] =
 
 static void __init do_security_initcalls(void)
 {
+       int ret;
        initcall_t *call;
        call = __security_initcall_start;
+       trace_initcall_level("security");
        while (call < __security_initcall_end) {
-               (*call) ();
+               trace_initcall_start((*call));
+               ret = (*call) ();
+               trace_initcall_finish((*call), ret);
                call++;
        }
 }
This page took 0.065574 seconds and 4 git commands to generate.