Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2490839pxj; Mon, 10 May 2021 04:22:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz/PKQmHsbNaUqtFfa/11Oe2eRoq+89k2253c7MThtarcm01BIq5zIU+UqoPMwZhoSbd3YL X-Received: by 2002:a05:6638:2603:: with SMTP id m3mr20889891jat.95.1620645754493; Mon, 10 May 2021 04:22:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620645754; cv=none; d=google.com; s=arc-20160816; b=DoK2RyQIU8/byzYsAg/UMmdcof6Kh4STpkx+p2lVr9pqXB8LCWaSr46sogY3TAI18G Ihn6u9jJZZa5otXtxwkeU1V2HupkqjFOFpHW95BpbhrfhaV4JejAn/zAOYyokRcb5x9J 1ihgfpRp89bYSYw5eqeeWDrTX4E9dUG4+Bxf4PUHl0LkrSGZG5G/xKPaR5DJZpkN3Af4 hwqxu+lzhPC5XaI4xd2Rw00rrSLIyG9evFimbcVpzdWmIWHkVL7GSUDWq3JbM0t1gj1i NeI5y9NqTapfTmGE83wtu8172DOq8qBz9NxeKwB2wgvBRfNiDCLc/V/caseJGwlCCI4r S0Iw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=0nSfW5lgmojOOzsEzRtboE/L8HkEQA9+sxEDLrkmYV0=; b=u451KNRKPvtpP5GNCAqqblDINBbUmEYqvoBAcE5oooSbwOeOuRnR3gcRgK351VXOpt 6V0l9wC6wFZEhPDZPsnlKNfz1PxLrLVXwDABupjXZOH0xQeSNqOH3ebMb7WaERWAs7EO gPwuGA94H+lRA/dBlu1/ipqoDTNqjw6htRd7Drkmk2AHM9AM5LMByHRoUD+65k/5T0H4 waWR7IJgP2oojzVcKwTDBYhazDWAanlHSlL/cgTSbeUzYUdV/t2/4LMqdVH7Nzw+Azjz 26ysArrpW1I2xrqWkDvOqPXSBbW6/Uf7Mf1giWDxetgm5Y1t1d1Phkf/QcjFXLjdfMgM GQsQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=eP0JSKdS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d7si16341499ilg.78.2021.05.10.04.22.21; Mon, 10 May 2021 04:22:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=eP0JSKdS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237938AbhEJLQf (ORCPT + 99 others); Mon, 10 May 2021 07:16:35 -0400 Received: from mail.kernel.org ([198.145.29.99]:42198 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232871AbhEJKvQ (ORCPT ); Mon, 10 May 2021 06:51:16 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 2FD0C6194E; Mon, 10 May 2021 10:40:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620643231; bh=5fuRqTcKIiPzxbE9ZPKDhNPvkmZlbtvNlweGkPwV8cQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eP0JSKdScNyo7BUbLXymaSXa5mQg+5OzCkPPdhrq1q6NSSHKpqoyAaw13dGzBzD/F gwp0aTF05W/jEkr2PErULyvxqXJt4/H1VIorlv8SWxtlvV3F29X7ftZPgg2AL7HMOO IMPmb4iLoi2VDiJDt4jiUkWIkNRuVDesnY1/3jh0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ido Schimmel , Petr Machata , Jakub Kicinski Subject: [PATCH 5.10 230/299] mlxsw: spectrum_mr: Update egress RIF list before routes action Date: Mon, 10 May 2021 12:20:27 +0200 Message-Id: <20210510102012.557689924@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102004.821838356@linuxfoundation.org> References: <20210510102004.821838356@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ido Schimmel commit cbaf3f6af9c268caf558c8e7ec52bcb35c5455dd upstream. Each multicast route that is forwarding packets (as opposed to trapping them) points to a list of egress router interfaces (RIFs) through which packets are replicated. A route's action can transition from trap to forward when a RIF is created for one of the route's egress virtual interfaces (eVIF). When this happens, the route's action is first updated and only later the list of egress RIFs is committed to the device. This results in the route pointing to an invalid list. In case the list pointer is out of range (due to uninitialized memory), the device will complain: mlxsw_spectrum2 0000:06:00.0: EMAD reg access failed (tid=5733bf490000905c,reg_id=300f(pefa),type=write,status=7(bad parameter)) Fix this by first committing the list of egress RIFs to the device and only later update the route's action. Note that a fix is not needed in the reverse function (i.e., mlxsw_sp_mr_route_evif_unresolve()), as there the route's action is first updated and only later the RIF is removed from the list. Cc: stable@vger.kernel.org Fixes: c011ec1bbfd6 ("mlxsw: spectrum: Add the multicast routing offloading logic") Signed-off-by: Ido Schimmel Reviewed-by: Petr Machata Link: https://lore.kernel.org/r/20210506072308.3834303-1-idosch@idosch.org Signed-off-by: Jakub Kicinski Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/mellanox/mlxsw/spectrum_mr.c | 30 +++++++++++----------- 1 file changed, 15 insertions(+), 15 deletions(-) --- a/drivers/net/ethernet/mellanox/mlxsw/spectrum_mr.c +++ b/drivers/net/ethernet/mellanox/mlxsw/spectrum_mr.c @@ -535,6 +535,16 @@ mlxsw_sp_mr_route_evif_resolve(struct ml u16 erif_index = 0; int err; + /* Add the eRIF */ + if (mlxsw_sp_mr_vif_valid(rve->mr_vif)) { + erif_index = mlxsw_sp_rif_index(rve->mr_vif->rif); + err = mr->mr_ops->route_erif_add(mlxsw_sp, + rve->mr_route->route_priv, + erif_index); + if (err) + return err; + } + /* Update the route action, as the new eVIF can be a tunnel or a pimreg * device which will require updating the action. */ @@ -544,17 +554,7 @@ mlxsw_sp_mr_route_evif_resolve(struct ml rve->mr_route->route_priv, route_action); if (err) - return err; - } - - /* Add the eRIF */ - if (mlxsw_sp_mr_vif_valid(rve->mr_vif)) { - erif_index = mlxsw_sp_rif_index(rve->mr_vif->rif); - err = mr->mr_ops->route_erif_add(mlxsw_sp, - rve->mr_route->route_priv, - erif_index); - if (err) - goto err_route_erif_add; + goto err_route_action_update; } /* Update the minimum MTU */ @@ -572,14 +572,14 @@ mlxsw_sp_mr_route_evif_resolve(struct ml return 0; err_route_min_mtu_update: - if (mlxsw_sp_mr_vif_valid(rve->mr_vif)) - mr->mr_ops->route_erif_del(mlxsw_sp, rve->mr_route->route_priv, - erif_index); -err_route_erif_add: if (route_action != rve->mr_route->route_action) mr->mr_ops->route_action_update(mlxsw_sp, rve->mr_route->route_priv, rve->mr_route->route_action); +err_route_action_update: + if (mlxsw_sp_mr_vif_valid(rve->mr_vif)) + mr->mr_ops->route_erif_del(mlxsw_sp, rve->mr_route->route_priv, + erif_index); return err; }