mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-30 08:04:13 +08:00
net: dsa: xrs700x: check if partner is same as port in hsr join
Don't assign dp to partner if it's the same port that xrs700x_hsr_join
was called with. The partner port is supposed to be the other port in
the HSR/PRP redundant pair not the same port. This fixes an issue
observed in testing where forwarding between redundant HSR ports on this
switch didn't work depending on the order the ports were added to the
hsr device.
Fixes: bd62e6f5e6
("net: dsa: xrs700x: add HSR offloading support")
Signed-off-by: George McCollister <george.mccollister@gmail.com>
Reviewed-by: Vladimir Oltean <olteanv@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f7d9d48545
commit
286a8624d7
@ -528,7 +528,10 @@ static int xrs700x_hsr_join(struct dsa_switch *ds, int port,
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
dsa_hsr_foreach_port(dp, ds, hsr) {
|
||||
partner = dp;
|
||||
if (dp->index != port) {
|
||||
partner = dp;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* We can't enable redundancy on the switch until both
|
||||
@ -582,7 +585,10 @@ static int xrs700x_hsr_leave(struct dsa_switch *ds, int port,
|
||||
unsigned int val;
|
||||
|
||||
dsa_hsr_foreach_port(dp, ds, hsr) {
|
||||
partner = dp;
|
||||
if (dp->index != port) {
|
||||
partner = dp;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (!partner)
|
||||
|
Loading…
Reference in New Issue
Block a user