Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2542636imu; Thu, 29 Nov 2018 06:38:47 -0800 (PST) X-Google-Smtp-Source: AFSGD/W+T/EKYfDQQ/5ouXY7TKXdeMI/MxTp8ezmnZaFTJnJqZFlaoY0g9r0eXbUSCjuQEpv6354 X-Received: by 2002:a17:902:20c8:: with SMTP id v8mr1730017plg.319.1543502327892; Thu, 29 Nov 2018 06:38:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543502327; cv=none; d=google.com; s=arc-20160816; b=hyZdWZG+QeqPyajqJ7o7DixYo6F1BH2f2YxvGfbhfulHxwqpvvE0zKdJZtmdvlzE8R YwYtNZjyLIJjrjocaHqZ6Tt2rKEpaB9rc3rAlNE5Pwl6xJ0ztTW8T08MsAZB5b0RGFDH O9IwBL0nWJ59dHHzPIslubCV2z+o6MNVT/bMOD9nqeptCfPfeDT98ZXlbRqeVM6r5Muw IOa/QGlWVR+qfyHFw9NOvdosTqAhFGCCTa2yZHNzLf+M0RDFEZSGsC5272VVysb/shXG gDBRHXtB1hDg+fySyp0i8sIp0c+kQs8UAN6MQSyF7aJw+USj3d9kEdw5PlWn5ECL/e3V VTEg== 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=uVtOHpcXn8uzLicrv8TQZnysihY996Pn+/+rAsAhMn0=; b=E+GDmksyR3tB7cFzQ+Jf6DX/+MWC18Qu8r/nZDu1g6kFlcmAkM5lu8PgBxNYgIsmP9 3vZrCic1WuPN52FFtXBjJm2aAT+U0KKVJBQeo5QG5VK01Rf+iM8jO71JlfDKLBp6Dwhq ymupIGVHHBKD4D3QOBp1wtG996v/OoUOqfpMDiwhj9oghEOs1PLz/582gWUlvpTel8NL mhFtQgSN1pAa4h+JDhGRevy8g1ZjkJCOdp3hPZaW+YrHzgmcAQfZ40juAO8yxKEX7Mcd 5U/uJBNyOXu8sbC90jC0AO3VeJLOBOkvtaBVhLE6qp2I/LJTYMDfgYfTyraKZLhiLKR6 DVDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=lICTm7Fr; 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 x128si2296336pfb.128.2018.11.29.06.38.33; Thu, 29 Nov 2018 06:38:47 -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=lICTm7Fr; 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 S1732618AbeK3Bmn (ORCPT + 99 others); Thu, 29 Nov 2018 20:42:43 -0500 Received: from mail.kernel.org ([198.145.29.99]:38172 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388788AbeK3BgD (ORCPT ); Thu, 29 Nov 2018 20:36:03 -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 74CF52145D; Thu, 29 Nov 2018 14:30:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1543501829; bh=alP5hWPKDmUmnFMAjrlNe8bTEVy9q7LjHl6z+FNLdZw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=lICTm7FrJZGl9oTraNXBNqZMqocwDhOD9q35SLImNxqwjlMMxye7Fd7aivtbd2I/S n6G9AYokNK8rtW3mwARj05c5HT3pFOveZixNUxKUX/znsm9daYKwAhy4xIRrdi48l9 9fHmCl0KG9zjPPBfWnSp3x1jzBtjLnkXZzvSVEiA= 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.19 024/110] iwlwifi: mvm: fix regulatory domain update when the firmware starts Date: Thu, 29 Nov 2018 15:11:55 +0100 Message-Id: <20181129135922.237479598@linuxfoundation.org> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181129135921.231283053@linuxfoundation.org> References: <20181129135921.231283053@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.19-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 @@ -306,8 +306,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 @@ -545,9 +545,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);