提交 a80e89d4 编写于 作者: A Alexander Duyck 提交者: David S. Miller

fib_trie: Fall back to slen update on inflate/halve failure

This change corrects an issue where if inflate or halve fails we were
exiting the resize function without at least updating the slen for the
node.  To correct this I have moved the update of max_size into the while
loop so that it is only decremented on a successful call to either inflate
or halve.
Signed-off-by: NAlexander Duyck <alexander.h.duyck@redhat.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 69fa57b1
...@@ -752,7 +752,7 @@ static void resize(struct trie *t, struct tnode *tn) ...@@ -752,7 +752,7 @@ static void resize(struct trie *t, struct tnode *tn)
{ {
struct tnode *tp = node_parent(tn), *n = NULL; struct tnode *tp = node_parent(tn), *n = NULL;
struct tnode __rcu **cptr; struct tnode __rcu **cptr;
int max_work; int max_work = MAX_WORK;
pr_debug("In tnode_resize %p inflate_threshold=%d threshold=%d\n", pr_debug("In tnode_resize %p inflate_threshold=%d threshold=%d\n",
tn, inflate_threshold, halve_threshold); tn, inflate_threshold, halve_threshold);
...@@ -775,8 +775,7 @@ static void resize(struct trie *t, struct tnode *tn) ...@@ -775,8 +775,7 @@ static void resize(struct trie *t, struct tnode *tn)
/* Double as long as the resulting node has a number of /* Double as long as the resulting node has a number of
* nonempty nodes that are above the threshold. * nonempty nodes that are above the threshold.
*/ */
max_work = MAX_WORK; while (should_inflate(tp, tn) && max_work) {
while (should_inflate(tp, tn) && max_work--) {
if (inflate(t, tn)) { if (inflate(t, tn)) {
#ifdef CONFIG_IP_FIB_TRIE_STATS #ifdef CONFIG_IP_FIB_TRIE_STATS
this_cpu_inc(t->stats->resize_node_skipped); this_cpu_inc(t->stats->resize_node_skipped);
...@@ -784,6 +783,7 @@ static void resize(struct trie *t, struct tnode *tn) ...@@ -784,6 +783,7 @@ static void resize(struct trie *t, struct tnode *tn)
break; break;
} }
max_work--;
tn = rtnl_dereference(*cptr); tn = rtnl_dereference(*cptr);
} }
...@@ -794,8 +794,7 @@ static void resize(struct trie *t, struct tnode *tn) ...@@ -794,8 +794,7 @@ static void resize(struct trie *t, struct tnode *tn)
/* Halve as long as the number of empty children in this /* Halve as long as the number of empty children in this
* node is above threshold. * node is above threshold.
*/ */
max_work = MAX_WORK; while (should_halve(tp, tn) && max_work) {
while (should_halve(tp, tn) && max_work--) {
if (halve(t, tn)) { if (halve(t, tn)) {
#ifdef CONFIG_IP_FIB_TRIE_STATS #ifdef CONFIG_IP_FIB_TRIE_STATS
this_cpu_inc(t->stats->resize_node_skipped); this_cpu_inc(t->stats->resize_node_skipped);
...@@ -803,6 +802,7 @@ static void resize(struct trie *t, struct tnode *tn) ...@@ -803,6 +802,7 @@ static void resize(struct trie *t, struct tnode *tn)
break; break;
} }
max_work--;
tn = rtnl_dereference(*cptr); tn = rtnl_dereference(*cptr);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册