b59d4d5502
While it is worth clarifying whether the fake mbuf in virtnet_rx struct is really necessary, it is sure that it heavily impacts cache usage by being part of the struct. Indeed, it uses two cachelines, and requires alignment on a cacheline. Before this series, it means it took 120 bytes in virtnet_rx struct: struct virtnet_rx { struct virtqueue *vq; /*0 8*/ /* XXX 56 bytes hole, try to pack */ /* --- cacheline 1 boundary (64 bytes) --- */ struct rte_mbuf fake_mbuf __attribute__((__aligned__(64))); /*64 128*/ /* --- cacheline 3 boundary (192 bytes) --- */ This patch allocates it using malloc in order to optimize virtnet_rx cache usage and so virtqueue cache usage. Signed-off-by: Maxime Coquelin <maxime.coquelin@redhat.com> Reviewed-by: David Marchand <david.marchand@redhat.com> Reviewed-by: Chenbo Xia <chenbo.xia@intel.com> Tested-by: Balazs Nemeth <bnemeth@redhat.com>
63 lines
1.8 KiB
C
63 lines
1.8 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(c) 2010-2015 Intel Corporation
|
|
*/
|
|
|
|
#ifndef _VIRTIO_RXTX_H_
|
|
#define _VIRTIO_RXTX_H_
|
|
|
|
#define RTE_PMD_VIRTIO_RX_MAX_BURST 64
|
|
|
|
struct virtnet_stats {
|
|
uint64_t packets;
|
|
uint64_t bytes;
|
|
uint64_t errors;
|
|
uint64_t multicast;
|
|
uint64_t broadcast;
|
|
/* Size bins in array as RFC 2819, undersized [0], 64 [1], etc */
|
|
uint64_t size_bins[8];
|
|
};
|
|
|
|
struct virtnet_rx {
|
|
/* dummy mbuf, for wraparound when processing RX ring. */
|
|
struct rte_mbuf *fake_mbuf;
|
|
uint64_t mbuf_initializer; /**< value to init mbufs. */
|
|
struct rte_mempool *mpool; /**< mempool for mbuf allocation */
|
|
|
|
uint16_t queue_id; /**< DPDK queue index. */
|
|
uint16_t port_id; /**< Device port identifier. */
|
|
|
|
/* Statistics */
|
|
struct virtnet_stats stats;
|
|
|
|
const struct rte_memzone *mz; /**< mem zone to populate RX ring. */
|
|
};
|
|
|
|
struct virtnet_tx {
|
|
/**< memzone to populate hdr. */
|
|
const struct rte_memzone *virtio_net_hdr_mz;
|
|
rte_iova_t virtio_net_hdr_mem; /**< hdr for each xmit packet */
|
|
|
|
uint16_t queue_id; /**< DPDK queue index. */
|
|
uint16_t port_id; /**< Device port identifier. */
|
|
|
|
/* Statistics */
|
|
struct virtnet_stats stats;
|
|
|
|
const struct rte_memzone *mz; /**< mem zone to populate TX ring. */
|
|
};
|
|
|
|
struct virtnet_ctl {
|
|
/**< memzone to populate hdr. */
|
|
const struct rte_memzone *virtio_net_hdr_mz;
|
|
rte_iova_t virtio_net_hdr_mem; /**< hdr for each xmit packet */
|
|
uint16_t port_id; /**< Device port identifier. */
|
|
const struct rte_memzone *mz; /**< mem zone to populate CTL ring. */
|
|
rte_spinlock_t lock; /**< spinlock for control queue. */
|
|
};
|
|
|
|
int virtio_rxq_vec_setup(struct virtnet_rx *rxvq);
|
|
void virtio_update_packet_stats(struct virtnet_stats *stats,
|
|
struct rte_mbuf *mbuf);
|
|
|
|
#endif /* _VIRTIO_RXTX_H_ */
|