[PATCH 3/6] lib: sbi: Optimize fifo enqueue/dequeue for basic data types
Himanshu Chauhan
hchauhan at ventanamicro.com
Tue Jul 23 22:37:36 PDT 2024
On Fri, Jul 5, 2024 at 12:45 PM Anup Patel <apatel at ventanamicro.com> wrote:
>
> Don't use sbi_memcpy() for basic data types in fifo enqueue/dequeue
> instead use direct type-cast and assignment.
>
> Signed-off-by: Anup Patel <apatel at ventanamicro.com>
> ---
> lib/sbi/sbi_fifo.c | 43 ++++++++++++++++++++++++++++++++++++++++---
> 1 file changed, 40 insertions(+), 3 deletions(-)
>
> diff --git a/lib/sbi/sbi_fifo.c b/lib/sbi/sbi_fifo.c
> index 72c6d39..9199a30 100644
> --- a/lib/sbi/sbi_fifo.c
> +++ b/lib/sbi/sbi_fifo.c
> @@ -66,7 +66,26 @@ static inline void __sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data)
> if (head >= fifo->num_entries)
> head = head - fifo->num_entries;
>
> - sbi_memcpy((char *)fifo->queue + head * fifo->entry_size, data, fifo->entry_size);
> + switch (fifo->entry_size) {
> + case 1:
> + *(char *)(fifo->queue + head * fifo->entry_size) = *(char *)data;
> + break;
> + case 2:
> + *(u16 *)(fifo->queue + head * fifo->entry_size) = *(u16 *)data;
> + break;
> + case 4:
> + *(u32 *)(fifo->queue + head * fifo->entry_size) = *(u32 *)data;
> + break;
> +#if __riscv_xlen > 32
> + case 8:
> + *(u64 *)(fifo->queue + head * fifo->entry_size) = *(u64 *)data;
> + break;
> +#endif
> + default:
> + sbi_memcpy(fifo->queue + head * fifo->entry_size,
> + data, fifo->entry_size);
> + break;
> + }
>
> fifo->avail++;
> }
> @@ -184,8 +203,26 @@ int sbi_fifo_dequeue(struct sbi_fifo *fifo, void *data)
> return SBI_ENOENT;
> }
>
> - sbi_memcpy(data, (char *)fifo->queue + (u32)fifo->tail * fifo->entry_size,
> - fifo->entry_size);
> + switch (fifo->entry_size) {
> + case 1:
> + *(char *)data = *(char *)(fifo->queue + (u32)fifo->tail * fifo->entry_size);
> + break;
> + case 2:
> + *(u16 *)data = *(u16 *)(fifo->queue + (u32)fifo->tail * fifo->entry_size);
> + break;
> + case 4:
> + *(u32 *)data = *(u32 *)(fifo->queue + (u32)fifo->tail * fifo->entry_size);
> + break;
> +#if __riscv_xlen > 32
> + case 8:
> + *(u64 *)data = *(u64 *)(fifo->queue + (u32)fifo->tail * fifo->entry_size);
> + break;
> +#endif
> + default:
> + sbi_memcpy(data, fifo->queue + (u32)fifo->tail * fifo->entry_size,
> + fifo->entry_size);
> + break;
> + }
>
> fifo->avail--;
> fifo->tail++;
> --
> 2.34.1
>
LGTM
Reviewed-By: Himanshu Chauhan <hchauhan at ventanamicro.com>
>
>
> --
> opensbi mailing list
> opensbi at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/opensbi
More information about the opensbi
mailing list