Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0f47aeea authored by Stanislaw Gruszka's avatar Stanislaw Gruszka Committed by Kalle Valo
Browse files

rt2800: do not enable watchdog by default



Make watchdog disabled by default and add module parameter to enable it.

User will have to create file in /etc/modprobe.d/ with

options rt2800lib watchdog=1

to enable the watchdog or load "rt2800lib watchdog=1" module manually
before loading rt2800{soc,pci,usb} module.

Signed-off-by: default avatarStanislaw Gruszka <sgruszka@redhat.com>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent e403fa31
Loading
Loading
Loading
Loading
+10 −2
Original line number Diff line number Diff line
@@ -30,6 +30,10 @@
#include "rt2800lib.h"
#include "rt2800.h"

static bool modparam_watchdog;
module_param_named(watchdog, modparam_watchdog, bool, S_IRUGO);
MODULE_PARM_DESC(watchdog, "Enable watchdog to detect tx/rx hangs and reset hardware if detected");

/*
 * Register access.
 * All access to the CSR registers will go through the methods
@@ -10286,8 +10290,12 @@ int rt2800_probe_hw(struct rt2x00_dev *rt2x00dev)
		__set_bit(REQUIRE_TASKLET_CONTEXT, &rt2x00dev->cap_flags);
	}

	if (modparam_watchdog) {
		__set_bit(CAPABILITY_RESTART_HW, &rt2x00dev->cap_flags);
		rt2x00dev->link.watchdog_interval = msecs_to_jiffies(100);
	} else {
		rt2x00dev->link.watchdog_disabled = true;
	}

	/*
	 * Set the rssi offset.
+1 −0
Original line number Diff line number Diff line
@@ -326,6 +326,7 @@ struct link {
	 */
	struct delayed_work watchdog_work;
	unsigned int watchdog_interval;
	bool watchdog_disabled;

	/*
	 * Work structure for scheduling periodic AGC adjustments.
+1 −1
Original line number Diff line number Diff line
@@ -384,7 +384,7 @@ void rt2x00link_start_watchdog(struct rt2x00_dev *rt2x00dev)
	struct link *link = &rt2x00dev->link;

	if (test_bit(DEVICE_STATE_PRESENT, &rt2x00dev->flags) &&
	    rt2x00dev->ops->lib->watchdog)
	    rt2x00dev->ops->lib->watchdog && !link->watchdog_disabled)
		ieee80211_queue_delayed_work(rt2x00dev->hw,
					     &link->watchdog_work,
					     link->watchdog_interval);