diff options
Diffstat (limited to 'net/wireless/nl80211.c')
| -rw-r--r-- | net/wireless/nl80211.c | 15 | 
1 files changed, 8 insertions, 7 deletions
| diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index 5fb9b7dd9831..4b8ec659e797 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c @@ -669,13 +669,13 @@ static int nl80211_msg_put_wmm_rules(struct sk_buff *msg,  			goto nla_put_failure;  		if (nla_put_u16(msg, NL80211_WMMR_CW_MIN, -				rule->wmm_rule->client[j].cw_min) || +				rule->wmm_rule.client[j].cw_min) ||  		    nla_put_u16(msg, NL80211_WMMR_CW_MAX, -				rule->wmm_rule->client[j].cw_max) || +				rule->wmm_rule.client[j].cw_max) ||  		    nla_put_u8(msg, NL80211_WMMR_AIFSN, -			       rule->wmm_rule->client[j].aifsn) || -		    nla_put_u8(msg, NL80211_WMMR_TXOP, -			       rule->wmm_rule->client[j].cot)) +			       rule->wmm_rule.client[j].aifsn) || +		    nla_put_u16(msg, NL80211_WMMR_TXOP, +			        rule->wmm_rule.client[j].cot))  			goto nla_put_failure;  		nla_nest_end(msg, nl_wmm_rule); @@ -766,9 +766,9 @@ static int nl80211_msg_put_channel(struct sk_buff *msg, struct wiphy *wiphy,  	if (large) {  		const struct ieee80211_reg_rule *rule = -			freq_reg_info(wiphy, chan->center_freq); +			freq_reg_info(wiphy, MHZ_TO_KHZ(chan->center_freq)); -		if (!IS_ERR(rule) && rule->wmm_rule) { +		if (!IS_ERR_OR_NULL(rule) && rule->has_wmm) {  			if (nl80211_msg_put_wmm_rules(msg, rule))  				goto nla_put_failure;  		} @@ -12205,6 +12205,7 @@ static int nl80211_update_ft_ies(struct sk_buff *skb, struct genl_info *info)  		return -EOPNOTSUPP;  	if (!info->attrs[NL80211_ATTR_MDID] || +	    !info->attrs[NL80211_ATTR_IE] ||  	    !is_valid_ie_attr(info->attrs[NL80211_ATTR_IE]))  		return -EINVAL; | 
