> Hi Szymon, Hi, > > ack_timer should be cleared when sending ACK to avoid acking I-frames > > twice. > > explain why you are creating a helper for it. Since that is clearly not > obvious to me. To avoid code duplication - helper is not clearing ack timer and is used by both l2cap_send_ack and l2cap_ack_timeout. There is no need to clear ack timer in timer funtion. But if you prefer to not have helper and are fine with clearing ack timer also in l2cap_ack_timeout then ack timer can be clear in l2cap_send_ack. > > > > Signed-off-by: Szymon Janc <szymon.janc@xxxxxxxxx> > > --- > > net/bluetooth/l2cap_core.c | 10 ++++++++-- > > 1 files changed, 8 insertions(+), 2 deletions(-) > > > > diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c > > index 308d9d7..b9e232e 100644 > > --- a/net/bluetooth/l2cap_core.c > > +++ b/net/bluetooth/l2cap_core.c > > @@ -1478,7 +1478,7 @@ static int l2cap_retransmit_frames(struct l2cap_chan *chan) > > return ret; > > } > > > > -static void l2cap_send_ack(struct l2cap_chan *chan) > > +static void __l2cap_send_ack(struct l2cap_chan *chan) > > { > > u32 control = 0; > > > > @@ -1498,6 +1498,12 @@ static void l2cap_send_ack(struct l2cap_chan *chan) > > l2cap_send_sframe(chan, control); > > } > > > > +static void l2cap_send_ack(struct l2cap_chan *chan) > > +{ > > + __clear_ack_timer(chan); > > + __l2cap_send_ack(chan); > > +} > > + > > static void l2cap_send_srejtail(struct l2cap_chan *chan) > > { > > struct srej_list *tail; > > @@ -1988,7 +1994,7 @@ static void l2cap_ack_timeout(struct work_struct *work) > > BT_DBG("chan %p", chan); > > > > lock_sock(chan->sk); > > I would have just added > > __clear_ack_timer(chan): > > here. This is a timer function so there is no need to clear timer here. > > - l2cap_send_ack(chan); > > + __l2cap_send_ack(chan); > > release_sock(chan->sk); > > } > > BR Szymon Janc -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html