aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnup Patel <anup.patel@wdc.com>2019-04-03 12:27:27 +0530
committerAtish Patra <atishp04@gmail.com>2019-04-03 13:48:38 -0700
commit3fbe233a159798ee0360cc978aa1c9c3c51f6d88 (patch)
treefb518b27251d6e05e285ffca6cf27b926801a680
parent9dc95021dbf29b96a84e0b7dca491f768aa0ef0d (diff)
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>
-rw-r--r--include/sbi/sbi_fifo.h13
-rw-r--r--lib/sbi_fifo.c18
2 files changed, 15 insertions, 16 deletions
diff --git a/include/sbi/sbi_fifo.h b/include/sbi/sbi_fifo.h
index 1a59518..3754a5e 100644
--- a/include/sbi/sbi_fifo.h
+++ b/include/sbi/sbi_fifo.h
@@ -15,21 +15,18 @@
#include <sbi/sbi_types.h>
struct sbi_fifo {
- /* Static members of struct */
void *queue;
- unsigned long entry_size;
- unsigned long num_entries;
- /* Dynamic members of struct protected by lock */
spinlock_t qlock;
- unsigned long avail;
- unsigned long head;
- unsigned long tail;
+ u16 entry_size;
+ u16 num_entries;
+ u16 avail;
+ u16 tail;
};
int sbi_fifo_dequeue(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,
- 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_full(struct sbi_fifo *fifo);
diff --git a/lib/sbi_fifo.c b/lib/sbi_fifo.c
index c0010e4..36ff6d0 100644
--- a/lib/sbi_fifo.c
+++ b/lib/sbi_fifo.c
@@ -13,13 +13,13 @@
#include <plat/string.h>
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->num_entries = entries;
fifo->entry_size = entry_size;
SPIN_LOCK_INIT(&fifo->qlock);
- fifo->avail = fifo->head = fifo->tail = 0;
+ fifo->avail = fifo->tail = 0;
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)
{
+ u32 head;
+
if (!fifo || !data)
return SBI_EINVAL;
@@ -69,13 +71,13 @@ int sbi_fifo_enqueue(struct sbi_fifo *fifo, void *data)
return SBI_ENOSPC;
}
- memcpy(fifo->queue + fifo->head * fifo->entry_size, data,
- fifo->entry_size);
+ head = (u32)fifo->tail + fifo->avail;
+ if (head >= fifo->num_entries)
+ head = head - fifo->num_entries;
+
+ memcpy(fifo->queue + head * fifo->entry_size, data, fifo->entry_size);
fifo->avail++;
- fifo->head++;
- if (fifo->head >= fifo->num_entries)
- fifo->head = 0;
spin_unlock(&fifo->qlock);
@@ -94,7 +96,7 @@ int sbi_fifo_dequeue(struct sbi_fifo *fifo, void *data)
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->avail--;