Bluetooth: Use new header structures in l2cap_send_rr_or_rnr
struct l2cap_ctrl is now used, and the sframe is now sent directly rather than depending on a separate call. Signed-off-by: Mat Martineau <mathewm@codeaurora.org> Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
This commit is contained in:
committed by
Johan Hedberg
parent
fcd289df88
commit
c9e3d5e004
@@ -920,15 +920,23 @@ static void l2cap_send_sframe(struct l2cap_chan *chan,
|
|||||||
l2cap_do_send(chan, skb);
|
l2cap_do_send(chan, skb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void l2cap_send_rr_or_rnr(struct l2cap_chan *chan, u32 control)
|
static void l2cap_send_rr_or_rnr(struct l2cap_chan *chan, bool poll)
|
||||||
{
|
{
|
||||||
if (test_bit(CONN_LOCAL_BUSY, &chan->conn_state)) {
|
struct l2cap_ctrl control;
|
||||||
control |= __set_ctrl_super(chan, L2CAP_SUPER_RNR);
|
|
||||||
set_bit(CONN_RNR_SENT, &chan->conn_state);
|
|
||||||
} else
|
|
||||||
control |= __set_ctrl_super(chan, L2CAP_SUPER_RR);
|
|
||||||
|
|
||||||
control |= __set_reqseq(chan, chan->buffer_seq);
|
BT_DBG("chan %p, poll %d", chan, poll);
|
||||||
|
|
||||||
|
memset(&control, 0, sizeof(control));
|
||||||
|
control.sframe = 1;
|
||||||
|
control.poll = poll;
|
||||||
|
|
||||||
|
if (test_bit(CONN_LOCAL_BUSY, &chan->conn_state))
|
||||||
|
control.super = L2CAP_SUPER_RNR;
|
||||||
|
else
|
||||||
|
control.super = L2CAP_SUPER_RR;
|
||||||
|
|
||||||
|
control.reqseq = chan->buffer_seq;
|
||||||
|
l2cap_send_sframe(chan, &control);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int __l2cap_no_conn_pending(struct l2cap_chan *chan)
|
static inline int __l2cap_no_conn_pending(struct l2cap_chan *chan)
|
||||||
|
Reference in New Issue
Block a user