From 759ba256e86cd46b48669f892fa0a672630e3157 Mon Sep 17 00:00:00 2001 From: patacongo Date: Sat, 26 Jul 2008 14:02:46 +0000 Subject: [PATCH] Minor pipe updates git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@780 42af7a65-404d-4744-a932-0658087f49c3 --- Documentation/NuttxPortingGuide.html | 4 +-- configs/README.txt | 4 +-- drivers/fifo.c | 4 +-- drivers/pipe-common.c | 54 ++++++++++++++-------------- drivers/pipe-common.h | 26 +++++++------- drivers/pipe.c | 4 +-- 6 files changed, 48 insertions(+), 48 deletions(-) diff --git a/Documentation/NuttxPortingGuide.html b/Documentation/NuttxPortingGuide.html index c164f5a54b..4c07bbba76 100644 --- a/Documentation/NuttxPortingGuide.html +++ b/Documentation/NuttxPortingGuide.html @@ -1510,8 +1510,8 @@ The system can be re-made subsequently by just typing make. watchdog structures to minimize dynamic allocations
  • - CONFIG_DEV_FIFO_SIZE: Size, in bytes, of the buffer to allocated - for FIFO support (default is 1024). + CONFIG_DEV_PIPE_SIZE: Size, in bytes, of the buffer to allocated + for pipe and FIFO support (default is 1024).
  • diff --git a/configs/README.txt b/configs/README.txt index 1de7e8def8..24b91112c0 100644 --- a/configs/README.txt +++ b/configs/README.txt @@ -239,8 +239,8 @@ defconfig -- This is a configuration file similar to the Linux CONFIG_PREALLOC_WDOGS - The number of pre-allocated watchdog structures. The system manages a pool of preallocated watchdog structures to minimize dynamic allocations - CONFIG_DEV_FIFO_SIZE - Size, in bytes, of the buffer to allocated - for FIFO support + CONFIG_DEV_PIPE_SIZE - Size, in bytes, of the buffer to allocated + for pipe and FIFO support TCP/IP and UDP support via uIP CONFIG_NET - Enable or disable all network features diff --git a/drivers/fifo.c b/drivers/fifo.c index 8435c597fe..88ab1deb60 100644 --- a/drivers/fifo.c +++ b/drivers/fifo.c @@ -49,7 +49,7 @@ #include "pipe-common.h" -#if CONFIG_DEV_FIFO_SIZE > 0 +#if CONFIG_DEV_PIPE_SIZE > 0 /**************************************************************************** * Definitions @@ -129,4 +129,4 @@ int mkfifo(FAR const char *pathname, mode_t mode) } return ret; } -#endif /* CONFIG_DEV_FIFO_SIZE > 0 */ +#endif /* CONFIG_DEV_PIPE_SIZE > 0 */ diff --git a/drivers/pipe-common.c b/drivers/pipe-common.c index a2bf391aaa..1004d15f87 100644 --- a/drivers/pipe-common.c +++ b/drivers/pipe-common.c @@ -56,7 +56,7 @@ #include "pipe-common.h" -#if CONFIG_DEV_FIFO_SIZE > 0 +#if CONFIG_DEV_PIPE_SIZE > 0 /**************************************************************************** * Definitions @@ -106,7 +106,7 @@ FAR struct pipe_dev_s *pipecommon_allocdev(void) { struct pipe_dev_s *dev; - /* Allocate a private structure to manage the FIFO */ + /* Allocate a private structure to manage the pipe */ dev = (struct pipe_dev_s *)malloc(sizeof(struct pipe_dev_s)); if (dev) @@ -162,6 +162,8 @@ int pipecommon_open(FAR struct file *filep) dev->s.d_nwriters++; } + /* If opened for read-only, then wait for at least one writer on the pipe */ + (void)sem_post(&dev->s.d_bfsem); return OK; } @@ -175,6 +177,7 @@ int pipecommon_close(FAR struct file *filep) { struct inode *inode = filep->f_inode; struct pipe_dev_s *dev = inode->i_private; + int sval; /* Some sanity checking */ #if CONFIG_DEBUG @@ -203,14 +206,16 @@ int pipecommon_close(FAR struct file *filep) if ((filep->f_oflags & O_WROK) != 0) { - /* If there are no longer any writers on the pipe, then notify any - * waiting readers that must return end-of-file. + /* If there are no longer any writers on the pipe, then notify all of the + * waiting readers that they must return end-of-file. */ - if (--dev->s.d_nwriters <= 0 && dev->s.d_rdwaiters > 0) + if (--dev->s.d_nwriters <= 0) { - dev->s.d_rdwaiters--; - sem_post(&dev->s.d_rdsem); + while (sem_getvalue(&dev->s.d_rdsem, &sval) == 0 && sval < 0) + { + sem_post(&dev->s.d_rdsem); + } } } sem_post(&dev->s.d_bfsem); @@ -222,7 +227,7 @@ int pipecommon_close(FAR struct file *filep) inode->i_private = NULL; sem_post(&dev->s.d_bfsem); - /* Then free the fifo structure instance */ + /* Then free the pipe structure instance */ pipecommon_freedev(dev); } @@ -237,6 +242,7 @@ ssize_t pipecommon_read(FAR struct file *filep, FAR char *buffer, size_t len) struct inode *inode = filep->f_inode; struct pipe_dev_s *dev = inode->i_private; ssize_t nread = 0; + int sval; int ret; /* Some sanity checking */ @@ -254,7 +260,7 @@ ssize_t pipecommon_read(FAR struct file *filep, FAR char *buffer, size_t len) return ERROR; } - /* If the fifo is empty, then wait for something to be written to it */ + /* If the pipe is empty, then wait for something to be written to it */ while (dev->s.d_wrndx == dev->s.d_rdndx) { @@ -274,9 +280,8 @@ ssize_t pipecommon_read(FAR struct file *filep, FAR char *buffer, size_t len) return 0; } - /* Otherwise, wait for something to be written to the FIFO */ + /* Otherwise, wait for something to be written to the pipe */ - dev->s.d_rdwaiters++; sched_lock(); sem_post(&dev->s.d_bfsem); ret = sem_wait(&dev->s.d_rdsem); @@ -287,24 +292,23 @@ ssize_t pipecommon_read(FAR struct file *filep, FAR char *buffer, size_t len) } } - /* Then return whatever is available in the FIFO (which is at least one byte) */ + /* Then return whatever is available in the pipe (which is at least one byte) */ nread = 0; while (nread < len && dev->s.d_wrndx != dev->s.d_rdndx) { *buffer++ = dev->d_buffer[dev->s.d_rdndx]; - if (++dev->s.d_rdndx >= CONFIG_DEV_FIFO_SIZE) + if (++dev->s.d_rdndx >= CONFIG_DEV_PIPE_SIZE) { dev->s.d_rdndx = 0; } nread++; } - /* Notify any waiting writers that bytes have been removed from the buffer */ + /* Notify all waiting writers that bytes have been removed from the buffer */ - if (dev->s.d_nwrwaiters > 0) + while (sem_getvalue(&dev->s.d_wrsem, &sval) == 0 && sval < 0) { - dev->s.d_nwrwaiters--; sem_post(&dev->s.d_wrsem); } @@ -322,6 +326,7 @@ ssize_t pipecommon_write(FAR struct file *filep, FAR const char *buffer, size_t ssize_t nwritten = 0; ssize_t last; int nxtwrndx; + int sval; /* Some sanity checking */ #if CONFIG_DEBUG @@ -346,7 +351,7 @@ ssize_t pipecommon_write(FAR struct file *filep, FAR const char *buffer, size_t /* Calculate the write index AFTER the next byte is written */ nxtwrndx = dev->s.d_wrndx + 1; - if (nxtwrndx >= CONFIG_DEV_FIFO_SIZE) + if (nxtwrndx >= CONFIG_DEV_PIPE_SIZE) { nxtwrndx = 0; } @@ -364,11 +369,10 @@ ssize_t pipecommon_write(FAR struct file *filep, FAR const char *buffer, size_t if (++nwritten >= len) { - /* Yes.. Notify the waiting readers that more data is available */ + /* Yes.. Notify all of the waiting readers that more data is available */ - if (dev->s.d_rdwaiters > 0) + while (sem_getvalue(&dev->s.d_rdsem, &sval) == 0 && sval < 0) { - dev->s.d_rdwaiters--; sem_post(&dev->s.d_rdsem); } @@ -384,11 +388,10 @@ ssize_t pipecommon_write(FAR struct file *filep, FAR const char *buffer, size_t if (last < nwritten) { - /* Yes.. Notify the waiting readers that more data is available */ + /* Yes.. Notify all of the waiting readers that more data is available */ - if (dev->s.d_rdwaiters > 0) + while (sem_getvalue(&dev->s.d_rdsem, &sval) == 0 && sval < 0) { - dev->s.d_rdwaiters--; sem_post(&dev->s.d_rdsem); } } @@ -406,9 +409,8 @@ ssize_t pipecommon_write(FAR struct file *filep, FAR const char *buffer, size_t return nwritten; } - /* There is more to be written.. wait for data to be removed from the FIFO */ + /* There is more to be written.. wait for data to be removed from the pipe */ - dev->s.d_nwrwaiters++; sched_lock(); sem_post(&dev->s.d_bfsem); pipecommon_semtake(&dev->s.d_wrsem); @@ -418,4 +420,4 @@ ssize_t pipecommon_write(FAR struct file *filep, FAR const char *buffer, size_t } } -#endif /* CONFIG_DEV_FIFO_SIZE > 0 */ +#endif /* CONFIG_DEV_PIPE_SIZE > 0 */ diff --git a/drivers/pipe-common.h b/drivers/pipe-common.h index 36b424d932..9f0a9d0460 100644 --- a/drivers/pipe-common.h +++ b/drivers/pipe-common.h @@ -43,28 +43,28 @@ #include #include -#ifndef CONFIG_DEV_FIFO_SIZE -# define CONFIG_DEV_FIFO_SIZE 1024 +#ifndef CONFIG_DEV_PIPE_SIZE +# define CONFIG_DEV_PIPE_SIZE 1024 #endif -#if CONFIG_DEV_FIFO_SIZE > 0 +#if CONFIG_DEV_PIPE_SIZE > 0 /**************************************************************************** * Definitions ****************************************************************************/ -/* Maximum number of open's supported on FIFO */ +/* Maximum number of open's supported on pipe */ -#define CONFIG_DEV_FIFO_MAXUSER 255 +#define CONFIG_DEV_PIPE_MAXUSER 255 /**************************************************************************** * Public Types ****************************************************************************/ -/* Make the FIFO index as small as possible for the configured FIFO size */ +/* Make the buffer index as small as possible for the configured pipe size */ -#if CONFIG_DEV_FIFO_SIZE > 65535 +#if CONFIG_DEV_PIPE_SIZE > 65535 typedef uint32 pipe_ndx_t; /* 32-bit index */ -#elif CONFIG_DEV_FIFO_SIZE > 255 +#elif CONFIG_DEV_PIPE_SIZE > 255 typedef uint16 pipe_ndx_t; /* 16-bit index */ #else typedef ubyte pipe_ndx_t; /* 8-bit index */ @@ -77,17 +77,15 @@ struct pipe_state_s sem_t d_wrsem; /* Full buffer - Writer waits for data read */ pipe_ndx_t d_wrndx; /* Index in d_buffer to save next byte written */ pipe_ndx_t d_rdndx; /* Index in d_buffer to return the next byte read */ - ubyte d_refs; /* References counts on FIFO (limited to 255) */ - ubyte d_nwriters; /* Number of open counts for write access */ - ubyte d_rdwaiters; /* Number of readers waiting for write data to empty buffer */ - ubyte d_nwrwaiters; /* Number of writers wiating for data read out of full buffer */ + ubyte d_refs; /* References counts on pipe (limited to 255) */ + ubyte d_nwriters; /* Number of reference counts for write access */ ubyte d_pipeno; /* Pipe minor number */ }; struct pipe_dev_s { struct pipe_state_s s; - ubyte d_buffer[CONFIG_DEV_FIFO_SIZE]; + ubyte d_buffer[CONFIG_DEV_PIPE_SIZE]; }; /**************************************************************************** @@ -113,5 +111,5 @@ EXTERN ssize_t pipecommon_write(FAR struct file *, FAR const char *, size_t); } #endif -#endif /* CONFIG_DEV_FIFO_SIZE > 0 */ +#endif /* CONFIG_DEV_PIPE_SIZE > 0 */ #endif /* __DRIVERS_PIPE_COMMON_H */ diff --git a/drivers/pipe.c b/drivers/pipe.c index fd5292cc1b..b4479963d7 100644 --- a/drivers/pipe.c +++ b/drivers/pipe.c @@ -53,7 +53,7 @@ #include "pipe-common.h" -#if CONFIG_DEV_FIFO_SIZE > 0 +#if CONFIG_DEV_PIPE_SIZE > 0 /**************************************************************************** * Definitions @@ -254,4 +254,4 @@ errout: return ERROR; } -#endif /* CONFIG_DEV_FIFO_SIZE > 0 */ +#endif /* CONFIG_DEV_PIPE_SIZE > 0 */