ftrace: Replace uses of _ftrace_direct APIs with _ftrace_direct_multi
authorFlorent Revest <revest@chromium.org>
Tue, 21 Mar 2023 14:04:19 +0000 (15:04 +0100)
committerSteven Rostedt (Google) <rostedt@goodmis.org>
Tue, 21 Mar 2023 17:42:12 +0000 (13:42 -0400)
The _multi API requires that users keep their own ops but can enforce
that an op is only associated to one direct call.

Link: https://lkml.kernel.org/r/20230321140424.345218-3-revest@chromium.org
Signed-off-by: Florent Revest <revest@chromium.org>
Acked-by: Mark Rutland <mark.rutland@arm.com>
Tested-by: Mark Rutland <mark.rutland@arm.com>
Acked-by: Jiri Olsa <jolsa@kernel.org>
Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
kernel/trace/trace_selftest.c
samples/ftrace/ftrace-direct-modify.c
samples/ftrace/ftrace-direct-too.c
samples/ftrace/ftrace-direct.c

index ff0536cea9682179e3a708b5b9c7d46e2bea7084..9ce80b3ad06d0e3f7fbf82e8e1eeb3daf4c3410e 100644 (file)
@@ -785,6 +785,7 @@ static struct fgraph_ops fgraph_ops __initdata  = {
 };
 
 #ifdef CONFIG_DYNAMIC_FTRACE_WITH_DIRECT_CALLS
+static struct ftrace_ops direct;
 #ifndef CALL_DEPTH_ACCOUNT
 #define CALL_DEPTH_ACCOUNT ""
 #endif
@@ -870,8 +871,8 @@ trace_selftest_startup_function_graph(struct tracer *trace,
         * Register direct function together with graph tracer
         * and make sure we get graph trace.
         */
-       ret = register_ftrace_direct((unsigned long) DYN_FTRACE_TEST_NAME,
-                                    (unsigned long) trace_direct_tramp);
+       ftrace_set_filter_ip(&direct, (unsigned long)DYN_FTRACE_TEST_NAME, 0, 0);
+       ret = register_ftrace_direct_multi(&direct, (unsigned long)trace_direct_tramp);
        if (ret)
                goto out;
 
@@ -891,8 +892,9 @@ trace_selftest_startup_function_graph(struct tracer *trace,
 
        unregister_ftrace_graph(&fgraph_ops);
 
-       ret = unregister_ftrace_direct((unsigned long) DYN_FTRACE_TEST_NAME,
-                                      (unsigned long) trace_direct_tramp);
+       ret = unregister_ftrace_direct_multi(&direct,
+                                            (unsigned long) trace_direct_tramp,
+                                            true);
        if (ret)
                goto out;
 
index d93abbcb1f4c5433fd1b6211fb7670318de2c4f8..f01ac74bac10948ff5ebd7a5f14103d0af351b4a 100644 (file)
@@ -96,6 +96,8 @@ asm (
 
 #endif /* CONFIG_S390 */
 
+static struct ftrace_ops direct;
+
 static unsigned long my_tramp = (unsigned long)my_tramp1;
 static unsigned long tramps[2] = {
        (unsigned long)my_tramp1,
@@ -114,7 +116,7 @@ static int simple_thread(void *arg)
                if (ret)
                        continue;
                t ^= 1;
-               ret = modify_ftrace_direct(my_ip, my_tramp, tramps[t]);
+               ret = modify_ftrace_direct_multi(&direct, tramps[t]);
                if (!ret)
                        my_tramp = tramps[t];
                WARN_ON_ONCE(ret);
@@ -129,7 +131,9 @@ static int __init ftrace_direct_init(void)
 {
        int ret;
 
-       ret = register_ftrace_direct(my_ip, my_tramp);
+       ftrace_set_filter_ip(&direct, (unsigned long) my_ip, 0, 0);
+       ret = register_ftrace_direct_multi(&direct, my_tramp);
+
        if (!ret)
                simple_tsk = kthread_run(simple_thread, NULL, "event-sample-fn");
        return ret;
@@ -138,12 +142,12 @@ static int __init ftrace_direct_init(void)
 static void __exit ftrace_direct_exit(void)
 {
        kthread_stop(simple_tsk);
-       unregister_ftrace_direct(my_ip, my_tramp);
+       unregister_ftrace_direct_multi(&direct, my_tramp, true);
 }
 
 module_init(ftrace_direct_init);
 module_exit(ftrace_direct_exit);
 
 MODULE_AUTHOR("Steven Rostedt");
-MODULE_DESCRIPTION("Example use case of using modify_ftrace_direct()");
+MODULE_DESCRIPTION("Example use case of using modify_ftrace_direct_multi()");
 MODULE_LICENSE("GPL");
index 8139dce2a31cbd06b4f56f5463f4436dfe789487..05c3585ac15ea34a926c30367298cc64aaf045e8 100644 (file)
@@ -70,21 +70,23 @@ asm (
 
 #endif /* CONFIG_S390 */
 
+static struct ftrace_ops direct;
+
 static int __init ftrace_direct_init(void)
 {
-       return register_ftrace_direct((unsigned long)handle_mm_fault,
-                                    (unsigned long)my_tramp);
+       ftrace_set_filter_ip(&direct, (unsigned long) handle_mm_fault, 0, 0);
+
+       return register_ftrace_direct_multi(&direct, (unsigned long) my_tramp);
 }
 
 static void __exit ftrace_direct_exit(void)
 {
-       unregister_ftrace_direct((unsigned long)handle_mm_fault,
-                                (unsigned long)my_tramp);
+       unregister_ftrace_direct_multi(&direct, (unsigned long)my_tramp, true);
 }
 
 module_init(ftrace_direct_init);
 module_exit(ftrace_direct_exit);
 
 MODULE_AUTHOR("Steven Rostedt");
-MODULE_DESCRIPTION("Another example use case of using register_ftrace_direct()");
+MODULE_DESCRIPTION("Another example use case of using register_ftrace_direct_multi()");
 MODULE_LICENSE("GPL");
index 1d3d307ca33d6e64f5fa6529758d03595dfdfff1..42ec9e39453bf7a9cd09b8c0128f9aeb29a5ae2e 100644 (file)
@@ -63,21 +63,23 @@ asm (
 
 #endif /* CONFIG_S390 */
 
+static struct ftrace_ops direct;
+
 static int __init ftrace_direct_init(void)
 {
-       return register_ftrace_direct((unsigned long)wake_up_process,
-                                    (unsigned long)my_tramp);
+       ftrace_set_filter_ip(&direct, (unsigned long) wake_up_process, 0, 0);
+
+       return register_ftrace_direct_multi(&direct, (unsigned long) my_tramp);
 }
 
 static void __exit ftrace_direct_exit(void)
 {
-       unregister_ftrace_direct((unsigned long)wake_up_process,
-                                (unsigned long)my_tramp);
+       unregister_ftrace_direct_multi(&direct, (unsigned long)my_tramp, true);
 }
 
 module_init(ftrace_direct_init);
 module_exit(ftrace_direct_exit);
 
 MODULE_AUTHOR("Steven Rostedt");
-MODULE_DESCRIPTION("Example use case of using register_ftrace_direct()");
+MODULE_DESCRIPTION("Example use case of using register_ftrace_direct_multi()");
 MODULE_LICENSE("GPL");