drivers/rwbuffer.c: Fix coding style issues. (#164)
Run .c and .h files affected by PR163 through nxstyle and fix all coding style complaints. Co-authored-by: Gregory Nutt <gnutt@nuttx.org>
This commit is contained in:
parent
aad1ab2574
commit
ecb2f99dfb
@ -1,8 +1,8 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* drivers/rwbuffer.c
|
* drivers/rwbuffer.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2009, 2011, 2013-2014, 2017 Gregory Nutt. All rights
|
* Copyright (C) 2009, 2011, 2013-2014, 2017, 2020 Gregory Nutt. All
|
||||||
* reserved.
|
* rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -71,18 +71,6 @@
|
|||||||
# error "Worker thread support is required (CONFIG_SCHED_WORKQUEUE)"
|
# error "Worker thread support is required (CONFIG_SCHED_WORKQUEUE)"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Private Types
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Private Data
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Public Data
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -91,7 +79,7 @@
|
|||||||
* Name: rwb_semtake
|
* Name: rwb_semtake
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static void rwb_semtake(sem_t *sem)
|
static void rwb_semtake(FAR sem_t *sem)
|
||||||
{
|
{
|
||||||
nxsem_wait_uninterruptible(sem);
|
nxsem_wait_uninterruptible(sem);
|
||||||
}
|
}
|
||||||
@ -130,7 +118,7 @@ static inline bool rwb_overlap(off_t blockstart1, size_t nblocks1,
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_DRVR_WRITEBUFFER
|
#ifdef CONFIG_DRVR_WRITEBUFFER
|
||||||
static inline void rwb_resetwrbuffer(struct rwbuffer_s *rwb)
|
static inline void rwb_resetwrbuffer(FAR struct rwbuffer_s *rwb)
|
||||||
{
|
{
|
||||||
/* We assume that the caller holds the wrsem */
|
/* We assume that the caller holds the wrsem */
|
||||||
|
|
||||||
@ -149,7 +137,7 @@ static inline void rwb_resetwrbuffer(struct rwbuffer_s *rwb)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_DRVR_WRITEBUFFER
|
#ifdef CONFIG_DRVR_WRITEBUFFER
|
||||||
static void rwb_wrflush(struct rwbuffer_s *rwb)
|
static void rwb_wrflush(FAR struct rwbuffer_s *rwb)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -163,7 +151,8 @@ static void rwb_wrflush(struct rwbuffer_s *rwb)
|
|||||||
* an error.
|
* an error.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ret = rwb->wrflush(rwb->dev, rwb->wrbuffer, rwb->wrblockstart, rwb->wrnblocks);
|
ret = rwb->wrflush(rwb->dev, rwb->wrbuffer, rwb->wrblockstart,
|
||||||
|
rwb->wrnblocks);
|
||||||
if (ret != rwb->wrnblocks)
|
if (ret != rwb->wrnblocks)
|
||||||
{
|
{
|
||||||
ferr("ERROR: Error flushing write buffer: %d\n", ret);
|
ferr("ERROR: Error flushing write buffer: %d\n", ret);
|
||||||
@ -183,7 +172,7 @@ static void rwb_wrtimeout(FAR void *arg)
|
|||||||
{
|
{
|
||||||
/* The following assumes that the size of a pointer is 4-bytes or less */
|
/* The following assumes that the size of a pointer is 4-bytes or less */
|
||||||
|
|
||||||
FAR struct rwbuffer_s *rwb = (struct rwbuffer_s *)arg;
|
FAR struct rwbuffer_s *rwb = (FAR struct rwbuffer_s *)arg;
|
||||||
DEBUGASSERT(rwb != NULL);
|
DEBUGASSERT(rwb != NULL);
|
||||||
|
|
||||||
finfo("Timeout!\n");
|
finfo("Timeout!\n");
|
||||||
@ -222,7 +211,7 @@ static void rwb_wrstarttimeout(FAR struct rwbuffer_s *rwb)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_DRVR_WRITEBUFFER
|
#ifdef CONFIG_DRVR_WRITEBUFFER
|
||||||
static inline void rwb_wrcanceltimeout(struct rwbuffer_s *rwb)
|
static inline void rwb_wrcanceltimeout(FAR struct rwbuffer_s *rwb)
|
||||||
{
|
{
|
||||||
#if CONFIG_DRVR_WRDELAY != 0
|
#if CONFIG_DRVR_WRDELAY != 0
|
||||||
work_cancel(LPWORK, &rwb->work);
|
work_cancel(LPWORK, &rwb->work);
|
||||||
@ -258,7 +247,8 @@ static ssize_t rwb_writebuffer(FAR struct rwbuffer_s *rwb,
|
|||||||
|
|
||||||
/* Flush the write buffer */
|
/* Flush the write buffer */
|
||||||
|
|
||||||
ret = rwb->wrflush(rwb->dev, rwb->wrbuffer, rwb->wrblockstart, rwb->wrnblocks);
|
ret = rwb->wrflush(rwb->dev, rwb->wrbuffer, rwb->wrblockstart,
|
||||||
|
rwb->wrnblocks);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
ferr("ERROR: Error writing multiple from cache: %d\n", -ret);
|
ferr("ERROR: Error writing multiple from cache: %d\n", -ret);
|
||||||
@ -296,7 +286,7 @@ static ssize_t rwb_writebuffer(FAR struct rwbuffer_s *rwb,
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_DRVR_READAHEAD
|
#ifdef CONFIG_DRVR_READAHEAD
|
||||||
static inline void rwb_resetrhbuffer(struct rwbuffer_s *rwb)
|
static inline void rwb_resetrhbuffer(FAR struct rwbuffer_s *rwb)
|
||||||
{
|
{
|
||||||
/* We assume that the caller holds the readAheadBufferSemphore */
|
/* We assume that the caller holds the readAheadBufferSemphore */
|
||||||
|
|
||||||
@ -311,9 +301,11 @@ static inline void rwb_resetrhbuffer(struct rwbuffer_s *rwb)
|
|||||||
|
|
||||||
#ifdef CONFIG_DRVR_READAHEAD
|
#ifdef CONFIG_DRVR_READAHEAD
|
||||||
static inline void
|
static inline void
|
||||||
rwb_bufferread(struct rwbuffer_s *rwb, off_t startblock,
|
rwb_bufferread(FAR struct rwbuffer_s *rwb, off_t startblock,
|
||||||
size_t nblocks, uint8_t **rdbuffer)
|
size_t nblocks, FAR uint8_t **rdbuffer)
|
||||||
{
|
{
|
||||||
|
FAR uint8_t *rhbuffer;
|
||||||
|
|
||||||
/* We assume that (1) the caller holds the readAheadBufferSemphore, and (2)
|
/* We assume that (1) the caller holds the readAheadBufferSemphore, and (2)
|
||||||
* that the caller already knows that all of the blocks are in the
|
* that the caller already knows that all of the blocks are in the
|
||||||
* read-ahead buffer.
|
* read-ahead buffer.
|
||||||
@ -327,7 +319,7 @@ rwb_bufferread(struct rwbuffer_s *rwb, off_t startblock,
|
|||||||
|
|
||||||
/* Get the byte address in the read-ahead buffer */
|
/* Get the byte address in the read-ahead buffer */
|
||||||
|
|
||||||
uint8_t *rhbuffer = rwb->rhbuffer + byteoffset;
|
rhbuffer = rwb->rhbuffer + byteoffset;
|
||||||
|
|
||||||
/* Copy the data from the read-ahead buffer into the IO buffer */
|
/* Copy the data from the read-ahead buffer into the IO buffer */
|
||||||
|
|
||||||
@ -344,7 +336,7 @@ rwb_bufferread(struct rwbuffer_s *rwb, off_t startblock,
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_DRVR_READAHEAD
|
#ifdef CONFIG_DRVR_READAHEAD
|
||||||
static int rwb_rhreload(struct rwbuffer_s *rwb, off_t startblock)
|
static int rwb_rhreload(FAR struct rwbuffer_s *rwb, off_t startblock)
|
||||||
{
|
{
|
||||||
off_t endblock;
|
off_t endblock;
|
||||||
size_t nblocks;
|
size_t nblocks;
|
||||||
@ -449,7 +441,7 @@ int rwb_invalidate_writebuffer(FAR struct rwbuffer_s *rwb,
|
|||||||
|
|
||||||
else if (rwb->wrblockstart < startblock && wrbend > invend)
|
else if (rwb->wrblockstart < startblock && wrbend > invend)
|
||||||
{
|
{
|
||||||
uint8_t *src;
|
FAR uint8_t *src;
|
||||||
off_t block;
|
off_t block;
|
||||||
off_t offset;
|
off_t offset;
|
||||||
size_t nblocks;
|
size_t nblocks;
|
||||||
@ -470,6 +462,7 @@ int rwb_invalidate_writebuffer(FAR struct rwbuffer_s *rwb,
|
|||||||
/* Keep the blocks at the beginning of the buffer up the
|
/* Keep the blocks at the beginning of the buffer up the
|
||||||
* start of the invalidated region.
|
* start of the invalidated region.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
rwb->wrnblocks = startblock - rwb->wrblockstart;
|
rwb->wrnblocks = startblock - rwb->wrblockstart;
|
||||||
@ -489,7 +482,7 @@ int rwb_invalidate_writebuffer(FAR struct rwbuffer_s *rwb,
|
|||||||
|
|
||||||
else /* if (rwb->wrblockstart >= startblock && wrbend > invend) */
|
else /* if (rwb->wrblockstart >= startblock && wrbend > invend) */
|
||||||
{
|
{
|
||||||
uint8_t *src;
|
FAR uint8_t *src;
|
||||||
size_t ninval;
|
size_t ninval;
|
||||||
size_t nkeep;
|
size_t nkeep;
|
||||||
|
|
||||||
@ -605,7 +598,7 @@ int rwb_invalidate_readahead(FAR struct rwbuffer_s *rwb,
|
|||||||
|
|
||||||
else /* if (rwb->rhblockstart >= startblock && rhbend > invend) */
|
else /* if (rwb->rhblockstart >= startblock && rhbend > invend) */
|
||||||
{
|
{
|
||||||
uint8_t *src;
|
FAR uint8_t *src;
|
||||||
size_t ninval;
|
size_t ninval;
|
||||||
size_t nkeep;
|
size_t nkeep;
|
||||||
|
|
||||||
@ -650,6 +643,7 @@ int rwb_invalidate_readahead(FAR struct rwbuffer_s *rwb,
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: rwb_initialize
|
* Name: rwb_initialize
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -824,7 +818,9 @@ static ssize_t rwb_read_(FAR struct rwbuffer_s *rwb, off_t startblock,
|
|||||||
ret = rwb_rhreload(rwb, startblock);
|
ret = rwb_rhreload(rwb, startblock);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
ferr("ERROR: Failed to fill the read-ahead buffer: %d\n", ret);
|
ferr("ERROR: Failed to fill the read-ahead buffer: %d\n",
|
||||||
|
ret);
|
||||||
|
|
||||||
rwb_semgive(&rwb->rhsem);
|
rwb_semgive(&rwb->rhsem);
|
||||||
return (ssize_t)ret;
|
return (ssize_t)ret;
|
||||||
}
|
}
|
||||||
@ -875,7 +871,8 @@ ssize_t rwb_read(FAR struct rwbuffer_s *rwb, off_t startblock,
|
|||||||
/* If the write buffer overlaps the block(s) requested */
|
/* If the write buffer overlaps the block(s) requested */
|
||||||
|
|
||||||
rwb_semtake(&rwb->wrsem);
|
rwb_semtake(&rwb->wrsem);
|
||||||
if (rwb_overlap(rwb->wrblockstart, rwb->wrnblocks, startblock, nblocks))
|
if (rwb_overlap(rwb->wrblockstart, rwb->wrnblocks, startblock,
|
||||||
|
nblocks))
|
||||||
{
|
{
|
||||||
size_t rdblocks = 0;
|
size_t rdblocks = 0;
|
||||||
size_t wrnpass = 0;
|
size_t wrnpass = 0;
|
||||||
@ -944,7 +941,8 @@ ssize_t rwb_write(FAR struct rwbuffer_s *rwb, off_t startblock,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
rwb_semtake(&rwb->rhsem);
|
rwb_semtake(&rwb->rhsem);
|
||||||
if (rwb_overlap(rwb->rhblockstart, rwb->rhnblocks, startblock, nblocks))
|
if (rwb_overlap(rwb->rhblockstart, rwb->rhnblocks, startblock,
|
||||||
|
nblocks))
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_DRVR_INVALIDATE
|
#ifdef CONFIG_DRVR_INVALIDATE
|
||||||
/* Just invalidate the read buffer startblock + nblocks data */
|
/* Just invalidate the read buffer startblock + nblocks data */
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* include/nuttx/drivers/rwbuffer.h
|
* include/nuttx/drivers/rwbuffer.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2009, 2014 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2009, 2014, 2020 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -85,7 +85,7 @@ typedef CODE ssize_t (*rwbflush_t)(FAR void *dev, FAR const uint8_t *buffer,
|
|||||||
* A reference to the struct rwbuffer_s instance is then passed to each
|
* A reference to the struct rwbuffer_s instance is then passed to each
|
||||||
* interface like:
|
* interface like:
|
||||||
*
|
*
|
||||||
* struct foo_dev_s *priv;
|
* FAR struct foo_dev_s *priv;
|
||||||
* ...
|
* ...
|
||||||
* ... [Setup blocksize, nblocks, dev, wrmaxblocks, wrflush,
|
* ... [Setup blocksize, nblocks, dev, wrmaxblocks, wrflush,
|
||||||
* rhmaxblocks, rhreload] ...
|
* rhmaxblocks, rhreload] ...
|
||||||
@ -94,7 +94,8 @@ typedef CODE ssize_t (*rwbflush_t)(FAR void *dev, FAR const uint8_t *buffer,
|
|||||||
|
|
||||||
struct rwbuffer_s
|
struct rwbuffer_s
|
||||||
{
|
{
|
||||||
/********************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
/* These values must be provided by the user prior to calling
|
/* These values must be provided by the user prior to calling
|
||||||
* rwb_initialize()
|
* rwb_initialize()
|
||||||
*/
|
*/
|
||||||
@ -130,7 +131,8 @@ struct rwbuffer_s
|
|||||||
rwbflush_t wrflush; /* Callout to flush the write buffer */
|
rwbflush_t wrflush; /* Callout to flush the write buffer */
|
||||||
rwbreload_t rhreload; /* Callout to reload the read-ahead buffer */
|
rwbreload_t rhreload; /* Callout to reload the read-ahead buffer */
|
||||||
|
|
||||||
/********************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
/* The user should never modify any of the remaining fields */
|
/* The user should never modify any of the remaining fields */
|
||||||
|
|
||||||
/* This is the state of the write buffering */
|
/* This is the state of the write buffering */
|
||||||
|
Loading…
Reference in New Issue
Block a user