]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net: qca_spi: Move reset_count to struct qcaspi
authorStefan Wahren <stefan.wahren@in-tech.com>
Wed, 20 Nov 2019 17:29:13 +0000 (18:29 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 20 Nov 2019 20:42:23 +0000 (12:42 -0800)
The reset counter is specific for every QCA700x chip. So move this
into the private driver struct. Otherwise we get unpredictable reset
behavior in setups with multiple QCA700x chips.

Fixes: 291ab06ecf67 (net: qualcomm: new Ethernet over SPI driver for QCA7000)
Signed-off-by: Stefan Wahren <stefan.wahren@in-tech.com>
Signed-off-by: Stefan Wahren <wahrenst@gmx.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/qualcomm/qca_spi.c
drivers/net/ethernet/qualcomm/qca_spi.h

index 351f24ff4ca5abe91e385603f640c46733474f50..baac016f3ec0bd6fd10fdd1ed33117e0af4893f1 100644 (file)
@@ -496,7 +496,6 @@ qcaspi_qca7k_sync(struct qcaspi *qca, int event)
        u16 signature = 0;
        u16 spi_config;
        u16 wrbuf_space = 0;
-       static u16 reset_count;
 
        if (event == QCASPI_EVENT_CPUON) {
                /* Read signature twice, if not valid
@@ -549,13 +548,13 @@ qcaspi_qca7k_sync(struct qcaspi *qca, int event)
 
                qca->sync = QCASPI_SYNC_RESET;
                qca->stats.trig_reset++;
-               reset_count = 0;
+               qca->reset_count = 0;
                break;
        case QCASPI_SYNC_RESET:
-               reset_count++;
+               qca->reset_count++;
                netdev_dbg(qca->net_dev, "sync: waiting for CPU on, count %u.\n",
-                          reset_count);
-               if (reset_count >= QCASPI_RESET_TIMEOUT) {
+                          qca->reset_count);
+               if (qca->reset_count >= QCASPI_RESET_TIMEOUT) {
                        /* reset did not seem to take place, try again */
                        qca->sync = QCASPI_SYNC_UNKNOWN;
                        qca->stats.reset_timeout++;
index eb9af45fcc5e9a903e65bc537cc46baa51392058..d13a67e20d6504999d02cf9a89bf104d9c240bbb 100644 (file)
@@ -94,6 +94,7 @@ struct qcaspi {
 
        unsigned int intr_req;
        unsigned int intr_svc;
+       u16 reset_count;
 
 #ifdef CONFIG_DEBUG_FS
        struct dentry *device_root;