diff options
author | Gwendal Grignou <gwendal@chromium.org> | 2015-05-30 11:40:34 -0700 |
---|---|---|
committer | ChromeOS Commit Bot <chromeos-commit-bot@chromium.org> | 2015-06-09 12:10:37 +0000 |
commit | f58d821a5ac305c963722997713c6fc35a4dc6f7 (patch) | |
tree | ef366e68fc1cd970272daabe67cd29baea01f8c3 /common | |
parent | 930e001165c2df0b491288b2a8de1071b58ac6ec (diff) | |
download | chrome-ec-f58d821a5ac305c963722997713c6fc35a4dc6f7.tar.gz |
Queue: add peek_memcpy function
Add queue_peek_memcpy to peek at queue and move the element using
specific memcpy function.
Also change memcpy prototype argument from void const * to const void*.
BUG=none
BRANCH=none
TEST=Compile and use.
Change-Id: I8c582563e7d204ee5568637f819d63404624faf6
Signed-off-by: Gwendal Grignou <gwendal@chromium.org>
Reviewed-on: https://chromium-review.googlesource.com/274226
Reviewed-by: Vincent Palatin <vpalatin@chromium.org>
Reviewed-by: Bill Richardson <wfrichar@chromium.org>
Reviewed-by: Anton Staaf <robotboy@chromium.org>
Diffstat (limited to 'common')
-rw-r--r-- | common/queue.c | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/common/queue.c b/common/queue.c index 6e5e9e65ad..e289584a85 100644 --- a/common/queue.c +++ b/common/queue.c @@ -42,7 +42,7 @@ size_t queue_space(struct queue const *q) return q->buffer_units - queue_count(q); } -size_t queue_add_unit(struct queue const *q, void const *src) +size_t queue_add_unit(struct queue const *q, const void *src) { size_t tail = q->state->tail & (q->buffer_units - 1); @@ -61,16 +61,16 @@ size_t queue_add_unit(struct queue const *q, void const *src) return 1; } -size_t queue_add_units(struct queue const *q, void const *src, size_t count) +size_t queue_add_units(struct queue const *q, const void *src, size_t count) { return queue_add_memcpy(q, src, count, memcpy); } size_t queue_add_memcpy(struct queue const *q, - void const *src, + const void *src, size_t count, void *(*memcpy)(void *dest, - void const *src, + const void *src, size_t n)) { size_t transfer = MIN(count, queue_space(q)); @@ -98,7 +98,7 @@ static void queue_read_safe(struct queue const *q, size_t head, size_t transfer, void *(*memcpy)(void *dest, - void const *src, + const void *src, size_t n)) { size_t first = MIN(transfer, q->buffer_units - head); @@ -141,7 +141,7 @@ size_t queue_remove_memcpy(struct queue const *q, void *dest, size_t count, void *(*memcpy)(void *dest, - void const *src, + const void *src, size_t n)) { size_t transfer = MIN(count, queue_count(q)); @@ -161,6 +161,17 @@ size_t queue_peek_units(struct queue const *q, size_t i, size_t count) { + return queue_peek_memcpy(q, dest, i, count, memcpy); +} + +size_t queue_peek_memcpy(struct queue const *q, + void *dest, + size_t i, + size_t count, + void *(*memcpy)(void *dest, + const void *src, + size_t n)) +{ size_t available = queue_count(q); size_t transfer = MIN(count, available - i); |