net: ena: Put orthogonal fields in ena_tx_buffer in a union
authorDavid Arinzon <darinzon@amazon.com>
Mon, 1 Jan 2024 19:08:47 +0000 (19:08 +0000)
committerJakub Kicinski <kuba@kernel.org>
Thu, 4 Jan 2024 02:00:57 +0000 (18:00 -0800)
The skb and xdpf pointers cannot be set together in the driver
(each TX descriptor can send either an SKB or an XDP frame), and so it
makes more sense to put them both in a union.

This decreases the overall size of the ena_tx_buffer struct which
improves cache locality.

Signed-off-by: Shay Agroskin <shayagr@amazon.com>
Signed-off-by: David Arinzon <darinzon@amazon.com>
Link: https://lore.kernel.org/r/20240101190855.18739-4-darinzon@amazon.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/amazon/ena/ena_netdev.h

index 236d1f859a783e294af666168e5cad1d1f779fd7..78a4dee5a3c6b9fad1bc4cd3aff70a3b3e3ec3cf 100644 (file)
@@ -131,7 +131,13 @@ struct ena_napi {
 };
 
 struct ena_tx_buffer {
-       struct sk_buff *skb;
+       union {
+               struct sk_buff *skb;
+               /* XDP buffer structure which is used for sending packets in
+                * the xdp queues
+                */
+               struct xdp_frame *xdpf;
+       };
        /* num of ena desc for this specific skb
         * (includes data desc and metadata desc)
         */
@@ -139,10 +145,6 @@ struct ena_tx_buffer {
        /* num of buffers used by this skb */
        u32 num_of_bufs;
 
-       /* XDP buffer structure which is used for sending packets in
-        * the xdp queues
-        */
-       struct xdp_frame *xdpf;
 
        /* Indicate if bufs[0] map the linear data of the skb. */
        u8 map_linear_data;