X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=kernel%2Ftracepoint.c;h=63630aef3bd368ca34aaeb783b731767da499fbf;hb=012c0f413d5d28c2e49f22d39a51d9e65cc87ee7;hp=29f26540e9c9550fd1c099512e7b20beb21ce234;hpb=19d2f8e0fb7bba99cc585d2467e9fa54a84c8557;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git diff --git a/kernel/tracepoint.c b/kernel/tracepoint.c index 29f2654..63630ae 100644 --- a/kernel/tracepoint.c +++ b/kernel/tracepoint.c @@ -631,17 +631,25 @@ void tracepoint_iter_reset(struct tracepoint_iter *iter) EXPORT_SYMBOL_GPL(tracepoint_iter_reset); #ifdef CONFIG_MODULES +bool trace_module_has_bad_taint(struct module *mod) +{ + return mod->taints & ~((1 << TAINT_OOT_MODULE) | (1 << TAINT_CRAP)); +} + static int tracepoint_module_coming(struct module *mod) { struct tp_module *tp_mod, *iter; int ret = 0; + if (!mod->num_tracepoints) + return 0; + /* * We skip modules that taint the kernel, especially those with different * module headers (for forced load), to make sure we don't cause a crash. * Staging and out-of-tree GPL modules are fine. */ - if (mod->taints & ~((1 << TAINT_OOT_MODULE) | (1 << TAINT_CRAP))) + if (trace_module_has_bad_taint(mod)) return 0; mutex_lock(&tracepoints_mutex); tp_mod = kmalloc(sizeof(struct tp_module), GFP_KERNEL); @@ -679,6 +687,9 @@ static int tracepoint_module_going(struct module *mod) { struct tp_module *pos; + if (!mod->num_tracepoints) + return 0; + mutex_lock(&tracepoints_mutex); tracepoint_update_probe_range(mod->tracepoints_ptrs, mod->tracepoints_ptrs + mod->num_tracepoints);