ath9k: merge a regulatory handling fix
Signed-off-by: Felix Fietkau <nbd@openwrt.org> SVN-Revision: 43028
This commit is contained in:
parent
3df1a20197
commit
201fb55ac5
4 changed files with 59 additions and 3 deletions
|
@ -0,0 +1,56 @@
|
|||
From: Felix Fietkau <nbd@openwrt.org>
|
||||
Date: Wed, 22 Oct 2014 15:21:22 +0200
|
||||
Subject: [PATCH] ath: use CTL region from cfg80211 if unset in EEPROM
|
||||
|
||||
Many AP devices do not have the proper regulatory domain programmed in
|
||||
EEPROM. Instead they expect the software to set the appropriate region.
|
||||
For these devices, the country code defaults to US, and the driver uses
|
||||
the US CTL tables as well.
|
||||
On devices bought in Europe this can lead to tx power being set too high
|
||||
on the band edges, even if the cfg80211 regdomain is set correctly.
|
||||
Fix this issue by taking into account the DFS region, but only when the
|
||||
EEPROM regdomain is set to default.
|
||||
|
||||
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
|
||||
---
|
||||
|
||||
--- a/drivers/net/wireless/ath/ath.h
|
||||
+++ b/drivers/net/wireless/ath/ath.h
|
||||
@@ -80,6 +80,7 @@ struct reg_dmn_pair_mapping {
|
||||
|
||||
struct ath_regulatory {
|
||||
char alpha2[2];
|
||||
+ enum nl80211_dfs_regions region;
|
||||
u16 country_code;
|
||||
u16 max_power_level;
|
||||
u16 current_rd;
|
||||
--- a/drivers/net/wireless/ath/regd.c
|
||||
+++ b/drivers/net/wireless/ath/regd.c
|
||||
@@ -515,6 +515,7 @@ void ath_reg_notifier_apply(struct wiphy
|
||||
if (!request)
|
||||
return;
|
||||
|
||||
+ reg->region = request->dfs_region;
|
||||
switch (request->initiator) {
|
||||
case NL80211_REGDOM_SET_BY_CORE:
|
||||
/*
|
||||
@@ -779,6 +780,19 @@ u32 ath_regd_get_band_ctl(struct ath_reg
|
||||
return SD_NO_CTL;
|
||||
}
|
||||
|
||||
+ if (ath_regd_get_eepromRD(reg) == CTRY_DEFAULT) {
|
||||
+ switch (reg->region) {
|
||||
+ case NL80211_DFS_FCC:
|
||||
+ return CTL_FCC;
|
||||
+ case NL80211_DFS_ETSI:
|
||||
+ return CTL_ETSI;
|
||||
+ case NL80211_DFS_JP:
|
||||
+ return CTL_MKK;
|
||||
+ default:
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
switch (band) {
|
||||
case IEEE80211_BAND_2GHZ:
|
||||
return reg->regpair->reg_2ghz_ctl;
|
|
@ -14,7 +14,7 @@
|
|||
ccflags-y += -D__CHECK_ENDIAN__
|
||||
--- a/drivers/net/wireless/ath/ath.h
|
||||
+++ b/drivers/net/wireless/ath/ath.h
|
||||
@@ -300,13 +300,6 @@ void _ath_dbg(struct ath_common *common,
|
||||
@@ -301,13 +301,6 @@ void _ath_dbg(struct ath_common *common,
|
||||
#endif /* CPTCFG_ATH_DEBUG */
|
||||
|
||||
/** Returns string describing opmode, or NULL if unknown mode. */
|
||||
|
|
|
@ -33,7 +33,7 @@
|
|||
if (!wiphy->bands[IEEE80211_BAND_5GHZ])
|
||||
return;
|
||||
|
||||
@@ -631,6 +643,10 @@ ath_regd_init_wiphy(struct ath_regulator
|
||||
@@ -632,6 +644,10 @@ ath_regd_init_wiphy(struct ath_regulator
|
||||
{
|
||||
const struct ieee80211_regdomain *regd;
|
||||
|
||||
|
|
|
@ -64,7 +64,7 @@
|
|||
debugfs_create_file("interrupt", S_IRUSR, sc->debug.debugfs_phy, sc,
|
||||
--- a/drivers/net/wireless/ath/ath.h
|
||||
+++ b/drivers/net/wireless/ath/ath.h
|
||||
@@ -141,6 +141,7 @@ struct ath_common {
|
||||
@@ -142,6 +142,7 @@ struct ath_common {
|
||||
int debug_mask;
|
||||
enum ath_device_state state;
|
||||
unsigned long op_flags;
|
||||
|
|
Loading…
Reference in a new issue