Commit 761cb06c authored by Marcel Holtmann's avatar Marcel Holtmann Committed by Marcel Holtmann

[Bluetooth] Handle priority bits in parameter negotiation

The PN response have to return the same value for the priority
bits as in the request. The priority value is now also stored
in the rfcomm_dlc structure and the default value is 7.
parent 0247c40a
...@@ -185,6 +185,7 @@ struct rfcomm_dlc { ...@@ -185,6 +185,7 @@ struct rfcomm_dlc {
atomic_t refcnt; atomic_t refcnt;
u8 dlci; u8 dlci;
u8 addr; u8 addr;
u8 priority;
uint mtu; uint mtu;
u8 v24_sig; u8 v24_sig;
......
...@@ -304,10 +304,11 @@ static int __rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst, ...@@ -304,10 +304,11 @@ static int __rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst,
rfcomm_dlc_clear_state(d); rfcomm_dlc_clear_state(d);
d->dlci = dlci; d->dlci = dlci;
d->addr = __addr(s->initiator, dlci); d->addr = __addr(s->initiator, dlci);
d->priority = 7;
d->state = BT_CONFIG; d->state = BT_CONFIG;
rfcomm_dlc_link(s, d); rfcomm_dlc_link(s, d);
d->mtu = s->mtu; d->mtu = s->mtu;
...@@ -741,7 +742,7 @@ static int rfcomm_send_pn(struct rfcomm_session *s, int cr, struct rfcomm_dlc *d ...@@ -741,7 +742,7 @@ static int rfcomm_send_pn(struct rfcomm_session *s, int cr, struct rfcomm_dlc *d
pn = (void *) ptr; ptr += sizeof(*pn); pn = (void *) ptr; ptr += sizeof(*pn);
pn->dlci = d->dlci; pn->dlci = d->dlci;
pn->priority = 0; pn->priority = d->priority;
pn->ack_timer = 0; pn->ack_timer = 0;
pn->max_retrans = 0; pn->max_retrans = 0;
...@@ -1099,8 +1100,6 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn) ...@@ -1099,8 +1100,6 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn)
set_bit(RFCOMM_TX_THROTTLED, &d->flags); set_bit(RFCOMM_TX_THROTTLED, &d->flags);
d->credits = 0; d->credits = 0;
} }
d->mtu = btohs(pn->mtu);
} else { } else {
if (pn->flow_ctrl == 0xe0) { if (pn->flow_ctrl == 0xe0) {
d->tx_credits = pn->credits; d->tx_credits = pn->credits;
...@@ -1108,10 +1107,12 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn) ...@@ -1108,10 +1107,12 @@ static int rfcomm_apply_pn(struct rfcomm_dlc *d, int cr, struct rfcomm_pn *pn)
set_bit(RFCOMM_TX_THROTTLED, &d->flags); set_bit(RFCOMM_TX_THROTTLED, &d->flags);
d->credits = 0; d->credits = 0;
} }
d->mtu = btohs(pn->mtu);
} }
d->priority = pn->priority;
d->mtu = btohs(pn->mtu);
return 0; return 0;
} }
...@@ -1137,7 +1138,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb) ...@@ -1137,7 +1138,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
switch (d->state) { switch (d->state) {
case BT_CONFIG: case BT_CONFIG:
rfcomm_apply_pn(d, cr, pn); rfcomm_apply_pn(d, cr, pn);
d->state = BT_CONNECT; d->state = BT_CONNECT;
rfcomm_send_sabm(s, d->dlci); rfcomm_send_sabm(s, d->dlci);
break; break;
...@@ -1148,7 +1149,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb) ...@@ -1148,7 +1149,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
if (!cr) if (!cr)
return 0; return 0;
/* PN request for non existing DLC. /* PN request for non existing DLC.
* Assume incomming connection. */ * Assume incomming connection. */
if (rfcomm_connect_ind(s, channel, &d)) { if (rfcomm_connect_ind(s, channel, &d)) {
...@@ -1157,7 +1158,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb) ...@@ -1157,7 +1158,7 @@ static int rfcomm_recv_pn(struct rfcomm_session *s, int cr, struct sk_buff *skb)
rfcomm_dlc_link(s, d); rfcomm_dlc_link(s, d);
rfcomm_apply_pn(d, cr, pn); rfcomm_apply_pn(d, cr, pn);
d->state = BT_OPEN; d->state = BT_OPEN;
rfcomm_send_pn(s, 0, d); rfcomm_send_pn(s, 0, d);
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment