ath10k: expose hw restart via debugfs
authorMichal Kazior <michal.kazior@tieto.com>
Tue, 28 Oct 2014 09:34:37 +0000 (10:34 +0100)
committerKalle Valo <kvalo@qca.qualcomm.com>
Fri, 31 Oct 2014 00:32:21 +0000 (02:32 +0200)
Until now it was possible to simulate soft and
hard fw crashes but it wasn't possible to trigger
an immediately hw restart itself (without the fw
crash).

This can be useful when stress testing hw
restarting stability, e.g. during heavy tx/rx
traffic.

Signed-off-by: Michal Kazior <michal.kazior@tieto.com>
Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
drivers/net/wireless/ath/ath10k/debug.c

index 9147dd36dcdd931de0a6ac6e38f016063751e5ae..a8f5a72ba2591059594dcf590f960d195c85d8eb 100644 (file)
@@ -695,7 +695,8 @@ static ssize_t ath10k_read_simulate_fw_crash(struct file *file,
                "To simulate firmware crash write one of the keywords to this file:\n"
                "`soft` - this will send WMI_FORCE_FW_HANG_ASSERT to firmware if FW supports that command.\n"
                "`hard` - this will send to firmware command with illegal parameters causing firmware crash.\n"
-               "`assert` - this will send special illegal parameter to firmware to cause assert failure and crash.\n";
+               "`assert` - this will send special illegal parameter to firmware to cause assert failure and crash.\n"
+               "`hw-restart` - this will simply queue hw restart without fw/hw actually crashing.\n";
 
        return simple_read_from_buffer(user_buf, count, ppos, buf, strlen(buf));
 }
@@ -748,6 +749,10 @@ static ssize_t ath10k_write_simulate_fw_crash(struct file *file,
        } else if (!strcmp(buf, "assert")) {
                ath10k_info(ar, "simulating firmware assert crash\n");
                ret = ath10k_debug_fw_assert(ar);
+       } else if (!strcmp(buf, "hw-restart")) {
+               ath10k_info(ar, "user requested hw restart\n");
+               queue_work(ar->workqueue, &ar->restart_work);
+               ret = 0;
        } else {
                ret = -EINVAL;
                goto exit;