tracing/boot: Fix a hist trigger dependency for boot time tracing
authorMasami Hiramatsu <mhiramat@kernel.org>
Tue, 10 Aug 2021 02:07:14 +0000 (11:07 +0900)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 22 Sep 2021 10:28:03 +0000 (12:28 +0200)
[ Upstream commit 6fe7c745f2acb73e4cc961d7f91125eef5a8861f ]

Fixes a build error when CONFIG_HIST_TRIGGERS=n with boot-time
tracing. Since the trigger_process_regex() is defined only
when CONFIG_HIST_TRIGGERS=y, if it is disabled, the 'actions'
event option also must be disabled.

Link: https://lkml.kernel.org/r/162856123376.203126.582144262622247352.stgit@devnote2
Fixes: 81a59555ff15 ("tracing/boot: Add per-event settings")
Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
kernel/trace/trace_boot.c

index a82f03f385f89609d9ebce780b8e19ca0f68923f..0996d59750ff0f12425463237cd35665ec7854a8 100644 (file)
@@ -205,12 +205,15 @@ trace_boot_init_one_event(struct trace_array *tr, struct xbc_node *gnode,
                        pr_err("Failed to apply filter: %s\n", buf);
        }
 
-       xbc_node_for_each_array_value(enode, "actions", anode, p) {
-               if (strlcpy(buf, p, ARRAY_SIZE(buf)) >= ARRAY_SIZE(buf))
-                       pr_err("action string is too long: %s\n", p);
-               else if (trigger_process_regex(file, buf) < 0)
-                       pr_err("Failed to apply an action: %s\n", buf);
-       }
+       if (IS_ENABLED(CONFIG_HIST_TRIGGERS)) {
+               xbc_node_for_each_array_value(enode, "actions", anode, p) {
+                       if (strlcpy(buf, p, ARRAY_SIZE(buf)) >= ARRAY_SIZE(buf))
+                               pr_err("action string is too long: %s\n", p);
+                       else if (trigger_process_regex(file, buf) < 0)
+                               pr_err("Failed to apply an action: %s\n", buf);
+               }
+       } else if (xbc_node_find_value(enode, "actions", NULL))
+               pr_err("Failed to apply event actions because CONFIG_HIST_TRIGGERS is not set.\n");
 
        if (xbc_node_find_value(enode, "enable", NULL)) {
                if (trace_event_enable_disable(file, 1, 0) < 0)