[PATCH 6/6] spi: spi-s3c64xx: Allow higher transfer lengths in polling IO mode
andi at etezian.org
andi at etezian.org
Mon Apr 16 12:19:42 PDT 2018
Hi Sylwester,
On 17.04.2018 00:40, Sylwester Nawrocki wrote:
> Some variants of the SPI controller have no DMA support, in such case
> SPI transfers longer than the FIFO length are not currently properly
> handled by the driver. Fix it by doing multiple transfers in the
> s3c64xx_spi_transfer_one() function if the SPI transfer length exceeds
> the FIFO size.
this patch is a mix of cosmetics and what you are actually describing
in the commit log...
> @@ -634,11 +634,15 @@ static int s3c64xx_spi_transfer_one(struct
> spi_master *master,
> struct spi_transfer *xfer)
> {
> struct s3c64xx_spi_driver_data *sdd = spi_master_get_devdata(master);
> + const unsigned int fifo_len = (FIFO_LVL_MASK(sdd) >> 1) + 1;
> + const void *tx_buf = NULL;
> + void *rx_buf = NULL;
> + int target_len = 0, origin_len = 0;
> + bool use_dma = false;
> int status;
> u32 speed;
> u8 bpw;
> unsigned long flags;
> - int use_dma;
... for example 'use_dma' bool instead of int or the 'fifo_len'. I agree
with these changes and, even though they are trivial, I would prefer
having them in separate patches.
Thanks,
Andi
More information about the linux-arm-kernel
mailing list