Re: [PATCH] spi: spi-imx: Revert "spi: spi-imx: add PIO polling support"

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

 



On 15.11.2022 18:11:07, Frieder Schrempf wrote:
> On 15.11.22 17:52, Marc Kleine-Budde wrote:
> > On 15.11.2022 15:46:28, Frieder Schrempf wrote:
> >>> diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c
> >>> index 30d82cc7300b..76021b9bb445 100644
> >>> --- a/drivers/spi/spi-imx.c
> >>> +++ b/drivers/spi/spi-imx.c
> >>> @@ -1270,9 +1270,22 @@ static int spi_imx_setupxfer(struct spi_device *spi,
> >>>                 spi_imx->dynamic_burst = 0;
> >>>         }
> >>>  
> >>> -       if (spi_imx_can_dma(spi_imx->controller, spi, t))
> >>> -               spi_imx->usedma = true;
> >>> -       else
> >>> +       if (spi_imx_can_dma(spi_imx->controller, spi, t)) {
> >>> +               unsigned long hz_per_byte, byte_limit;
> >>> +
> >>> +               /*
> >>> +                * Calculate the estimated time in us the transfer runs. Find
> >>> +                * the number of Hz per byte per polling limit.
> >>> +                */
> >>> +               hz_per_byte = polling_limit_us ? ((8 + 4) * USEC_PER_SEC) / polling_limit_us : 0;
> >>> +               byte_limit = hz_per_byte ? t->effective_speed_hz / hz_per_byte : 1;
> >>> +
> >>> +               /* run in polling mode for short transfers */
> >>> +               if (t->len < byte_limit)
> >>> +                       spi_imx->usedma = false;
> >>> +               else
> >>> +                       spi_imx->usedma = true;
> >>> +       } else
> >>>                 spi_imx->usedma = false;
> >>>  
> >>>         spi_imx->rx_only = ((t->tx_buf == NULL)
> >>> @@ -1597,8 +1610,8 @@ static int spi_imx_transfer_one(struct spi_controller *controller,
> >>>         struct spi_imx_data *spi_imx = spi_controller_get_devdata(spi->controller);
> >>>         unsigned long hz_per_byte, byte_limit;
> >>>  
> >>> -       spi_imx_setupxfer(spi, transfer);
> >>>         transfer->effective_speed_hz = spi_imx->spi_bus_clk;
> >>> +       spi_imx_setupxfer(spi, transfer);
> >>>  
> >>>         /* flush rxfifo before transfer */
> >>>         while (spi_imx->devtype_data->rx_available(spi_imx))
> >>>
> >>
> >> Thanks for the patch, but unfortunately this doesn't help. I did some
> >> more debugging and it looks like there are two problems.
> > 
> > Can you try this one?
> > 
> > diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c
> > index 30d82cc7300b..d45da1d0ac1d 100644
> > --- a/drivers/spi/spi-imx.c
> > +++ b/drivers/spi/spi-imx.c
> > @@ -1607,6 +1607,13 @@ static int spi_imx_transfer_one(struct spi_controller *controller,
> >         if (spi_imx->slave_mode)
> >                 return spi_imx_pio_transfer_slave(spi, transfer);
> >  
> > +       /*
> > +        * If we decided in spi_imx_can_dma() that we want to do a DMA
> > +        * transfer, the message has already been mapped, so we have
> > +        * to do the DMA transfer now.
> > +        */
> > +       if (spi_imx->usedma)
> > +               return spi_imx_dma_transfer(spi_imx, transfer);
> >         /*
> >          * Calculate the estimated time in us the transfer runs. Find
> >          * the number of Hz per byte per polling limit.
> > @@ -1618,9 +1625,6 @@ static int spi_imx_transfer_one(struct spi_controller *controller,
> >         if (transfer->len < byte_limit)
> >                 return spi_imx_poll_transfer(spi, transfer);
> >  
> > -       if (spi_imx->usedma)
> > -               return spi_imx_dma_transfer(spi_imx, transfer);
> > -
> >         return spi_imx_pio_transfer(spi, transfer);
> >  }
> > 
> > The problem is: we decide on DMA in spi_imx_can_dma() the SPI frameworks
> > maps the message, and then calls spi_imx_transfer_one(). We cannot
> > operate with the CPU in the memory mapped to the DMA engine.
> > 
> > This should fix the problem without any additional patches.
> 
> This does fix the issue.

\o/

> My previous patch had the same result, as
> spi_imx_can_dma() returns false if transfer size is below fifo_size. But
> of course this is the correct fix with the correct explanation.

Ok, but I don't want to limit polling on <= FIFO sized transfers :)

Marc

-- 
Pengutronix e.K.                 | Marc Kleine-Budde           |
Embedded Linux                   | https://www.pengutronix.de  |
Vertretung West/Dortmund         | Phone: +49-231-2826-924     |
Amtsgericht Hildesheim, HRA 2686 | Fax:   +49-5121-206917-5555 |

Attachment: signature.asc
Description: PGP signature


[Index of Archives]     [Linux Kernel]     [Linux ARM (vger)]     [Linux ARM MSM]     [Linux Omap]     [Linux Arm]     [Linux Tegra]     [Fedora ARM]     [Linux for Samsung SOC]     [eCos]     [Linux Fastboot]     [Gcc Help]     [Git]     [DCCP]     [IETF Announce]     [Security]     [Linux MIPS]     [Yosemite Campsites]

  Powered by Linux