On Thu, 18 Apr 2024 14:26:33 +0800, Jason Wang <jasowang@xxxxxxxxxx> wrote: > On Thu, Apr 11, 2024 at 10:51 AM Xuan Zhuo <xuanzhuo@xxxxxxxxxxxxxxxxx> wrote: > > > > Currently, big, merge, and small modes all support the premapped mode. > > We can now enable premapped mode by default. Furthermore, > > virtqueue_set_dma_premapped() must succeed when called immediately after > > find_vqs(). Consequently, we can assume that premapped mode is always > > enabled. > > > > Signed-off-by: Xuan Zhuo <xuanzhuo@xxxxxxxxxxxxxxxxx> > > --- > > drivers/net/virtio_net.c | 12 +++++------- > > 1 file changed, 5 insertions(+), 7 deletions(-) > > > > diff --git a/drivers/net/virtio_net.c b/drivers/net/virtio_net.c > > index 7ea7e9bcd5d7..f0faf7c0fe59 100644 > > --- a/drivers/net/virtio_net.c > > +++ b/drivers/net/virtio_net.c > > @@ -860,15 +860,13 @@ static void *virtnet_rq_alloc(struct receive_queue *rq, u32 size, gfp_t gfp) > > > > static void virtnet_rq_set_premapped(struct virtnet_info *vi) > > { > > - int i; > > - > > - /* disable for big mode */ > > - if (!vi->mergeable_rx_bufs && vi->big_packets) > > - return; > > + int i, err; > > > > for (i = 0; i < vi->max_queue_pairs; i++) { > > - if (virtqueue_set_dma_premapped(vi->rq[i].vq)) > > - continue; > > + err = virtqueue_set_dma_premapped(vi->rq[i].vq); > > + > > + /* never happen */ > > + BUG_ON(err); > > Nit: > > Maybe just a BUG_ON(virtqueue_set_dma_premapped()). OK > > Btw, if there's no way to disable pre mapping, maybe it's better to > rename virtqueue_set_dma_premapped() to > virtqueue_enable_dma_premapped(ing). This patch will add a way to disable pre mapping. https://lore.kernel.org/all/20240327111430.108787-11-xuanzhuo@xxxxxxxxxxxxxxxxx/ Thanks. > > Thanks > > > > > vi->rq[i].do_dma = true; > > } > > -- > > 2.32.0.3.g01195cf9f > > >