From f113099711f067ef90fcd433b7b2be84544f6537 Mon Sep 17 00:00:00 2001 From: Bowen Wang Date: Mon, 21 Oct 2024 21:33:04 +0800 Subject: [PATCH] rpmsg_virtio: fix the rpmsg_get_tx/rx_buffer() api user tx/rx buffer size = orignal tx/rx buffer_size - sizeof(rpmsg_hdr) And use buffer size in config to calculate the user buffer size instead the buffer size from virtqueue, because there may be no buffer in virtqueeu. Signed-off-by: Tao Yin Signed-off-by: Bowen Wang --- lib/rpmsg/rpmsg_virtio.c | 34 ++++++---------------------------- 1 file changed, 6 insertions(+), 28 deletions(-) diff --git a/lib/rpmsg/rpmsg_virtio.c b/lib/rpmsg/rpmsg_virtio.c index ac75c836..04291042 100644 --- a/lib/rpmsg/rpmsg_virtio.c +++ b/lib/rpmsg/rpmsg_virtio.c @@ -714,22 +714,11 @@ int rpmsg_virtio_get_tx_buffer_size(struct rpmsg_device *rdev) metal_mutex_acquire(&rdev->lock); rvdev = (struct rpmsg_virtio_device *)rdev; - if (VIRTIO_ROLE_IS_DRIVER(rvdev->vdev)) { - /* - * If device role is host then buffers are provided by us, - * so just provide the macro. - */ + if (VIRTIO_ROLE_IS_DRIVER(rvdev->vdev)) size = rvdev->config.h2r_buf_size - sizeof(struct rpmsg_hdr); - } - if (VIRTIO_ROLE_IS_DEVICE(rvdev->vdev)) { - /* - * If other core is host then buffers are provided by it, - * so get the buffer size from the virtqueue. - */ - size = (int)virtqueue_get_desc_size(rvdev->svq) - - sizeof(struct rpmsg_hdr); - } + if (VIRTIO_ROLE_IS_DEVICE(rvdev->vdev)) + size = rvdev->config.r2h_buf_size - sizeof(struct rpmsg_hdr); if (size <= 0) size = RPMSG_ERR_NO_BUFF; @@ -750,22 +739,11 @@ int rpmsg_virtio_get_rx_buffer_size(struct rpmsg_device *rdev) metal_mutex_acquire(&rdev->lock); rvdev = (struct rpmsg_virtio_device *)rdev; - if (VIRTIO_ROLE_IS_DRIVER(rvdev->vdev)) { - /* - * If device role is host then buffers are provided by us, - * so just provide the macro. - */ + if (VIRTIO_ROLE_IS_DRIVER(rvdev->vdev)) size = rvdev->config.r2h_buf_size - sizeof(struct rpmsg_hdr); - } - if (VIRTIO_ROLE_IS_DEVICE(rvdev->vdev)) { - /* - * If other core is host then buffers are provided by it, - * so get the buffer size from the virtqueue. - */ - size = (int)virtqueue_get_desc_size(rvdev->rvq) - - sizeof(struct rpmsg_hdr); - } + if (VIRTIO_ROLE_IS_DEVICE(rvdev->vdev)) + size = rvdev->config.h2r_buf_size - sizeof(struct rpmsg_hdr); if (size <= 0) size = RPMSG_ERR_NO_BUFF;