From fdacc4ffe104279a258b1e3cd855ce95b9227fba Mon Sep 17 00:00:00 2001 From: Luis R. Rodriguez Date: Wed, 23 Dec 2009 16:18:09 -0800 Subject: [PATCH 2/5] mac80211: fix propagation of failed hardware reconfigurations This is a port of upstream commit: mac80211 does not propagate failed hardware reconfiguration requests. For suspend and resume this is important due to all the possible issues that can come out of the suspend <-> resume cycle. Not propagating the error means cfg80211 will assume the resume for the device went through fine and mac80211 will continue on trying to poke at the hardware, enable timers, queue work, and so on for a device which is completley unfunctional. The least we can do is to propagate device start issues and warn when this occurs upon resume. A side effect of this patch is we also now propagate the start errors upon harware reconfigurations (non-suspend), but this should also be desirable anyway, there is not point in continuing to reconfigure a device if mac80211 was unable to start the device. For further details refer to the thread: http://marc.info/?t=126151038700001&r=1&w=2 Cc: stable@kernel.org Signed-off-by: Luis R. Rodriguez --- net/mac80211/util.c | 6 ++++++ 1 files changed, 6 insertions(+), 0 deletions(-) diff --git a/net/mac80211/util.c b/net/mac80211/util.c index aeb65b3..7f4d1b3 100644 --- a/net/mac80211/util.c +++ b/net/mac80211/util.c @@ -1036,6 +1036,12 @@ int ieee80211_reconfig(struct ieee80211_local *local) /* restart hardware */ if (local->open_count) { res = drv_start(local); + if (res) { + WARN(local->suspended, "Harware became unavailable " + "upon resume likely due to a bug on mac80211, " + "your driver or a bus issue\n"); + return res; + } ieee80211_led_radio(local, true); } -- 1.6.3.3