lib: Pack struct sbi_fifo

This patch reduces memory consumed by struct sbi_fifo by droping
redundant "head" member and using u16 in-place of "unsigned long".

Signed-off-by: Anup Patel <anup.patel@wdc.com>
This commit is contained in:
Anup Patel
2019-04-03 12:27:27 +05:30
committed by Atish Patra
parent 9dc95021db
commit 3fbe233a15
2 changed files with 15 additions and 16 deletions

View File

@@ -15,21 +15,18 @@
#include <sbi/sbi_types.h> #include <sbi/sbi_types.h>
struct sbi_fifo { struct sbi_fifo {
/* Static members of struct */
void *queue; void *queue;
unsigned long entry_size;
unsigned long num_entries;
/* Dynamic members of struct protected by lock */
spinlock_t qlock; spinlock_t qlock;
unsigned long avail; u16 entry_size;
unsigned long head; u16 num_entries;
unsigned long tail; u16 avail;
u16 tail;
}; };
int sbi_fifo_dequeue(struct sbi_fifo *fifo, void *data); int sbi_fifo_dequeue(struct sbi_fifo *fifo, void *data);
int sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data); int sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data);
void sbi_fifo_init(struct sbi_fifo *fifo, void *queue_mem, void sbi_fifo_init(struct sbi_fifo *fifo, void *queue_mem,
unsigned long entries, unsigned long entry_size); u16 entries, u16 entry_size);
bool sbi_fifo_is_empty(struct sbi_fifo *fifo); bool sbi_fifo_is_empty(struct sbi_fifo *fifo);
bool sbi_fifo_is_full(struct sbi_fifo *fifo); bool sbi_fifo_is_full(struct sbi_fifo *fifo);

View File

@@ -13,13 +13,13 @@
#include <plat/string.h> #include <plat/string.h>
void sbi_fifo_init(struct sbi_fifo *fifo, void *queue_mem, void sbi_fifo_init(struct sbi_fifo *fifo, void *queue_mem,
unsigned long entries, unsigned long entry_size) u16 entries, u16 entry_size)
{ {
fifo->queue = queue_mem; fifo->queue = queue_mem;
fifo->num_entries = entries; fifo->num_entries = entries;
fifo->entry_size = entry_size; fifo->entry_size = entry_size;
SPIN_LOCK_INIT(&fifo->qlock); SPIN_LOCK_INIT(&fifo->qlock);
fifo->avail = fifo->head = fifo->tail = 0; fifo->avail = fifo->tail = 0;
memset(fifo->queue, 0, entries * entry_size); memset(fifo->queue, 0, entries * entry_size);
} }
@@ -59,6 +59,8 @@ bool sbi_fifo_is_empty(struct sbi_fifo *fifo)
int sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data) int sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data)
{ {
u32 head;
if (!fifo || !data) if (!fifo || !data)
return SBI_EINVAL; return SBI_EINVAL;
@@ -69,13 +71,13 @@ int sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data)
return SBI_ENOSPC; return SBI_ENOSPC;
} }
memcpy(fifo->queue + fifo->head * fifo->entry_size, data, head = (u32)fifo->tail + fifo->avail;
fifo->entry_size); if (head >= fifo->num_entries)
head = head - fifo->num_entries;
memcpy(fifo->queue + head * fifo->entry_size, data, fifo->entry_size);
fifo->avail++; fifo->avail++;
fifo->head++;
if (fifo->head >= fifo->num_entries)
fifo->head = 0;
spin_unlock(&fifo->qlock); spin_unlock(&fifo->qlock);
@@ -94,7 +96,7 @@ int sbi_fifo_dequeue(struct sbi_fifo *fifo, void *data)
return SBI_ENOENT; return SBI_ENOENT;
} }
memcpy(data, fifo->queue + fifo->tail * fifo->entry_size, memcpy(data, fifo->queue + (u32)fifo->tail * fifo->entry_size,
fifo->entry_size); fifo->entry_size);
fifo->avail--; fifo->avail--;