diff mbox series

[U-Boot] spi: omap3: fix claim/release bus within DM

Message ID 1530022119-31174-1-git-send-email-oe5hpm@oevsv.at
State Accepted
Commit c0eaffa03959a97e6c139ea023e4041170e105e6
Delegated to: Jagannadha Sutradharudu Teki
Headers show
Series [U-Boot] spi: omap3: fix claim/release bus within DM | expand

Commit Message

Hannes Schmelzer June 26, 2018, 2:08 p.m. UTC
The claim/release bus function must not reset the whole SPI core because
settings regarding wordlen, clock-frequency and so on made by
set_wordlen, set_mode, set_speed get lost with this action. Resulting in
a non-functional SPI.

Without DM the failure didn't came up since after the spi_reset within
claim bus all the setup (wordlen, mode, ...) was called, in DM they are
called by the spi uclass.

We change now the things as following for having a working SPI instance
in DM:

- move the spi_reset(...) to the probe call in DM for having a known
hardware state after probe. Without DM we don't have a probe call, so we
issue the reset as before during the claim_bus call.

- in release bus we just reset the modulctrl to the reset-value (spi-
slave)

Signed-off-by: Hannes Schmelzer <oe5hpm@oevsv.at>

---

 drivers/spi/omap3_spi.c | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)

Comments

Jagan Teki June 27, 2018, 11:53 a.m. UTC | #1
On Tue, Jun 26, 2018 at 7:38 PM, Hannes Schmelzer <oe5hpm@oevsv.at> wrote:
> The claim/release bus function must not reset the whole SPI core because
> settings regarding wordlen, clock-frequency and so on made by
> set_wordlen, set_mode, set_speed get lost with this action. Resulting in
> a non-functional SPI.
>
> Without DM the failure didn't came up since after the spi_reset within
> claim bus all the setup (wordlen, mode, ...) was called, in DM they are
> called by the spi uclass.
>
> We change now the things as following for having a working SPI instance
> in DM:
>
> - move the spi_reset(...) to the probe call in DM for having a known
> hardware state after probe. Without DM we don't have a probe call, so we
> issue the reset as before during the claim_bus call.
>
> - in release bus we just reset the modulctrl to the reset-value (spi-
> slave)
>
> Signed-off-by: Hannes Schmelzer <oe5hpm@oevsv.at>
>
> ---
>
>  drivers/spi/omap3_spi.c | 14 +++++++-------
>  1 file changed, 7 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/spi/omap3_spi.c b/drivers/spi/omap3_spi.c
> index 4169abd..41bdab7 100644
> --- a/drivers/spi/omap3_spi.c
> +++ b/drivers/spi/omap3_spi.c
> @@ -443,9 +443,6 @@ static void spi_reset(struct mcspi *regs)
>  static void _omap3_spi_claim_bus(struct omap3_spi_priv *priv)
>  {
>         unsigned int conf;
> -
> -       spi_reset(priv->regs);
> -
>         /*
>          * setup when switching from (reset default) slave mode
>          * to single-channel master mode
> @@ -480,6 +477,8 @@ int spi_claim_bus(struct spi_slave *slave)
>  {
>         struct omap3_spi_priv *priv = to_omap3_spi(slave);
>
> +       spi_reset(priv->regs);
> +
>         _omap3_spi_claim_bus(priv);
>         _omap3_spi_set_wordlen(priv);
>         _omap3_spi_set_mode(priv);
> @@ -492,8 +491,7 @@ void spi_release_bus(struct spi_slave *slave)
>  {
>         struct omap3_spi_priv *priv = to_omap3_spi(slave);
>
> -       /* Reset the SPI hardware */
> -       spi_reset(priv->regs);
> +       writel(OMAP3_MCSPI_MODULCTRL_MS, &priv->regs->modulctrl);
>  }
>
>  struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,
> @@ -600,8 +598,7 @@ static int omap3_spi_release_bus(struct udevice *dev)
>         struct udevice *bus = dev->parent;
>         struct omap3_spi_priv *priv = dev_get_priv(bus);
>
> -       /* Reset the SPI hardware */
> -       spi_reset(priv->regs);
> +       writel(OMAP3_MCSPI_MODULCTRL_MS, &priv->regs->modulctrl);

