spi: s3c64xx: determine the fifo depth only once
[ Upstream commit c6e776ab6abdfce5a1edcde7a22c639e76499939 ] Determine the FIFO depth only once, at probe time. ``sdd->fifo_depth`` can be set later on with the FIFO depth specified in the device tree. Signed-off-by: Tudor Ambarus <tudor.ambarus@linaro.org> Link: https://msgid.link/r/20240216070555.2483977-5-tudor.ambarus@linaro.org Signed-off-by: Mark Brown <broonie@kernel.org> Stable-dep-of: a3d3eab627bb ("spi: s3c64xx: Use DMA mode from fifo size") Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
f8a6edd449
commit
5448a99c80
|
@ -189,6 +189,7 @@ struct s3c64xx_spi_port_config {
|
|||
* @tx_dma: Local transmit DMA data (e.g. chan and direction)
|
||||
* @port_conf: Local SPI port configuartion data
|
||||
* @port_id: Port identification number
|
||||
* @fifo_depth: depth of the FIFO.
|
||||
* @rx_fifomask: SPI_STATUS.RX_FIFO_LVL mask. Shifted mask defining the field's
|
||||
* length and position.
|
||||
* @tx_fifomask: SPI_STATUS.TX_FIFO_LVL mask. Shifted mask defining the field's
|
||||
|
@ -212,6 +213,7 @@ struct s3c64xx_spi_driver_data {
|
|||
struct s3c64xx_spi_dma_data tx_dma;
|
||||
const struct s3c64xx_spi_port_config *port_conf;
|
||||
unsigned int port_id;
|
||||
unsigned int fifo_depth;
|
||||
u32 rx_fifomask;
|
||||
u32 tx_fifomask;
|
||||
};
|
||||
|
@ -422,7 +424,7 @@ static bool s3c64xx_spi_can_dma(struct spi_controller *host,
|
|||
struct s3c64xx_spi_driver_data *sdd = spi_controller_get_devdata(host);
|
||||
|
||||
if (sdd->rx_dma.ch && sdd->tx_dma.ch)
|
||||
return xfer->len > FIFO_DEPTH(sdd);
|
||||
return xfer->len > sdd->fifo_depth;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
@ -509,7 +511,7 @@ static u32 s3c64xx_spi_wait_for_timeout(struct s3c64xx_spi_driver_data *sdd,
|
|||
void __iomem *regs = sdd->regs;
|
||||
unsigned long val = 1;
|
||||
u32 status;
|
||||
u32 max_fifo = FIFO_DEPTH(sdd);
|
||||
u32 max_fifo = sdd->fifo_depth;
|
||||
|
||||
if (timeout_ms)
|
||||
val = msecs_to_loops(timeout_ms);
|
||||
|
@ -616,7 +618,7 @@ static int s3c64xx_wait_for_pio(struct s3c64xx_spi_driver_data *sdd,
|
|||
* For any size less than the fifo size the below code is
|
||||
* executed atleast once.
|
||||
*/
|
||||
loops = xfer->len / FIFO_DEPTH(sdd);
|
||||
loops = xfer->len / sdd->fifo_depth;
|
||||
buf = xfer->rx_buf;
|
||||
do {
|
||||
/* wait for data to be received in the fifo */
|
||||
|
@ -753,7 +755,7 @@ static int s3c64xx_spi_transfer_one(struct spi_controller *host,
|
|||
struct spi_transfer *xfer)
|
||||
{
|
||||
struct s3c64xx_spi_driver_data *sdd = spi_controller_get_devdata(host);
|
||||
const unsigned int fifo_len = FIFO_DEPTH(sdd);
|
||||
const unsigned int fifo_len = sdd->fifo_depth;
|
||||
const void *tx_buf = NULL;
|
||||
void *rx_buf = NULL;
|
||||
int target_len = 0, origin_len = 0;
|
||||
|
@ -1220,6 +1222,8 @@ static int s3c64xx_spi_probe(struct platform_device *pdev)
|
|||
sdd->port_id = pdev->id;
|
||||
}
|
||||
|
||||
sdd->fifo_depth = FIFO_DEPTH(sdd);
|
||||
|
||||
s3c64xx_spi_set_fifomask(sdd);
|
||||
|
||||
sdd->cur_bpw = 8;
|
||||
|
@ -1311,7 +1315,7 @@ static int s3c64xx_spi_probe(struct platform_device *pdev)
|
|||
dev_dbg(&pdev->dev, "Samsung SoC SPI Driver loaded for Bus SPI-%d with %d Targets attached\n",
|
||||
sdd->port_id, host->num_chipselect);
|
||||
dev_dbg(&pdev->dev, "\tIOmem=[%pR]\tFIFO %dbytes\n",
|
||||
mem_res, FIFO_DEPTH(sdd));
|
||||
mem_res, sdd->fifo_depth);
|
||||
|
||||
pm_runtime_mark_last_busy(&pdev->dev);
|
||||
pm_runtime_put_autosuspend(&pdev->dev);
|
||||
|
|
Loading…
Reference in New Issue