aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/events
diff options
context:
space:
mode:
authorOleg Nesterov <oleg@redhat.com>2012-06-15 11:43:53 -0400
committerIngo Molnar <mingo@kernel.org>2012-06-16 03:10:48 -0400
commit449d0d7c9fb87277175db34c009c70cb348004a8 (patch)
tree90c1abe494cd40ccc05aa2a11c5da52714b4e168 /kernel/events
parentd9c4a30e82614d43b55893a73f31e7284007ce82 (diff)
uprobes: Simplify the usage of uprobe->pending_list
uprobe->pending_list is only used to create the temporary list, it has no meaning after we drop uprobes_mmap_hash(inode). No need to initialize this node or remove it from tmp_list, and we can use list_for_each_entry(). Signed-off-by: Oleg Nesterov <oleg@redhat.com> Cc: Ananth N Mavinakayanahalli <ananth@in.ibm.com> Cc: Anton Arapov <anton@redhat.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> Link: http://lkml.kernel.org/r/20120615154353.GA9614@redhat.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/events')
-rw-r--r--kernel/events/uprobes.c12
1 files changed, 4 insertions, 8 deletions
diff --git a/kernel/events/uprobes.c b/kernel/events/uprobes.c
index b9c61bda902..7d5c78f063a 100644
--- a/kernel/events/uprobes.c
+++ b/kernel/events/uprobes.c
@@ -513,7 +513,6 @@ static struct uprobe *alloc_uprobe(struct inode *inode, loff_t offset)
513 uprobe->inode = igrab(inode); 513 uprobe->inode = igrab(inode);
514 uprobe->offset = offset; 514 uprobe->offset = offset;
515 init_rwsem(&uprobe->consumer_rwsem); 515 init_rwsem(&uprobe->consumer_rwsem);
516 INIT_LIST_HEAD(&uprobe->pending_list);
517 516
518 /* add to uprobes_tree, sorted on inode:offset */ 517 /* add to uprobes_tree, sorted on inode:offset */
519 cur_uprobe = insert_uprobe(uprobe); 518 cur_uprobe = insert_uprobe(uprobe);
@@ -1037,7 +1036,7 @@ static void build_probe_list(struct inode *inode, struct list_head *head)
1037int uprobe_mmap(struct vm_area_struct *vma) 1036int uprobe_mmap(struct vm_area_struct *vma)
1038{ 1037{
1039 struct list_head tmp_list; 1038 struct list_head tmp_list;
1040 struct uprobe *uprobe, *u; 1039 struct uprobe *uprobe;
1041 struct inode *inode; 1040 struct inode *inode;
1042 int ret, count; 1041 int ret, count;
1043 1042
@@ -1055,10 +1054,9 @@ int uprobe_mmap(struct vm_area_struct *vma)
1055 ret = 0; 1054 ret = 0;
1056 count = 0; 1055 count = 0;
1057 1056
1058 list_for_each_entry_safe(uprobe, u, &tmp_list, pending_list) { 1057 list_for_each_entry(uprobe, &tmp_list, pending_list) {
1059 loff_t vaddr; 1058 loff_t vaddr;
1060 1059
1061 list_del(&uprobe->pending_list);
1062 if (!ret) { 1060 if (!ret) {
1063 vaddr = vma_address(vma, uprobe->offset); 1061 vaddr = vma_address(vma, uprobe->offset);
1064 1062
@@ -1106,7 +1104,7 @@ int uprobe_mmap(struct vm_area_struct *vma)
1106void uprobe_munmap(struct vm_area_struct *vma, unsigned long start, unsigned long end) 1104void uprobe_munmap(struct vm_area_struct *vma, unsigned long start, unsigned long end)
1107{ 1105{
1108 struct list_head tmp_list; 1106 struct list_head tmp_list;
1109 struct uprobe *uprobe, *u; 1107 struct uprobe *uprobe;
1110 struct inode *inode; 1108 struct inode *inode;
1111 1109
1112 if (!atomic_read(&uprobe_events) || !valid_vma(vma, false)) 1110 if (!atomic_read(&uprobe_events) || !valid_vma(vma, false))
@@ -1123,12 +1121,10 @@ void uprobe_munmap(struct vm_area_struct *vma, unsigned long start, unsigned lon
1123 mutex_lock(uprobes_mmap_hash(inode)); 1121 mutex_lock(uprobes_mmap_hash(inode));
1124 build_probe_list(inode, &tmp_list); 1122 build_probe_list(inode, &tmp_list);
1125 1123
1126 list_for_each_entry_safe(uprobe, u, &tmp_list, pending_list) { 1124 list_for_each_entry(uprobe, &tmp_list, pending_list) {
1127 loff_t vaddr; 1125 loff_t vaddr;
1128 1126
1129 list_del(&uprobe->pending_list);
1130 vaddr = vma_address(vma, uprobe->offset); 1127 vaddr = vma_address(vma, uprobe->offset);
1131
1132 if (vaddr >= start && vaddr < end) { 1128 if (vaddr >= start && vaddr < end) {
1133 /* 1129 /*
1134 * An unregister could have removed the probe before 1130 * An unregister could have removed the probe before