Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2562281imu; Thu, 29 Nov 2018 06:57:27 -0800 (PST) X-Google-Smtp-Source: AFSGD/WPp12PDoJliBdhahcPb0cCvjZzx1NG5R+EJuOImtVjuCEUlDjjkg0gXemONd5SMKZlZtdx X-Received: by 2002:a62:220d:: with SMTP id i13mr1682794pfi.162.1543503447438; Thu, 29 Nov 2018 06:57:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543503447; cv=none; d=google.com; s=arc-20160816; b=zMql7vnPf4t+lPhHUsbPrrnVdNBlvHMh37z6YQXws8zzYDNAqJRuVJWLVYppPkg6bW hOT+3p0dBZ25vYkLoITjW8H/OTrVws7roZFRNmggO9zRZvrGNNQDLD1Nn+tyklshMpg7 wDO+V+X3NrZ/8jqfPEP54xCE8EZTeXkgXKNFaqr/4Jb+Jvhi4SFSImpTeV5fVJwqNllW U680iHaF6H0SMsqIAhYp1NQmuT7PlMya7jzFk+/aueyXFzIOEMt5G2vEEFEnlFLRJLFE GMeQl44XCYCBfB8ot9EcEcmXjk+RY33sdJcZxLNosSBXz8Mqmp//JMy3hn0yfQJLd/5o 2BBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=6Emdw/XVb3b6jSqSqd0Tzwmrf5kgm13Dd+mwvjioV9I=; b=TWbbSkHoaHzBempJ1Uqvnbb0cQ6g/oRzB+AGobKH40nfX4GQOvMUQAyJm60ZqO77sw mXK58PtEKS/kYGBkZ02EZSxsztRnKMTGs3N37U28Mwas0hk8qkEkTMbkk8UqNWqnjkmB L2TFWZZ2KeKwgVIkRlqdep8pAvCqWyK/Jj7rAgIPVu+FOaYA6wX+DqvZ2Wln8/7w+nzZ MyYwoCVJP8HoRt265UMgH0PxXqxWxnm2ZrQHSibEVa8vOIPTXRkkJv/fTYqI9j/3MGI4 z4E2pY3cYK19Bg//3Vw/LPP1RDHUdJe5GNCP0/n9kkKVXRbWEHSgG8ULjNzfLcS6EFC2 ensw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HBdYHYGg; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g71si2070395pgc.419.2018.11.29.06.57.12; Thu, 29 Nov 2018 06:57:27 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HBdYHYGg; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731614AbeK3B0t (ORCPT + 99 others); Thu, 29 Nov 2018 20:26:49 -0500 Received: from mail.kernel.org ([198.145.29.99]:51152 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730438AbeK3B0s (ORCPT ); Thu, 29 Nov 2018 20:26:48 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 8C275205C9; Thu, 29 Nov 2018 14:21:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1543501277; bh=Klk324mbtu9HWfkF5siH5oc0E6sEe8WH2zpyAyBKrwM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HBdYHYGgOXgE1VY6Kd1+0tjXhE5rWr2RJoVxVW7MA+gPbxWKRIuI2Ffg7/hB6bVix ZZ259nPXQX6iKHSRzBSHBUbfDIzZodBIQpJcJspU8jBkxMd34ystivNQ6w4FYGNvxP L/zS0HgbMBYbPQkiAXMjhQj/9XcHFzoMwfoiJnAk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Emmanuel Grumbach , Luca Coelho Subject: [PATCH 4.9 07/92] iwlwifi: mvm: fix regulatory domain update when the firmware starts Date: Thu, 29 Nov 2018 15:11:36 +0100 Message-Id: <20181129140107.092372163@linuxfoundation.org> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181129140106.520639693@linuxfoundation.org> References: <20181129140106.520639693@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Emmanuel Grumbach commit 82715ac71e6b94a2c2136e31f3a8e6748e33aa8c upstream. When the firmware starts, it doesn't have any regulatory information, hence it uses the world wide limitations. The driver can feed the firmware with previous knowledge that was kept in the driver, but the firmware may still not update its internal tables. This happens when we start a BSS interface, and then the firmware can change the regulatory tables based on our location and it'll use more lenient, location specific rules. Then, if the firmware is shut down (when the interface is brought down), and then an AP interface is created, the firmware will forget the country specific rules. The host will think that we are in a certain country that may allow channels and will try to teach the firmware about our location, but the firmware may still not allow to drop the world wide limitations and apply country specific rules because it was just re-started. In this case, the firmware will reply with MCC_RESP_ILLEGAL to the MCC_UPDATE_CMD. In that case, iwlwifi needs to let the upper layers (cfg80211 / hostapd) know that the channel list they know about has been updated. This fixes https://bugzilla.kernel.org/show_bug.cgi?id=201105 Cc: stable@vger.kernel.org Signed-off-by: Emmanuel Grumbach Signed-off-by: Luca Coelho Signed-off-by: Greg Kroah-Hartman --- drivers/net/wireless/intel/iwlwifi/mvm/mac80211.c | 8 ++++++-- drivers/net/wireless/intel/iwlwifi/mvm/nvm.c | 5 ++--- 2 files changed, 8 insertions(+), 5 deletions(-) --- a/drivers/net/wireless/intel/iwlwifi/mvm/mac80211.c +++ b/drivers/net/wireless/intel/iwlwifi/mvm/mac80211.c @@ -327,8 +327,12 @@ struct ieee80211_regdomain *iwl_mvm_get_ goto out; } - if (changed) - *changed = (resp->status == MCC_RESP_NEW_CHAN_PROFILE); + if (changed) { + u32 status = le32_to_cpu(resp->status); + + *changed = (status == MCC_RESP_NEW_CHAN_PROFILE || + status == MCC_RESP_ILLEGAL); + } regd = iwl_parse_nvm_mcc_info(mvm->trans->dev, mvm->cfg, __le32_to_cpu(resp->n_channels), --- a/drivers/net/wireless/intel/iwlwifi/mvm/nvm.c +++ b/drivers/net/wireless/intel/iwlwifi/mvm/nvm.c @@ -739,9 +739,8 @@ iwl_mvm_update_mcc(struct iwl_mvm *mvm, } IWL_DEBUG_LAR(mvm, - "MCC response status: 0x%x. new MCC: 0x%x ('%c%c') change: %d n_chans: %d\n", - status, mcc, mcc >> 8, mcc & 0xff, - !!(status == MCC_RESP_NEW_CHAN_PROFILE), n_channels); + "MCC response status: 0x%x. new MCC: 0x%x ('%c%c') n_chans: %d\n", + status, mcc, mcc >> 8, mcc & 0xff, n_channels); exit: iwl_free_resp(&cmd);