diff options
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/fib_trie.c | 28 |
1 files changed, 11 insertions, 17 deletions
diff --git a/net/ipv4/fib_trie.c b/net/ipv4/fib_trie.c index f5c046b517e4..e047de6873bd 100644 --- a/net/ipv4/fib_trie.c +++ b/net/ipv4/fib_trie.c | |||
@@ -980,8 +980,7 @@ static struct node *trie_rebalance(struct trie *t, struct tnode *tn) | |||
980 | 980 | ||
981 | /* only used from updater-side */ | 981 | /* only used from updater-side */ |
982 | 982 | ||
983 | static struct list_head * | 983 | static struct list_head *fib_insert_node(struct trie *t, u32 key, int plen) |
984 | fib_insert_node(struct trie *t, int *err, u32 key, int plen) | ||
985 | { | 984 | { |
986 | int pos, newpos; | 985 | int pos, newpos; |
987 | struct tnode *tp = NULL, *tn = NULL; | 986 | struct tnode *tp = NULL, *tn = NULL; |
@@ -1043,10 +1042,8 @@ fib_insert_node(struct trie *t, int *err, u32 key, int plen) | |||
1043 | 1042 | ||
1044 | li = leaf_info_new(plen); | 1043 | li = leaf_info_new(plen); |
1045 | 1044 | ||
1046 | if (!li) { | 1045 | if (!li) |
1047 | *err = -ENOMEM; | 1046 | return NULL; |
1048 | goto done; | ||
1049 | } | ||
1050 | 1047 | ||
1051 | fa_head = &li->falh; | 1048 | fa_head = &li->falh; |
1052 | insert_leaf_info(&l->list, li); | 1049 | insert_leaf_info(&l->list, li); |
@@ -1055,18 +1052,15 @@ fib_insert_node(struct trie *t, int *err, u32 key, int plen) | |||
1055 | t->size++; | 1052 | t->size++; |
1056 | l = leaf_new(); | 1053 | l = leaf_new(); |
1057 | 1054 | ||
1058 | if (!l) { | 1055 | if (!l) |
1059 | *err = -ENOMEM; | 1056 | return NULL; |
1060 | goto done; | ||
1061 | } | ||
1062 | 1057 | ||
1063 | l->key = key; | 1058 | l->key = key; |
1064 | li = leaf_info_new(plen); | 1059 | li = leaf_info_new(plen); |
1065 | 1060 | ||
1066 | if (!li) { | 1061 | if (!li) { |
1067 | tnode_free((struct tnode *) l); | 1062 | tnode_free((struct tnode *) l); |
1068 | *err = -ENOMEM; | 1063 | return NULL; |
1069 | goto done; | ||
1070 | } | 1064 | } |
1071 | 1065 | ||
1072 | fa_head = &li->falh; | 1066 | fa_head = &li->falh; |
@@ -1102,8 +1096,7 @@ fib_insert_node(struct trie *t, int *err, u32 key, int plen) | |||
1102 | if (!tn) { | 1096 | if (!tn) { |
1103 | free_leaf_info(li); | 1097 | free_leaf_info(li); |
1104 | tnode_free((struct tnode *) l); | 1098 | tnode_free((struct tnode *) l); |
1105 | *err = -ENOMEM; | 1099 | return NULL; |
1106 | goto done; | ||
1107 | } | 1100 | } |
1108 | 1101 | ||
1109 | node_set_parent((struct node *)tn, tp); | 1102 | node_set_parent((struct node *)tn, tp); |
@@ -1262,10 +1255,11 @@ static int fn_trie_insert(struct fib_table *tb, struct fib_config *cfg) | |||
1262 | */ | 1255 | */ |
1263 | 1256 | ||
1264 | if (!fa_head) { | 1257 | if (!fa_head) { |
1265 | err = 0; | 1258 | fa_head = fib_insert_node(t, key, plen); |
1266 | fa_head = fib_insert_node(t, &err, key, plen); | 1259 | if (unlikely(!fa_head)) { |
1267 | if (err) | 1260 | err = -ENOMEM; |
1268 | goto out_free_new_fa; | 1261 | goto out_free_new_fa; |
1262 | } | ||
1269 | } | 1263 | } |
1270 | 1264 | ||
1271 | list_add_tail_rcu(&new_fa->fa_list, | 1265 | list_add_tail_rcu(&new_fa->fa_list, |