diff options
author | Reshetova, Elena <elena.reshetova@intel.com> | 2017-06-30 06:08:00 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-07-01 10:39:08 -0400 |
commit | 14afee4b6092fde451ee17604e5f5c89da33e71e (patch) | |
tree | 19be7a1d72a1b25c5e5366c1213cdda982aacca2 /net/atm/mpc.c | |
parent | 2638595afccf6554bfe55268ff9b2d3ac3dff2e6 (diff) |
net: convert sock.sk_wmem_alloc 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/atm/mpc.c')
-rw-r--r-- | net/atm/mpc.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/atm/mpc.c b/net/atm/mpc.c index a190800572bd..680a4b9095a1 100644 --- a/net/atm/mpc.c +++ b/net/atm/mpc.c | |||
@@ -555,7 +555,7 @@ static int send_via_shortcut(struct sk_buff *skb, struct mpoa_client *mpc) | |||
555 | sizeof(struct llc_snap_hdr)); | 555 | sizeof(struct llc_snap_hdr)); |
556 | } | 556 | } |
557 | 557 | ||
558 | atomic_add(skb->truesize, &sk_atm(entry->shortcut)->sk_wmem_alloc); | 558 | refcount_add(skb->truesize, &sk_atm(entry->shortcut)->sk_wmem_alloc); |
559 | ATM_SKB(skb)->atm_options = entry->shortcut->atm_options; | 559 | ATM_SKB(skb)->atm_options = entry->shortcut->atm_options; |
560 | entry->shortcut->send(entry->shortcut, skb); | 560 | entry->shortcut->send(entry->shortcut, skb); |
561 | entry->packets_fwded++; | 561 | entry->packets_fwded++; |
@@ -911,7 +911,7 @@ static int msg_from_mpoad(struct atm_vcc *vcc, struct sk_buff *skb) | |||
911 | 911 | ||
912 | struct mpoa_client *mpc = find_mpc_by_vcc(vcc); | 912 | struct mpoa_client *mpc = find_mpc_by_vcc(vcc); |
913 | struct k_message *mesg = (struct k_message *)skb->data; | 913 | struct k_message *mesg = (struct k_message *)skb->data; |
914 | atomic_sub(skb->truesize, &sk_atm(vcc)->sk_wmem_alloc); | 914 | WARN_ON(refcount_sub_and_test(skb->truesize, &sk_atm(vcc)->sk_wmem_alloc)); |
915 | 915 | ||
916 | if (mpc == NULL) { | 916 | if (mpc == NULL) { |
917 | pr_info("no mpc found\n"); | 917 | pr_info("no mpc found\n"); |