Commit 3c5e4878 authored by Stefan Wahren's avatar Stefan Wahren Committed by David S. Miller

qca_spi: Improve SPI IRQ handling

The functions qcaspi_netdev_open/close are responsible of request &
free of the SPI interrupt, which wasn't the best choice because
allocation problems are discovered not during probe. So let us split
IRQ allocation & enabling, so we can take advantage of a device
managed IRQ.
Signed-off-by: default avatarStefan Wahren <wahrenst@gmx.net>
Reviewed-by: default avatarJacob Keller <jacob.e.keller@intel.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1a10d67c
...@@ -688,7 +688,6 @@ qcaspi_netdev_open(struct net_device *dev) ...@@ -688,7 +688,6 @@ qcaspi_netdev_open(struct net_device *dev)
{ {
struct qcaspi *qca = netdev_priv(dev); struct qcaspi *qca = netdev_priv(dev);
struct task_struct *thread; struct task_struct *thread;
int ret = 0;
if (!qca) if (!qca)
return -EINVAL; return -EINVAL;
...@@ -709,14 +708,7 @@ qcaspi_netdev_open(struct net_device *dev) ...@@ -709,14 +708,7 @@ qcaspi_netdev_open(struct net_device *dev)
qca->spi_thread = thread; qca->spi_thread = thread;
ret = request_irq(qca->spi_dev->irq, qcaspi_intr_handler, 0, enable_irq(qca->spi_dev->irq);
dev->name, qca);
if (ret) {
netdev_err(dev, "%s: unable to get IRQ %d (irqval=%d).\n",
QCASPI_DRV_NAME, qca->spi_dev->irq, ret);
kthread_stop(qca->spi_thread);
return ret;
}
/* SPI thread takes care of TX queue */ /* SPI thread takes care of TX queue */
...@@ -731,7 +723,7 @@ qcaspi_netdev_close(struct net_device *dev) ...@@ -731,7 +723,7 @@ qcaspi_netdev_close(struct net_device *dev)
netif_stop_queue(dev); netif_stop_queue(dev);
qcaspi_write_register(qca, SPI_REG_INTR_ENABLE, 0, wr_verify); qcaspi_write_register(qca, SPI_REG_INTR_ENABLE, 0, wr_verify);
free_irq(qca->spi_dev->irq, qca); disable_irq(qca->spi_dev->irq);
if (qca->spi_thread) { if (qca->spi_thread) {
kthread_stop(qca->spi_thread); kthread_stop(qca->spi_thread);
...@@ -989,6 +981,15 @@ qca_spi_probe(struct spi_device *spi) ...@@ -989,6 +981,15 @@ qca_spi_probe(struct spi_device *spi)
spi_set_drvdata(spi, qcaspi_devs); spi_set_drvdata(spi, qcaspi_devs);
ret = devm_request_irq(&spi->dev, spi->irq, qcaspi_intr_handler,
IRQF_NO_AUTOEN, qca->net_dev->name, qca);
if (ret) {
dev_err(&spi->dev, "Unable to get IRQ %d (irqval=%d).\n",
spi->irq, ret);
free_netdev(qcaspi_devs);
return ret;
}
ret = of_get_ethdev_address(spi->dev.of_node, qca->net_dev); ret = of_get_ethdev_address(spi->dev.of_node, qca->net_dev);
if (ret) { if (ret) {
eth_hw_addr_random(qca->net_dev); eth_hw_addr_random(qca->net_dev);
......
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