All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v4 0/3] virtio support cache indirect desc
@ 2021-11-08 11:49 ` Xuan Zhuo
  0 siblings, 0 replies; 25+ messages in thread
From: Xuan Zhuo @ 2021-11-08 11:49 UTC (permalink / raw)
  To: virtualization, netdev
  Cc: Michael S. Tsirkin, Jason Wang, David S. Miller, Jakub Kicinski

If the VIRTIO_RING_F_INDIRECT_DESC negotiation succeeds, and the number
of sgs used for sending packets is greater than 1. We must constantly
call __kmalloc/kfree to allocate/release desc.

In the case of extremely fast package delivery, the overhead cannot be
ignored:

  27.46%  [kernel]  [k] virtqueue_add
  16.66%  [kernel]  [k] detach_buf_split
  16.51%  [kernel]  [k] virtnet_xsk_xmit
  14.04%  [kernel]  [k] virtqueue_add_outbuf
   5.18%  [kernel]  [k] __kmalloc
   4.08%  [kernel]  [k] kfree
   2.80%  [kernel]  [k] virtqueue_get_buf_ctx
   2.22%  [kernel]  [k] xsk_tx_peek_desc
   2.08%  [kernel]  [k] memset_erms
   0.83%  [kernel]  [k] virtqueue_kick_prepare
   0.76%  [kernel]  [k] virtnet_xsk_run
   0.62%  [kernel]  [k] __free_old_xmit_ptr
   0.60%  [kernel]  [k] vring_map_one_sg
   0.53%  [kernel]  [k] native_apic_mem_write
   0.46%  [kernel]  [k] sg_next
   0.43%  [kernel]  [k] sg_init_table
   0.41%  [kernel]  [k] kmalloc_slab

This patch adds a cache function to virtio to cache these allocated indirect
desc instead of constantly allocating and releasing desc.

v4:
    1. Only allow desc cache when VIRTIO_RING_F_INDIRECT_DESC negotiation is successful
    2. The desc cache threshold can be set for each virtqueue

v3:
  pre-allocate per buffer indirect descriptors array

v2:
  use struct list_head to cache the desc

Xuan Zhuo (3):
  virtio: cache indirect desc for split
  virtio: cache indirect desc for packed
  virtio-net: enable virtio desc cache

 drivers/net/virtio_net.c     |  12 ++-
 drivers/virtio/virtio_ring.c | 152 +++++++++++++++++++++++++++++++----
 include/linux/virtio.h       |  17 ++++
 3 files changed, 163 insertions(+), 18 deletions(-)

--
2.31.0


^ permalink raw reply	[flat|nested] 25+ messages in thread

end of thread, other threads:[~2021-11-12  1:53 UTC | newest]

Thread overview: 25+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-11-08 11:49 [PATCH v4 0/3] virtio support cache indirect desc Xuan Zhuo
2021-11-08 11:49 ` Xuan Zhuo
2021-11-08 11:49 ` [PATCH v4 1/3] virtio: cache indirect desc for split Xuan Zhuo
2021-11-08 11:49   ` Xuan Zhuo
2021-11-09 13:09   ` Michael S. Tsirkin
2021-11-09 13:09     ` Michael S. Tsirkin
2021-11-09 15:00     ` Xuan Zhuo
2021-11-08 11:49 ` [PATCH v4 2/3] virtio: cache indirect desc for packed Xuan Zhuo
2021-11-08 11:49   ` Xuan Zhuo
2021-11-08 11:49 ` [PATCH v4 3/3] virtio-net: enable virtio desc cache Xuan Zhuo
2021-11-08 11:49   ` Xuan Zhuo
2021-11-08 13:49 ` [PATCH v4 0/3] virtio support cache indirect desc Michael S. Tsirkin
2021-11-08 13:49   ` Michael S. Tsirkin
2021-11-08 14:47   ` Xuan Zhuo
2021-11-10 12:53     ` Michael S. Tsirkin
2021-11-10 12:53       ` Michael S. Tsirkin
2021-11-10 12:54       ` Michael S. Tsirkin
2021-11-10 12:54         ` Michael S. Tsirkin
2021-11-11  6:52       ` Xuan Zhuo
2021-11-11 15:02         ` Michael S. Tsirkin
2021-11-11 15:02           ` Michael S. Tsirkin
2021-11-12  1:53           ` Xuan Zhuo
2021-11-09 13:03 ` Michael S. Tsirkin
2021-11-09 13:03   ` Michael S. Tsirkin
2021-11-09 15:14   ` Xuan Zhuo

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.