diff options
author | Reshetova, Elena <elena.reshetova@intel.com> | 2017-07-04 08:53:00 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-07-04 17:35:15 -0400 |
commit | e0542dd5185e68247b08c3418bdba14644b4c414 (patch) | |
tree | 1e887d070c0b3a07bff7a829bc7e78a929a49574 /net/decnet | |
parent | 66af846fe54b780f8f5bd9a62aee081bd2ace582 (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.c | 6 |
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); |