From: Tristram Ha <tristram...@microchip.com>

SPI driver calls own specific switch register function.
Shutdown callback function is added to reset switch to default state.

Signed-off-by: Tristram Ha <tristram...@microchip.com>
---
diff --git a/drivers/net/dsa/microchip/ksz_spi.c 
b/drivers/net/dsa/microchip/ksz_spi.c
index c519469..d03eb83 100644
--- a/drivers/net/dsa/microchip/ksz_spi.c
+++ b/drivers/net/dsa/microchip/ksz_spi.c
@@ -25,6 +25,8 @@
 
 #include "ksz_priv.h"
 
+int ksz9477_switch_register(struct ksz_device *dev);
+
 /* SPI frame opcodes */
 #define KS_SPIOP_RD                    3
 #define KS_SPIOP_WR                    2
@@ -174,7 +176,7 @@ static int ksz_spi_probe(struct spi_device *spi)
        if (spi->dev.platform_data)
                dev->pdata = spi->dev.platform_data;
 
-       ret = ksz_switch_register(dev);
+       ret = ksz9477_switch_register(dev);
        if (ret)
                return ret;
 
@@ -193,6 +195,14 @@ static int ksz_spi_remove(struct spi_device *spi)
        return 0;
 }
 
+static void ksz_spi_shutdown(struct spi_device *spi) {
+       struct ksz_device *dev = spi_get_drvdata(spi);
+
+       if (dev)
+               dev->dev_ops->reset(dev);
+}
+
 static const struct of_device_id ksz_dt_ids[] = {
        { .compatible = "microchip,ksz9477" },
        {},
@@ -207,6 +217,7 @@ static int ksz_spi_remove(struct spi_device *spi)
        },
        .probe  = ksz_spi_probe,
        .remove = ksz_spi_remove,
+       .shutdown = ksz_spi_shutdown,
 };
 
 module_spi_driver(ksz_spi_driver);

Reply via email to