From bbefedd4950c05113e4025688d160196c61157c3 Mon Sep 17 00:00:00 2001 From: Guiding Li Date: Thu, 12 Oct 2023 17:07:00 +0800 Subject: [PATCH] rpmsg: set ept address to incease num when alloc from the bitmap CPU0 CPU1 create_ept1:addr1 create_ept1 OK <====== msg1 OK <====== msg2 OK <====== msg3 msg4 <====== msg4 on the virtioqueue close_ept1 close_ept1 create_ept2:addr1 create_ept1 (same addr with ept1) msg4 ept2 recv ept1 msg ERROR <====== The msg4 which belong to ep1, error received by ept2. For this issue, I give a resolve method: Let the rpmsg_get_address() always return a new increased num. Signed-off-by: Guiding Li --- lib/include/openamp/rpmsg.h | 1 + lib/rpmsg/rpmsg.c | 7 ++++--- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/lib/include/openamp/rpmsg.h b/lib/include/openamp/rpmsg.h index 9cf1e7444..35573ca78 100644 --- a/lib/include/openamp/rpmsg.h +++ b/lib/include/openamp/rpmsg.h @@ -125,6 +125,7 @@ struct rpmsg_device { /** Table endpoint address allocation */ unsigned long bitmap[metal_bitmap_longs(RPMSG_ADDR_BMP_SIZE)]; + unsigned int bitnext; /** Mutex lock for RPMsg management */ metal_mutex_t lock; diff --git a/lib/rpmsg/rpmsg.c b/lib/rpmsg/rpmsg.c index 5a9237f47..a9f1c1e84 100644 --- a/lib/rpmsg/rpmsg.c +++ b/lib/rpmsg/rpmsg.c @@ -24,12 +24,12 @@ * * @return A unique address */ -static uint32_t rpmsg_get_address(unsigned long *bitmap, int size) +static uint32_t rpmsg_get_address(unsigned long *bitmap, unsigned int start, int size) { unsigned int addr = RPMSG_ADDR_ANY; unsigned int nextbit; - nextbit = metal_bitmap_next_clear_bit(bitmap, 0, size); + nextbit = metal_bitmap_next_clear_bit(bitmap, start, size); if (nextbit < (uint32_t)size) { addr = RPMSG_RESERVED_ADDRESSES + nextbit; metal_bitmap_set_bit(bitmap, nextbit); @@ -277,11 +277,12 @@ int rpmsg_create_ept(struct rpmsg_endpoint *ept, struct rpmsg_device *rdev, metal_mutex_acquire(&rdev->lock); if (src == RPMSG_ADDR_ANY) { - addr = rpmsg_get_address(rdev->bitmap, RPMSG_ADDR_BMP_SIZE); + addr = rpmsg_get_address(rdev->bitmap, rdev->bitnext, RPMSG_ADDR_BMP_SIZE); if (addr == RPMSG_ADDR_ANY) { status = RPMSG_ERR_ADDR; goto ret_status; } + rdev->bitnext = (addr + 1) % RPMSG_ADDR_BMP_SIZE; } else if (src >= RPMSG_RESERVED_ADDRESSES) { status = rpmsg_is_address_set(rdev->bitmap, RPMSG_ADDR_BMP_SIZE, src);