summaryrefslogtreecommitdiffstats
path: root/net/decnet
diff options
context:
space:
mode:
authorReshetova, Elena <elena.reshetova@intel.com>2017-07-04 08:53:00 -0400
committerDavid S. Miller <davem@davemloft.net>2017-07-04 17:35:15 -0400
commite0542dd5185e68247b08c3418bdba14644b4c414 (patch)
tree1e887d070c0b3a07bff7a829bc7e78a929a49574 /net/decnet
parent66af846fe54b780f8f5bd9a62aee081bd2ace582 (diff)
net, decnet: convert dn_fib_info.fib_clntref from atomic_t to refcount_t
refcount_t type and corresponding API should be used instead of atomic_t when the variable is used as a reference counter. This allows to avoid accidental refcounter overflows that might lead to use-after-free situations. Signed-off-by: Elena Reshetova <elena.reshetova@intel.com> Signed-off-by: Hans Liljestrand <ishkamiel@gmail.com> Signed-off-by: Kees Cook <keescook@chromium.org> Signed-off-by: David Windsor <dwindsor@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/decnet')
-rw-r--r--net/decnet/dn_fib.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/net/decnet/dn_fib.c b/net/decnet/dn_fib.c
index f9058ebeb635..f9f6fb3f3c5b 100644
--- a/net/decnet/dn_fib.c
+++ b/net/decnet/dn_fib.c
@@ -389,7 +389,7 @@ link_it:
389 } 389 }
390 390
391 fi->fib_treeref++; 391 fi->fib_treeref++;
392 atomic_inc(&fi->fib_clntref); 392 refcount_set(&fi->fib_clntref, 1);
393 spin_lock(&dn_fib_info_lock); 393 spin_lock(&dn_fib_info_lock);
394 fi->fib_next = dn_fib_info_list; 394 fi->fib_next = dn_fib_info_list;
395 fi->fib_prev = NULL; 395 fi->fib_prev = NULL;
@@ -425,7 +425,7 @@ int dn_fib_semantic_match(int type, struct dn_fib_info *fi, const struct flowidn
425 switch (type) { 425 switch (type) {
426 case RTN_NAT: 426 case RTN_NAT:
427 DN_FIB_RES_RESET(*res); 427 DN_FIB_RES_RESET(*res);
428 atomic_inc(&fi->fib_clntref); 428 refcount_inc(&fi->fib_clntref);
429 return 0; 429 return 0;
430 case RTN_UNICAST: 430 case RTN_UNICAST:
431 case RTN_LOCAL: 431 case RTN_LOCAL:
@@ -438,7 +438,7 @@ int dn_fib_semantic_match(int type, struct dn_fib_info *fi, const struct flowidn
438 } 438 }
439 if (nhsel < fi->fib_nhs) { 439 if (nhsel < fi->fib_nhs) {
440 res->nh_sel = nhsel; 440 res->nh_sel = nhsel;
441 atomic_inc(&fi->fib_clntref); 441 refcount_inc(&fi->fib_clntref);
442 return 0; 442 return 0;
443 } 443 }
444 endfor_nexthops(fi); 444 endfor_nexthops(fi);