tracing: Put back comma for empty fields in boot string parsing
authorSteven Rostedt (Red Hat) <rostedt@goodmis.org>
Wed, 4 Nov 2015 03:15:14 +0000 (22:15 -0500)
committerSteven Rostedt <rostedt@goodmis.org>
Wed, 4 Nov 2015 03:15:14 +0000 (22:15 -0500)
Both early_enable_events() and apply_trace_boot_options() parse a boot
string that may get parsed later on. They both use strsep() which converts a
comma into a nul character. To still allow the boot string to be parsed
again the same way, the nul character gets converted back to a comma after
the token is processed.

The problem is that these two functions check for an empty parameter (two
commas in a row ",,"), and continue the loop if the parameter is empty, but
fails to place the comma back. In this case, the second parsing will end at
this blank field, and not process fields afterward.

In most cases, users should not have an empty field, but if its going to be
checked, the code might as well be correct.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/trace.c
kernel/trace/trace_events.c

index 7fe7cc987dabcecf3ade44172c47efb81d820814..2198a630ef5826a30e51a2974d472b078273f80c 100644 (file)
@@ -3636,10 +3636,9 @@ static void __init apply_trace_boot_options(void)
 
                if (!option)
                        break;
-               if (!*option)
-                       continue;
 
-               trace_set_options(&global_trace, option);
+               if (*option)
+                       trace_set_options(&global_trace, option);
 
                /* Put back the comma to allow this to be called again */
                if (buf)
index 292bccf3e0112f7ad348c4c47b6252ea15355393..bee1e153005278b63676622207b4f606e2c84f72 100644 (file)
@@ -3042,16 +3042,16 @@ early_enable_events(struct trace_array *tr, bool disable_first)
 
                if (!token)
                        break;
-               if (!*token)
-                       continue;
 
-               /* Restarting syscalls requires that we stop them first */
-               if (disable_first)
-                       ftrace_set_clr_event(tr, token, 0);
+               if (*token) {
+                       /* Restarting syscalls requires that we stop them first */
+                       if (disable_first)
+                               ftrace_set_clr_event(tr, token, 0);
 
-               ret = ftrace_set_clr_event(tr, token, 1);
-               if (ret)
-                       pr_warn("Failed to enable trace event: %s\n", token);
+                       ret = ftrace_set_clr_event(tr, token, 1);
+                       if (ret)
+                               pr_warn("Failed to enable trace event: %s\n", token);
+               }
 
                /* Put back the comma to allow this to be called again */
                if (buf)