rsi: reset device changes for 9116
authorSiva Rebbagondla <siva8118@gmail.com>
Wed, 3 Apr 2019 04:13:08 +0000 (09:43 +0530)
committerKalle Valo <kvalo@codeaurora.org>
Thu, 25 Apr 2019 16:44:29 +0000 (19:44 +0300)
Device reset register(watchdog timer related) addresses and
values are different for 9116.

Signed-off-by: Siva Rebbagondla <siva8118@gmail.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/rsi/rsi_91x_sdio.c
drivers/net/wireless/rsi/rsi_91x_usb.c
drivers/net/wireless/rsi/rsi_hal.h

index e9a2af0a1a8029ceca9ff984f10a4d780350673c..f9c67ed473d1f286e4c1acc8d694ba102ebb6b38 100644 (file)
@@ -1167,16 +1167,41 @@ static void rsi_reset_chip(struct rsi_hw *adapter)
         * and any pending dma transfers to rf spi in device to finish.
         */
        msleep(100);
-
-       ulp_read_write(adapter, RSI_ULP_RESET_REG, RSI_ULP_WRITE_0, 32);
-       ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_1, RSI_ULP_WRITE_2, 32);
-       ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_2, RSI_ULP_WRITE_0, 32);
-       ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_1, RSI_ULP_WRITE_50,
-                      32);
-       ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_2, RSI_ULP_WRITE_0,
-                      32);
-       ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_ENABLE,
-                      RSI_ULP_TIMER_ENABLE, 32);
+       if (adapter->device_model != RSI_DEV_9116) {
+               ulp_read_write(adapter, RSI_ULP_RESET_REG, RSI_ULP_WRITE_0, 32);
+               ulp_read_write(adapter,
+                              RSI_WATCH_DOG_TIMER_1, RSI_ULP_WRITE_2, 32);
+               ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_2, RSI_ULP_WRITE_0,
+                              32);
+               ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_1,
+                              RSI_ULP_WRITE_50, 32);
+               ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_2,
+                              RSI_ULP_WRITE_0, 32);
+               ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_ENABLE,
+                              RSI_ULP_TIMER_ENABLE, 32);
+       } else {
+               if ((rsi_sdio_master_reg_write(adapter,
+                                              NWP_WWD_INTERRUPT_TIMER,
+                                              NWP_WWD_INT_TIMER_CLKS,
+                                              RSI_9116_REG_SIZE)) < 0) {
+                       rsi_dbg(ERR_ZONE, "Failed to write to intr timer\n");
+               }
+               if ((rsi_sdio_master_reg_write(adapter,
+                                              NWP_WWD_SYSTEM_RESET_TIMER,
+                                              NWP_WWD_SYS_RESET_TIMER_CLKS,
+                                              RSI_9116_REG_SIZE)) < 0) {
+                       rsi_dbg(ERR_ZONE,
+                               "Failed to write to system reset timer\n");
+               }
+               if ((rsi_sdio_master_reg_write(adapter,
+                                              NWP_WWD_MODE_AND_RSTART,
+                                              NWP_WWD_TIMER_DISABLE,
+                                              RSI_9116_REG_SIZE)) < 0) {
+                       rsi_dbg(ERR_ZONE,
+                               "Failed to write to mode and restart\n");
+               }
+               rsi_dbg(ERR_ZONE, "***** Watch Dog Reset Successful *****\n");
+       }
        /* This msleep will be sufficient for the ulp
         * read write operations to complete for chip reset.
         */
index 7d9b85925150443895c260ee7abf12457a40d468..f0475b20f1533b09b5a9fa37fda1e45dab254cd2 100644 (file)
@@ -698,26 +698,47 @@ static int rsi_reset_card(struct rsi_hw *adapter)
                goto fail;
        }
 
-       ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_1,
-                                RSI_ULP_WRITE_2, 32);
-       if (ret < 0)
-               goto fail;
-       ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_2,
-                                RSI_ULP_WRITE_0, 32);
-       if (ret < 0)
-               goto fail;
-       ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_1,
-                                RSI_ULP_WRITE_50, 32);
-       if (ret < 0)
-               goto fail;
-       ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_2,
-                                RSI_ULP_WRITE_0, 32);
-       if (ret < 0)
-               goto fail;
-       ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_ENABLE,
-                                RSI_ULP_TIMER_ENABLE, 32);
-       if (ret < 0)
-               goto fail;
+       if (adapter->device_model != RSI_DEV_9116) {
+               ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_1,
+                                        RSI_ULP_WRITE_2, 32);
+               if (ret < 0)
+                       goto fail;
+               ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_2,
+                                        RSI_ULP_WRITE_0, 32);
+               if (ret < 0)
+                       goto fail;
+               ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_1,
+                                        RSI_ULP_WRITE_50, 32);
+               if (ret < 0)
+                       goto fail;
+               ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_2,
+                                        RSI_ULP_WRITE_0, 32);
+               if (ret < 0)
+                       goto fail;
+               ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_ENABLE,
+                                        RSI_ULP_TIMER_ENABLE, 32);
+               if (ret < 0)
+                       goto fail;
+       } else {
+               if ((rsi_usb_master_reg_write(adapter,
+                                             NWP_WWD_INTERRUPT_TIMER,
+                                             NWP_WWD_INT_TIMER_CLKS,
+                                             RSI_9116_REG_SIZE)) < 0) {
+                       goto fail;
+               }
+               if ((rsi_usb_master_reg_write(adapter,
+                                             NWP_WWD_SYSTEM_RESET_TIMER,
+                                             NWP_WWD_SYS_RESET_TIMER_CLKS,
+                                             RSI_9116_REG_SIZE)) < 0) {
+                       goto fail;
+               }
+               if ((rsi_usb_master_reg_write(adapter,
+                                             NWP_WWD_MODE_AND_RSTART,
+                                             NWP_WWD_TIMER_DISABLE,
+                                             RSI_9116_REG_SIZE)) < 0) {
+                       goto fail;
+               }
+       }
 
        rsi_dbg(INFO_ZONE, "Reset card done\n");
        return ret;
index c07b1a006d3fdabda5eb66d9552ea32e9a3185b4..46e36df9e8e3ccb4ff14aab41f7d098592a2f308 100644 (file)
 #define RSI_WATCH_DOG_DELAY_TIMER_2            0x16f
 #define RSI_WATCH_DOG_TIMER_ENABLE             0x170
 
+/* Watchdog timer addresses for 9116 */
+#define NWP_AHB_BASE_ADDR              0x41300000
+#define NWP_WWD_INTERRUPT_TIMER                (NWP_AHB_BASE_ADDR + 0x300)
+#define NWP_WWD_SYSTEM_RESET_TIMER     (NWP_AHB_BASE_ADDR + 0x304)
+#define NWP_WWD_WINDOW_TIMER           (NWP_AHB_BASE_ADDR + 0x308)
+#define NWP_WWD_TIMER_SETTINGS         (NWP_AHB_BASE_ADDR + 0x30C)
+#define NWP_WWD_MODE_AND_RSTART                (NWP_AHB_BASE_ADDR + 0x310)
+#define NWP_WWD_RESET_BYPASS           (NWP_AHB_BASE_ADDR + 0x314)
+#define NWP_FSM_INTR_MASK_REG          (NWP_AHB_BASE_ADDR + 0x104)
+
+/* Watchdog timer values */
+#define NWP_WWD_INT_TIMER_CLKS         5
+#define NWP_WWD_SYS_RESET_TIMER_CLKS   4
+#define NWP_WWD_TIMER_DISABLE          0xAA0001
+
 #define RSI_ULP_WRITE_0                        00
 #define RSI_ULP_WRITE_2                        02
 #define RSI_ULP_WRITE_50               50