aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth/smp.c
diff options
context:
space:
mode:
authorJohan Hedberg <johan.hedberg@intel.com>2014-09-05 23:59:10 -0400
committerMarcel Holtmann <marcel@holtmann.org>2014-09-08 13:07:57 -0400
commitc68b7f127d5f517c214e8bcf231d0188f6776d2a (patch)
tree586ab7b881e121d59a68340225e6e7f70dc5e07a /net/bluetooth/smp.c
parent9f06a8d623b2c3aea09292b844e329fbfb401231 (diff)
Bluetooth: Fix dereferencing conn variable before NULL check
This patch fixes the following type of static analyzer warning (and probably a real bug as well as the NULL check should be there for a reason): net/bluetooth/smp.c:1182 smp_conn_security() warn: variable dereferenced before check 'conn' (see line 1174) Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net/bluetooth/smp.c')
-rw-r--r--net/bluetooth/smp.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c
index 1201670afe38..560f78a9f960 100644
--- a/net/bluetooth/smp.c
+++ b/net/bluetooth/smp.c
@@ -1210,7 +1210,7 @@ static u8 smp_cmd_security_req(struct l2cap_conn *conn, struct sk_buff *skb)
1210int smp_conn_security(struct hci_conn *hcon, __u8 sec_level) 1210int smp_conn_security(struct hci_conn *hcon, __u8 sec_level)
1211{ 1211{
1212 struct l2cap_conn *conn = hcon->l2cap_data; 1212 struct l2cap_conn *conn = hcon->l2cap_data;
1213 struct l2cap_chan *chan = conn->smp; 1213 struct l2cap_chan *chan;
1214 struct smp_chan *smp; 1214 struct smp_chan *smp;
1215 __u8 authreq; 1215 __u8 authreq;
1216 int ret; 1216 int ret;
@@ -1221,6 +1221,8 @@ int smp_conn_security(struct hci_conn *hcon, __u8 sec_level)
1221 if (!conn) 1221 if (!conn)
1222 return 1; 1222 return 1;
1223 1223
1224 chan = conn->smp;
1225
1224 if (!test_bit(HCI_LE_ENABLED, &hcon->hdev->dev_flags)) 1226 if (!test_bit(HCI_LE_ENABLED, &hcon->hdev->dev_flags))
1225 return 1; 1227 return 1;
1226 1228