diff options
-rw-r--r-- | net/ipv4/inetpeer.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/net/ipv4/inetpeer.c b/net/ipv4/inetpeer.c index 337ad41bb80a..e7eb590c86ce 100644 --- a/net/ipv4/inetpeer.c +++ b/net/ipv4/inetpeer.c | |||
@@ -102,15 +102,18 @@ static struct inet_peer *lookup(const struct inetpeer_addr *daddr, | |||
102 | struct rb_node **parent_p, | 102 | struct rb_node **parent_p, |
103 | struct rb_node ***pp_p) | 103 | struct rb_node ***pp_p) |
104 | { | 104 | { |
105 | struct rb_node **pp, *parent; | 105 | struct rb_node **pp, *parent, *next; |
106 | struct inet_peer *p; | 106 | struct inet_peer *p; |
107 | 107 | ||
108 | pp = &base->rb_root.rb_node; | 108 | pp = &base->rb_root.rb_node; |
109 | parent = NULL; | 109 | parent = NULL; |
110 | while (*pp) { | 110 | while (1) { |
111 | int cmp; | 111 | int cmp; |
112 | 112 | ||
113 | parent = rcu_dereference_raw(*pp); | 113 | next = rcu_dereference_raw(*pp); |
114 | if (!next) | ||
115 | break; | ||
116 | parent = next; | ||
114 | p = rb_entry(parent, struct inet_peer, rb_node); | 117 | p = rb_entry(parent, struct inet_peer, rb_node); |
115 | cmp = inetpeer_addr_cmp(daddr, &p->daddr); | 118 | cmp = inetpeer_addr_cmp(daddr, &p->daddr); |
116 | if (cmp == 0) { | 119 | if (cmp == 0) { |