[OpenWrt-Devel] [PATCH] mac80211: fix WARN_ON_ONCE() caused by inbalanced set/clear of beacon enable bit.

Yousong Zhou yszhou4tech at gmail.com
Sun Aug 24 23:29:42 EDT 2014


A WARN_ON_ONCE() dump was triggered on a MT7620A based device with
following config.  Fixes ticket #17032.

	config wifi-iface
		option device   radio0
		option network  lan
		option mode     ap
		option ssid     OpenWrt__T
		option encryption none

	config wifi-iface
		option device   radio0
		option network  lan
		option mode     ap
		option ssid     OpenWrt__TT
		option encryption none

The dumped warning message.

	[   23.890000] ------------[ cut here ]------------
	[   23.900000] WARNING: at /home/yousong/trunk-openwrt/build_dir/target-mipsel_24kec+dsp_uClibc-0.9.33.2/linux-ramips_mt7620a/compat-wireless-2014-05-22/drivers/net/wireless/rt2x00/rt2800lib.c:1092 rt2800_conf_tx+0x3c8/0x494 [rt2800lib]()
	[   23.940000] Modules linked in: rt2800soc rt2800pci rt2800mmio
		rt2800lib pppoe ppp_async iptable_nat rt2x00soc rt2x00pci rt2x00mmio
		rt2x00lib pppox ppp_generic nf_nat_ipv4 nf_conntrack_ipv4 mac80211
		ipt_MASQUERADE cfg80211 xt_time xt_tcpudp xt_tcpmss xt_string
		xt_statistic xt_state xt_recent xt_nat xt_multiport xt_mark xt_mac
		xt_limit xt_length xt_hl xt_helper xt_ecn xt_dscp xt_conntrack
		xt_connmark xt_connlimit xt_connbytes xt_comment xt_TCPMSS xt_REDIRECT
		xt_LOG xt_HL xt_DSCP xt_CT xt_CLASSIFY ts_kmp ts_fsm ts_bm slhc
		nf_nat_irc nf_nat_ftp nf_nat nf_defrag_ipv4 nf_conntrack_irc
		nf_conntrack_ftp iptable_raw iptable_mangle iptable_filter ipt_REJECT
		ipt_ECN ip_tables crc_itu_t crc_ccitt compat act_connmark act_skbedit
		act_mirred em_u32 cls_u32 cls_tcindex cls_flow cls_route cls_fw sch_hfsc
		sch_ingress ledtrig_usbdev ip6t_REJECT ip6table_raw ip6table_mangle
		ip6table_filter ip6_tables x_tables nf_conntrack_ipv6 nf_conntrack
		nf_defrag_ipv6 ifb ipv6 eeprom_93cx6 arc4 crypto_blkcipher leds_gpio
		gpio_button_hotplug usbcore nls_base usb_common
	[   24.130000] CPU: 0 PID: 1502 Comm: hostapd Not tainted 3.10.44 #17
	[   24.140000] Stack : 00000000 00000000 00000000 00000000 80322eea 00000036 8390f818 83154140
		  80282f60 802d31fb 000005de 80322694 8390f818 83154140 00000008 0000001c
		  00000001 8001f00c 00000003 8001ca78 83173bd8 83154140 802847ec 82897794
		  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000
		  00000000 00000000 00000000 00000000 00000000 00000000 00000000 82897720
		  ...
	[   24.210000] Call Trace:
	[   24.220000] [<800121b4>] show_stack+0x48/0x70
	[   24.220000] [<8001cb74>] warn_slowpath_common+0x78/0xa8
	[   24.240000] [<8001cc2c>] warn_slowpath_null+0x18/0x24
	[   24.250000] [<83164078>] rt2800_conf_tx+0x3c8/0x494 [rt2800lib]
	[   24.260000]
	[   24.260000] ---[ end trace ff7bf97509953be2 ]---

Signed-off-by: Yousong Zhou <yszhou4tech at gmail.com>
---
 .../921-rt2x00-fix-beacon-bit-balance.patch        |   50 ++++++++++++++++++++
 1 file changed, 50 insertions(+)
 create mode 100644 package/kernel/mac80211/patches/921-rt2x00-fix-beacon-bit-balance.patch

diff --git a/package/kernel/mac80211/patches/921-rt2x00-fix-beacon-bit-balance.patch b/package/kernel/mac80211/patches/921-rt2x00-fix-beacon-bit-balance.patch
new file mode 100644
index 0000000..f43f2cc
--- /dev/null
+++ b/package/kernel/mac80211/patches/921-rt2x00-fix-beacon-bit-balance.patch
@@ -0,0 +1,50 @@
+Index: compat-wireless-2014-05-22/drivers/net/wireless/rt2x00/rt2x00mac.c
+===================================================================
+--- compat-wireless-2014-05-22.orig/drivers/net/wireless/rt2x00/rt2x00mac.c	2014-08-17 10:39:03.433122703 +0800
++++ compat-wireless-2014-05-22/drivers/net/wireless/rt2x00/rt2x00mac.c	2014-08-17 10:52:18.050450172 +0800
+@@ -647,12 +647,7 @@
+ 		} else if (bss_conf->enable_beacon && !intf->enable_beacon) {
+ 			rt2x00dev->intf_beaconing++;
+ 			intf->enable_beacon = true;
+-			/*
+-			 * Upload beacon to the H/W. This is only required on
+-			 * USB devices. PCI devices fetch beacons periodically.
+-			 */
+-			if (rt2x00_is_usb(rt2x00dev))
+-				rt2x00queue_update_beacon(rt2x00dev, vif);
++			rt2x00queue_update_beacon(rt2x00dev, vif);
+ 
+ 			if (rt2x00dev->intf_beaconing == 1) {
+ 				/*
+Index: compat-wireless-2014-05-22/drivers/net/wireless/rt2x00/rt2x00dev.c
+===================================================================
+--- compat-wireless-2014-05-22.orig/drivers/net/wireless/rt2x00/rt2x00dev.c	2014-08-17 10:39:04.653173875 +0800
++++ compat-wireless-2014-05-22/drivers/net/wireless/rt2x00/rt2x00dev.c	2014-08-17 10:39:23.765975494 +0800
+@@ -143,7 +143,8 @@
+ 
+ 	if (test_and_clear_bit(DELAYED_UPDATE_BEACON, &intf->delayed_flags)) {
+ 		mutex_lock(&intf->beacon_skb_mutex);
+-		rt2x00queue_update_beacon(rt2x00dev, vif);
++		if (intf->enable_beacon)
++			rt2x00queue_update_beacon(rt2x00dev, vif);
+ 		mutex_unlock(&intf->beacon_skb_mutex);
+ 	}
+ }
+@@ -206,6 +207,7 @@
+ 					struct ieee80211_vif *vif)
+ {
+ 	struct rt2x00_dev *rt2x00dev = data;
++	struct rt2x00_intf *intf = vif_to_intf(vif);
+ 
+ 	if (vif->type != NL80211_IFTYPE_AP &&
+ 	    vif->type != NL80211_IFTYPE_ADHOC &&
+@@ -219,7 +221,8 @@
+ 	 * never be called for USB devices.
+ 	 */
+ 	WARN_ON(rt2x00_is_usb(rt2x00dev));
+-	rt2x00queue_update_beacon(rt2x00dev, vif);
++	if (intf->enable_beacon)
++		rt2x00queue_update_beacon(rt2x00dev, vif);
+ }
+ 
+ void rt2x00lib_beacondone(struct rt2x00_dev *rt2x00dev)
-- 
1.7.10.4
_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel



More information about the openwrt-devel mailing list