Commit eefc6c5c authored by Yang Yingliang's avatar Yang Yingliang Committed by Mark Brown

spi: dw: switch to use modern name

Change legacy name master to modern name host or controller.

No functional changed.
Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
Link: https://lore.kernel.org/r/20230728093221.3312026-20-yangyingliang@huawei.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 5ab7a7e3
...@@ -61,7 +61,7 @@ static void dw_spi_debugfs_init(struct dw_spi *dws) ...@@ -61,7 +61,7 @@ static void dw_spi_debugfs_init(struct dw_spi *dws)
{ {
char name[32]; char name[32];
snprintf(name, 32, "dw_spi%d", dws->master->bus_num); snprintf(name, 32, "dw_spi%d", dws->host->bus_num);
dws->debugfs = debugfs_create_dir(name, NULL); dws->debugfs = debugfs_create_dir(name, NULL);
dws->regset.regs = dw_spi_dbgfs_regs; dws->regset.regs = dw_spi_dbgfs_regs;
...@@ -183,25 +183,25 @@ int dw_spi_check_status(struct dw_spi *dws, bool raw) ...@@ -183,25 +183,25 @@ int dw_spi_check_status(struct dw_spi *dws, bool raw)
irq_status = dw_readl(dws, DW_SPI_ISR); irq_status = dw_readl(dws, DW_SPI_ISR);
if (irq_status & DW_SPI_INT_RXOI) { if (irq_status & DW_SPI_INT_RXOI) {
dev_err(&dws->master->dev, "RX FIFO overflow detected\n"); dev_err(&dws->host->dev, "RX FIFO overflow detected\n");
ret = -EIO; ret = -EIO;
} }
if (irq_status & DW_SPI_INT_RXUI) { if (irq_status & DW_SPI_INT_RXUI) {
dev_err(&dws->master->dev, "RX FIFO underflow detected\n"); dev_err(&dws->host->dev, "RX FIFO underflow detected\n");
ret = -EIO; ret = -EIO;
} }
if (irq_status & DW_SPI_INT_TXOI) { if (irq_status & DW_SPI_INT_TXOI) {
dev_err(&dws->master->dev, "TX FIFO overflow detected\n"); dev_err(&dws->host->dev, "TX FIFO overflow detected\n");
ret = -EIO; ret = -EIO;
} }
/* Generically handle the erroneous situation */ /* Generically handle the erroneous situation */
if (ret) { if (ret) {
dw_spi_reset_chip(dws); dw_spi_reset_chip(dws);
if (dws->master->cur_msg) if (dws->host->cur_msg)
dws->master->cur_msg->status = ret; dws->host->cur_msg->status = ret;
} }
return ret; return ret;
...@@ -213,7 +213,7 @@ static irqreturn_t dw_spi_transfer_handler(struct dw_spi *dws) ...@@ -213,7 +213,7 @@ static irqreturn_t dw_spi_transfer_handler(struct dw_spi *dws)
u16 irq_status = dw_readl(dws, DW_SPI_ISR); u16 irq_status = dw_readl(dws, DW_SPI_ISR);
if (dw_spi_check_status(dws, false)) { if (dw_spi_check_status(dws, false)) {
spi_finalize_current_transfer(dws->master); spi_finalize_current_transfer(dws->host);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
...@@ -227,7 +227,7 @@ static irqreturn_t dw_spi_transfer_handler(struct dw_spi *dws) ...@@ -227,7 +227,7 @@ static irqreturn_t dw_spi_transfer_handler(struct dw_spi *dws)
dw_reader(dws); dw_reader(dws);
if (!dws->rx_len) { if (!dws->rx_len) {
dw_spi_mask_intr(dws, 0xff); dw_spi_mask_intr(dws, 0xff);
spi_finalize_current_transfer(dws->master); spi_finalize_current_transfer(dws->host);
} else if (dws->rx_len <= dw_readl(dws, DW_SPI_RXFTLR)) { } else if (dws->rx_len <= dw_readl(dws, DW_SPI_RXFTLR)) {
dw_writel(dws, DW_SPI_RXFTLR, dws->rx_len - 1); dw_writel(dws, DW_SPI_RXFTLR, dws->rx_len - 1);
} }
...@@ -248,14 +248,14 @@ static irqreturn_t dw_spi_transfer_handler(struct dw_spi *dws) ...@@ -248,14 +248,14 @@ static irqreturn_t dw_spi_transfer_handler(struct dw_spi *dws)
static irqreturn_t dw_spi_irq(int irq, void *dev_id) static irqreturn_t dw_spi_irq(int irq, void *dev_id)
{ {
struct spi_controller *master = dev_id; struct spi_controller *host = dev_id;
struct dw_spi *dws = spi_controller_get_devdata(master); struct dw_spi *dws = spi_controller_get_devdata(host);
u16 irq_status = dw_readl(dws, DW_SPI_ISR) & DW_SPI_INT_MASK; u16 irq_status = dw_readl(dws, DW_SPI_ISR) & DW_SPI_INT_MASK;
if (!irq_status) if (!irq_status)
return IRQ_NONE; return IRQ_NONE;
if (!master->cur_msg) { if (!host->cur_msg) {
dw_spi_mask_intr(dws, 0xff); dw_spi_mask_intr(dws, 0xff);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
...@@ -408,11 +408,11 @@ static int dw_spi_poll_transfer(struct dw_spi *dws, ...@@ -408,11 +408,11 @@ static int dw_spi_poll_transfer(struct dw_spi *dws,
return 0; return 0;
} }
static int dw_spi_transfer_one(struct spi_controller *master, static int dw_spi_transfer_one(struct spi_controller *host,
struct spi_device *spi, struct spi_device *spi,
struct spi_transfer *transfer) struct spi_transfer *transfer)
{ {
struct dw_spi *dws = spi_controller_get_devdata(master); struct dw_spi *dws = spi_controller_get_devdata(host);
struct dw_spi_cfg cfg = { struct dw_spi_cfg cfg = {
.tmode = DW_SPI_CTRLR0_TMOD_TR, .tmode = DW_SPI_CTRLR0_TMOD_TR,
.dfs = transfer->bits_per_word, .dfs = transfer->bits_per_word,
...@@ -440,8 +440,8 @@ static int dw_spi_transfer_one(struct spi_controller *master, ...@@ -440,8 +440,8 @@ static int dw_spi_transfer_one(struct spi_controller *master,
transfer->effective_speed_hz = dws->current_freq; transfer->effective_speed_hz = dws->current_freq;
/* Check if current transfer is a DMA transaction */ /* Check if current transfer is a DMA transaction */
if (master->can_dma && master->can_dma(master, spi, transfer)) if (host->can_dma && host->can_dma(host, spi, transfer))
dws->dma_mapped = master->cur_msg_mapped; dws->dma_mapped = host->cur_msg_mapped;
/* For poll mode just disable all interrupts */ /* For poll mode just disable all interrupts */
dw_spi_mask_intr(dws, 0xff); dw_spi_mask_intr(dws, 0xff);
...@@ -464,10 +464,10 @@ static int dw_spi_transfer_one(struct spi_controller *master, ...@@ -464,10 +464,10 @@ static int dw_spi_transfer_one(struct spi_controller *master,
return 1; return 1;
} }
static void dw_spi_handle_err(struct spi_controller *master, static void dw_spi_handle_err(struct spi_controller *host,
struct spi_message *msg) struct spi_message *msg)
{ {
struct dw_spi *dws = spi_controller_get_devdata(master); struct dw_spi *dws = spi_controller_get_devdata(host);
if (dws->dma_mapped) if (dws->dma_mapped)
dws->dma_ops->dma_stop(dws); dws->dma_ops->dma_stop(dws);
...@@ -576,7 +576,7 @@ static int dw_spi_write_then_read(struct dw_spi *dws, struct spi_device *spi) ...@@ -576,7 +576,7 @@ static int dw_spi_write_then_read(struct dw_spi *dws, struct spi_device *spi)
while (len) { while (len) {
entries = readl_relaxed(dws->regs + DW_SPI_TXFLR); entries = readl_relaxed(dws->regs + DW_SPI_TXFLR);
if (!entries) { if (!entries) {
dev_err(&dws->master->dev, "CS de-assertion on Tx\n"); dev_err(&dws->host->dev, "CS de-assertion on Tx\n");
return -EIO; return -EIO;
} }
room = min(dws->fifo_len - entries, len); room = min(dws->fifo_len - entries, len);
...@@ -596,7 +596,7 @@ static int dw_spi_write_then_read(struct dw_spi *dws, struct spi_device *spi) ...@@ -596,7 +596,7 @@ static int dw_spi_write_then_read(struct dw_spi *dws, struct spi_device *spi)
if (!entries) { if (!entries) {
sts = readl_relaxed(dws->regs + DW_SPI_RISR); sts = readl_relaxed(dws->regs + DW_SPI_RISR);
if (sts & DW_SPI_INT_RXOI) { if (sts & DW_SPI_INT_RXOI) {
dev_err(&dws->master->dev, "FIFO overflow on Rx\n"); dev_err(&dws->host->dev, "FIFO overflow on Rx\n");
return -EIO; return -EIO;
} }
continue; continue;
...@@ -637,7 +637,7 @@ static int dw_spi_wait_mem_op_done(struct dw_spi *dws) ...@@ -637,7 +637,7 @@ static int dw_spi_wait_mem_op_done(struct dw_spi *dws)
spi_delay_exec(&delay, NULL); spi_delay_exec(&delay, NULL);
if (retry < 0) { if (retry < 0) {
dev_err(&dws->master->dev, "Mem op hanged up\n"); dev_err(&dws->host->dev, "Mem op hanged up\n");
return -EIO; return -EIO;
} }
...@@ -884,56 +884,56 @@ static void dw_spi_hw_init(struct device *dev, struct dw_spi *dws) ...@@ -884,56 +884,56 @@ static void dw_spi_hw_init(struct device *dev, struct dw_spi *dws)
int dw_spi_add_host(struct device *dev, struct dw_spi *dws) int dw_spi_add_host(struct device *dev, struct dw_spi *dws)
{ {
struct spi_controller *master; struct spi_controller *host;
int ret; int ret;
if (!dws) if (!dws)
return -EINVAL; return -EINVAL;
master = spi_alloc_master(dev, 0); host = spi_alloc_host(dev, 0);
if (!master) if (!host)
return -ENOMEM; return -ENOMEM;
device_set_node(&master->dev, dev_fwnode(dev)); device_set_node(&host->dev, dev_fwnode(dev));
dws->master = master; dws->host = host;
dws->dma_addr = (dma_addr_t)(dws->paddr + DW_SPI_DR); dws->dma_addr = (dma_addr_t)(dws->paddr + DW_SPI_DR);
spi_controller_set_devdata(master, dws); spi_controller_set_devdata(host, dws);
/* Basic HW init */ /* Basic HW init */
dw_spi_hw_init(dev, dws); dw_spi_hw_init(dev, dws);
ret = request_irq(dws->irq, dw_spi_irq, IRQF_SHARED, dev_name(dev), ret = request_irq(dws->irq, dw_spi_irq, IRQF_SHARED, dev_name(dev),
master); host);
if (ret < 0 && ret != -ENOTCONN) { if (ret < 0 && ret != -ENOTCONN) {
dev_err(dev, "can not get IRQ\n"); dev_err(dev, "can not get IRQ\n");
goto err_free_master; goto err_free_host;
} }
dw_spi_init_mem_ops(dws); dw_spi_init_mem_ops(dws);
master->use_gpio_descriptors = true; host->use_gpio_descriptors = true;
master->mode_bits = SPI_CPOL | SPI_CPHA | SPI_LOOP; host->mode_bits = SPI_CPOL | SPI_CPHA | SPI_LOOP;
if (dws->caps & DW_SPI_CAP_DFS32) if (dws->caps & DW_SPI_CAP_DFS32)
master->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 32); host->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 32);
else else
master->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 16); host->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 16);
master->bus_num = dws->bus_num; host->bus_num = dws->bus_num;
master->num_chipselect = dws->num_cs; host->num_chipselect = dws->num_cs;
master->setup = dw_spi_setup; host->setup = dw_spi_setup;
master->cleanup = dw_spi_cleanup; host->cleanup = dw_spi_cleanup;
if (dws->set_cs) if (dws->set_cs)
master->set_cs = dws->set_cs; host->set_cs = dws->set_cs;
else else
master->set_cs = dw_spi_set_cs; host->set_cs = dw_spi_set_cs;
master->transfer_one = dw_spi_transfer_one; host->transfer_one = dw_spi_transfer_one;
master->handle_err = dw_spi_handle_err; host->handle_err = dw_spi_handle_err;
if (dws->mem_ops.exec_op) if (dws->mem_ops.exec_op)
master->mem_ops = &dws->mem_ops; host->mem_ops = &dws->mem_ops;
master->max_speed_hz = dws->max_freq; host->max_speed_hz = dws->max_freq;
master->flags = SPI_CONTROLLER_GPIO_SS; host->flags = SPI_CONTROLLER_GPIO_SS;
master->auto_runtime_pm = true; host->auto_runtime_pm = true;
/* Get default rx sample delay */ /* Get default rx sample delay */
device_property_read_u32(dev, "rx-sample-delay-ns", device_property_read_u32(dev, "rx-sample-delay-ns",
...@@ -946,14 +946,14 @@ int dw_spi_add_host(struct device *dev, struct dw_spi *dws) ...@@ -946,14 +946,14 @@ int dw_spi_add_host(struct device *dev, struct dw_spi *dws)
} else if (ret) { } else if (ret) {
dev_warn(dev, "DMA init failed\n"); dev_warn(dev, "DMA init failed\n");
} else { } else {
master->can_dma = dws->dma_ops->can_dma; host->can_dma = dws->dma_ops->can_dma;
master->flags |= SPI_CONTROLLER_MUST_TX; host->flags |= SPI_CONTROLLER_MUST_TX;
} }
} }
ret = spi_register_controller(master); ret = spi_register_controller(host);
if (ret) { if (ret) {
dev_err_probe(dev, ret, "problem registering spi master\n"); dev_err_probe(dev, ret, "problem registering spi host\n");
goto err_dma_exit; goto err_dma_exit;
} }
...@@ -965,9 +965,9 @@ int dw_spi_add_host(struct device *dev, struct dw_spi *dws) ...@@ -965,9 +965,9 @@ int dw_spi_add_host(struct device *dev, struct dw_spi *dws)
dws->dma_ops->dma_exit(dws); dws->dma_ops->dma_exit(dws);
dw_spi_enable_chip(dws, 0); dw_spi_enable_chip(dws, 0);
err_free_irq: err_free_irq:
free_irq(dws->irq, master); free_irq(dws->irq, host);
err_free_master: err_free_host:
spi_controller_put(master); spi_controller_put(host);
return ret; return ret;
} }
EXPORT_SYMBOL_NS_GPL(dw_spi_add_host, SPI_DW_CORE); EXPORT_SYMBOL_NS_GPL(dw_spi_add_host, SPI_DW_CORE);
...@@ -976,14 +976,14 @@ void dw_spi_remove_host(struct dw_spi *dws) ...@@ -976,14 +976,14 @@ void dw_spi_remove_host(struct dw_spi *dws)
{ {
dw_spi_debugfs_remove(dws); dw_spi_debugfs_remove(dws);
spi_unregister_controller(dws->master); spi_unregister_controller(dws->host);
if (dws->dma_ops && dws->dma_ops->dma_exit) if (dws->dma_ops && dws->dma_ops->dma_exit)
dws->dma_ops->dma_exit(dws); dws->dma_ops->dma_exit(dws);
dw_spi_shutdown_chip(dws); dw_spi_shutdown_chip(dws);
free_irq(dws->irq, dws->master); free_irq(dws->irq, dws->host);
} }
EXPORT_SYMBOL_NS_GPL(dw_spi_remove_host, SPI_DW_CORE); EXPORT_SYMBOL_NS_GPL(dw_spi_remove_host, SPI_DW_CORE);
...@@ -991,7 +991,7 @@ int dw_spi_suspend_host(struct dw_spi *dws) ...@@ -991,7 +991,7 @@ int dw_spi_suspend_host(struct dw_spi *dws)
{ {
int ret; int ret;
ret = spi_controller_suspend(dws->master); ret = spi_controller_suspend(dws->host);
if (ret) if (ret)
return ret; return ret;
...@@ -1002,8 +1002,8 @@ EXPORT_SYMBOL_NS_GPL(dw_spi_suspend_host, SPI_DW_CORE); ...@@ -1002,8 +1002,8 @@ EXPORT_SYMBOL_NS_GPL(dw_spi_suspend_host, SPI_DW_CORE);
int dw_spi_resume_host(struct dw_spi *dws) int dw_spi_resume_host(struct dw_spi *dws)
{ {
dw_spi_hw_init(&dws->master->dev, dws); dw_spi_hw_init(&dws->host->dev, dws);
return spi_controller_resume(dws->master); return spi_controller_resume(dws->host);
} }
EXPORT_SYMBOL_NS_GPL(dw_spi_resume_host, SPI_DW_CORE); EXPORT_SYMBOL_NS_GPL(dw_spi_resume_host, SPI_DW_CORE);
......
...@@ -139,8 +139,8 @@ static int dw_spi_dma_init_mfld(struct device *dev, struct dw_spi *dws) ...@@ -139,8 +139,8 @@ static int dw_spi_dma_init_mfld(struct device *dev, struct dw_spi *dws)
if (!dws->txchan) if (!dws->txchan)
goto free_rxchan; goto free_rxchan;
dws->master->dma_rx = dws->rxchan; dws->host->dma_rx = dws->rxchan;
dws->master->dma_tx = dws->txchan; dws->host->dma_tx = dws->txchan;
init_completion(&dws->dma_completion); init_completion(&dws->dma_completion);
...@@ -183,8 +183,8 @@ static int dw_spi_dma_init_generic(struct device *dev, struct dw_spi *dws) ...@@ -183,8 +183,8 @@ static int dw_spi_dma_init_generic(struct device *dev, struct dw_spi *dws)
goto free_rxchan; goto free_rxchan;
} }
dws->master->dma_rx = dws->rxchan; dws->host->dma_rx = dws->rxchan;
dws->master->dma_tx = dws->txchan; dws->host->dma_tx = dws->txchan;
init_completion(&dws->dma_completion); init_completion(&dws->dma_completion);
...@@ -242,10 +242,10 @@ static enum dma_slave_buswidth dw_spi_dma_convert_width(u8 n_bytes) ...@@ -242,10 +242,10 @@ static enum dma_slave_buswidth dw_spi_dma_convert_width(u8 n_bytes)
} }
} }
static bool dw_spi_can_dma(struct spi_controller *master, static bool dw_spi_can_dma(struct spi_controller *host,
struct spi_device *spi, struct spi_transfer *xfer) struct spi_device *spi, struct spi_transfer *xfer)
{ {
struct dw_spi *dws = spi_controller_get_devdata(master); struct dw_spi *dws = spi_controller_get_devdata(host);
enum dma_slave_buswidth dma_bus_width; enum dma_slave_buswidth dma_bus_width;
if (xfer->len <= dws->fifo_len) if (xfer->len <= dws->fifo_len)
...@@ -271,7 +271,7 @@ static int dw_spi_dma_wait(struct dw_spi *dws, unsigned int len, u32 speed) ...@@ -271,7 +271,7 @@ static int dw_spi_dma_wait(struct dw_spi *dws, unsigned int len, u32 speed)
msecs_to_jiffies(ms)); msecs_to_jiffies(ms));
if (ms == 0) { if (ms == 0) {
dev_err(&dws->master->cur_msg->spi->dev, dev_err(&dws->host->cur_msg->spi->dev,
"DMA transaction timed out\n"); "DMA transaction timed out\n");
return -ETIMEDOUT; return -ETIMEDOUT;
} }
...@@ -299,7 +299,7 @@ static int dw_spi_dma_wait_tx_done(struct dw_spi *dws, ...@@ -299,7 +299,7 @@ static int dw_spi_dma_wait_tx_done(struct dw_spi *dws,
spi_delay_exec(&delay, xfer); spi_delay_exec(&delay, xfer);
if (retry < 0) { if (retry < 0) {
dev_err(&dws->master->dev, "Tx hanged up\n"); dev_err(&dws->host->dev, "Tx hanged up\n");
return -EIO; return -EIO;
} }
...@@ -400,7 +400,7 @@ static int dw_spi_dma_wait_rx_done(struct dw_spi *dws) ...@@ -400,7 +400,7 @@ static int dw_spi_dma_wait_rx_done(struct dw_spi *dws)
spi_delay_exec(&delay, NULL); spi_delay_exec(&delay, NULL);
if (retry < 0) { if (retry < 0) {
dev_err(&dws->master->dev, "Rx hanged up\n"); dev_err(&dws->host->dev, "Rx hanged up\n");
return -EIO; return -EIO;
} }
...@@ -656,13 +656,13 @@ static int dw_spi_dma_transfer(struct dw_spi *dws, struct spi_transfer *xfer) ...@@ -656,13 +656,13 @@ static int dw_spi_dma_transfer(struct dw_spi *dws, struct spi_transfer *xfer)
if (ret) if (ret)
return ret; return ret;
if (dws->master->cur_msg->status == -EINPROGRESS) { if (dws->host->cur_msg->status == -EINPROGRESS) {
ret = dw_spi_dma_wait_tx_done(dws, xfer); ret = dw_spi_dma_wait_tx_done(dws, xfer);
if (ret) if (ret)
return ret; return ret;
} }
if (xfer->rx_buf && dws->master->cur_msg->status == -EINPROGRESS) if (xfer->rx_buf && dws->host->cur_msg->status == -EINPROGRESS)
ret = dw_spi_dma_wait_rx_done(dws); ret = dw_spi_dma_wait_rx_done(dws);
return ret; return ret;
......
...@@ -68,7 +68,7 @@ struct dw_spi_mscc { ...@@ -68,7 +68,7 @@ struct dw_spi_mscc {
((((val) << 1) | BIT(0)) << ELBA_SPICS_OFFSET(cs)) ((((val) << 1) | BIT(0)) << ELBA_SPICS_OFFSET(cs))
/* /*
* The Designware SPI controller (referred to as master in the documentation) * The Designware SPI controller (referred to as host in the documentation)
* automatically deasserts chip select when the tx fifo is empty. The chip * automatically deasserts chip select when the tx fifo is empty. The chip
* selects then needs to be either driven as GPIOs or, for the first 4 using * selects then needs to be either driven as GPIOs or, for the first 4 using
* the SPI boot controller registers. the final chip select is an OR gate * the SPI boot controller registers. the final chip select is an OR gate
...@@ -76,7 +76,7 @@ struct dw_spi_mscc { ...@@ -76,7 +76,7 @@ struct dw_spi_mscc {
*/ */
static void dw_spi_mscc_set_cs(struct spi_device *spi, bool enable) static void dw_spi_mscc_set_cs(struct spi_device *spi, bool enable)
{ {
struct dw_spi *dws = spi_master_get_devdata(spi->master); struct dw_spi *dws = spi_controller_get_devdata(spi->controller);
struct dw_spi_mmio *dwsmmio = container_of(dws, struct dw_spi_mmio, dws); struct dw_spi_mmio *dwsmmio = container_of(dws, struct dw_spi_mmio, dws);
struct dw_spi_mscc *dwsmscc = dwsmmio->priv; struct dw_spi_mscc *dwsmscc = dwsmmio->priv;
u32 cs = spi_get_chipselect(spi, 0); u32 cs = spi_get_chipselect(spi, 0);
...@@ -142,14 +142,14 @@ static int dw_spi_mscc_jaguar2_init(struct platform_device *pdev, ...@@ -142,14 +142,14 @@ static int dw_spi_mscc_jaguar2_init(struct platform_device *pdev,
} }
/* /*
* The Designware SPI controller (referred to as master in the * The Designware SPI controller (referred to as host in the
* documentation) automatically deasserts chip select when the tx fifo * documentation) automatically deasserts chip select when the tx fifo
* is empty. The chip selects then needs to be driven by a CS override * is empty. The chip selects then needs to be driven by a CS override
* register. enable is an active low signal. * register. enable is an active low signal.
*/ */
static void dw_spi_sparx5_set_cs(struct spi_device *spi, bool enable) static void dw_spi_sparx5_set_cs(struct spi_device *spi, bool enable)
{ {
struct dw_spi *dws = spi_master_get_devdata(spi->master); struct dw_spi *dws = spi_controller_get_devdata(spi->controller);
struct dw_spi_mmio *dwsmmio = container_of(dws, struct dw_spi_mmio, dws); struct dw_spi_mmio *dwsmmio = container_of(dws, struct dw_spi_mmio, dws);
struct dw_spi_mscc *dwsmscc = dwsmmio->priv; struct dw_spi_mscc *dwsmscc = dwsmmio->priv;
u8 cs = spi_get_chipselect(spi, 0); u8 cs = spi_get_chipselect(spi, 0);
...@@ -277,7 +277,7 @@ static void dw_spi_elba_override_cs(struct regmap *syscon, int cs, int enable) ...@@ -277,7 +277,7 @@ static void dw_spi_elba_override_cs(struct regmap *syscon, int cs, int enable)
static void dw_spi_elba_set_cs(struct spi_device *spi, bool enable) static void dw_spi_elba_set_cs(struct spi_device *spi, bool enable)
{ {
struct dw_spi *dws = spi_master_get_devdata(spi->master); struct dw_spi *dws = spi_controller_get_devdata(spi->controller);
struct dw_spi_mmio *dwsmmio = container_of(dws, struct dw_spi_mmio, dws); struct dw_spi_mmio *dwsmmio = container_of(dws, struct dw_spi_mmio, dws);
struct regmap *syscon = dwsmmio->priv; struct regmap *syscon = dwsmmio->priv;
u8 cs; u8 cs;
......
...@@ -142,14 +142,14 @@ struct dw_spi_dma_ops { ...@@ -142,14 +142,14 @@ struct dw_spi_dma_ops {
int (*dma_init)(struct device *dev, struct dw_spi *dws); int (*dma_init)(struct device *dev, struct dw_spi *dws);
void (*dma_exit)(struct dw_spi *dws); void (*dma_exit)(struct dw_spi *dws);
int (*dma_setup)(struct dw_spi *dws, struct spi_transfer *xfer); int (*dma_setup)(struct dw_spi *dws, struct spi_transfer *xfer);
bool (*can_dma)(struct spi_controller *master, struct spi_device *spi, bool (*can_dma)(struct spi_controller *host, struct spi_device *spi,
struct spi_transfer *xfer); struct spi_transfer *xfer);
int (*dma_transfer)(struct dw_spi *dws, struct spi_transfer *xfer); int (*dma_transfer)(struct dw_spi *dws, struct spi_transfer *xfer);
void (*dma_stop)(struct dw_spi *dws); void (*dma_stop)(struct dw_spi *dws);
}; };
struct dw_spi { struct dw_spi {
struct spi_controller *master; struct spi_controller *host;
u32 ip; /* Synopsys DW SSI IP-core ID */ u32 ip; /* Synopsys DW SSI IP-core ID */
u32 ver; /* Synopsys component version */ u32 ver; /* Synopsys component version */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment