aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorIlia Kolomisnky <iliak@ti.com>2011-07-10 01:47:44 -0400
committerGustavo F. Padovan <padovan@profusion.mobi>2011-07-11 00:43:25 -0400
commite2fd318e3a9208245ee1041f6d413c8593fba29d (patch)
tree09eb380881b2c82922f69cdf5dced58143e6695e /net
parent8f360119243c214eb5c5549c61981d51a276154a (diff)
Bluetooth: Fixes l2cap "command reject" reply according to spec
There can 3 reasons for the "command reject" reply produced by the stack. Each such reply should be accompanied by the relevand data ( as defined in spec. ). Currently there is one instance of "command reject" reply with reason "invalid cid" wich is fixed. Also, added clean-up definitions related to the "command reject" replies. Signed-off-by: Ilia Kolomisnky <iliak@ti.com> Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
Diffstat (limited to 'net')
-rw-r--r--net/bluetooth/l2cap_core.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c
index ab2e244a76c4..52c791ed038d 100644
--- a/net/bluetooth/l2cap_core.c
+++ b/net/bluetooth/l2cap_core.c
@@ -2277,9 +2277,9 @@ done:
2277 2277
2278static inline int l2cap_command_rej(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data) 2278static inline int l2cap_command_rej(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
2279{ 2279{
2280 struct l2cap_cmd_rej *rej = (struct l2cap_cmd_rej *) data; 2280 struct l2cap_cmd_rej_unk *rej = (struct l2cap_cmd_rej_unk *) data;
2281 2281
2282 if (rej->reason != 0x0000) 2282 if (rej->reason != L2CAP_REJ_NOT_UNDERSTOOD)
2283 return 0; 2283 return 0;
2284 2284
2285 if ((conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT) && 2285 if ((conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT) &&
@@ -2524,9 +2524,12 @@ static inline int l2cap_config_req(struct l2cap_conn *conn, struct l2cap_cmd_hdr
2524 sk = chan->sk; 2524 sk = chan->sk;
2525 2525
2526 if (chan->state != BT_CONFIG) { 2526 if (chan->state != BT_CONFIG) {
2527 struct l2cap_cmd_rej rej; 2527 struct l2cap_cmd_rej_cid rej;
2528
2529 rej.reason = cpu_to_le16(L2CAP_REJ_INVALID_CID);
2530 rej.scid = cpu_to_le16(chan->scid);
2531 rej.dcid = cpu_to_le16(chan->dcid);
2528 2532
2529 rej.reason = cpu_to_le16(0x0002);
2530 l2cap_send_cmd(conn, cmd->ident, L2CAP_COMMAND_REJ, 2533 l2cap_send_cmd(conn, cmd->ident, L2CAP_COMMAND_REJ,
2531 sizeof(rej), &rej); 2534 sizeof(rej), &rej);
2532 goto unlock; 2535 goto unlock;
@@ -3017,12 +3020,12 @@ static inline void l2cap_sig_channel(struct l2cap_conn *conn,
3017 err = l2cap_bredr_sig_cmd(conn, &cmd, cmd_len, data); 3020 err = l2cap_bredr_sig_cmd(conn, &cmd, cmd_len, data);
3018 3021
3019 if (err) { 3022 if (err) {
3020 struct l2cap_cmd_rej rej; 3023 struct l2cap_cmd_rej_unk rej;
3021 3024
3022 BT_ERR("Wrong link type (%d)", err); 3025 BT_ERR("Wrong link type (%d)", err);
3023 3026
3024 /* FIXME: Map err to a valid reason */ 3027 /* FIXME: Map err to a valid reason */
3025 rej.reason = cpu_to_le16(0); 3028 rej.reason = cpu_to_le16(L2CAP_REJ_NOT_UNDERSTOOD);
3026 l2cap_send_cmd(conn, cmd.ident, L2CAP_COMMAND_REJ, sizeof(rej), &rej); 3029 l2cap_send_cmd(conn, cmd.ident, L2CAP_COMMAND_REJ, sizeof(rej), &rej);
3027 } 3030 }
3028 3031