|
@@ -1387,10 +1387,8 @@ static int smp_sig_channel(struct l2cap_chan *chan, struct sk_buff *skb)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
- if (skb->len < 1) {
|
|
|
- kfree_skb(skb);
|
|
|
+ if (skb->len < 1)
|
|
|
return -EILSEQ;
|
|
|
- }
|
|
|
|
|
|
if (!test_bit(HCI_LE_ENABLED, &hcon->hdev->dev_flags)) {
|
|
|
err = -EOPNOTSUPP;
|
|
@@ -1410,8 +1408,9 @@ static int smp_sig_channel(struct l2cap_chan *chan, struct sk_buff *skb)
|
|
|
if (code != SMP_CMD_PAIRING_REQ && code != SMP_CMD_SECURITY_REQ &&
|
|
|
!test_bit(HCI_CONN_LE_SMP_PEND, &hcon->flags)) {
|
|
|
BT_ERR("Unexpected SMP command 0x%02x. Disconnecting.", code);
|
|
|
- kfree_skb(skb);
|
|
|
- return -EOPNOTSUPP;
|
|
|
+ reason = SMP_CMD_NOTSUPP;
|
|
|
+ err = -EOPNOTSUPP;
|
|
|
+ goto done;
|
|
|
}
|
|
|
|
|
|
switch (code) {
|
|
@@ -1472,8 +1471,8 @@ static int smp_sig_channel(struct l2cap_chan *chan, struct sk_buff *skb)
|
|
|
done:
|
|
|
if (reason)
|
|
|
smp_failure(conn, reason);
|
|
|
-
|
|
|
- kfree_skb(skb);
|
|
|
+ if (!err)
|
|
|
+ kfree_skb(skb);
|
|
|
return err;
|
|
|
}
|
|
|
|