diff mbox

[RFT] spi: sc18is602: Convert to let spi core validate transfer speed

Message ID 1393583973.18537.2.camel@phoenix (mailing list archive)
State Accepted
Commit 09e99bca8324c3335794b86802486bb5191861d5
Delegated to: Mark Brown
Headers show

Commit Message

Axel Lin Feb. 28, 2014, 10:39 a.m. UTC
Set master->max_speed_hz and master->min_speed_hz then spi core will handle
checking transfer speed. So we can remove the same checking in this driver.

This patch also remove testing if hz is 0 because spi->max_speed_hz will be
default set to master->min_speed_hz if it was not set. So the transfer speed
will never set to 0.

Signed-off-by: Axel Lin <axel.lin@ingics.com>
---
 drivers/spi/spi-sc18is602.c | 13 +++----------
 1 file changed, 3 insertions(+), 10 deletions(-)

Comments

Mark Brown March 13, 2014, 9:47 a.m. UTC | #1
On Fri, Feb 28, 2014 at 06:39:33PM +0800, Axel Lin wrote:
> Set master->max_speed_hz and master->min_speed_hz then spi core will handle
> checking transfer speed. So we can remove the same checking in this driver.
> 
> This patch also remove testing if hz is 0 because spi->max_speed_hz will be
> default set to master->min_speed_hz if it was not set. So the transfer speed
> will never set to 0.

Applied, thanks.
Guenter Roeck March 15, 2014, 6:05 p.m. UTC | #2
On 02/28/2014 02:39 AM, Axel Lin wrote:
> Set master->max_speed_hz and master->min_speed_hz then spi core will handle
> checking transfer speed. So we can remove the same checking in this driver.
>
> This patch also remove testing if hz is 0 because spi->max_speed_hz will be
> default set to master->min_speed_hz if it was not set. So the transfer speed
> will never set to 0.
>
> Signed-off-by: Axel Lin <axel.lin@ingics.com>
> ---
>   drivers/spi/spi-sc18is602.c | 13 +++----------
>   1 file changed, 3 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/spi/spi-sc18is602.c b/drivers/spi/spi-sc18is602.c
> index 7fba10b..237f2e7 100644
> --- a/drivers/spi/spi-sc18is602.c
> +++ b/drivers/spi/spi-sc18is602.c
> @@ -183,17 +183,9 @@ static int sc18is602_setup_transfer(struct sc18is602 *hw, u32 hz, u8 mode)
>   static int sc18is602_check_transfer(struct spi_device *spi,
>   				    struct spi_transfer *t, int tlen)
>   {
> -	uint32_t hz;
> -
>   	if (t && t->len + tlen > SC18IS602_BUFSIZ)
>   		return -EINVAL;
>
> -	hz = spi->max_speed_hz;
> -	if (t && t->speed_hz)
> -		hz = t->speed_hz;
> -	if (hz == 0)
> -		return -EINVAL;
> -
>   	return 0;
>   }
>
> @@ -207,14 +199,13 @@ static int sc18is602_transfer_one(struct spi_master *master,
>
>   	hw->tlen = 0;
>   	list_for_each_entry(t, &m->transfers, transfer_list) {
> -		u32 hz = t->speed_hz ? : spi->max_speed_hz;
>   		bool do_transfer;
>
>   		status = sc18is602_check_transfer(spi, t, hw->tlen);
>   		if (status < 0)
>   			break;
>
> -		status = sc18is602_setup_transfer(hw, hz, spi->mode);
> +		status = sc18is602_setup_transfer(hw, t->speed_hz, spi->mode);
>   		if (status < 0)
>   			break;
>
> @@ -305,6 +296,8 @@ static int sc18is602_probe(struct i2c_client *client,
>   	master->setup = sc18is602_setup;
>   	master->transfer_one_message = sc18is602_transfer_one;
>   	master->dev.of_node = np;
> +	master->min_speed_hz = hw->freq / 128;
> +	master->max_speed_hz = hw->freq / 4;
>

Turns out this results in a failure if the requested speed is higher than
the supported speed. Previous code would simply update the speed to the
maximum supported speed.

Since the patch was already accepted, I'll send a follow-up patch to make
this less restrictive; I don't see the need to reject a transfer request
at 2mbps because the chip can only support 1.843 mbps.

Guenter

--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/spi/spi-sc18is602.c b/drivers/spi/spi-sc18is602.c
index 7fba10b..237f2e7 100644
--- a/drivers/spi/spi-sc18is602.c
+++ b/drivers/spi/spi-sc18is602.c
@@ -183,17 +183,9 @@  static int sc18is602_setup_transfer(struct sc18is602 *hw, u32 hz, u8 mode)
 static int sc18is602_check_transfer(struct spi_device *spi,
 				    struct spi_transfer *t, int tlen)
 {
-	uint32_t hz;
-
 	if (t && t->len + tlen > SC18IS602_BUFSIZ)
 		return -EINVAL;
 
-	hz = spi->max_speed_hz;
-	if (t && t->speed_hz)
-		hz = t->speed_hz;
-	if (hz == 0)
-		return -EINVAL;
-
 	return 0;
 }
 
@@ -207,14 +199,13 @@  static int sc18is602_transfer_one(struct spi_master *master,
 
 	hw->tlen = 0;
 	list_for_each_entry(t, &m->transfers, transfer_list) {
-		u32 hz = t->speed_hz ? : spi->max_speed_hz;
 		bool do_transfer;
 
 		status = sc18is602_check_transfer(spi, t, hw->tlen);
 		if (status < 0)
 			break;
 
-		status = sc18is602_setup_transfer(hw, hz, spi->mode);
+		status = sc18is602_setup_transfer(hw, t->speed_hz, spi->mode);
 		if (status < 0)
 			break;
 
@@ -305,6 +296,8 @@  static int sc18is602_probe(struct i2c_client *client,
 	master->setup = sc18is602_setup;
 	master->transfer_one_message = sc18is602_transfer_one;
 	master->dev.of_node = np;
+	master->min_speed_hz = hw->freq / 128;
+	master->max_speed_hz = hw->freq / 4;
 
 	error = devm_spi_register_master(dev, master);
 	if (error)