Received: by 10.213.65.68 with SMTP id h4csp2124804imn; Sun, 8 Apr 2018 20:19:19 -0700 (PDT) X-Google-Smtp-Source: AIpwx482t+ucKscd5tDrH5bCZbnNDO4Z4JM2i6rLqtJLgtdaU7rDC1urpXo3Ap65tmFzzVj6RLYV X-Received: by 10.98.182.8 with SMTP id j8mr22291294pff.115.1523243959540; Sun, 08 Apr 2018 20:19:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523243959; cv=none; d=google.com; s=arc-20160816; b=Mlo3xFY5cXyeN6YwTiocIcSanG7Ayi6Jpq9tpj5a69gCFXhOngsYjdDZFOiOVvBUVH Ioi+sk49JPLWl6Bo46uZRG34x38yIxKMNdKc9XhG0RP5h0l4lmnlXJzyfOr7C98GVBZG GdVkILUVu3Fqqt2OZoHzZB7pMa+ytxzMRetx7xqtMzpX5VIJAoWhAovdO/PLVX8ZQtFC zgyjOKlxgdblsCa45j6oJw7iBo4U5qWFPAx+8TRXQmcNM8tVmJn3nUB1iV1PsGE5Wk6c BNZv+xg2fP0NgGB6cuGDZo4vtcYV5B1PA0mnTjMrJQl9llu79zlyTxww/n6xquIS8Ynt zPFg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=aDSAjr4NB5fl3HqrNDicVW4rPx+2x0J6HOwV6lrUBlI=; b=e/vLM/e+9fmW09zhcErjWkCo6V2aw6Lhrmi9ugvPeQmZ6oh/MIc1yJ+WgbWeOrAhsT 4FlmnY4ot7o+vVHSHY5BEbNDGf0YHCIxZAh3i0Y18Xh800HSnfvh65pbndAKba2eA+n/ dNxIN/fWNjWfevP4hZnnCwFL123yHFPHoJQ27YSCBgiqAh0s1e1Dl4gtIXDyfBxBPltc VrhlrOQLqOiSiguhs7ymvu2jZMbeUJ9qUSgFaCiQTmRY7cVpqWSSqo/96QKofmbS3bjy SFt7kX9oiod1pZYryJ00x1VrQREgLl1yzwen3H62aUuA1mbIPHueErUURtGh0TIcjjdR xu6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=SwQm569F; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i21si12097101pfk.34.2018.04.08.20.18.42; Sun, 08 Apr 2018 20:19:19 -0700 (PDT) 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=@microsoft.com header.s=selector1 header.b=SwQm569F; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755244AbeDIDNA (ORCPT + 99 others); Sun, 8 Apr 2018 23:13:00 -0400 Received: from mail-by2nam03on0115.outbound.protection.outlook.com ([104.47.42.115]:29467 "EHLO NAM03-BY2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1754962AbeDIAXy (ORCPT ); Sun, 8 Apr 2018 20:23:54 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=aDSAjr4NB5fl3HqrNDicVW4rPx+2x0J6HOwV6lrUBlI=; b=SwQm569Fgio8Ph4ottfVYKkv+Ri2Oko2/1J2BUHL6WngzB1tRUv5F4B0PzSJerZxsHGUC+xd4PoAEZA8hXlAiF4dFQJOS+87mZt3GbtwMfeG/fKrAu45VyV8xEtfnMexAOZxk0Ke/8tNfAGatQ29y+kq2uqQtfLNG6owIQ7wprQ= Received: from DM5PR2101MB1032.namprd21.prod.outlook.com (52.132.128.13) by DM5PR2101MB1080.namprd21.prod.outlook.com (52.132.130.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.696.0; Mon, 9 Apr 2018 00:23:49 +0000 Received: from DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::8109:aef0:a777:7059]) by DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::8109:aef0:a777:7059%2]) with mapi id 15.20.0696.003; Mon, 9 Apr 2018 00:23:49 +0000 From: Sasha Levin To: "stable@vger.kernel.org" , "linux-kernel@vger.kernel.org" CC: Ngai-Mint Kwan , Jacob Keller , Jeff Kirsher , Sasha Levin Subject: [PATCH AUTOSEL for 4.14 074/161] fm10k: fix "failed to kill vid" message for VF Thread-Topic: [PATCH AUTOSEL for 4.14 074/161] fm10k: fix "failed to kill vid" message for VF Thread-Index: AQHTz5iaug310ASGP0aShbTsOZWL6w== Date: Mon, 9 Apr 2018 00:20:46 +0000 Message-ID: <20180409001936.162706-74-alexander.levin@microsoft.com> References: <20180409001936.162706-1-alexander.levin@microsoft.com> In-Reply-To: <20180409001936.162706-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;DM5PR2101MB1080;7:p+HONh3sKrJ5+bFVeREjyn7rWKZHD62vZE1of1HnKD6DZGs0Wv0EEald4013ZB+bhXwZ4ITAgsLqklQ9bCUaESphcxkcB32MS5mdjXPgZKrXOovYnwTzemQ4SDkg7u2FcdRUyKbSr3uSHtTG+o+qqV7ItEvF5IOW6Jov3zlYi30/yFvsFHJlEQS0+tNfK7MgouCIcOD+jbLI/ABTvU8Nt/PW8d9vCJP8ojtPQwMLyFTZQ2lhC2xGLSHih9UPd3u7;20:hBu+bY1jhsL+tpzUum6rDBpZMJK+n8I5C7e8QgM7FOqB5tPRRY9zHJnjhP8bcV28VLVcytuX5ZXsubXusuBK6edOt0e4cExjw7VSAglRV6N74QVBURIHqL/Pch0yZVst7Ya5q3UqHHO39eUK7Rnhy/kwVITGyFzO5rR0RlBKKSk= x-ms-office365-filtering-ht: Tenant X-MS-Office365-Filtering-Correlation-Id: 25eedfe6-7006-413b-641d-08d59db02a9f x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:(7020095)(4652020)(48565401081)(5600026)(4604075)(3008032)(4534165)(4627221)(201703031133081)(201702281549075)(2017052603328)(7193020);SRVR:DM5PR2101MB1080; x-ms-traffictypediagnostic: DM5PR2101MB1080: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(89211679590171)(228905959029699); x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(61425038)(6040522)(2401047)(8121501046)(5005006)(10201501046)(93006095)(93001095)(3002001)(3231221)(944501327)(52105095)(6055026)(61426038)(61427038)(6041310)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123558120)(20161123562045)(20161123564045)(20161123560045)(6072148)(201708071742011);SRVR:DM5PR2101MB1080;BCL:0;PCL:0;RULEID:;SRVR:DM5PR2101MB1080; x-forefront-prvs: 0637FCE711 x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(376002)(346002)(396003)(39380400002)(366004)(39860400002)(199004)(189003)(2501003)(5250100002)(8936002)(10090500001)(5660300001)(3660700001)(446003)(107886003)(14454004)(36756003)(6436002)(15650500001)(476003)(3280700002)(2616005)(11346002)(4326008)(6666003)(53936002)(6512007)(22452003)(305945005)(10290500003)(316002)(102836004)(2906002)(6116002)(66066001)(6506007)(3846002)(7736002)(486006)(54906003)(110136005)(186003)(72206003)(26005)(1076002)(105586002)(2900100001)(6486002)(97736004)(478600001)(81156014)(81166006)(86612001)(8676002)(106356001)(99286004)(86362001)(76176011)(59450400001)(68736007)(25786009)(22906009)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:DM5PR2101MB1080;H:DM5PR2101MB1032.namprd21.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;A:1;MX:1; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: MGO+kMdg37O3AjwWgNPFOV9D3OdGiOoVcpUHt4dZ27MJ+8iYgAX4Jbp2pNpee/wKx8OAOImXtpg5yMXyPTPisyvAGPE0ub+0jLRHljcD8SrwwW7om4CwlpO8rlbdtraq9FPlwgrZ1BJ5RiI0LDfBvGHlsNJwj/YnPnK+NyLj6+IsKIv0cR1JJM7uW6pVboAkv41GvN5T539H36W/PBgw2kTXCIyVIZSum+EXZvLlRv9g32zRJhV/WGdBuNiqvf+Z9sCz+e172oShUZ/zJyFHGBOlrBOhKEscysaIXgZNSaeSRXo67CaaCwKylxefcPi5dmvSRaFYiHfiouz10AcUkCHiweorW75+D3hwJt08M8ED9Wyq+t6X2x5SYZandvRK1QHyrFqcPwCTu7nnNurdi0DmKRwySd5heLWWTu50ces= spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: 25eedfe6-7006-413b-641d-08d59db02a9f X-MS-Exchange-CrossTenant-originalarrivaltime: 09 Apr 2018 00:20:46.4409 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR2101MB1080 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ngai-Mint Kwan [ Upstream commit cf315ea596ec26d7aa542a9ce354990875a920c0 ] When a VF is under PF VLAN assignment: ip link set vf <#> vlan This will remove all previous entries in the VLAN table including those generated by VLAN interfaces created on the VF. The issue arises when the VF is under PF VLAN assignment and one or more of these VLAN interfaces of the VF are deleted. When deleting these VLAN interfaces, the following message will be generated in "dmesg": failed to kill vid 0081/ for device This is due to the fact that "ndo_vlan_rx_kill_vid" exits with an error. The handler for this ndo is "fm10k_update_vid". Any calls to this function while under PF VLAN management will exit prematurely and, thus, it will generate the failure message. Additionally, since "fm10k_update_vid" exits prematurely, none of the VLAN update is performed. So, even though the actual VLAN interfaces of the VF will be deleted, the active_vlans bitmask is not cleared. When the VF is no longer under PF VLAN assignment, the driver mistakenly restores the previous entries of the VLAN table based on an unsynchronized list of active VLANs. The solution to this issue involves checking the VLAN update action type before exiting "fm10k_update_vid". If the VLAN update action type is to "add", this action will not be permitted while the VF is under PF VLAN assignment and the VLAN update is abandoned like before. However, if the VLAN update action type is to "kill", then we need to also clear the active_vlans bitmask. However, we don't need to actually queue any messages to the PF, because the MAC and VLAN tables have already been cleared, and the PF would silently ignore these requests anyways. Signed-off-by: Ngai-Mint Kwan Signed-off-by: Jacob Keller Tested-by: Krishneil Singh Signed-off-by: Jeff Kirsher Signed-off-by: Sasha Levin --- drivers/net/ethernet/intel/fm10k/fm10k_netdev.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/intel/fm10k/fm10k_netdev.c b/drivers/net/= ethernet/intel/fm10k/fm10k_netdev.c index e69d49d91d67..914258310ddd 100644 --- a/drivers/net/ethernet/intel/fm10k/fm10k_netdev.c +++ b/drivers/net/ethernet/intel/fm10k/fm10k_netdev.c @@ -815,8 +815,12 @@ static int fm10k_update_vid(struct net_device *netdev,= u16 vid, bool set) if (vid >=3D VLAN_N_VID) return -EINVAL; =20 - /* Verify we have permission to add VLANs */ - if (hw->mac.vlan_override) + /* Verify that we have permission to add VLANs. If this is a request + * to remove a VLAN, we still want to allow the user to remove the + * VLAN device. In that case, we need to clear the bit in the + * active_vlans bitmask. + */ + if (set && hw->mac.vlan_override) return -EACCES; =20 /* update active_vlans bitmask */ @@ -835,6 +839,12 @@ static int fm10k_update_vid(struct net_device *netdev,= u16 vid, bool set) rx_ring->vid &=3D ~FM10K_VLAN_CLEAR; } =20 + /* If our VLAN has been overridden, there is no reason to send VLAN + * removal requests as they will be silently ignored. + */ + if (hw->mac.vlan_override) + return 0; + /* Do not remove default VLAN ID related entries from VLAN and MAC * tables */ --=20 2.15.1