This change look compared to what patch is trying to fix. so release
doen't require reset?  are you sure we need to write only this bit
release the bus or do we need to clear?
Hannes Schmelzer June 27, 2018, 7:57 p.m. UTC | #2
On 06/27/2018 01:53 PM, Jagan Teki wrote:
> On Tue, Jun 26, 2018 at 7:38 PM, Hannes Schmelzer <oe5hpm@oevsv.at> wrote:
>> The claim/release bus function must not reset the whole SPI core because
>> settings regarding wordlen, clock-frequency and so on made by
>> set_wordlen, set_mode, set_speed get lost with this action. Resulting in
>> a non-functional SPI.
>>
>> Without DM the failure didn't came up since after the spi_reset within
>> claim bus all the setup (wordlen, mode, ...) was called, in DM they are
>> called by the spi uclass.
>>
>> We change now the things as following for having a working SPI instance
>> in DM:
>>
>> - move the spi_reset(...) to the probe call in DM for having a known
>> hardware state after probe. Without DM we don't have a probe call, so we
>> issue the reset as before during the claim_bus call.
>>
>> - in release bus we just reset the modulctrl to the reset-value (spi-
>> slave)
>>
>> Signed-off-by: Hannes Schmelzer <oe5hpm@oevsv.at>
>>
>> ---
>>
>>   drivers/spi/omap3_spi.c | 14 +++++++-------
>>   1 file changed, 7 insertions(+), 7 deletions(-)
>>
>> diff --git a/drivers/spi/omap3_spi.c b/drivers/spi/omap3_spi.c
>> index 4169abd..41bdab7 100644
>> --- a/drivers/spi/omap3_spi.c
>> +++ b/drivers/spi/omap3_spi.c
>> @@ -443,9 +443,6 @@ static void spi_reset(struct mcspi *regs)
>>   static void _omap3_spi_claim_bus(struct omap3_spi_priv *priv)
>>   {
>>          unsigned int conf;
>> -
>> -       spi_reset(priv->regs);
>> -
>>          /*
>>           * setup when switching from (reset default) slave mode
>>           * to single-channel master mode
>> @@ -480,6 +477,8 @@ int spi_claim_bus(struct spi_slave *slave)
>>   {
>>          struct omap3_spi_priv *priv = to_omap3_spi(slave);
>>
>> +       spi_reset(priv->regs);
>> +
>>          _omap3_spi_claim_bus(priv);
>>          _omap3_spi_set_wordlen(priv);
>>          _omap3_spi_set_mode(priv);
>> @@ -492,8 +491,7 @@ void spi_release_bus(struct spi_slave *slave)
>>   {
>>          struct omap3_spi_priv *priv = to_omap3_spi(slave);
>>
>> -       /* Reset the SPI hardware */
>> -       spi_reset(priv->regs);
>> +       writel(OMAP3_MCSPI_MODULCTRL_MS, &priv->regs->modulctrl);
>>   }
>>
>>   struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,
>> @@ -600,8 +598,7 @@ static int omap3_spi_release_bus(struct udevice *dev)
>>          struct udevice *bus = dev->parent;
>>          struct omap3_spi_priv *priv = dev_get_priv(bus);
>>
>> -       /* Reset the SPI hardware */
>> -       spi_reset(priv->regs);
>> +       writel(OMAP3_MCSPI_MODULCTRL_MS, &priv->regs->modulctrl);
> This change look compared to what patch is trying to fix. so release
> doen't require reset?  are you sure we need to write only this bit
> release the bus or do we need to clear?

Yes, this bit switches the mcspi ip core into slave mode, meaning be 
high impedance on the spi lines, what is exactly the meaning/sense of a 
bus release.

I know the mcspi ip core very good since i've made already some vxworks 
driver and even now the
fixes in u-boot for running it with dm.

cheers,
Hannes
Jagan Teki June 28, 2018, 2:26 p.m. UTC | #3
On Tue, Jun 26, 2018 at 7:38 PM, Hannes Schmelzer <oe5hpm@oevsv.at> wrote:
> The claim/release bus function must not reset the whole SPI core because
> settings regarding wordlen, clock-frequency and so on made by
> set_wordlen, set_mode, set_speed get lost with this action. Resulting in
> a non-functional SPI.
>
> Without DM the failure didn't came up since after the spi_reset within
> claim bus all the setup (wordlen, mode, ...) was called, in DM they are
> called by the spi uclass.
>
> We change now the things as following for having a working SPI instance
> in DM:
>
> - move the spi_reset(...) to the probe call in DM for having a known
> hardware state after probe. Without DM we don't have a probe call, so we
> issue the reset as before during the claim_bus call.
>
> - in release bus we just reset the modulctrl to the reset-value (spi-
> slave)
>
> Signed-off-by: Hannes Schmelzer <oe5hpm@oevsv.at>
>
> ---

