Re: [PATCH 3/5] Bluetooth: Clear ack_timer when sending ack

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Szymon,

> > > 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.

put that in the commit message please.

> > > 
> > > 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);
> > >  }
> > >  

You are absolutely correct of course. I confused myself here. This also
means that either we add proper comments here or make it simpler to
follow the code. See what makes more sense.

Regards

Marcel


--
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


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux