RE: [PATCH] wlcore: time sync : add support for 64 bit clock

From: Machani, Yaniv
Date: Thu Jun 23 2016 - 07:32:48 EST


On Thu, Jun 23, 2016 at 14:18:00, Johannes Berg wrote:
> linux-wireless@xxxxxxxxxxxxxxx; netdev@xxxxxxxxxxxxxxx
> Subject: Re: [PATCH] wlcore: time sync : add support for 64 bit clock
>
> On Thu, 2016-06-23 at 14:12 +0300, Yaniv Machani wrote:
> > Changed the configuration to support 64bit instead of 32bit this in
> > order to offload the driver from handling a wraparound.
>
> [...]
>
> Since you Cc'ed me, and presumably want me to review it, I'll say that
> this looks like a terrible idea:
>
> > @@ -74,10 +74,16 @@ struct wl18xx_event_mailbox {
>
> This struct is evidently used for firmware/host communication.
>
> > Â __le16 bss_loss_bitmap;
> >
> > Â /* bitmap of stations (by HLID) which exceeded max tx retries */
> > - __le32 tx_retry_exceeded_bitmap;
> > + __le16 tx_retry_exceeded_bitmap;
> > +
> > + /* time sync high msb*/
> > + u16 time_sync_tsf_high_msb;
>
> So first of all, just using u16 instead of __le16 seems wrong.

Agree, should be changed.

>
> Additionally, this looks like it changes the firmware API, so that
> older firmware images will no longer work?

It is backwards compatible,
although it changes a API structure, older firmware are using only u16 for the field so there is no impact on that.
Of course that for actually using the 64bit information, you will have to upgrade the firmware.

Yaniv