summaryrefslogtreecommitdiffstats
path: root/net/atm/mpc.c
diff options
context:
space:
mode:
authorReshetova, Elena <elena.reshetova@intel.com>2017-06-30 06:08:00 -0400
committerDavid S. Miller <davem@davemloft.net>2017-07-01 10:39:08 -0400
commit14afee4b6092fde451ee17604e5f5c89da33e71e (patch)
tree19be7a1d72a1b25c5e5366c1213cdda982aacca2 /net/atm/mpc.c
parent2638595afccf6554bfe55268ff9b2d3ac3dff2e6 (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.c4
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");