Merge branch 'skbuff-bitfields'
authorDavid S. Miller <davem@davemloft.net>
Wed, 19 Apr 2023 12:04:31 +0000 (13:04 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 19 Apr 2023 12:04:31 +0000 (13:04 +0100)
commitfbb192a836bee873e4e94c5deca19bf558ab7bb9
tree6938e8d57eebc712f9820a5f363e9d4840b284f2
parent4edd97fbdc23e917ef0787dbf0ccc543b400bb34
parent48d80c394d3d1afcb49d26398917f5be27bf44cb
Merge branch 'skbuff-bitfields'

Jakub Kicinski says:

====================
net: skbuff: hide some bitfield members

There is a number of protocol or subsystem specific fields
in struct sk_buff which are only accessed by one subsystem.
We can wrap them in ifdefs with minimal code impact.

This gives us a better chance to save a 2B and a 4B holes
resulting with the following savings (assuming a lucky
kernel config):

- /* size: 232, cachelines: 4, members: 28 */
- /* sum members: 227, holes: 1, sum holes: 4 */
- /* sum bitfield members: 8 bits (1 bytes) */
+ /* size: 224, cachelines: 4, members: 28 */
  /* forced alignments: 2 */
- /* last cacheline: 40 bytes */
+ /* last cacheline: 32 bytes */

I think that the changes shouldn't be too controversial.
The only one I'm not 100% sure of is the SCTP one,
12 extra LoC for one bit.. But it did fit squarely
in the "this bit has only one user" category.
====================

Signed-off-by: David S. Miller <davem@davemloft.net>
Acked-by: Simon Horman <horms@kernel.org>