Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp942477imm; Fri, 12 Oct 2018 09:08:01 -0700 (PDT) X-Google-Smtp-Source: ACcGV62IXxpWCHIOt35KnYBIZKXeDXYqq3YLAiMzxntp5CvOcnAEzrXmXbbsTLZPGHkYE1UBOsUZ X-Received: by 2002:a63:6111:: with SMTP id v17-v6mr6025364pgb.226.1539360481244; Fri, 12 Oct 2018 09:08:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539360481; cv=none; d=google.com; s=arc-20160816; b=rCBCxKneK+bKDYUdTtNz7VZ4Iv8InQ+EcTd1l0LiKAk5J3m2vUwhEV83cFWvNJ0iP1 l2FhNt2zMuAwYzCTtVJiyBZ5pmmveboQ8lOfCJmLkr30e/dgIQ48jvwajzP+xzNkv1EC UqokDCE8Z9L/ywjXwx16fU5wi+wlgZMG7rcZvYSJGxZizfJKcdfrvJ04TZ2C0HxmkDFl CfZfNNf8RLU6cZ98+IeNqCPkawnCAkfvxo2Wy/UuyjxelFTa6EgVKVu4O9eAEGJeRFjn zbfIAA/CxCzBN/Car5TEiFmnuHLrefh9a695qXmi6oEG8BJ+/1rfhL1hSNg59YRU52OY YgSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=ugxvMaHgww4tCznq8+Zrv/s/hrVuJo2pMgDC2pw469c=; b=nWw1AsycJSyOqpgyQoXHF0GWFpIKhs+LLKLAS0ZwrrlGMehlWzj4JIDZf5B4BKyhtv r73atkKK2Ly3GGqmM0dwkHlCchmychTyv09BGHQQrm2vYxqST42jNHWnNQ9hn1B5WfkW tN9hJcJY/liy+rBnE+rdFy0+rnAOMdSmwnujjD7K3npgG12VUdGZR2oRaV59brxEvpKK AbsFAaIPgeHGof+CUgbxTONiUHdlOT4xYvp3thmVcYMk9++mFDLyYIVNdyXz28/dYy0k nHpT79XuiFp5NMHwVL3WZ4rRV2wYqeAvDZUJRZmWlBLwejNpa+fiflb1XhzhqAWHU690 o4AA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=e3c60FRu; 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=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n11-v6si1577340plk.333.2018.10.12.09.07.46; Fri, 12 Oct 2018 09:08:01 -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=@linaro.org header.s=google header.b=e3c60FRu; 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=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728857AbeJLXjp (ORCPT + 99 others); Fri, 12 Oct 2018 19:39:45 -0400 Received: from mail-lj1-f195.google.com ([209.85.208.195]:34074 "EHLO mail-lj1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728725AbeJLXjp (ORCPT ); Fri, 12 Oct 2018 19:39:45 -0400 Received: by mail-lj1-f195.google.com with SMTP id j17-v6so11854765lja.1 for ; Fri, 12 Oct 2018 09:06:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id; bh=ugxvMaHgww4tCznq8+Zrv/s/hrVuJo2pMgDC2pw469c=; b=e3c60FRuz9kFhciQ50JNXUyVX20s+6Ko3fG3Yf22hDiQFSW9jh45eXxzinMPhsssJ3 hVZp5dYePoqVFQR9Stgl6hm42IoiSPrqXFwJBzBZqmqmeOy0Cd8rsVJ74oYmQLBE2ijr aU7ZZV+kmHTMX9gUSGfYOzIbjGygcLCOHISZs= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=ugxvMaHgww4tCznq8+Zrv/s/hrVuJo2pMgDC2pw469c=; b=TCDp8kc3GmHzyI89PhvdEHgKiPfmfeMyZnO5dgJRrDq5paDWUfuCg+PIC6qUncOb8q fcw9eXsM6/35jVAQDp/vyIkTfV64RQJjWTsDPErRHk/AFiNYjpKsW13fz014/FMXQN88 NIPuYN9ix7CsZ1Px9AddeGhsMSyirNJ2ZCYOZvUX8UIvFxa1TB6wHvrwyR6Wxd39eERN khVL3fVDw0ignyC6ZOoszSqGr8qT2Fmm4myKjyzjMjB0c49CWZezsucLs00++IjGDHuw Y8M0/V1XqKR/OIpH+RwiR4hrc05475dbl6dL2FzPn/LBYNDTd+GyM6h+E/7Gnw+mi0Qr OTzQ== X-Gm-Message-State: ABuFfoiwd6W+zRgs1GQbqk4j05YPIPzy/KuVC7jMimEJy6WSs4UlYpPI lHZFQwjojejdGbN57pNL8pu28A== X-Received: by 2002:a2e:98c2:: with SMTP id s2-v6mr4474534ljj.19.1539360393130; Fri, 12 Oct 2018 09:06:33 -0700 (PDT) Received: from localhost.localdomain (59-201-94-178.pool.ukrtel.net. [178.94.201.59]) by smtp.gmail.com with ESMTPSA id b10-v6sm335622lje.47.2018.10.12.09.06.31 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 12 Oct 2018 09:06:32 -0700 (PDT) From: Ivan Khoronzhuk To: grygorii.strashko@ti.com, davem@davemloft.net Cc: linux-omap@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Ivan Khoronzhuk Subject: [PATCH net-next] net: ethernet: ti: cpsw: use for mcast entries only host port Date: Fri, 12 Oct 2018 19:06:29 +0300 Message-Id: <20181012160629.7245-1-ivan.khoronzhuk@linaro.org> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In dual-emac mode the cpsw driver sends directed packets, that means that packets go to the directed port, but an ALE lookup is performed to determine untagged egress only. It means that on tx side no need to add port bit for ALE mcast entry mask, and basically ALE entry for port identification is needed only on rx side. So, add only host port in dual_emac mode as used directed transmission, and no need in one more port. For single port boards and switch mode all ports used, as usual, so no changes for them. Also it simplifies farther changes. In other words, mcast entries for dual-emac should behave exactly like unicast. It also can help avoid leaking packets between ports with same vlan on h/w level if ports could became members of same vid. So now, for instance, if mcast address 33:33:00:00:00:01 is added then entries in ALE table: vid = 1, addr = 33:33:00:00:00:01, port_mask = 0x1 vid = 2, addr = 33:33:00:00:00:01, port_mask = 0x1 Instead of: vid = 1, addr = 33:33:00:00:00:01, port_mask = 0x3 vid = 2, addr = 33:33:00:00:00:01, port_mask = 0x5 With the same considerations, set only host port for unregistered mcast for dual-emac mode in case of IFF_ALLMULTI is set, exactly like it's done in cpsw_ale_set_allmulti(). Signed-off-by: Ivan Khoronzhuk --- Based on net-next/master drivers/net/ethernet/ti/cpsw.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/drivers/net/ethernet/ti/cpsw.c b/drivers/net/ethernet/ti/cpsw.c index 16dcbf36f8cc..7bfb7ee3a261 100644 --- a/drivers/net/ethernet/ti/cpsw.c +++ b/drivers/net/ethernet/ti/cpsw.c @@ -576,10 +576,8 @@ static void cpsw_add_mcast(struct cpsw_priv *priv, u8 *addr) if (cpsw->data.dual_emac) { struct cpsw_slave *slave = cpsw->slaves + priv->emac_port; - int slave_port = cpsw_get_slave_port(slave->slave_num); - cpsw_ale_add_mcast(cpsw->ale, addr, - 1 << slave_port | ALE_PORT_HOST, + cpsw_ale_add_mcast(cpsw->ale, addr, ALE_PORT_HOST, ALE_VLAN, slave->port_vlan, 0); return; } @@ -1410,7 +1408,7 @@ static inline void cpsw_add_dual_emac_def_ale_entries( cpsw_ale_add_vlan(cpsw->ale, slave->port_vlan, port_mask, port_mask, port_mask, 0); cpsw_ale_add_mcast(cpsw->ale, priv->ndev->broadcast, - port_mask, ALE_VLAN, slave->port_vlan, 0); + ALE_PORT_HOST, ALE_VLAN, slave->port_vlan, 0); cpsw_ale_add_ucast(cpsw->ale, priv->mac_addr, HOST_PORT_NUM, ALE_VLAN | ALE_SECURE, slave->port_vlan); @@ -2293,16 +2291,19 @@ static inline int cpsw_add_vlan_ale_entry(struct cpsw_priv *priv, { int ret; int unreg_mcast_mask = 0; + int mcast_mask; u32 port_mask; struct cpsw_common *cpsw = priv->cpsw; if (cpsw->data.dual_emac) { port_mask = (1 << (priv->emac_port + 1)) | ALE_PORT_HOST; + mcast_mask = ALE_PORT_HOST; if (priv->ndev->flags & IFF_ALLMULTI) - unreg_mcast_mask = port_mask; + unreg_mcast_mask = mcast_mask; } else { port_mask = ALE_ALL_PORTS; + mcast_mask = port_mask; if (priv->ndev->flags & IFF_ALLMULTI) unreg_mcast_mask = ALE_ALL_PORTS; @@ -2321,7 +2322,7 @@ static inline int cpsw_add_vlan_ale_entry(struct cpsw_priv *priv, goto clean_vid; ret = cpsw_ale_add_mcast(cpsw->ale, priv->ndev->broadcast, - port_mask, ALE_VLAN, vid, 0); + mcast_mask, ALE_VLAN, vid, 0); if (ret != 0) goto clean_vlan_ucast; return 0; -- 2.17.1