[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1389017496.5891.15.camel@jlt4.sipsolutions.net>
Date: Mon, 06 Jan 2014 15:11:36 +0100
From: Johannes Berg <johannes@...solutions.net>
To: Sabrina Dubroca <sd@...asysnail.net>
Cc: davem@...emloft.net, bhutchings@...arflare.com,
netdev@...r.kernel.org
Subject: Re: [PATCH v2 5/5] alx: add stats to ethtool
On Mon, 2014-01-06 at 11:57 +0100, Sabrina Dubroca wrote:
> [2014-01-06, 10:03:10] Johannes Berg wrote:
> > On Sat, 2014-01-04 at 17:47 +0100, Sabrina Dubroca wrote:
> >
> > > + __alx_update_hw_stats(hw);
> > > + BUILD_BUG_ON(sizeof(hw->stats) - offsetof(struct alx_hw_stats, rx_ok) <
> > > + ALX_NUM_STATS * sizeof(u64));
> >
> > I think you should make that != instead of <, otherwise you won't catch
> > all possible differences.
>
> With a !=, BUILD_BUG_ON is triggered if a new field is added at the
> end of the structure.
That seems reasonable, you'd want to export that field as well? Fields
that shouldn't be exported could be added before rx_ok.
> But adding a field doesn't break the code,
> though I'm not sure allowing this is useful. The offsetof (and the
> source in memcpy) also allows to add new fields at the beginning.
>
> And the way alx_update_hw_stats is written already includes a kind of
> check that all fields are present.
I was more worried about type mismatches. That's not really a concern
with u64 since that's the largest type that really makes sense here, but
if the type of some variables changed vs. the ethtool type u64...
Maybe I'm overly worried. It seems likely nobody will ever touch this
code again :)
johannes
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists