diff options
Diffstat (limited to 'kernel/kprobes.c')
| -rw-r--r-- | kernel/kprobes.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/kernel/kprobes.c b/kernel/kprobes.c index 56a891914273..99865c33a60d 100644 --- a/kernel/kprobes.c +++ b/kernel/kprobes.c | |||
| @@ -74,7 +74,8 @@ static struct hlist_head kretprobe_inst_table[KPROBE_TABLE_SIZE]; | |||
| 74 | /* NOTE: change this value only with kprobe_mutex held */ | 74 | /* NOTE: change this value only with kprobe_mutex held */ |
| 75 | static bool kprobes_all_disarmed; | 75 | static bool kprobes_all_disarmed; |
| 76 | 76 | ||
| 77 | static DEFINE_MUTEX(kprobe_mutex); /* Protects kprobe_table */ | 77 | /* This protects kprobe_table and optimizing_list */ |
| 78 | static DEFINE_MUTEX(kprobe_mutex); | ||
| 78 | static DEFINE_PER_CPU(struct kprobe *, kprobe_instance) = NULL; | 79 | static DEFINE_PER_CPU(struct kprobe *, kprobe_instance) = NULL; |
| 79 | static struct { | 80 | static struct { |
| 80 | spinlock_t lock ____cacheline_aligned_in_smp; | 81 | spinlock_t lock ____cacheline_aligned_in_smp; |
| @@ -595,6 +596,7 @@ static __kprobes void try_to_optimize_kprobe(struct kprobe *p) | |||
| 595 | } | 596 | } |
| 596 | 597 | ||
| 597 | #ifdef CONFIG_SYSCTL | 598 | #ifdef CONFIG_SYSCTL |
| 599 | /* This should be called with kprobe_mutex locked */ | ||
| 598 | static void __kprobes optimize_all_kprobes(void) | 600 | static void __kprobes optimize_all_kprobes(void) |
| 599 | { | 601 | { |
| 600 | struct hlist_head *head; | 602 | struct hlist_head *head; |
| @@ -607,17 +609,16 @@ static void __kprobes optimize_all_kprobes(void) | |||
| 607 | return; | 609 | return; |
| 608 | 610 | ||
| 609 | kprobes_allow_optimization = true; | 611 | kprobes_allow_optimization = true; |
| 610 | mutex_lock(&text_mutex); | ||
| 611 | for (i = 0; i < KPROBE_TABLE_SIZE; i++) { | 612 | for (i = 0; i < KPROBE_TABLE_SIZE; i++) { |
| 612 | head = &kprobe_table[i]; | 613 | head = &kprobe_table[i]; |
| 613 | hlist_for_each_entry_rcu(p, node, head, hlist) | 614 | hlist_for_each_entry_rcu(p, node, head, hlist) |
| 614 | if (!kprobe_disabled(p)) | 615 | if (!kprobe_disabled(p)) |
| 615 | optimize_kprobe(p); | 616 | optimize_kprobe(p); |
| 616 | } | 617 | } |
| 617 | mutex_unlock(&text_mutex); | ||
| 618 | printk(KERN_INFO "Kprobes globally optimized\n"); | 618 | printk(KERN_INFO "Kprobes globally optimized\n"); |
| 619 | } | 619 | } |
| 620 | 620 | ||
| 621 | /* This should be called with kprobe_mutex locked */ | ||
| 621 | static void __kprobes unoptimize_all_kprobes(void) | 622 | static void __kprobes unoptimize_all_kprobes(void) |
| 622 | { | 623 | { |
| 623 | struct hlist_head *head; | 624 | struct hlist_head *head; |
