* [net PATCH 1/1] drivers: net: cpsw: discard dual emac default vlan configuration
@ 2015-01-20 12:25 Mugunthan V N
2015-01-20 14:25 ` Sergei Shtylyov
0 siblings, 1 reply; 3+ messages in thread
From: Mugunthan V N @ 2015-01-20 12:25 UTC (permalink / raw)
To: netdev; +Cc: davem, Mugunthan V N, stable
In Dual EMAC, the default vlans are used to segregate rx packets between
the ports, so adding the same default vlan to the switch will affect the
normal packet transfers. So returning error on addition of dual emac
default vlans.
Even if emac 0 default port vlan is added to emac 1, it will lead to
break dual EMAC port seperations.
Fixes: d9ba8f9 (driver: net: ethernet: cpsw: dual emac interface implementation)
Cc: <stable@vger.kernel.org> # v3.9+
Reported-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Mugunthan V N <mugunthanvnm@ti.com>
---
drivers/net/ethernet/ti/cpsw.c | 22 ++++++++++++++++++++++
1 file changed, 22 insertions(+)
diff --git a/drivers/net/ethernet/ti/cpsw.c b/drivers/net/ethernet/ti/cpsw.c
index e068d48..7c32815 100644
--- a/drivers/net/ethernet/ti/cpsw.c
+++ b/drivers/net/ethernet/ti/cpsw.c
@@ -1683,6 +1683,19 @@ static int cpsw_ndo_vlan_rx_add_vid(struct net_device *ndev,
if (vid == priv->data.default_vlan)
return 0;
+ if (priv->data.dual_emac) {
+ /* In dual EMAC, reserved VLAN id should not be used of
+ * creating vlan interfaces as this can break the dual
+ * EMAC port seperation
+ */
+ int i;
+
+ for (i = 0; i < priv->data.slaves; i++) {
+ if (vid == priv->slaves[i].port_vlan)
+ return -EINVAL;
+ }
+ }
+
dev_info(priv->dev, "Adding vlanid %d to vlan filter\n", vid);
return cpsw_add_vlan_ale_entry(priv, vid);
}
@@ -1696,6 +1709,15 @@ static int cpsw_ndo_vlan_rx_kill_vid(struct net_device *ndev,
if (vid == priv->data.default_vlan)
return 0;
+ if (priv->data.dual_emac) {
+ int i;
+
+ for (i = 0; i < priv->data.slaves; i++) {
+ if (vid == priv->slaves[i].port_vlan)
+ return -EINVAL;
+ }
+ }
+
dev_info(priv->dev, "removing vlanid %d from vlan filter\n", vid);
ret = cpsw_ale_del_vlan(priv->ale, vid, 0);
if (ret != 0)
--
2.2.1.62.g3f15098
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [net PATCH 1/1] drivers: net: cpsw: discard dual emac default vlan configuration
2015-01-20 12:25 [net PATCH 1/1] drivers: net: cpsw: discard dual emac default vlan configuration Mugunthan V N
@ 2015-01-20 14:25 ` Sergei Shtylyov
2015-01-22 8:20 ` Mugunthan V N
0 siblings, 1 reply; 3+ messages in thread
From: Sergei Shtylyov @ 2015-01-20 14:25 UTC (permalink / raw)
To: Mugunthan V N, netdev; +Cc: davem, stable
Hello.
On 1/20/2015 3:25 PM, Mugunthan V N wrote:
> In Dual EMAC, the default vlans are used to segregate rx packets between
VLANs. And RX.
> the ports, so adding the same default vlan to the switch will affect the
VLAN.
> normal packet transfers. So returning error on addition of dual emac
EMAC.
> default vlans.
VLANs.
> Even if emac 0 default port vlan is added to emac 1, it will lead to
EMAC. And VLAN
> break
Breaking.
> dual EMAC port seperations.
Separations.
> Fixes: d9ba8f9 (driver: net: ethernet: cpsw: dual emac interface implementation)
12 hex digits, please.
> Cc: <stable@vger.kernel.org> # v3.9+
> Reported-by: Felipe Balbi <balbi@ti.com>
> Signed-off-by: Mugunthan V N <mugunthanvnm@ti.com>
> ---
> drivers/net/ethernet/ti/cpsw.c | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
> diff --git a/drivers/net/ethernet/ti/cpsw.c b/drivers/net/ethernet/ti/cpsw.c
> index e068d48..7c32815 100644
> --- a/drivers/net/ethernet/ti/cpsw.c
> +++ b/drivers/net/ethernet/ti/cpsw.c
> @@ -1683,6 +1683,19 @@ static int cpsw_ndo_vlan_rx_add_vid(struct net_device *ndev,
> if (vid == priv->data.default_vlan)
> return 0;
>
> + if (priv->data.dual_emac) {
> + /* In dual EMAC, reserved VLAN id should not be used of
s/of/for/, perhaps?
> + * creating vlan interfaces as this can break the dual
s/vlan/VLAN/. Be consistent, please.
> + * EMAC port seperation
Separation.
[...]
WBR, Sergei
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [net PATCH 1/1] drivers: net: cpsw: discard dual emac default vlan configuration
2015-01-20 14:25 ` Sergei Shtylyov
@ 2015-01-22 8:20 ` Mugunthan V N
0 siblings, 0 replies; 3+ messages in thread
From: Mugunthan V N @ 2015-01-22 8:20 UTC (permalink / raw)
To: Sergei Shtylyov, netdev; +Cc: davem, stable
On Tuesday 20 January 2015 07:55 PM, Sergei Shtylyov wrote:
> Hello.
>
> On 1/20/2015 3:25 PM, Mugunthan V N wrote:
>
>> In Dual EMAC, the default vlans are used to segregate rx packets between
>
> VLANs. And RX.
>
>> the ports, so adding the same default vlan to the switch will affect the
>
> VLAN.
>
>> normal packet transfers. So returning error on addition of dual emac
>
> EMAC.
>
>> default vlans.
>
> VLANs.
>
>> Even if emac 0 default port vlan is added to emac 1, it will lead to
>
> EMAC. And VLAN
>
>> break
>
> Breaking.
>
>> dual EMAC port seperations.
>
> Separations.
>
>> Fixes: d9ba8f9 (driver: net: ethernet: cpsw: dual emac interface
>> implementation)
>
> 12 hex digits, please.
>
>> Cc: <stable@vger.kernel.org> # v3.9+
>> Reported-by: Felipe Balbi <balbi@ti.com>
>> Signed-off-by: Mugunthan V N <mugunthanvnm@ti.com>
>> ---
>> drivers/net/ethernet/ti/cpsw.c | 22 ++++++++++++++++++++++
>> 1 file changed, 22 insertions(+)
>
>> diff --git a/drivers/net/ethernet/ti/cpsw.c
>> b/drivers/net/ethernet/ti/cpsw.c
>> index e068d48..7c32815 100644
>> --- a/drivers/net/ethernet/ti/cpsw.c
>> +++ b/drivers/net/ethernet/ti/cpsw.c
>> @@ -1683,6 +1683,19 @@ static int cpsw_ndo_vlan_rx_add_vid(struct
>> net_device *ndev,
>> if (vid == priv->data.default_vlan)
>> return 0;
>>
>> + if (priv->data.dual_emac) {
>> + /* In dual EMAC, reserved VLAN id should not be used of
>
> s/of/for/, perhaps?
>
>> + * creating vlan interfaces as this can break the dual
>
> s/vlan/VLAN/. Be consistent, please.
>
>> + * EMAC port seperation
>
> Separation.
>
> [...]
Will fix this and resubmit next version.
Regards
Mugunthan V N
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2015-01-22 8:20 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-01-20 12:25 [net PATCH 1/1] drivers: net: cpsw: discard dual emac default vlan configuration Mugunthan V N
2015-01-20 14:25 ` Sergei Shtylyov
2015-01-22 8:20 ` Mugunthan V N
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).