From 08183a36843d8f629d62c981a53b935d2da48878 Mon Sep 17 00:00:00 2001 From: Iztok Jeras <iztok.jeras@redpitaya.com> Date: 周五, 16 10月 2015 18:36:09 +0800 Subject: [PATCH] integer parser: added test which caused issues with gcc-linaro-4.9-2014.11-x86_64_arm-linux-gnueabihf cross compiler --- libscpi/src/fifo.c | 40 +++++++++++++++++++++++++++++++++------- 1 files changed, 33 insertions(+), 7 deletions(-) diff --git a/libscpi/src/fifo.c b/libscpi/src/fifo.c index cb9d385..a69cf85 100644 --- a/libscpi/src/fifo.c +++ b/libscpi/src/fifo.c @@ -1,18 +1,32 @@ -#include "scpi/fifo.h" +#include "fifo_private.h" -void fifo_init(fifo_t * fifo) { +/** + * Initialize fifo + * @param fifo + */ +void fifo_init(scpi_fifo_t * fifo) { fifo->wr = 0; fifo->rd = 0; fifo->size = FIFO_SIZE; } -void fifo_clear(fifo_t * fifo) { +/** + * Empty fifo + * @param fifo + */ +void fifo_clear(scpi_fifo_t * fifo) { fifo->wr = 0; fifo->rd = 0; } -bool_t fifo_add(fifo_t * fifo, int16_t value) { +/** + * Add element to fifo. If fifo is full, remove last element. + * @param fifo + * @param value + * @return + */ +scpi_bool_t fifo_add(scpi_fifo_t * fifo, int16_t value) { /* FIFO full? */ if (fifo->wr == ((fifo->rd + fifo->size) % (fifo->size + 1))) { fifo_remove(fifo, NULL); @@ -24,13 +38,19 @@ return TRUE; } -bool_t fifo_remove(fifo_t * fifo, int16_t * value) { +/** + * Remove element form fifo + * @param fifo + * @param value + * @return FALSE - fifo is empty + */ +scpi_bool_t fifo_remove(scpi_fifo_t * fifo, int16_t * value) { /* FIFO empty? */ if (fifo->wr == fifo->rd) { return FALSE; } - if(value) { + if (value) { *value = fifo->data[fifo->rd]; } @@ -39,7 +59,13 @@ return TRUE; } -bool_t fifo_count(fifo_t * fifo, int16_t * value) { +/** + * Retrive number of elements in fifo + * @param fifo + * @param value + * @return + */ +scpi_bool_t fifo_count(scpi_fifo_t * fifo, int16_t * value) { *value = fifo->wr - fifo->rd; if (*value < 0) { *value += (fifo->size + 1); -- Gitblit v1.9.1