Browse Source

RDMA/cxgb4: Don't leak skb in c4iw_uld_rx_handler()

Signed-off-by: Steve Wise <swise@opengridcomputing.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
Steve Wise 11 years ago
parent
commit
dbb084cc5f
1 changed files with 4 additions and 2 deletions
  1. 4 2
      drivers/infiniband/hw/cxgb4/device.c

+ 4 - 2
drivers/infiniband/hw/cxgb4/device.c

@@ -897,11 +897,13 @@ static int c4iw_uld_rx_handler(void *handle, const __be64 *rsp,
 	}
 
 	opcode = *(u8 *)rsp;
-	if (c4iw_handlers[opcode])
+	if (c4iw_handlers[opcode]) {
 		c4iw_handlers[opcode](dev, skb);
-	else
+	} else {
 		pr_info("%s no handler opcode 0x%x...\n", __func__,
 		       opcode);
+		kfree_skb(skb);
+	}
 
 	return 0;
 nomem: