Re: [PATCH 3/6] staging: wilc1000: fix line over 80 characters in spi_cmd_complete()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On 14.02.2018 13:10, Ajay Singh wrote:
> Refactor spi_cmd_complete() to fix the line over 80 char issues reported
> by checkpatch.pl script.
> 
> Signed-off-by: Ajay Singh <ajay.kathat@xxxxxxxxxxxxx>
> ---
>  drivers/staging/wilc1000/wilc_spi.c | 250 ++++++++++++++++++------------------
>  1 file changed, 124 insertions(+), 126 deletions(-)
> 
> diff --git a/drivers/staging/wilc1000/wilc_spi.c b/drivers/staging/wilc1000/wilc_spi.c
> index 66b6aea..30a9a61 100644
> --- a/drivers/staging/wilc1000/wilc_spi.c
> +++ b/drivers/staging/wilc1000/wilc_spi.c
> @@ -287,17 +287,19 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  	u8 rsp;
>  	int len = 0;
>  	int result = N_OK;
> +	int retry;
> +	u8 crc[2];
>  
>  	wb[0] = cmd;
>  	switch (cmd) {
> -	case CMD_SINGLE_READ:                           /* single word (4 bytes) read */
> +	case CMD_SINGLE_READ: /* single word (4 bytes) read */
Ok with this but I think would be nicer to have them documented the place were
they are defined.
>  		wb[1] = (u8)(adr >> 16);
>  		wb[2] = (u8)(adr >> 8);
>  		wb[3] = (u8)adr;
>  		len = 5;
>  		break;
>  
> -	case CMD_INTERNAL_READ:                 /* internal register read */
> +	case CMD_INTERNAL_READ: /* internal register read */
Ditto
>  		wb[1] = (u8)(adr >> 8);
>  		if (clockless == 1)
>  			wb[1] |= BIT(7);
> @@ -306,29 +308,29 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  		len = 5;
>  		break;
>  
> -	case CMD_TERMINATE:                                     /* termination */
> +	case CMD_TERMINATE:
Ditto
>  		wb[1] = 0x00;
>  		wb[2] = 0x00;
>  		wb[3] = 0x00;
>  		len = 5;
>  		break;
>  
> -	case CMD_REPEAT:                                                /* repeat */
> +	case CMD_REPEAT:
Ditto
>  		wb[1] = 0x00;
>  		wb[2] = 0x00;
>  		wb[3] = 0x00;
>  		len = 5;
>  		break;
>  
> -	case CMD_RESET:                                                 /* reset */
> +	case CMD_RESET:
Ditto
>  		wb[1] = 0xff;
>  		wb[2] = 0xff;
>  		wb[3] = 0xff;
>  		len = 5;
>  		break;
>  
> -	case CMD_DMA_WRITE:                                     /* dma write */
> -	case CMD_DMA_READ:                                      /* dma read */
> +	case CMD_DMA_WRITE: /* dma write */
> +	case CMD_DMA_READ:  /* dma read */
Ditto
>  		wb[1] = (u8)(adr >> 16);
>  		wb[2] = (u8)(adr >> 8);
>  		wb[3] = (u8)adr;
> @@ -337,8 +339,8 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  		len = 7;
>  		break;
>  
> -	case CMD_DMA_EXT_WRITE:         /* dma extended write */
> -	case CMD_DMA_EXT_READ:                  /* dma extended read */
> +	case CMD_DMA_EXT_WRITE: /* dma extended write */
> +	case CMD_DMA_EXT_READ:  /* dma extended read */
Ditto
>  		wb[1] = (u8)(adr >> 16);
>  		wb[2] = (u8)(adr >> 8);
>  		wb[3] = (u8)adr;
> @@ -348,7 +350,7 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  		len = 8;
>  		break;
>  
> -	case CMD_INTERNAL_WRITE:                /* internal register write */
> +	case CMD_INTERNAL_WRITE: /* internal register write */
Ditto
>  		wb[1] = (u8)(adr >> 8);
>  		if (clockless == 1)
>  			wb[1] |= BIT(7);
> @@ -360,7 +362,7 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  		len = 8;
>  		break;
>  
> -	case CMD_SINGLE_WRITE:                  /* single word write */
> +	case CMD_SINGLE_WRITE: /* single word write */
Ditto
>  		wb[1] = (u8)(adr >> 16);
>  		wb[2] = (u8)(adr >> 8);
>  		wb[3] = (u8)(adr);
> @@ -395,13 +397,12 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  	    cmd == CMD_REPEAT) {
>  		len2 = len + (NUM_SKIP_BYTES + NUM_RSP_BYTES + NUM_DUMMY_BYTES);
>  	} else if (cmd == CMD_INTERNAL_READ || cmd == CMD_SINGLE_READ) {
> -		if (!g_spi.crc_off) {
> -			len2 = len + (NUM_RSP_BYTES + NUM_DATA_HDR_BYTES + NUM_DATA_BYTES
> -				      + NUM_CRC_BYTES + NUM_DUMMY_BYTES);
> -		} else {
> -			len2 = len + (NUM_RSP_BYTES + NUM_DATA_HDR_BYTES + NUM_DATA_BYTES
> -				      + NUM_DUMMY_BYTES);
> -		}
> +		int tmp = NUM_RSP_BYTES + NUM_DATA_HDR_BYTES + NUM_DATA_BYTES
> +			+ NUM_DUMMY_BYTES;
> +		if (!g_spi.crc_off)
> +			len2 = len + tmp + NUM_CRC_BYTES;
> +		else
> +			len2 = len + tmp;
>  	} else {
>  		len2 = len + (NUM_RSP_BYTES + NUM_DUMMY_BYTES);
>  	}
> @@ -425,11 +426,8 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  	/*
>  	 * Command/Control response
>  	 */
> -	if (cmd == CMD_RESET ||
> -	    cmd == CMD_TERMINATE ||
> -	    cmd == CMD_REPEAT) {
> -		rix++;         /* skip 1 byte */
> -	}
> +	if (cmd == CMD_RESET || cmd == CMD_TERMINATE || cmd == CMD_REPEAT)
> +		rix++; /* skip 1 byte */
>  
>  	rsp = rb[rix++];
>  
> @@ -452,8 +450,6 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  
>  	if (cmd == CMD_INTERNAL_READ || cmd == CMD_SINGLE_READ ||
>  	    cmd == CMD_DMA_READ || cmd == CMD_DMA_EXT_READ) {
> -		int retry;
> -		u8 crc[2];
>  		/*
>  		 * Data Respnose header
>  		 */
> @@ -478,132 +474,134 @@ static int spi_cmd_complete(struct wilc *wilc, u8 cmd, u32 adr, u8 *b, u32 sz,
>  				"Error, data read response (%02x)\n", rsp);
>  			return N_RESET;
>  		}
> +	}
> +
> +	if (cmd == CMD_INTERNAL_READ || cmd == CMD_SINGLE_READ) {
> +		/*
> +		 * Read bytes
> +		 */
> +		if ((rix + 3) < len2) {
> +			b[0] = rb[rix++];
> +			b[1] = rb[rix++];
> +			b[2] = rb[rix++];
> +			b[3] = rb[rix++];
> +		} else {
> +			dev_err(&spi->dev,
> +				"buffer overrun when reading data.\n");
> +			return N_FAIL;
> +		}
>  
> -		if (cmd == CMD_INTERNAL_READ || cmd == CMD_SINGLE_READ) {
> +		if (!g_spi.crc_off) {
>  			/*
> -			 * Read bytes
> +			 * Read Crc
>  			 */
> -			if ((rix + 3) < len2) {
> -				b[0] = rb[rix++];
> -				b[1] = rb[rix++];
> -				b[2] = rb[rix++];
> -				b[3] = rb[rix++];
> +			if ((rix + 1) < len2) {
> +				crc[0] = rb[rix++];
> +				crc[1] = rb[rix++];
>  			} else {
>  				dev_err(&spi->dev,
> -					"buffer overrun when reading data.\n");
> +					"buffer overrun when reading crc.\n");
Since you refactor, you may try to have a consistent way of returning in case of
errors. I'm thinking that this kind of block:
{
	dev_err(&spi->dev, "msg");
	return N_FAIL;
}

could be replaced with:
- at the beginning of function:
const char *errmsg = NULL;

- and in case of error you could add this block:
{
	errmsg = "you error string";
	result = N_FAIL;
	goto _error_;
}

and for _error_ label:
_error_:
	if (errmsg)
		dev_err(&spi->dev, errmsg);
	return result;

And use this pattern wherever an error needs to be thrown, in a consistent way.
This could remain as is in this patch, for the moment, but further re-factors
might be needed for this function to look better, maybe should be added to backlog.

I want to say that might be nice to have a consistent way of returning with
errors, some paths in this function just uses "return error;" other paths are using:
result = error;
goto _error_;
and the result is the same.

>  				return N_FAIL;
>  			}
> +		}
> +	} else if ((cmd == CMD_DMA_READ) || (cmd == CMD_DMA_EXT_READ)) {
> +		int ix;
>  
> -			if (!g_spi.crc_off) {
> -				/*
> -				 * Read Crc
> -				 */
> -				if ((rix + 1) < len2) {
> -					crc[0] = rb[rix++];
> -					crc[1] = rb[rix++];
> -				} else {
> -					dev_err(&spi->dev, "buffer overrun when reading crc.\n");
> -					return N_FAIL;
> -				}
> -			}
> -		} else if ((cmd == CMD_DMA_READ) || (cmd == CMD_DMA_EXT_READ)) {
> -			int ix;
> -
> -			/* some data may be read in response to dummy bytes. */
> -			for (ix = 0; (rix < len2) && (ix < sz); )
> -				b[ix++] = rb[rix++];
> -
> -			sz -= ix;
> -
> -			if (sz > 0) {
> -				int nbytes;
> +		/* some data may be read in response to dummy bytes. */
> +		for (ix = 0; (rix < len2) && (ix < sz); )
> +			b[ix++] = rb[rix++];
>  
> -				if (sz <= (DATA_PKT_SZ - ix))
> -					nbytes = sz;
> -				else
> -					nbytes = DATA_PKT_SZ - ix;
> +		sz -= ix;
>  
> -				/*
> -				 * Read bytes
> -				 */
> -				if (wilc_spi_rx(wilc, &b[ix], nbytes)) {
> -					dev_err(&spi->dev, "Failed data block read, bus error...\n");
> -					result = N_FAIL;
> -					goto _error_;
> -				}
> +		if (sz > 0) {
> +			int nbytes;
>  
> -				/*
> -				 * Read Crc
> -				 */
> -				if (!g_spi.crc_off) {
> -					if (wilc_spi_rx(wilc, crc, 2)) {
> -						dev_err(&spi->dev, "Failed data block crc read, bus error...\n");
> -						result = N_FAIL;
> -						goto _error_;
> -					}
> -				}
> +			if (sz <= (DATA_PKT_SZ - ix))
> +				nbytes = sz;
> +			else
> +				nbytes = DATA_PKT_SZ - ix;
>  
> -				ix += nbytes;
> -				sz -= nbytes;
> +			/*
> +			 * Read bytes
> +			 */
> +			if (wilc_spi_rx(wilc, &b[ix], nbytes)) {
> +				dev_err(&spi->dev,
> +					"Failed block read, bus err\n");
> +				result = N_FAIL;
> +				goto _error_;
>  			}
>  
>  			/*
> -			 * if any data in left unread,
> -			 * then read the rest using normal DMA code.
> +			 * Read Crc
>  			 */
> -			while (sz > 0) {
> -				int nbytes;
> +			if (!g_spi.crc_off && wilc_spi_rx(wilc, crc, 2)) {
> +				dev_err(&spi->dev,
> +					"Failed block crc read, bus err\n");
> +				result = N_FAIL;
> +				goto _error_;
> +			}
>  
> -				if (sz <= DATA_PKT_SZ)
> -					nbytes = sz;
> -				else
> -					nbytes = DATA_PKT_SZ;
> +			ix += nbytes;
> +			sz -= nbytes;
> +		}
>  
> -				/*
> -				 * read data response only on the next DMA cycles not
> -				 * the first DMA since data response header is already
> -				 * handled above for the first DMA.
> -				 */
> -				/*
> -				 * Data Respnose header
> -				 */
> -				retry = 10;
> -				do {
> -					if (wilc_spi_rx(wilc, &rsp, 1)) {
> -						dev_err(&spi->dev, "Failed data response read, bus error...\n");
> -						result = N_FAIL;
> -						break;
> -					}
> -					if (((rsp >> 4) & 0xf) == 0xf)
> -						break;
> -				} while (retry--);
> -
> -				if (result == N_FAIL)
> -					break;
> +		/*
> +		 * if any data in left unread,
> +		 * then read the rest using normal DMA code.
> +		 */
> +		while (sz > 0) {
> +			int nbytes;
>  
> -				/*
> -				 * Read bytes
> -				 */
> -				if (wilc_spi_rx(wilc, &b[ix], nbytes)) {
> -					dev_err(&spi->dev, "Failed data block read, bus error...\n");
> +			if (sz <= DATA_PKT_SZ)
> +				nbytes = sz;
> +			else
> +				nbytes = DATA_PKT_SZ;
> +
> +			/*
> +			 * read data response only on the next DMA cycles not
> +			 * the first DMA since data response header is already
> +			 * handled above for the first DMA.
> +			 */
> +			/*
> +			 * Data Respnose header
> +			 */
> +			retry = 10;
> +			do {
> +				if (wilc_spi_rx(wilc, &rsp, 1)) {
> +					dev_err(&spi->dev,
> +						"Failed resp read, bus err\n");
>  					result = N_FAIL;
>  					break;
Here, also, the proposed solution could be used. Or just return as in the other
cases or just goto _error_ instead of break and then check for result == N_FAIL.
>  				}
> +				if (((rsp >> 4) & 0xf) == 0xf)
> +					break;
> +			} while (retry--);
>  
> -				/*
> -				 * Read Crc
> -				 */
> -				if (!g_spi.crc_off) {
> -					if (wilc_spi_rx(wilc, crc, 2)) {
> -						dev_err(&spi->dev, "Failed data block crc read, bus error...\n");
> -						result = N_FAIL;
> -						break;
> -					}
> -				}
> +			if (result == N_FAIL)
> +				break;
>  
> -				ix += nbytes;
> -				sz -= nbytes;
> +			/*
> +			 * Read bytes
> +			 */
> +			if (wilc_spi_rx(wilc, &b[ix], nbytes)) {
> +				dev_err(&spi->dev,
> +					"Failed block read, bus err\n");
> +				result = N_FAIL;
> +				break;
>  			}
> +
> +			/*
> +			 * Read Crc
> +			 */
> +			if (!g_spi.crc_off && wilc_spi_rx(wilc, crc, 2)) {
> +				dev_err(&spi->dev,
> +					"Failed block crc read, bus err\n");
> +				result = N_FAIL;
> +				break;
> +			}
> +
> +			ix += nbytes;
> +			sz -= nbytes;
>  		}
>  	}
>  _error_:
> 
_______________________________________________
devel mailing list
devel@xxxxxxxxxxxxxxxxxxxxxx
http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel



[Index of Archives]     [Linux Driver Backports]     [DMA Engine]     [Linux GPIO]     [Linux SPI]     [Video for Linux]     [Linux USB Devel]     [Linux Coverity]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux