virtio-net: Reduce debug name field size to 16 bytes
authorParav Pandit <parav@nvidia.com>
Mon, 23 Jan 2023 03:55:11 +0000 (05:55 +0200)
committerDavid S. Miller <davem@davemloft.net>
Wed, 25 Jan 2023 09:27:13 +0000 (09:27 +0000)
virtio queue index can be maximum of 65535. 16 bytes are enough to store
the vq name with the existing string prefix.

With this change, send queue struct saves 24 bytes and receive
queue saves whole cache line worth 64 bytes per structure
due to saving in alignment bytes.

Pahole results before:

pahole -s drivers/net/virtio_net.o | \
    grep -e "send_queue" -e "receive_queue"
send_queue      1112    0
receive_queue   1280    1

Pahole results after:
pahole -s drivers/net/virtio_net.o | \
    grep -e "send_queue" -e "receive_queue"
send_queue      1088    0
receive_queue   1216    1

Signed-off-by: Parav Pandit <parav@nvidia.com>
Reviewed-by: Pavan Chebbi <pavan.chebbi@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/virtio_net.c

index a170b0075dcfb6b47664053f461b559490ca6e8e..3855b85243006bf13466524bbdec46ea6775916a 100644 (file)
@@ -134,7 +134,7 @@ struct send_queue {
        struct scatterlist sg[MAX_SKB_FRAGS + 2];
 
        /* Name of the send queue: output.$index */
-       char name[40];
+       char name[16];
 
        struct virtnet_sq_stats stats;
 
@@ -171,7 +171,7 @@ struct receive_queue {
        unsigned int min_buf_len;
 
        /* Name of this receive queue: input.$index */
-       char name[40];
+       char name[16];
 
        struct xdp_rxq_info xdp_rxq;
 };