mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 13:43:51 +00:00
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:
parent
fcd289df88
commit
c9e3d5e004
@ -920,15 +920,23 @@ static void l2cap_send_sframe(struct l2cap_chan *chan,
|
||||
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)) {
|
||||
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);
|
||||
struct l2cap_ctrl control;
|
||||
|
||||
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)
|
||||
|
Loading…
Reference in New Issue
Block a user