Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2548560pxj; Mon, 10 May 2021 05:41:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwKoUnq3FTvZVMqcTmeAVHAL94nbdIoPuVmtJiFiget7ZAbwly5swoUsVS1v3z8hwKNqiw/ X-Received: by 2002:a5d:87ca:: with SMTP id q10mr18457400ios.67.1620650499098; Mon, 10 May 2021 05:41:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620650499; cv=none; d=google.com; s=arc-20160816; b=axDV5VpP4nThmgkSrYa5fT6rMHDiDrLcg8paOt9Fg8yOT3pHCrWFaVevOT4GqFFjq/ xYxaO3IrXimI0fM5M7We31i+Y/a46tSp+qGKoK7fwv4Y4rdRsMXHDWcf+OX216FP+1sk yOIQsmyk60mo1Ep0d2uLKRvKTREgrvm03Rs0UgdWi1YbYiymPDotq57LpBozU8XRp7hQ NLIGVl1mFRmt5q1HLIlIu8PnNkTgpBbpnRPMHng+O2xnIOB01gXbEa2jmGn0gqFYwpP1 HiIeHVFC3N36UK4RIdF28E/wDADkGoG5rlG4K54Ctd0VS/eeaUleqpnUSHFSTdEzEgFw 5EyA== 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=LyjzYtg5QttvtnBUAB12hkmECR9vs+GxBWPADBsgeuLtrw/ENWQxoHt9Z+7GZVUQmy pej5QS+Pw43nmfy2+bKwNBtDPplsQqm9806llCwCUelL5fZAScU5dF/T6P1tmESkX8oU cU3DKxUsnucRHHKzyirDjMxGA3IbSZ64Dq7N68SywPzdjIAX40Fm92+aOlOTKUSsGUdl f6uUIeub8fOPlQRWbgsiN7US5I85o8Y69/vqdnZOSPSojd84Si00vWTgOXzmZWGx9P0s ONptAlqsqU9z8Y+IhMu5w/rlXIsaKtfMX+7YPHW01GVY58driSU5ZHJAld/SM7YTeiub DsYg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=EIvnVIFN; 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 g11si1691876ile.43.2021.05.10.05.41.27; Mon, 10 May 2021 05:41:39 -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=EIvnVIFN; 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 S1347140AbhEJMd0 (ORCPT + 99 others); Mon, 10 May 2021 08:33:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:46148 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232047AbhEJLLx (ORCPT ); Mon, 10 May 2021 07:11:53 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4F26061937; Mon, 10 May 2021 11:09:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620644963; bh=5fuRqTcKIiPzxbE9ZPKDhNPvkmZlbtvNlweGkPwV8cQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=EIvnVIFNY+VnOsUGFaW9R3QtlKNSwrdL3rf5CzRlL8JCuYUb7jNb6GtyBCvppAlmU NQ90zQ0oYwyWHdDbiZUfLTFCDb7m7EzUF11a4eVr66Ae37RA0ijO20lpjXL95BV5WI E/RIkBhubgvRZ1lC/fnY6Yn9mwi+ckwVJbHYa2Yw= 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.12 294/384] mlxsw: spectrum_mr: Update egress RIF list before routes action Date: Mon, 10 May 2021 12:21:23 +0200 Message-Id: <20210510102024.507462856@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102014.849075526@linuxfoundation.org> References: <20210510102014.849075526@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; }