Message ID | 1393583973.18537.2.camel@phoenix (mailing list archive) |
---|---|
State | Accepted |
Commit | 09e99bca8324c3335794b86802486bb5191861d5 |
Delegated to: | Mark Brown |
Headers | show |
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.
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 --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)
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(-)