Skip to content

Commit d8a84d3

Browse files
willdeacontorvalds
authored andcommitted
samples/hw_breakpoint: drop use of kallsyms_lookup_name()
The 'data_breakpoint' test code is the only modular user of kallsyms_lookup_name(), which was exported as part of fixing the test in f60d24d ("hw-breakpoints: Fix broken hw-breakpoint sample module"). In preparation for un-exporting this symbol, switch the test over to using __symbol_get(), which can be used to place breakpoints on exported symbols. Signed-off-by: Will Deacon <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Reviewed-by: Christoph Hellwig <[email protected]> Reviewed-by: Masami Hiramatsu <[email protected]> Reviewed-by: Quentin Perret <[email protected]> Cc: K.Prasad <[email protected]> Cc: Thomas Gleixner <[email protected]> Cc: Greg Kroah-Hartman <[email protected]> Cc: Frederic Weisbecker <[email protected]> Cc: Alexei Starovoitov <[email protected]> Cc: Miroslav Benes <[email protected]> Cc: Petr Mladek <[email protected]> Cc: Joe Lawrence <[email protected]> Link: http://lkml.kernel.org/r/[email protected] Signed-off-by: Linus Torvalds <[email protected]>
1 parent 4800314 commit d8a84d3

File tree

1 file changed

+7
-2
lines changed

1 file changed

+7
-2
lines changed

samples/hw_breakpoint/data_breakpoint.c

+7-2
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@
2323

2424
struct perf_event * __percpu *sample_hbp;
2525

26-
static char ksym_name[KSYM_NAME_LEN] = "pid_max";
26+
static char ksym_name[KSYM_NAME_LEN] = "jiffies";
2727
module_param_string(ksym, ksym_name, KSYM_NAME_LEN, S_IRUGO);
2828
MODULE_PARM_DESC(ksym, "Kernel symbol to monitor; this module will report any"
2929
" write operations on the kernel symbol");
@@ -41,9 +41,13 @@ static int __init hw_break_module_init(void)
4141
{
4242
int ret;
4343
struct perf_event_attr attr;
44+
void *addr = __symbol_get(ksym_name);
45+
46+
if (!addr)
47+
return -ENXIO;
4448

4549
hw_breakpoint_init(&attr);
46-
attr.bp_addr = kallsyms_lookup_name(ksym_name);
50+
attr.bp_addr = (unsigned long)addr;
4751
attr.bp_len = HW_BREAKPOINT_LEN_4;
4852
attr.bp_type = HW_BREAKPOINT_W;
4953

@@ -66,6 +70,7 @@ static int __init hw_break_module_init(void)
6670
static void __exit hw_break_module_exit(void)
6771
{
6872
unregister_wide_hw_breakpoint(sample_hbp);
73+
symbol_put(ksym_name);
6974
printk(KERN_INFO "HW Breakpoint for %s write uninstalled\n", ksym_name);
7075
}
7176

0 commit comments

Comments
 (0)