Applied to u-boot-spi/master
Hannes Schmelzer June 28, 2018, 8:37 p.m. UTC | #4
On 06/28/2018 04:26 PM, Jagan Teki wrote:
> On Tue, Jun 26, 2018 at 7:38 PM, Hannes Schmelzer <oe5hpm@oevsv.at> wrote:
>> The claim/release bus function must not reset the whole SPI core because
>> settings regarding wordlen, clock-frequency and so on made by
>> set_wordlen, set_mode, set_speed get lost with this action. Resulting in
>> a non-functional SPI.
>>
>> Without DM the failure didn't came up since after the spi_reset within
>> claim bus all the setup (wordlen, mode, ...) was called, in DM they are
>> called by the spi uclass.
>>
>> We change now the things as following for having a working SPI instance
>> in DM:
>>
>> - move the spi_reset(...) to the probe call in DM for having a known
>> hardware state after probe. Without DM we don't have a probe call, so we
>> issue the reset as before during the claim_bus call.
>>
>> - in release bus we just reset the modulctrl to the reset-value (spi-
>> slave)
>>
>> Signed-off-by: Hannes Schmelzer <oe5hpm@oevsv.at>
>>
>> ---
> Applied to u-boot-spi/master
do we have a chance to get into rc3 with this?

cheers,
Hannes
Tom Rini June 28, 2018, 9:52 p.m. UTC | #5
On Thu, Jun 28, 2018 at 10:37:10PM +0200, Hannes Schmelzer wrote:
> 
> On 06/28/2018 04:26 PM, Jagan Teki wrote:
> >On Tue, Jun 26, 2018 at 7:38 PM, Hannes Schmelzer <oe5hpm@oevsv.at> wrote:
> >>The claim/release bus function must not reset the whole SPI core because
> >>settings regarding wordlen, clock-frequency and so on made by
> >>set_wordlen, set_mode, set_speed get lost with this action. Resulting in
> >>a non-functional SPI.
> >>
> >>Without DM the failure didn't came up since after the spi_reset within
> >>claim bus all the setup (wordlen, mode, ...) was called, in DM they are
> >>called by the spi uclass.
> >>
> >>We change now the things as following for having a working SPI instance
> >>in DM:
> >>
> >>- move the spi_reset(...) to the probe call in DM for having a known
> >>hardware state after probe. Without DM we don't have a probe call, so we
> >>issue the reset as before during the claim_bus call.
> >>
> >>- in release bus we just reset the modulctrl to the reset-value (spi-
> >>slave)
> >>
> >>Signed-off-by: Hannes Schmelzer <oe5hpm@oevsv.at>
> >>
> >>---
> >Applied to u-boot-spi/master
> do we have a chance to get into rc3 with this?

I would like to see this and the other fixes in for that, yes, thanks!
diff mbox series

Patch

diff --git a/drivers/spi/omap3_spi.c b/drivers/spi/omap3_spi.c
index 4169abd..41bdab7 100644
--- a/drivers/spi/omap3_spi.c
+++ b/drivers/spi/omap3_spi.c
@@ -443,9 +443,6 @@  static void spi_reset(struct mcspi *regs)
 static void _omap3_spi_claim_bus(struct omap3_spi_priv *priv)
 {
 	unsigned int conf;
-
-	spi_reset(priv->regs);
-
 	/*
 	 * setup when switching from (reset default) slave mode
 	 * to single-channel master mode
@@ -480,6 +477,8 @@  int spi_claim_bus(struct spi_slave *slave)
 {
 	struct omap3_spi_priv *priv = to_omap3_spi(slave);
 
+	spi_reset(priv->regs);
+
 	_omap3_spi_claim_bus(priv);
 	_omap3_spi_set_wordlen(priv);
 	_omap3_spi_set_mode(priv);
@@ -492,8 +491,7 @@  void spi_release_bus(struct spi_slave *slave)
 {
 	struct omap3_spi_priv *priv = to_omap3_spi(slave);
 
-	/* Reset the SPI hardware */
-	spi_reset(priv->regs);
+	writel(OMAP3_MCSPI_MODULCTRL_MS, &priv->regs->modulctrl);
 }
 
 struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,
@@ -600,8 +598,7 @@  static int omap3_spi_release_bus(struct udevice *dev)
 	struct udevice *bus = dev->parent;
 	struct omap3_spi_priv *priv = dev_get_priv(bus);
 
-	/* Reset the SPI hardware */
-	spi_reset(priv->regs);
+	writel(OMAP3_MCSPI_MODULCTRL_MS, &priv->regs->modulctrl);
 
 	return 0;
 }
@@ -634,6 +631,9 @@  static int omap3_spi_probe(struct udevice *dev)
 	else
 		priv->pin_dir = MCSPI_PINDIR_D0_IN_D1_OUT;
 	priv->wordlen = SPI_DEFAULT_WORDLEN;
+
+	spi_reset(priv->regs);
+
 	return 0;
 }