提交 a89b433b 编写于 作者: V Vivien Didelot 提交者: David S. Miller

net: dsa: mv88e6xxx: prefix Port Control macros

For implicit namespacing and clarity, prefix the common Port Control
Register macros with MV88E6XXX_PORT_CTL0 and the ones which differ
between implementations with a chosen reference model
(e.g. MV88E6185_PORT_CTL0_USE_TAG.)

The reason for CTL0 is to make it clear between the badly named
"Port Control", "Port Control 1" and "Port Control 2" registers.

Document the register and prefer ordered hex masks values for all
Marvell 16-bit registers.
Signed-off-by: NVivien Didelot <vivien.didelot@savoirfairelinux.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 107fcc10
...@@ -1828,10 +1828,10 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port) ...@@ -1828,10 +1828,10 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
* If this is the upstream port for this switch, enable * If this is the upstream port for this switch, enable
* forwarding of unknown unicasts and multicasts. * forwarding of unknown unicasts and multicasts.
*/ */
reg = PORT_CONTROL_IGMP_MLD_SNOOP | reg = MV88E6XXX_PORT_CTL0_IGMP_MLD_SNOOP |
PORT_CONTROL_USE_TAG | PORT_CONTROL_USE_IP | MV88E6185_PORT_CTL0_USE_TAG | MV88E6185_PORT_CTL0_USE_IP |
PORT_CONTROL_STATE_FORWARDING; MV88E6XXX_PORT_CTL0_STATE_FORWARDING;
err = mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
if (err) if (err)
return err; return err;
......
...@@ -408,10 +408,10 @@ int mv88e6390_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in, ...@@ -408,10 +408,10 @@ int mv88e6390_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in,
/* Offset 0x04: Port Control Register */ /* Offset 0x04: Port Control Register */
static const char * const mv88e6xxx_port_state_names[] = { static const char * const mv88e6xxx_port_state_names[] = {
[PORT_CONTROL_STATE_DISABLED] = "Disabled", [MV88E6XXX_PORT_CTL0_STATE_DISABLED] = "Disabled",
[PORT_CONTROL_STATE_BLOCKING] = "Blocking/Listening", [MV88E6XXX_PORT_CTL0_STATE_BLOCKING] = "Blocking/Listening",
[PORT_CONTROL_STATE_LEARNING] = "Learning", [MV88E6XXX_PORT_CTL0_STATE_LEARNING] = "Learning",
[PORT_CONTROL_STATE_FORWARDING] = "Forwarding", [MV88E6XXX_PORT_CTL0_STATE_FORWARDING] = "Forwarding",
}; };
int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state) int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state)
...@@ -419,25 +419,25 @@ int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state) ...@@ -419,25 +419,25 @@ int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL0, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_STATE_MASK; reg &= ~MV88E6XXX_PORT_CTL0_STATE_MASK;
switch (state) { switch (state) {
case BR_STATE_DISABLED: case BR_STATE_DISABLED:
state = PORT_CONTROL_STATE_DISABLED; state = MV88E6XXX_PORT_CTL0_STATE_DISABLED;
break; break;
case BR_STATE_BLOCKING: case BR_STATE_BLOCKING:
case BR_STATE_LISTENING: case BR_STATE_LISTENING:
state = PORT_CONTROL_STATE_BLOCKING; state = MV88E6XXX_PORT_CTL0_STATE_BLOCKING;
break; break;
case BR_STATE_LEARNING: case BR_STATE_LEARNING:
state = PORT_CONTROL_STATE_LEARNING; state = MV88E6XXX_PORT_CTL0_STATE_LEARNING;
break; break;
case BR_STATE_FORWARDING: case BR_STATE_FORWARDING:
state = PORT_CONTROL_STATE_FORWARDING; state = MV88E6XXX_PORT_CTL0_STATE_FORWARDING;
break; break;
default: default:
return -EINVAL; return -EINVAL;
...@@ -445,7 +445,7 @@ int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state) ...@@ -445,7 +445,7 @@ int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state)
reg |= state; reg |= state;
err = mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
if (err) if (err)
return err; return err;
...@@ -461,30 +461,30 @@ int mv88e6xxx_port_set_egress_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -461,30 +461,30 @@ int mv88e6xxx_port_set_egress_mode(struct mv88e6xxx_chip *chip, int port,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL0, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_EGRESS_MASK; reg &= ~MV88E6XXX_PORT_CTL0_EGRESS_MODE_MASK;
switch (mode) { switch (mode) {
case MV88E6XXX_EGRESS_MODE_UNMODIFIED: case MV88E6XXX_EGRESS_MODE_UNMODIFIED:
reg |= PORT_CONTROL_EGRESS_UNMODIFIED; reg |= MV88E6XXX_PORT_CTL0_EGRESS_MODE_UNMODIFIED;
break; break;
case MV88E6XXX_EGRESS_MODE_UNTAGGED: case MV88E6XXX_EGRESS_MODE_UNTAGGED:
reg |= PORT_CONTROL_EGRESS_UNTAGGED; reg |= MV88E6XXX_PORT_CTL0_EGRESS_MODE_UNTAGGED;
break; break;
case MV88E6XXX_EGRESS_MODE_TAGGED: case MV88E6XXX_EGRESS_MODE_TAGGED:
reg |= PORT_CONTROL_EGRESS_TAGGED; reg |= MV88E6XXX_PORT_CTL0_EGRESS_MODE_TAGGED;
break; break;
case MV88E6XXX_EGRESS_MODE_ETHERTYPE: case MV88E6XXX_EGRESS_MODE_ETHERTYPE:
reg |= PORT_CONTROL_EGRESS_ADD_TAG; reg |= MV88E6XXX_PORT_CTL0_EGRESS_MODE_ETHER_TYPE_DSA;
break; break;
default: default:
return -EINVAL; return -EINVAL;
} }
return mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
} }
int mv88e6085_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port, int mv88e6085_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port,
...@@ -493,24 +493,24 @@ int mv88e6085_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -493,24 +493,24 @@ int mv88e6085_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL0, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_FRAME_MASK; reg &= ~MV88E6XXX_PORT_CTL0_FRAME_MODE_MASK;
switch (mode) { switch (mode) {
case MV88E6XXX_FRAME_MODE_NORMAL: case MV88E6XXX_FRAME_MODE_NORMAL:
reg |= PORT_CONTROL_FRAME_MODE_NORMAL; reg |= MV88E6XXX_PORT_CTL0_FRAME_MODE_NORMAL;
break; break;
case MV88E6XXX_FRAME_MODE_DSA: case MV88E6XXX_FRAME_MODE_DSA:
reg |= PORT_CONTROL_FRAME_MODE_DSA; reg |= MV88E6XXX_PORT_CTL0_FRAME_MODE_DSA;
break; break;
default: default:
return -EINVAL; return -EINVAL;
} }
return mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
} }
int mv88e6351_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port, int mv88e6351_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port,
...@@ -519,30 +519,30 @@ int mv88e6351_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -519,30 +519,30 @@ int mv88e6351_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL0, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_FRAME_MASK; reg &= ~MV88E6XXX_PORT_CTL0_FRAME_MODE_MASK;
switch (mode) { switch (mode) {
case MV88E6XXX_FRAME_MODE_NORMAL: case MV88E6XXX_FRAME_MODE_NORMAL:
reg |= PORT_CONTROL_FRAME_MODE_NORMAL; reg |= MV88E6XXX_PORT_CTL0_FRAME_MODE_NORMAL;
break; break;
case MV88E6XXX_FRAME_MODE_DSA: case MV88E6XXX_FRAME_MODE_DSA:
reg |= PORT_CONTROL_FRAME_MODE_DSA; reg |= MV88E6XXX_PORT_CTL0_FRAME_MODE_DSA;
break; break;
case MV88E6XXX_FRAME_MODE_PROVIDER: case MV88E6XXX_FRAME_MODE_PROVIDER:
reg |= PORT_CONTROL_FRAME_MODE_PROVIDER; reg |= MV88E6XXX_PORT_CTL0_FRAME_MODE_PROVIDER;
break; break;
case MV88E6XXX_FRAME_MODE_ETHERTYPE: case MV88E6XXX_FRAME_MODE_ETHERTYPE:
reg |= PORT_CONTROL_FRAME_ETHER_TYPE_DSA; reg |= MV88E6XXX_PORT_CTL0_FRAME_MODE_ETHER_TYPE_DSA;
break; break;
default: default:
return -EINVAL; return -EINVAL;
} }
return mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
} }
static int mv88e6185_port_set_forward_unknown(struct mv88e6xxx_chip *chip, static int mv88e6185_port_set_forward_unknown(struct mv88e6xxx_chip *chip,
...@@ -551,16 +551,16 @@ static int mv88e6185_port_set_forward_unknown(struct mv88e6xxx_chip *chip, ...@@ -551,16 +551,16 @@ static int mv88e6185_port_set_forward_unknown(struct mv88e6xxx_chip *chip,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL0, &reg);
if (err) if (err)
return err; return err;
if (unicast) if (unicast)
reg |= PORT_CONTROL_FORWARD_UNKNOWN; reg |= MV88E6185_PORT_CTL0_FORWARD_UNKNOWN;
else else
reg &= ~PORT_CONTROL_FORWARD_UNKNOWN; reg &= ~MV88E6185_PORT_CTL0_FORWARD_UNKNOWN;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
} }
int mv88e6352_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port, int mv88e6352_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port,
...@@ -569,22 +569,22 @@ int mv88e6352_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port, ...@@ -569,22 +569,22 @@ int mv88e6352_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL0, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_EGRESS_FLOODS_MASK; reg &= ~MV88E6352_PORT_CTL0_EGRESS_FLOODS_MASK;
if (unicast && multicast) if (unicast && multicast)
reg |= PORT_CONTROL_EGRESS_FLOODS_ALL_UNKNOWN_DA; reg |= MV88E6352_PORT_CTL0_EGRESS_FLOODS_ALL_UNKNOWN_DA;
else if (unicast) else if (unicast)
reg |= PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_MC_DA; reg |= MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_MC_DA;
else if (multicast) else if (multicast)
reg |= PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_UC_DA; reg |= MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_UC_DA;
else else
reg |= PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_DA; reg |= MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_DA;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL0, reg);
} }
/* Offset 0x05: Port Control 1 */ /* Offset 0x05: Port Control 1 */
......
...@@ -107,38 +107,40 @@ ...@@ -107,38 +107,40 @@
#define MV88E6XXX_PORT_SWITCH_ID_PROD_6390 0x3900 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6390 0x3900
#define MV88E6XXX_PORT_SWITCH_ID_REV_MASK 0x000f #define MV88E6XXX_PORT_SWITCH_ID_REV_MASK 0x000f
#define PORT_CONTROL 0x04 /* Offset 0x04: Port Control Register */
#define PORT_CONTROL_USE_CORE_TAG BIT(15) #define MV88E6XXX_PORT_CTL0 0x04
#define PORT_CONTROL_DROP_ON_LOCK BIT(14) #define MV88E6XXX_PORT_CTL0_USE_CORE_TAG 0x8000
#define PORT_CONTROL_EGRESS_UNMODIFIED (0x0 << 12) #define MV88E6XXX_PORT_CTL0_DROP_ON_LOCK 0x4000
#define PORT_CONTROL_EGRESS_UNTAGGED (0x1 << 12) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_MASK 0x3000
#define PORT_CONTROL_EGRESS_TAGGED (0x2 << 12) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_UNMODIFIED 0x0000
#define PORT_CONTROL_EGRESS_ADD_TAG (0x3 << 12) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_UNTAGGED 0x1000
#define PORT_CONTROL_EGRESS_MASK (0x3 << 12) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_TAGGED 0x2000
#define PORT_CONTROL_HEADER BIT(11) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_ETHER_TYPE_DSA 0x3000
#define PORT_CONTROL_IGMP_MLD_SNOOP BIT(10) #define MV88E6XXX_PORT_CTL0_HEADER 0x0800
#define PORT_CONTROL_DOUBLE_TAG BIT(9) #define MV88E6XXX_PORT_CTL0_IGMP_MLD_SNOOP 0x0400
#define PORT_CONTROL_FRAME_MODE_NORMAL (0x0 << 8) #define MV88E6XXX_PORT_CTL0_DOUBLE_TAG 0x0200
#define PORT_CONTROL_FRAME_MODE_DSA (0x1 << 8) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_MASK 0x0300
#define PORT_CONTROL_FRAME_MODE_PROVIDER (0x2 << 8) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_NORMAL 0x0000
#define PORT_CONTROL_FRAME_ETHER_TYPE_DSA (0x3 << 8) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_DSA 0x0100
#define PORT_CONTROL_FRAME_MASK (0x3 << 8) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_PROVIDER 0x0200
#define PORT_CONTROL_DSA_TAG BIT(8) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_ETHER_TYPE_DSA 0x0300
#define PORT_CONTROL_VLAN_TUNNEL BIT(7) #define MV88E6XXX_PORT_CTL0_DSA_TAG 0x0100
#define PORT_CONTROL_TAG_IF_BOTH BIT(6) #define MV88E6XXX_PORT_CTL0_VLAN_TUNNEL 0x0080
#define PORT_CONTROL_USE_IP BIT(5) #define MV88E6XXX_PORT_CTL0_TAG_IF_BOTH 0x0040
#define PORT_CONTROL_USE_TAG BIT(4) #define MV88E6185_PORT_CTL0_USE_IP 0x0020
#define PORT_CONTROL_FORWARD_UNKNOWN BIT(2) #define MV88E6185_PORT_CTL0_USE_TAG 0x0010
#define PORT_CONTROL_EGRESS_FLOODS_MASK (0x3 << 2) #define MV88E6185_PORT_CTL0_FORWARD_UNKNOWN 0x0004
#define PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_DA (0x0 << 2) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_MASK 0x000c
#define PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_MC_DA (0x1 << 2) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_DA 0x0000
#define PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_UC_DA (0x2 << 2) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_MC_DA 0x0004
#define PORT_CONTROL_EGRESS_FLOODS_ALL_UNKNOWN_DA (0x3 << 2) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_UC_DA 0x0008
#define PORT_CONTROL_STATE_MASK 0x03 #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_ALL_UNKNOWN_DA 0x000c
#define PORT_CONTROL_STATE_DISABLED 0x00 #define MV88E6XXX_PORT_CTL0_STATE_MASK 0x0003
#define PORT_CONTROL_STATE_BLOCKING 0x01 #define MV88E6XXX_PORT_CTL0_STATE_DISABLED 0x0000
#define PORT_CONTROL_STATE_LEARNING 0x02 #define MV88E6XXX_PORT_CTL0_STATE_BLOCKING 0x0001
#define PORT_CONTROL_STATE_FORWARDING 0x03 #define MV88E6XXX_PORT_CTL0_STATE_LEARNING 0x0002
#define MV88E6XXX_PORT_CTL0_STATE_FORWARDING 0x0003
#define PORT_CONTROL_1 0x05 #define PORT_CONTROL_1 0x05
#define PORT_CONTROL_1_MESSAGE_PORT BIT(15) #define PORT_CONTROL_1_MESSAGE_PORT BIT(15)
#define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0) #define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册