From 323ec66d62f19673e66762fe25585746d3b2a5e0 Mon Sep 17 00:00:00 2001 From: Jan Breuer <jan.breuer@jaybee.cz> Date: 周三, 18 3月 2015 17:09:30 +0800 Subject: [PATCH] Add new AUTO special value, resolve #20 --- libscpi/src/fifo.c | 12 +++++++----- 1 files changed, 7 insertions(+), 5 deletions(-) diff --git a/libscpi/src/fifo.c b/libscpi/src/fifo.c index 7c80c9f..ff8a345 100644 --- a/libscpi/src/fifo.c +++ b/libscpi/src/fifo.c @@ -12,10 +12,10 @@ fifo->rd = 0; } -bool_t fifo_push(fifo_t * fifo, int16_t value) { +scpi_bool_t fifo_add(fifo_t * fifo, int16_t value) { /* FIFO full? */ if (fifo->wr == ((fifo->rd + fifo->size) % (fifo->size + 1))) { - return FALSE; + fifo_remove(fifo, NULL); } fifo->data[fifo->wr] = value; @@ -24,20 +24,22 @@ return TRUE; } -bool_t fifo_pop(fifo_t * fifo, int16_t * value) { +scpi_bool_t fifo_remove(fifo_t * fifo, int16_t * value) { /* FIFO empty? */ if (fifo->wr == fifo->rd) { return FALSE; } - *value = fifo->data[fifo->rd]; + if(value) { + *value = fifo->data[fifo->rd]; + } fifo->rd = (fifo->rd + 1) % (fifo->size + 1); return TRUE; } -bool_t fifo_count(fifo_t * fifo, int16_t * value) { +scpi_bool_t fifo_count(fifo_t * fifo, int16_t * value) { *value = fifo->wr - fifo->rd; if (*value < 0) { *value += (fifo->size + 1); -- Gitblit v1.9.1