mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-27 05:32:27 +00:00
net: dsa: mv88e6xxx: setup message ports
All interconnectable Marvell switch chips have an ATU Learn2All feature which allows newly learnt addresses to be spanned on ports marked as "Message Port". This commit configures the DSA ports as Message Port. Note that this has no effect until the Learn2All feature is enabled. Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
a2ac29d2cc
commit
ea698f4f70
@ -2504,6 +2504,13 @@ static int mv88e6xxx_setup_port_normal(struct mv88e6xxx_chip *chip, int port)
|
||||
return chip->info->ops->port_set_egress_unknowns(chip, port, false);
|
||||
}
|
||||
|
||||
static int mv88e6xxx_setup_message_port(struct mv88e6xxx_chip *chip, int port)
|
||||
{
|
||||
bool message = dsa_is_dsa_port(chip->ds, port);
|
||||
|
||||
return mv88e6xxx_port_set_message_port(chip, port, message);
|
||||
}
|
||||
|
||||
static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
|
||||
{
|
||||
struct dsa_switch *ds = chip->ds;
|
||||
@ -2658,10 +2665,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
|
||||
return err;
|
||||
}
|
||||
|
||||
/* Port Control 1: disable trunking, disable sending
|
||||
* learning messages to this port.
|
||||
*/
|
||||
err = mv88e6xxx_port_write(chip, port, PORT_CONTROL_1, 0x0000);
|
||||
err = mv88e6xxx_setup_message_port(chip, port);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
|
@ -144,6 +144,7 @@
|
||||
#define PORT_CONTROL_STATE_LEARNING 0x02
|
||||
#define PORT_CONTROL_STATE_FORWARDING 0x03
|
||||
#define PORT_CONTROL_1 0x05
|
||||
#define PORT_CONTROL_1_MESSAGE_PORT BIT(15)
|
||||
#define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0)
|
||||
#define PORT_BASE_VLAN 0x06
|
||||
#define PORT_BASE_VLAN_FID_3_0_MASK (0xf << 12)
|
||||
|
@ -535,6 +535,24 @@ int mv88e6351_port_set_egress_unknowns(struct mv88e6xxx_chip *chip, int port,
|
||||
|
||||
/* Offset 0x05: Port Control 1 */
|
||||
|
||||
int mv88e6xxx_port_set_message_port(struct mv88e6xxx_chip *chip, int port,
|
||||
bool message_port)
|
||||
{
|
||||
u16 val;
|
||||
int err;
|
||||
|
||||
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_1, &val);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
if (message_port)
|
||||
val |= PORT_CONTROL_1_MESSAGE_PORT;
|
||||
else
|
||||
val &= ~PORT_CONTROL_1_MESSAGE_PORT;
|
||||
|
||||
return mv88e6xxx_port_write(chip, port, PORT_CONTROL_1, val);
|
||||
}
|
||||
|
||||
/* Offset 0x06: Port Based VLAN Map */
|
||||
|
||||
int mv88e6xxx_port_set_vlan_map(struct mv88e6xxx_chip *chip, int port, u16 map)
|
||||
|
@ -64,6 +64,8 @@ int mv88e6351_port_set_egress_unknowns(struct mv88e6xxx_chip *chip, int port,
|
||||
bool on);
|
||||
int mv88e6351_port_set_ether_type(struct mv88e6xxx_chip *chip, int port,
|
||||
u16 etype);
|
||||
int mv88e6xxx_port_set_message_port(struct mv88e6xxx_chip *chip, int port,
|
||||
bool message_port);
|
||||
int mv88e6165_port_jumbo_config(struct mv88e6xxx_chip *chip, int port);
|
||||
int mv88e6095_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port);
|
||||
int mv88e6097_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port);
|
||||
|
Loading…
x
Reference in New Issue
Block a user