From: Vladimir Oltean <vladimir.oltean@nxp.com>
To: Jacob Keller <jacob.e.keller@intel.com>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
Tony Nguyen <anthony.l.nguyen@intel.com>,
Przemek Kitszel <przemyslaw.kitszel@intel.com>,
Masahiro Yamada <masahiroy@kernel.org>,
netdev <netdev@vger.kernel.org>
Subject: Re: [PATCH net-next v8 03/10] lib: packing: add pack_fields() and unpack_fields()
Date: Thu, 5 Dec 2024 01:52:09 +0200 [thread overview]
Message-ID: <20241204235209.v4xjweehhp5knbew@skbuf> (raw)
In-Reply-To: <998519c0-a03f-4190-a090-f8ada78ea376@intel.com>
On Wed, Dec 04, 2024 at 03:24:59PM -0800, Jacob Keller wrote:
> On 12/4/2024 9:12 AM, Vladimir Oltean wrote:
> > And there's one more thing I tried, which mostly worked. That was to
> > express CHECK_PACKED_FIELDS_N in terms of CHECK_PACKED_FIELDS_N-1.
> > This further reduced the auto-generated code size from 1478 lines to 302
> > lines, which I think is appealing.
> >
>
> I figured it out! There are two key issues involved:
>
> > diff --git a/scripts/gen_packed_field_checks.c b/scripts/gen_packed_field_checks.c
> > index fabbb741c9a8..bac85c04ef20 100644
> > --- a/scripts/gen_packed_field_checks.c
> > +++ b/scripts/gen_packed_field_checks.c
> > @@ -10,9 +10,10 @@ int main(int argc, char **argv)
> > for (int i = 1; i <= MAX_PACKED_FIELD_SIZE; i++) {
> > printf("#define CHECK_PACKED_FIELDS_%d(fields) ({ \\\n", i);
> >
> > - for (int j = 0; j < i; j++)
> > - printf("\tCHECK_PACKED_FIELD(fields, %d); \\\n", j);
> > + if (i != 1)
> > + printf("\tCHECK_PACKED_FIELDS_%d(fields); \\\n", i - 1);
> >
> > + printf("\tCHECK_PACKED_FIELD(fields, %d); \\\n", i);
>
> This needs to be i - 1, since arrays are 0-indexed, so this code expands
> to checking the wrong value.
>
> CHECK_PACKED_FIELDS_1 needs to become
>
> CHECK_PACKED_FIELD(fields, 0)
>
> but this code makes it:
>
> CHECK_PACKED_FIELD(fields, 1)
>
> Thus, all the array definitions are off-by-one, leading to the last one
> being out-of-bounds.
ah :-/
I should have paid more attention, sorry.
> > printf("})\n\n");
> > }
> >
> >
> > The problem is that, for some reason, it introduces this sparse warning:
> >
> > ../lib/packing_test.c:436:9: warning: invalid access past the end of 'test_fields' (24 24)
> > ../lib/packing_test.c:448:9: warning: invalid access past the end of 'test_fields' (24 24)
> >
> > Nobody accesses past element 6 (ARRAY_SIZE) of test_fields[]. I ran the
>
> The array size is 6, but we try to access element 6 which is one past
> the array... good old off-by-one error :)
>
> There is one further complication which is that the nested statement
> expressions ({ ... }) for each CHECK_PACKED_FIELD_N eventually make GCC
> confused, as it doesn't seem to keep track of the types very well.
I only tested with clang which didn't complain, sorry.
> I fixed that by changing the individual CHECK_PACKED_FIELD_N to be
> non-statement expressions, and then wrapping their calls in the
> builtin_choose_expr() with ({ ... }), which prevents us from creating
> too many expression layers for GCC. It actually results in identical
> code being evaluated as with the old version but now with a constant
> scaling of the text size: 2 lines per additional check.
Yeah, I think that was the logical next development step. By doing this now,
I think you just saved an extra patch iteration, thanks.
> Of course the complexity scales linearly, but that means our text size
> no longer scales with O(n*log(n)) but just as O(N).
Well, technically, the number of lines of code required, in "naive" form,
for overlap checking of arrays up to length N should be N*(N+1)/2, which
"grows quicker" than N*log(N).
But I don't think we can talk about algorithmic complexity here (big O
notation), which stays the same (linear) in both ways of expressing the
same thing.
> Its fantastic improvement, thanks for the suggestion. I'll have v9 out
> with these improvements soon.
And thanks for staying online with this effort for more than an entire
kernel development cycle! Looking forward to v9.
next prev parent reply other threads:[~2024-12-04 23:52 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-03 23:53 [PATCH net-next v8 00/10] lib: packing: introduce and use (un)pack_fields Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 01/10] lib: packing: create __pack() and __unpack() variants without error checking Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 02/10] lib: packing: demote truncation error in pack() to a warning in __pack() Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 03/10] lib: packing: add pack_fields() and unpack_fields() Jacob Keller
2024-12-04 17:12 ` Vladimir Oltean
2024-12-04 18:47 ` Jacob Keller
2024-12-04 23:24 ` Jacob Keller
2024-12-04 23:52 ` Vladimir Oltean [this message]
2024-12-05 0:23 ` Jacob Keller
2024-12-04 23:43 ` Przemek Kitszel
2024-12-05 9:52 ` Vladimir Oltean
2024-12-05 21:26 ` Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 04/10] lib: packing: document recently added APIs Jacob Keller
2024-12-04 23:26 ` Vladimir Oltean
2024-12-04 23:31 ` Vladimir Oltean
2024-12-03 23:53 ` [PATCH net-next v8 05/10] ice: remove int_q_state from ice_tlan_ctx Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 06/10] ice: use structures to keep track of queue context size Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 07/10] ice: use <linux/packing.h> for Tx and Rx queue context data Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 08/10] ice: reduce size of queue context fields Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 09/10] ice: move prefetch enable to ice_setup_rx_ctx Jacob Keller
2024-12-03 23:53 ` [PATCH net-next v8 10/10] ice: cleanup Rx queue context programming functions Jacob Keller
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20241204235209.v4xjweehhp5knbew@skbuf \
--to=vladimir.oltean@nxp.com \
--cc=akpm@linux-foundation.org \
--cc=anthony.l.nguyen@intel.com \
--cc=edumazet@google.com \
--cc=jacob.e.keller@intel.com \
--cc=kuba@kernel.org \
--cc=masahiroy@kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=przemyslaw.kitszel@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox