Commit 88efe190 authored by David S. Miller's avatar David S. Miller

Merge branch 'dsa-mv88e6xxx-port-macros-cosmetics'

Vivien Didelot says:

====================
net: dsa: mv88e6xxx: port macros cosmetics

This patch series brings no functional changes.

It prefixes all common port registers macros with MV88E6XXX_PORT.
If registers or some bits differs between switch models, a reference
model is chosen (e.g. MV88E6390_PORT_MAC_CTL_SPEED_10000.)

The register names are documented as found in the datasheets.

Avoid BIT() and shifts defines and prefer a better representation of the
Marvell switch registers with ordered, hexadecimal, 16-bit values.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents a1fa1a00 b8109594
...@@ -828,11 +828,11 @@ static int mv88e6xxx_get_eee(struct dsa_switch *ds, int port, ...@@ -828,11 +828,11 @@ static int mv88e6xxx_get_eee(struct dsa_switch *ds, int port,
e->eee_enabled = !!(reg & 0x0200); e->eee_enabled = !!(reg & 0x0200);
e->tx_lpi_enabled = !!(reg & 0x0100); e->tx_lpi_enabled = !!(reg & 0x0100);
err = mv88e6xxx_port_read(chip, port, PORT_STATUS, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_STS, &reg);
if (err) if (err)
goto out; goto out;
e->eee_active = !!(reg & PORT_STATUS_EEE); e->eee_active = !!(reg & MV88E6352_PORT_STS_EEE);
out: out:
mutex_unlock(&chip->reg_lock); mutex_unlock(&chip->reg_lock);
...@@ -1213,8 +1213,8 @@ static int mv88e6xxx_port_vlan_filtering(struct dsa_switch *ds, int port, ...@@ -1213,8 +1213,8 @@ static int mv88e6xxx_port_vlan_filtering(struct dsa_switch *ds, int port,
bool vlan_filtering) bool vlan_filtering)
{ {
struct mv88e6xxx_chip *chip = ds->priv; struct mv88e6xxx_chip *chip = ds->priv;
u16 mode = vlan_filtering ? PORT_CONTROL_2_8021Q_SECURE : u16 mode = vlan_filtering ? MV88E6XXX_PORT_CTL2_8021Q_MODE_SECURE :
PORT_CONTROL_2_8021Q_DISABLED; MV88E6XXX_PORT_CTL2_8021Q_MODE_DISABLED;
int err; int err;
if (!chip->info->max_vid) if (!chip->info->max_vid)
...@@ -1729,14 +1729,14 @@ static int mv88e6xxx_set_port_mode_normal(struct mv88e6xxx_chip *chip, int port) ...@@ -1729,14 +1729,14 @@ static int mv88e6xxx_set_port_mode_normal(struct mv88e6xxx_chip *chip, int port)
{ {
return mv88e6xxx_set_port_mode(chip, port, MV88E6XXX_FRAME_MODE_NORMAL, return mv88e6xxx_set_port_mode(chip, port, MV88E6XXX_FRAME_MODE_NORMAL,
MV88E6XXX_EGRESS_MODE_UNMODIFIED, MV88E6XXX_EGRESS_MODE_UNMODIFIED,
PORT_ETH_TYPE_DEFAULT); MV88E6XXX_PORT_ETH_TYPE_DEFAULT);
} }
static int mv88e6xxx_set_port_mode_dsa(struct mv88e6xxx_chip *chip, int port) static int mv88e6xxx_set_port_mode_dsa(struct mv88e6xxx_chip *chip, int port)
{ {
return mv88e6xxx_set_port_mode(chip, port, MV88E6XXX_FRAME_MODE_DSA, return mv88e6xxx_set_port_mode(chip, port, MV88E6XXX_FRAME_MODE_DSA,
MV88E6XXX_EGRESS_MODE_UNMODIFIED, MV88E6XXX_EGRESS_MODE_UNMODIFIED,
PORT_ETH_TYPE_DEFAULT); MV88E6XXX_PORT_ETH_TYPE_DEFAULT);
} }
static int mv88e6xxx_set_port_mode_edsa(struct mv88e6xxx_chip *chip, int port) static int mv88e6xxx_set_port_mode_edsa(struct mv88e6xxx_chip *chip, int port)
...@@ -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;
...@@ -1872,7 +1872,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port) ...@@ -1872,7 +1872,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
} }
err = mv88e6xxx_port_set_8021q_mode(chip, port, err = mv88e6xxx_port_set_8021q_mode(chip, port,
PORT_CONTROL_2_8021Q_DISABLED); MV88E6XXX_PORT_CTL2_8021Q_MODE_DISABLED);
if (err) if (err)
return err; return err;
...@@ -1892,12 +1892,14 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port) ...@@ -1892,12 +1892,14 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
if (dsa_is_cpu_port(ds, port)) if (dsa_is_cpu_port(ds, port))
reg = 0; reg = 0;
err = mv88e6xxx_port_write(chip, port, PORT_ASSOC_VECTOR, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_ASSOC_VECTOR,
reg);
if (err) if (err)
return err; return err;
/* Egress rate control 2: disable egress rate control. */ /* Egress rate control 2: disable egress rate control. */
err = mv88e6xxx_port_write(chip, port, PORT_RATE_CONTROL_2, 0x0000); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL2,
0x0000);
if (err) if (err)
return err; return err;
...@@ -1950,7 +1952,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port) ...@@ -1950,7 +1952,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
/* Default VLAN ID and priority: don't set a default VLAN /* Default VLAN ID and priority: don't set a default VLAN
* ID, and set the default packet priority to zero. * ID, and set the default packet priority to zero.
*/ */
return mv88e6xxx_port_write(chip, port, PORT_DEFAULT_VLAN, 0x0000); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_DEFAULT_VLAN, 0);
} }
static int mv88e6xxx_port_enable(struct dsa_switch *ds, int port, static int mv88e6xxx_port_enable(struct dsa_switch *ds, int port,
...@@ -2181,7 +2183,7 @@ static int mv88e6xxx_mdio_read(struct mii_bus *bus, int phy, int reg) ...@@ -2181,7 +2183,7 @@ static int mv88e6xxx_mdio_read(struct mii_bus *bus, int phy, int reg)
* the mv88e6390 family model number instead. * the mv88e6390 family model number instead.
*/ */
if (!(val & 0x3f0)) if (!(val & 0x3f0))
val |= PORT_SWITCH_ID_PROD_NUM_6390; val |= MV88E6XXX_PORT_SWITCH_ID_PROD_6390 >> 4;
} }
return err ? err : val; return err ? err : val;
...@@ -3162,7 +3164,7 @@ static const struct mv88e6xxx_ops mv88e6390x_ops = { ...@@ -3162,7 +3164,7 @@ static const struct mv88e6xxx_ops mv88e6390x_ops = {
static const struct mv88e6xxx_info mv88e6xxx_table[] = { static const struct mv88e6xxx_info mv88e6xxx_table[] = {
[MV88E6085] = { [MV88E6085] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6085, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6085,
.family = MV88E6XXX_FAMILY_6097, .family = MV88E6XXX_FAMILY_6097,
.name = "Marvell 88E6085", .name = "Marvell 88E6085",
.num_databases = 4096, .num_databases = 4096,
...@@ -3180,7 +3182,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3180,7 +3182,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6095] = { [MV88E6095] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6095, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6095,
.family = MV88E6XXX_FAMILY_6095, .family = MV88E6XXX_FAMILY_6095,
.name = "Marvell 88E6095/88E6095F", .name = "Marvell 88E6095/88E6095F",
.num_databases = 256, .num_databases = 256,
...@@ -3197,7 +3199,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3197,7 +3199,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6097] = { [MV88E6097] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6097, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6097,
.family = MV88E6XXX_FAMILY_6097, .family = MV88E6XXX_FAMILY_6097,
.name = "Marvell 88E6097/88E6097F", .name = "Marvell 88E6097/88E6097F",
.num_databases = 4096, .num_databases = 4096,
...@@ -3215,7 +3217,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3215,7 +3217,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6123] = { [MV88E6123] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6123, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6123,
.family = MV88E6XXX_FAMILY_6165, .family = MV88E6XXX_FAMILY_6165,
.name = "Marvell 88E6123", .name = "Marvell 88E6123",
.num_databases = 4096, .num_databases = 4096,
...@@ -3233,7 +3235,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3233,7 +3235,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6131] = { [MV88E6131] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6131, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6131,
.family = MV88E6XXX_FAMILY_6185, .family = MV88E6XXX_FAMILY_6185,
.name = "Marvell 88E6131", .name = "Marvell 88E6131",
.num_databases = 256, .num_databases = 256,
...@@ -3250,7 +3252,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3250,7 +3252,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6141] = { [MV88E6141] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6141, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6141,
.family = MV88E6XXX_FAMILY_6341, .family = MV88E6XXX_FAMILY_6341,
.name = "Marvell 88E6341", .name = "Marvell 88E6341",
.num_databases = 4096, .num_databases = 4096,
...@@ -3267,7 +3269,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3267,7 +3269,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6161] = { [MV88E6161] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6161, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6161,
.family = MV88E6XXX_FAMILY_6165, .family = MV88E6XXX_FAMILY_6165,
.name = "Marvell 88E6161", .name = "Marvell 88E6161",
.num_databases = 4096, .num_databases = 4096,
...@@ -3285,7 +3287,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3285,7 +3287,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6165] = { [MV88E6165] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6165, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6165,
.family = MV88E6XXX_FAMILY_6165, .family = MV88E6XXX_FAMILY_6165,
.name = "Marvell 88E6165", .name = "Marvell 88E6165",
.num_databases = 4096, .num_databases = 4096,
...@@ -3303,7 +3305,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3303,7 +3305,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6171] = { [MV88E6171] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6171, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6171,
.family = MV88E6XXX_FAMILY_6351, .family = MV88E6XXX_FAMILY_6351,
.name = "Marvell 88E6171", .name = "Marvell 88E6171",
.num_databases = 4096, .num_databases = 4096,
...@@ -3321,7 +3323,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3321,7 +3323,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6172] = { [MV88E6172] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6172, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6172,
.family = MV88E6XXX_FAMILY_6352, .family = MV88E6XXX_FAMILY_6352,
.name = "Marvell 88E6172", .name = "Marvell 88E6172",
.num_databases = 4096, .num_databases = 4096,
...@@ -3339,7 +3341,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3339,7 +3341,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6175] = { [MV88E6175] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6175, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6175,
.family = MV88E6XXX_FAMILY_6351, .family = MV88E6XXX_FAMILY_6351,
.name = "Marvell 88E6175", .name = "Marvell 88E6175",
.num_databases = 4096, .num_databases = 4096,
...@@ -3357,7 +3359,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3357,7 +3359,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6176] = { [MV88E6176] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6176, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6176,
.family = MV88E6XXX_FAMILY_6352, .family = MV88E6XXX_FAMILY_6352,
.name = "Marvell 88E6176", .name = "Marvell 88E6176",
.num_databases = 4096, .num_databases = 4096,
...@@ -3375,7 +3377,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3375,7 +3377,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6185] = { [MV88E6185] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6185, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6185,
.family = MV88E6XXX_FAMILY_6185, .family = MV88E6XXX_FAMILY_6185,
.name = "Marvell 88E6185", .name = "Marvell 88E6185",
.num_databases = 256, .num_databases = 256,
...@@ -3392,7 +3394,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3392,7 +3394,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6190] = { [MV88E6190] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6190, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6190,
.family = MV88E6XXX_FAMILY_6390, .family = MV88E6XXX_FAMILY_6390,
.name = "Marvell 88E6190", .name = "Marvell 88E6190",
.num_databases = 4096, .num_databases = 4096,
...@@ -3410,7 +3412,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3410,7 +3412,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6190X] = { [MV88E6190X] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6190X, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6190X,
.family = MV88E6XXX_FAMILY_6390, .family = MV88E6XXX_FAMILY_6390,
.name = "Marvell 88E6190X", .name = "Marvell 88E6190X",
.num_databases = 4096, .num_databases = 4096,
...@@ -3428,7 +3430,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3428,7 +3430,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6191] = { [MV88E6191] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6191, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6191,
.family = MV88E6XXX_FAMILY_6390, .family = MV88E6XXX_FAMILY_6390,
.name = "Marvell 88E6191", .name = "Marvell 88E6191",
.num_databases = 4096, .num_databases = 4096,
...@@ -3446,7 +3448,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3446,7 +3448,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6240] = { [MV88E6240] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6240, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6240,
.family = MV88E6XXX_FAMILY_6352, .family = MV88E6XXX_FAMILY_6352,
.name = "Marvell 88E6240", .name = "Marvell 88E6240",
.num_databases = 4096, .num_databases = 4096,
...@@ -3464,7 +3466,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3464,7 +3466,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6290] = { [MV88E6290] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6290, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6290,
.family = MV88E6XXX_FAMILY_6390, .family = MV88E6XXX_FAMILY_6390,
.name = "Marvell 88E6290", .name = "Marvell 88E6290",
.num_databases = 4096, .num_databases = 4096,
...@@ -3482,7 +3484,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3482,7 +3484,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6320] = { [MV88E6320] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6320, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6320,
.family = MV88E6XXX_FAMILY_6320, .family = MV88E6XXX_FAMILY_6320,
.name = "Marvell 88E6320", .name = "Marvell 88E6320",
.num_databases = 4096, .num_databases = 4096,
...@@ -3500,7 +3502,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3500,7 +3502,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6321] = { [MV88E6321] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6321, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6321,
.family = MV88E6XXX_FAMILY_6320, .family = MV88E6XXX_FAMILY_6320,
.name = "Marvell 88E6321", .name = "Marvell 88E6321",
.num_databases = 4096, .num_databases = 4096,
...@@ -3517,7 +3519,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3517,7 +3519,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6341] = { [MV88E6341] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6341, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6341,
.family = MV88E6XXX_FAMILY_6341, .family = MV88E6XXX_FAMILY_6341,
.name = "Marvell 88E6341", .name = "Marvell 88E6341",
.num_databases = 4096, .num_databases = 4096,
...@@ -3534,7 +3536,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3534,7 +3536,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6350] = { [MV88E6350] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6350, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6350,
.family = MV88E6XXX_FAMILY_6351, .family = MV88E6XXX_FAMILY_6351,
.name = "Marvell 88E6350", .name = "Marvell 88E6350",
.num_databases = 4096, .num_databases = 4096,
...@@ -3552,7 +3554,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3552,7 +3554,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6351] = { [MV88E6351] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6351, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6351,
.family = MV88E6XXX_FAMILY_6351, .family = MV88E6XXX_FAMILY_6351,
.name = "Marvell 88E6351", .name = "Marvell 88E6351",
.num_databases = 4096, .num_databases = 4096,
...@@ -3570,7 +3572,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3570,7 +3572,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
}, },
[MV88E6352] = { [MV88E6352] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6352, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6352,
.family = MV88E6XXX_FAMILY_6352, .family = MV88E6XXX_FAMILY_6352,
.name = "Marvell 88E6352", .name = "Marvell 88E6352",
.num_databases = 4096, .num_databases = 4096,
...@@ -3587,7 +3589,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3587,7 +3589,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
.ops = &mv88e6352_ops, .ops = &mv88e6352_ops,
}, },
[MV88E6390] = { [MV88E6390] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6390, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6390,
.family = MV88E6XXX_FAMILY_6390, .family = MV88E6XXX_FAMILY_6390,
.name = "Marvell 88E6390", .name = "Marvell 88E6390",
.num_databases = 4096, .num_databases = 4096,
...@@ -3604,7 +3606,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = { ...@@ -3604,7 +3606,7 @@ static const struct mv88e6xxx_info mv88e6xxx_table[] = {
.ops = &mv88e6390_ops, .ops = &mv88e6390_ops,
}, },
[MV88E6390X] = { [MV88E6390X] = {
.prod_num = PORT_SWITCH_ID_PROD_NUM_6390X, .prod_num = MV88E6XXX_PORT_SWITCH_ID_PROD_6390X,
.family = MV88E6XXX_FAMILY_6390, .family = MV88E6XXX_FAMILY_6390,
.name = "Marvell 88E6390X", .name = "Marvell 88E6390X",
.num_databases = 4096, .num_databases = 4096,
...@@ -3641,13 +3643,13 @@ static int mv88e6xxx_detect(struct mv88e6xxx_chip *chip) ...@@ -3641,13 +3643,13 @@ static int mv88e6xxx_detect(struct mv88e6xxx_chip *chip)
int err; int err;
mutex_lock(&chip->reg_lock); mutex_lock(&chip->reg_lock);
err = mv88e6xxx_port_read(chip, 0, PORT_SWITCH_ID, &id); err = mv88e6xxx_port_read(chip, 0, MV88E6XXX_PORT_SWITCH_ID, &id);
mutex_unlock(&chip->reg_lock); mutex_unlock(&chip->reg_lock);
if (err) if (err)
return err; return err;
prod_num = (id & 0xfff0) >> 4; prod_num = id & MV88E6XXX_PORT_SWITCH_ID_PROD_MASK;
rev = id & 0x000f; rev = id & MV88E6XXX_PORT_SWITCH_ID_REV_MASK;
info = mv88e6xxx_lookup_info(prod_num); info = mv88e6xxx_lookup_info(prod_num);
if (!info) if (!info)
......
...@@ -49,23 +49,23 @@ static int mv88e6xxx_port_set_rgmii_delay(struct mv88e6xxx_chip *chip, int port, ...@@ -49,23 +49,23 @@ static int mv88e6xxx_port_set_rgmii_delay(struct mv88e6xxx_chip *chip, int port,
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_PCS_CTRL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_MAC_CTL, &reg);
if (err) if (err)
return err; return err;
reg &= ~(PORT_PCS_CTRL_RGMII_DELAY_RXCLK | reg &= ~(MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_RXCLK |
PORT_PCS_CTRL_RGMII_DELAY_TXCLK); MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_TXCLK);
switch (mode) { switch (mode) {
case PHY_INTERFACE_MODE_RGMII_RXID: case PHY_INTERFACE_MODE_RGMII_RXID:
reg |= PORT_PCS_CTRL_RGMII_DELAY_RXCLK; reg |= MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_RXCLK;
break; break;
case PHY_INTERFACE_MODE_RGMII_TXID: case PHY_INTERFACE_MODE_RGMII_TXID:
reg |= PORT_PCS_CTRL_RGMII_DELAY_TXCLK; reg |= MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_TXCLK;
break; break;
case PHY_INTERFACE_MODE_RGMII_ID: case PHY_INTERFACE_MODE_RGMII_ID:
reg |= PORT_PCS_CTRL_RGMII_DELAY_RXCLK | reg |= MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_RXCLK |
PORT_PCS_CTRL_RGMII_DELAY_TXCLK; MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_TXCLK;
break; break;
case PHY_INTERFACE_MODE_RGMII: case PHY_INTERFACE_MODE_RGMII:
break; break;
...@@ -73,13 +73,13 @@ static int mv88e6xxx_port_set_rgmii_delay(struct mv88e6xxx_chip *chip, int port, ...@@ -73,13 +73,13 @@ static int mv88e6xxx_port_set_rgmii_delay(struct mv88e6xxx_chip *chip, int port,
return 0; return 0;
} }
err = mv88e6xxx_port_write(chip, port, PORT_PCS_CTRL, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_MAC_CTL, reg);
if (err) if (err)
return err; return err;
dev_dbg(chip->dev, "p%d: delay RXCLK %s, TXCLK %s\n", port, dev_dbg(chip->dev, "p%d: delay RXCLK %s, TXCLK %s\n", port,
reg & PORT_PCS_CTRL_RGMII_DELAY_RXCLK ? "yes" : "no", reg & MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_RXCLK ? "yes" : "no",
reg & PORT_PCS_CTRL_RGMII_DELAY_TXCLK ? "yes" : "no"); reg & MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_TXCLK ? "yes" : "no");
return 0; return 0;
} }
...@@ -107,18 +107,20 @@ int mv88e6xxx_port_set_link(struct mv88e6xxx_chip *chip, int port, int link) ...@@ -107,18 +107,20 @@ int mv88e6xxx_port_set_link(struct mv88e6xxx_chip *chip, int port, int link)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_PCS_CTRL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_MAC_CTL, &reg);
if (err) if (err)
return err; return err;
reg &= ~(PORT_PCS_CTRL_FORCE_LINK | PORT_PCS_CTRL_LINK_UP); reg &= ~(MV88E6XXX_PORT_MAC_CTL_FORCE_LINK |
MV88E6XXX_PORT_MAC_CTL_LINK_UP);
switch (link) { switch (link) {
case LINK_FORCED_DOWN: case LINK_FORCED_DOWN:
reg |= PORT_PCS_CTRL_FORCE_LINK; reg |= MV88E6XXX_PORT_MAC_CTL_FORCE_LINK;
break; break;
case LINK_FORCED_UP: case LINK_FORCED_UP:
reg |= PORT_PCS_CTRL_FORCE_LINK | PORT_PCS_CTRL_LINK_UP; reg |= MV88E6XXX_PORT_MAC_CTL_FORCE_LINK |
MV88E6XXX_PORT_MAC_CTL_LINK_UP;
break; break;
case LINK_UNFORCED: case LINK_UNFORCED:
/* normal link detection */ /* normal link detection */
...@@ -127,13 +129,13 @@ int mv88e6xxx_port_set_link(struct mv88e6xxx_chip *chip, int port, int link) ...@@ -127,13 +129,13 @@ int mv88e6xxx_port_set_link(struct mv88e6xxx_chip *chip, int port, int link)
return -EINVAL; return -EINVAL;
} }
err = mv88e6xxx_port_write(chip, port, PORT_PCS_CTRL, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_MAC_CTL, reg);
if (err) if (err)
return err; return err;
dev_dbg(chip->dev, "p%d: %s link %s\n", port, dev_dbg(chip->dev, "p%d: %s link %s\n", port,
reg & PORT_PCS_CTRL_FORCE_LINK ? "Force" : "Unforce", reg & MV88E6XXX_PORT_MAC_CTL_FORCE_LINK ? "Force" : "Unforce",
reg & PORT_PCS_CTRL_LINK_UP ? "up" : "down"); reg & MV88E6XXX_PORT_MAC_CTL_LINK_UP ? "up" : "down");
return 0; return 0;
} }
...@@ -143,18 +145,20 @@ int mv88e6xxx_port_set_duplex(struct mv88e6xxx_chip *chip, int port, int dup) ...@@ -143,18 +145,20 @@ int mv88e6xxx_port_set_duplex(struct mv88e6xxx_chip *chip, int port, int dup)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_PCS_CTRL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_MAC_CTL, &reg);
if (err) if (err)
return err; return err;
reg &= ~(PORT_PCS_CTRL_FORCE_DUPLEX | PORT_PCS_CTRL_DUPLEX_FULL); reg &= ~(MV88E6XXX_PORT_MAC_CTL_FORCE_DUPLEX |
MV88E6XXX_PORT_MAC_CTL_DUPLEX_FULL);
switch (dup) { switch (dup) {
case DUPLEX_HALF: case DUPLEX_HALF:
reg |= PORT_PCS_CTRL_FORCE_DUPLEX; reg |= MV88E6XXX_PORT_MAC_CTL_FORCE_DUPLEX;
break; break;
case DUPLEX_FULL: case DUPLEX_FULL:
reg |= PORT_PCS_CTRL_FORCE_DUPLEX | PORT_PCS_CTRL_DUPLEX_FULL; reg |= MV88E6XXX_PORT_MAC_CTL_FORCE_DUPLEX |
MV88E6XXX_PORT_MAC_CTL_DUPLEX_FULL;
break; break;
case DUPLEX_UNFORCED: case DUPLEX_UNFORCED:
/* normal duplex detection */ /* normal duplex detection */
...@@ -163,13 +167,13 @@ int mv88e6xxx_port_set_duplex(struct mv88e6xxx_chip *chip, int port, int dup) ...@@ -163,13 +167,13 @@ int mv88e6xxx_port_set_duplex(struct mv88e6xxx_chip *chip, int port, int dup)
return -EINVAL; return -EINVAL;
} }
err = mv88e6xxx_port_write(chip, port, PORT_PCS_CTRL, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_MAC_CTL, reg);
if (err) if (err)
return err; return err;
dev_dbg(chip->dev, "p%d: %s %s duplex\n", port, dev_dbg(chip->dev, "p%d: %s %s duplex\n", port,
reg & PORT_PCS_CTRL_FORCE_DUPLEX ? "Force" : "Unforce", reg & MV88E6XXX_PORT_MAC_CTL_FORCE_DUPLEX ? "Force" : "Unforce",
reg & PORT_PCS_CTRL_DUPLEX_FULL ? "full" : "half"); reg & MV88E6XXX_PORT_MAC_CTL_DUPLEX_FULL ? "full" : "half");
return 0; return 0;
} }
...@@ -182,47 +186,49 @@ static int mv88e6xxx_port_set_speed(struct mv88e6xxx_chip *chip, int port, ...@@ -182,47 +186,49 @@ static int mv88e6xxx_port_set_speed(struct mv88e6xxx_chip *chip, int port,
switch (speed) { switch (speed) {
case 10: case 10:
ctrl = PORT_PCS_CTRL_SPEED_10; ctrl = MV88E6XXX_PORT_MAC_CTL_SPEED_10;
break; break;
case 100: case 100:
ctrl = PORT_PCS_CTRL_SPEED_100; ctrl = MV88E6XXX_PORT_MAC_CTL_SPEED_100;
break; break;
case 200: case 200:
if (alt_bit) if (alt_bit)
ctrl = PORT_PCS_CTRL_SPEED_100 | PORT_PCS_CTRL_ALTSPEED; ctrl = MV88E6XXX_PORT_MAC_CTL_SPEED_100 |
MV88E6390_PORT_MAC_CTL_ALTSPEED;
else else
ctrl = PORT_PCS_CTRL_SPEED_200; ctrl = MV88E6065_PORT_MAC_CTL_SPEED_200;
break; break;
case 1000: case 1000:
ctrl = PORT_PCS_CTRL_SPEED_1000; ctrl = MV88E6XXX_PORT_MAC_CTL_SPEED_1000;
break; break;
case 2500: case 2500:
ctrl = PORT_PCS_CTRL_SPEED_10000 | PORT_PCS_CTRL_ALTSPEED; ctrl = MV88E6390_PORT_MAC_CTL_SPEED_10000 |
MV88E6390_PORT_MAC_CTL_ALTSPEED;
break; break;
case 10000: case 10000:
/* all bits set, fall through... */ /* all bits set, fall through... */
case SPEED_UNFORCED: case SPEED_UNFORCED:
ctrl = PORT_PCS_CTRL_SPEED_UNFORCED; ctrl = MV88E6XXX_PORT_MAC_CTL_SPEED_UNFORCED;
break; break;
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;
} }
err = mv88e6xxx_port_read(chip, port, PORT_PCS_CTRL, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_MAC_CTL, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_PCS_CTRL_SPEED_MASK; reg &= ~MV88E6XXX_PORT_MAC_CTL_SPEED_MASK;
if (alt_bit) if (alt_bit)
reg &= ~PORT_PCS_CTRL_ALTSPEED; reg &= ~MV88E6390_PORT_MAC_CTL_ALTSPEED;
if (force_bit) { if (force_bit) {
reg &= ~PORT_PCS_CTRL_FORCE_SPEED; reg &= ~MV88E6390_PORT_MAC_CTL_FORCE_SPEED;
if (speed != SPEED_UNFORCED) if (speed != SPEED_UNFORCED)
ctrl |= PORT_PCS_CTRL_FORCE_SPEED; ctrl |= MV88E6390_PORT_MAC_CTL_FORCE_SPEED;
} }
reg |= ctrl; reg |= ctrl;
err = mv88e6xxx_port_write(chip, port, PORT_PCS_CTRL, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_MAC_CTL, reg);
if (err) if (err)
return err; return err;
...@@ -322,33 +328,33 @@ int mv88e6390x_port_set_cmode(struct mv88e6xxx_chip *chip, int port, ...@@ -322,33 +328,33 @@ int mv88e6390x_port_set_cmode(struct mv88e6xxx_chip *chip, int port,
switch (mode) { switch (mode) {
case PHY_INTERFACE_MODE_1000BASEX: case PHY_INTERFACE_MODE_1000BASEX:
cmode = PORT_STATUS_CMODE_1000BASE_X; cmode = MV88E6XXX_PORT_STS_CMODE_1000BASE_X;
break; break;
case PHY_INTERFACE_MODE_SGMII: case PHY_INTERFACE_MODE_SGMII:
cmode = PORT_STATUS_CMODE_SGMII; cmode = MV88E6XXX_PORT_STS_CMODE_SGMII;
break; break;
case PHY_INTERFACE_MODE_2500BASEX: case PHY_INTERFACE_MODE_2500BASEX:
cmode = PORT_STATUS_CMODE_2500BASEX; cmode = MV88E6XXX_PORT_STS_CMODE_2500BASEX;
break; break;
case PHY_INTERFACE_MODE_XGMII: case PHY_INTERFACE_MODE_XGMII:
cmode = PORT_STATUS_CMODE_XAUI; cmode = MV88E6XXX_PORT_STS_CMODE_XAUI;
break; break;
case PHY_INTERFACE_MODE_RXAUI: case PHY_INTERFACE_MODE_RXAUI:
cmode = PORT_STATUS_CMODE_RXAUI; cmode = MV88E6XXX_PORT_STS_CMODE_RXAUI;
break; break;
default: default:
cmode = 0; cmode = 0;
} }
if (cmode) { if (cmode) {
err = mv88e6xxx_port_read(chip, port, PORT_STATUS, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_STS, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_STATUS_CMODE_MASK; reg &= ~MV88E6XXX_PORT_STS_CMODE_MASK;
reg |= cmode; reg |= cmode;
err = mv88e6xxx_port_write(chip, port, PORT_STATUS, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_STS, reg);
if (err) if (err)
return err; return err;
} }
...@@ -361,16 +367,16 @@ int mv88e6xxx_port_get_cmode(struct mv88e6xxx_chip *chip, int port, u8 *cmode) ...@@ -361,16 +367,16 @@ int mv88e6xxx_port_get_cmode(struct mv88e6xxx_chip *chip, int port, u8 *cmode)
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_STATUS, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_STS, &reg);
if (err) if (err)
return err; return err;
*cmode = reg & PORT_STATUS_CMODE_MASK; *cmode = reg & MV88E6XXX_PORT_STS_CMODE_MASK;
return 0; return 0;
} }
/* Offset 0x02: Pause Control /* Offset 0x02: Jamming Control
* *
* Do not limit the period of time that this port can be paused for by * Do not limit the period of time that this port can be paused for by
* the remote end or the period of time that this port can pause the * the remote end or the period of time that this port can pause the
...@@ -379,7 +385,8 @@ int mv88e6xxx_port_get_cmode(struct mv88e6xxx_chip *chip, int port, u8 *cmode) ...@@ -379,7 +385,8 @@ int mv88e6xxx_port_get_cmode(struct mv88e6xxx_chip *chip, int port, u8 *cmode)
int mv88e6097_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in, int mv88e6097_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in,
u8 out) u8 out)
{ {
return mv88e6xxx_port_write(chip, port, PORT_PAUSE_CTRL, out << 8 | in); return mv88e6xxx_port_write(chip, port, MV88E6097_PORT_JAM_CTL,
out << 8 | in);
} }
int mv88e6390_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in, int mv88e6390_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in,
...@@ -387,22 +394,24 @@ int mv88e6390_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in, ...@@ -387,22 +394,24 @@ int mv88e6390_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in,
{ {
int err; int err;
err = mv88e6xxx_port_write(chip, port, PORT_PAUSE_CTRL, err = mv88e6xxx_port_write(chip, port, MV88E6390_PORT_FLOW_CTL,
PORT_FLOW_CTRL_LIMIT_IN | in); MV88E6390_PORT_FLOW_CTL_UPDATE |
MV88E6390_PORT_FLOW_CTL_LIMIT_IN | in);
if (err) if (err)
return err; return err;
return mv88e6xxx_port_write(chip, port, PORT_PAUSE_CTRL, return mv88e6xxx_port_write(chip, port, MV88E6390_PORT_FLOW_CTL,
PORT_FLOW_CTRL_LIMIT_OUT | out); MV88E6390_PORT_FLOW_CTL_UPDATE |
MV88E6390_PORT_FLOW_CTL_LIMIT_OUT | out);
} }
/* 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)
...@@ -410,25 +419,25 @@ int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state) ...@@ -410,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;
...@@ -436,7 +445,7 @@ int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state) ...@@ -436,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;
...@@ -452,30 +461,30 @@ int mv88e6xxx_port_set_egress_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -452,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,
...@@ -484,24 +493,24 @@ int mv88e6085_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -484,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,
...@@ -510,30 +519,30 @@ int mv88e6351_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -510,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,
...@@ -542,16 +551,16 @@ static int mv88e6185_port_set_forward_unknown(struct mv88e6xxx_chip *chip, ...@@ -542,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,
...@@ -560,22 +569,22 @@ int mv88e6352_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port, ...@@ -560,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 */
...@@ -586,16 +595,16 @@ int mv88e6xxx_port_set_message_port(struct mv88e6xxx_chip *chip, int port, ...@@ -586,16 +595,16 @@ int mv88e6xxx_port_set_message_port(struct mv88e6xxx_chip *chip, int port,
u16 val; u16 val;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_1, &val); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL1, &val);
if (err) if (err)
return err; return err;
if (message_port) if (message_port)
val |= PORT_CONTROL_1_MESSAGE_PORT; val |= MV88E6XXX_PORT_CTL1_MESSAGE_PORT;
else else
val &= ~PORT_CONTROL_1_MESSAGE_PORT; val &= ~MV88E6XXX_PORT_CTL1_MESSAGE_PORT;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL_1, val); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL1, val);
} }
/* Offset 0x06: Port Based VLAN Map */ /* Offset 0x06: Port Based VLAN Map */
...@@ -606,14 +615,14 @@ int mv88e6xxx_port_set_vlan_map(struct mv88e6xxx_chip *chip, int port, u16 map) ...@@ -606,14 +615,14 @@ int mv88e6xxx_port_set_vlan_map(struct mv88e6xxx_chip *chip, int port, u16 map)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_BASE_VLAN, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_BASE_VLAN, &reg);
if (err) if (err)
return err; return err;
reg &= ~mask; reg &= ~mask;
reg |= map & mask; reg |= map & mask;
err = mv88e6xxx_port_write(chip, port, PORT_BASE_VLAN, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_BASE_VLAN, reg);
if (err) if (err)
return err; return err;
...@@ -629,7 +638,7 @@ int mv88e6xxx_port_get_fid(struct mv88e6xxx_chip *chip, int port, u16 *fid) ...@@ -629,7 +638,7 @@ int mv88e6xxx_port_get_fid(struct mv88e6xxx_chip *chip, int port, u16 *fid)
int err; int err;
/* Port's default FID lower 4 bits are located in reg 0x06, offset 12 */ /* Port's default FID lower 4 bits are located in reg 0x06, offset 12 */
err = mv88e6xxx_port_read(chip, port, PORT_BASE_VLAN, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_BASE_VLAN, &reg);
if (err) if (err)
return err; return err;
...@@ -637,7 +646,8 @@ int mv88e6xxx_port_get_fid(struct mv88e6xxx_chip *chip, int port, u16 *fid) ...@@ -637,7 +646,8 @@ int mv88e6xxx_port_get_fid(struct mv88e6xxx_chip *chip, int port, u16 *fid)
/* Port's default FID upper bits are located in reg 0x05, offset 0 */ /* Port's default FID upper bits are located in reg 0x05, offset 0 */
if (upper_mask) { if (upper_mask) {
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_1, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL1,
&reg);
if (err) if (err)
return err; return err;
...@@ -657,27 +667,29 @@ int mv88e6xxx_port_set_fid(struct mv88e6xxx_chip *chip, int port, u16 fid) ...@@ -657,27 +667,29 @@ int mv88e6xxx_port_set_fid(struct mv88e6xxx_chip *chip, int port, u16 fid)
return -EINVAL; return -EINVAL;
/* Port's default FID lower 4 bits are located in reg 0x06, offset 12 */ /* Port's default FID lower 4 bits are located in reg 0x06, offset 12 */
err = mv88e6xxx_port_read(chip, port, PORT_BASE_VLAN, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_BASE_VLAN, &reg);
if (err) if (err)
return err; return err;
reg &= 0x0fff; reg &= 0x0fff;
reg |= (fid & 0x000f) << 12; reg |= (fid & 0x000f) << 12;
err = mv88e6xxx_port_write(chip, port, PORT_BASE_VLAN, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_BASE_VLAN, reg);
if (err) if (err)
return err; return err;
/* Port's default FID upper bits are located in reg 0x05, offset 0 */ /* Port's default FID upper bits are located in reg 0x05, offset 0 */
if (upper_mask) { if (upper_mask) {
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_1, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL1,
&reg);
if (err) if (err)
return err; return err;
reg &= ~upper_mask; reg &= ~upper_mask;
reg |= (fid >> 4) & upper_mask; reg |= (fid >> 4) & upper_mask;
err = mv88e6xxx_port_write(chip, port, PORT_CONTROL_1, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL1,
reg);
if (err) if (err)
return err; return err;
} }
...@@ -694,11 +706,12 @@ int mv88e6xxx_port_get_pvid(struct mv88e6xxx_chip *chip, int port, u16 *pvid) ...@@ -694,11 +706,12 @@ int mv88e6xxx_port_get_pvid(struct mv88e6xxx_chip *chip, int port, u16 *pvid)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_DEFAULT_VLAN, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_DEFAULT_VLAN,
&reg);
if (err) if (err)
return err; return err;
*pvid = reg & PORT_DEFAULT_VLAN_MASK; *pvid = reg & MV88E6XXX_PORT_DEFAULT_VLAN_MASK;
return 0; return 0;
} }
...@@ -708,14 +721,16 @@ int mv88e6xxx_port_set_pvid(struct mv88e6xxx_chip *chip, int port, u16 pvid) ...@@ -708,14 +721,16 @@ int mv88e6xxx_port_set_pvid(struct mv88e6xxx_chip *chip, int port, u16 pvid)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_DEFAULT_VLAN, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_DEFAULT_VLAN,
&reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_DEFAULT_VLAN_MASK; reg &= ~MV88E6XXX_PORT_DEFAULT_VLAN_MASK;
reg |= pvid & PORT_DEFAULT_VLAN_MASK; reg |= pvid & MV88E6XXX_PORT_DEFAULT_VLAN_MASK;
err = mv88e6xxx_port_write(chip, port, PORT_DEFAULT_VLAN, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_DEFAULT_VLAN,
reg);
if (err) if (err)
return err; return err;
...@@ -727,10 +742,10 @@ int mv88e6xxx_port_set_pvid(struct mv88e6xxx_chip *chip, int port, u16 pvid) ...@@ -727,10 +742,10 @@ int mv88e6xxx_port_set_pvid(struct mv88e6xxx_chip *chip, int port, u16 pvid)
/* Offset 0x08: Port Control 2 Register */ /* Offset 0x08: Port Control 2 Register */
static const char * const mv88e6xxx_port_8021q_mode_names[] = { static const char * const mv88e6xxx_port_8021q_mode_names[] = {
[PORT_CONTROL_2_8021Q_DISABLED] = "Disabled", [MV88E6XXX_PORT_CTL2_8021Q_MODE_DISABLED] = "Disabled",
[PORT_CONTROL_2_8021Q_FALLBACK] = "Fallback", [MV88E6XXX_PORT_CTL2_8021Q_MODE_FALLBACK] = "Fallback",
[PORT_CONTROL_2_8021Q_CHECK] = "Check", [MV88E6XXX_PORT_CTL2_8021Q_MODE_CHECK] = "Check",
[PORT_CONTROL_2_8021Q_SECURE] = "Secure", [MV88E6XXX_PORT_CTL2_8021Q_MODE_SECURE] = "Secure",
}; };
static int mv88e6185_port_set_default_forward(struct mv88e6xxx_chip *chip, static int mv88e6185_port_set_default_forward(struct mv88e6xxx_chip *chip,
...@@ -739,16 +754,16 @@ static int mv88e6185_port_set_default_forward(struct mv88e6xxx_chip *chip, ...@@ -739,16 +754,16 @@ static int mv88e6185_port_set_default_forward(struct mv88e6xxx_chip *chip,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_2, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL2, &reg);
if (err) if (err)
return err; return err;
if (multicast) if (multicast)
reg |= PORT_CONTROL_2_DEFAULT_FORWARD; reg |= MV88E6XXX_PORT_CTL2_DEFAULT_FORWARD;
else else
reg &= ~PORT_CONTROL_2_DEFAULT_FORWARD; reg &= ~MV88E6XXX_PORT_CTL2_DEFAULT_FORWARD;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL_2, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL2, reg);
} }
int mv88e6185_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port, int mv88e6185_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port,
...@@ -769,14 +784,14 @@ int mv88e6095_port_set_upstream_port(struct mv88e6xxx_chip *chip, int port, ...@@ -769,14 +784,14 @@ int mv88e6095_port_set_upstream_port(struct mv88e6xxx_chip *chip, int port,
int err; int err;
u16 reg; u16 reg;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_2, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL2, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_2_UPSTREAM_MASK; reg &= ~MV88E6095_PORT_CTL2_CPU_PORT_MASK;
reg |= upstream_port; reg |= upstream_port;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL_2, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL2, reg);
} }
int mv88e6xxx_port_set_8021q_mode(struct mv88e6xxx_chip *chip, int port, int mv88e6xxx_port_set_8021q_mode(struct mv88e6xxx_chip *chip, int port,
...@@ -785,14 +800,14 @@ int mv88e6xxx_port_set_8021q_mode(struct mv88e6xxx_chip *chip, int port, ...@@ -785,14 +800,14 @@ int mv88e6xxx_port_set_8021q_mode(struct mv88e6xxx_chip *chip, int port,
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_2, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL2, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_2_8021Q_MASK; reg &= ~MV88E6XXX_PORT_CTL2_8021Q_MODE_MASK;
reg |= mode & PORT_CONTROL_2_8021Q_MASK; reg |= mode & MV88E6XXX_PORT_CTL2_8021Q_MODE_MASK;
err = mv88e6xxx_port_write(chip, port, PORT_CONTROL_2, reg); err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL2, reg);
if (err) if (err)
return err; return err;
...@@ -807,13 +822,13 @@ int mv88e6xxx_port_set_map_da(struct mv88e6xxx_chip *chip, int port) ...@@ -807,13 +822,13 @@ int mv88e6xxx_port_set_map_da(struct mv88e6xxx_chip *chip, int port)
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_2, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL2, &reg);
if (err) if (err)
return err; return err;
reg |= PORT_CONTROL_2_MAP_DA; reg |= MV88E6XXX_PORT_CTL2_MAP_DA;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL_2, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL2, reg);
} }
int mv88e6165_port_set_jumbo_size(struct mv88e6xxx_chip *chip, int port, int mv88e6165_port_set_jumbo_size(struct mv88e6xxx_chip *chip, int port,
...@@ -822,48 +837,50 @@ int mv88e6165_port_set_jumbo_size(struct mv88e6xxx_chip *chip, int port, ...@@ -822,48 +837,50 @@ int mv88e6165_port_set_jumbo_size(struct mv88e6xxx_chip *chip, int port,
u16 reg; u16 reg;
int err; int err;
err = mv88e6xxx_port_read(chip, port, PORT_CONTROL_2, &reg); err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_CTL2, &reg);
if (err) if (err)
return err; return err;
reg &= ~PORT_CONTROL_2_JUMBO_MASK; reg &= ~MV88E6XXX_PORT_CTL2_JUMBO_MODE_MASK;
if (size <= 1522) if (size <= 1522)
reg |= PORT_CONTROL_2_JUMBO_1522; reg |= MV88E6XXX_PORT_CTL2_JUMBO_MODE_1522;
else if (size <= 2048) else if (size <= 2048)
reg |= PORT_CONTROL_2_JUMBO_2048; reg |= MV88E6XXX_PORT_CTL2_JUMBO_MODE_2048;
else if (size <= 10240) else if (size <= 10240)
reg |= PORT_CONTROL_2_JUMBO_10240; reg |= MV88E6XXX_PORT_CTL2_JUMBO_MODE_10240;
else else
return -ERANGE; return -ERANGE;
return mv88e6xxx_port_write(chip, port, PORT_CONTROL_2, reg); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL2, reg);
} }
/* Offset 0x09: Port Rate Control */ /* Offset 0x09: Port Rate Control */
int mv88e6095_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port) int mv88e6095_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port)
{ {
return mv88e6xxx_port_write(chip, port, PORT_RATE_CONTROL, 0x0000); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL1,
0x0000);
} }
int mv88e6097_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port) int mv88e6097_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port)
{ {
return mv88e6xxx_port_write(chip, port, PORT_RATE_CONTROL, 0x0001); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL1,
0x0001);
} }
/* Offset 0x0C: Port ATU Control */ /* Offset 0x0C: Port ATU Control */
int mv88e6xxx_port_disable_learn_limit(struct mv88e6xxx_chip *chip, int port) int mv88e6xxx_port_disable_learn_limit(struct mv88e6xxx_chip *chip, int port)
{ {
return mv88e6xxx_port_write(chip, port, PORT_ATU_CONTROL, 0); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_ATU_CTL, 0);
} }
/* Offset 0x0D: (Priority) Override Register */ /* Offset 0x0D: (Priority) Override Register */
int mv88e6xxx_port_disable_pri_override(struct mv88e6xxx_chip *chip, int port) int mv88e6xxx_port_disable_pri_override(struct mv88e6xxx_chip *chip, int port)
{ {
return mv88e6xxx_port_write(chip, port, PORT_PRI_OVERRIDE, 0); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_PRI_OVERRIDE, 0);
} }
/* Offset 0x0f: Port Ether type */ /* Offset 0x0f: Port Ether type */
...@@ -871,7 +888,7 @@ int mv88e6xxx_port_disable_pri_override(struct mv88e6xxx_chip *chip, int port) ...@@ -871,7 +888,7 @@ int mv88e6xxx_port_disable_pri_override(struct mv88e6xxx_chip *chip, int port)
int mv88e6351_port_set_ether_type(struct mv88e6xxx_chip *chip, int port, int mv88e6351_port_set_ether_type(struct mv88e6xxx_chip *chip, int port,
u16 etype) u16 etype)
{ {
return mv88e6xxx_port_write(chip, port, PORT_ETH_TYPE, etype); return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_ETH_TYPE, etype);
} }
/* Offset 0x18: Port IEEE Priority Remapping Registers [0-3] /* Offset 0x18: Port IEEE Priority Remapping Registers [0-3]
...@@ -883,11 +900,15 @@ int mv88e6095_port_tag_remap(struct mv88e6xxx_chip *chip, int port) ...@@ -883,11 +900,15 @@ int mv88e6095_port_tag_remap(struct mv88e6xxx_chip *chip, int port)
int err; int err;
/* Use a direct priority mapping for all IEEE tagged frames */ /* Use a direct priority mapping for all IEEE tagged frames */
err = mv88e6xxx_port_write(chip, port, PORT_TAG_REGMAP_0123, 0x3210); err = mv88e6xxx_port_write(chip, port,
MV88E6095_PORT_IEEE_PRIO_REMAP_0123,
0x3210);
if (err) if (err)
return err; return err;
return mv88e6xxx_port_write(chip, port, PORT_TAG_REGMAP_4567, 0x7654); return mv88e6xxx_port_write(chip, port,
MV88E6095_PORT_IEEE_PRIO_REMAP_4567,
0x7654);
} }
static int mv88e6xxx_port_ieeepmt_write(struct mv88e6xxx_chip *chip, static int mv88e6xxx_port_ieeepmt_write(struct mv88e6xxx_chip *chip,
...@@ -896,40 +917,39 @@ static int mv88e6xxx_port_ieeepmt_write(struct mv88e6xxx_chip *chip, ...@@ -896,40 +917,39 @@ static int mv88e6xxx_port_ieeepmt_write(struct mv88e6xxx_chip *chip,
{ {
u16 reg; u16 reg;
reg = PORT_IEEE_PRIO_MAP_TABLE_UPDATE | reg = MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_UPDATE |
table | table |
(pointer << PORT_IEEE_PRIO_MAP_TABLE_POINTER_SHIFT) | (pointer << MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_POINTER_SHIFT) |
data; data;
return mv88e6xxx_port_write(chip, port, PORT_IEEE_PRIO_MAP_TABLE, reg); return mv88e6xxx_port_write(chip, port,
MV88E6390_PORT_IEEE_PRIO_MAP_TABLE, reg);
} }
int mv88e6390_port_tag_remap(struct mv88e6xxx_chip *chip, int port) int mv88e6390_port_tag_remap(struct mv88e6xxx_chip *chip, int port)
{ {
int err, i; int err, i;
u16 table;
for (i = 0; i <= 7; i++) { for (i = 0; i <= 7; i++) {
err = mv88e6xxx_port_ieeepmt_write( table = MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_INGRESS_PCP;
chip, port, PORT_IEEE_PRIO_MAP_TABLE_INGRESS_PCP, err = mv88e6xxx_port_ieeepmt_write(chip, port, table, i,
i, (i | i << 4)); (i | i << 4));
if (err) if (err)
return err; return err;
err = mv88e6xxx_port_ieeepmt_write( table = MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_GREEN_PCP;
chip, port, PORT_IEEE_PRIO_MAP_TABLE_EGRESS_GREEN_PCP, err = mv88e6xxx_port_ieeepmt_write(chip, port, table, i, i);
i, i);
if (err) if (err)
return err; return err;
err = mv88e6xxx_port_ieeepmt_write( table = MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_YELLOW_PCP;
chip, port, PORT_IEEE_PRIO_MAP_TABLE_EGRESS_YELLOW_PCP, err = mv88e6xxx_port_ieeepmt_write(chip, port, table, i, i);
i, i);
if (err) if (err)
return err; return err;
err = mv88e6xxx_port_ieeepmt_write( table = MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_AVB_PCP;
chip, port, PORT_IEEE_PRIO_MAP_TABLE_EGRESS_AVB_PCP, err = mv88e6xxx_port_ieeepmt_write(chip, port, table, i, i);
i, i);
if (err) if (err)
return err; return err;
} }
......
...@@ -17,166 +17,225 @@ ...@@ -17,166 +17,225 @@
#include "chip.h" #include "chip.h"
#define PORT_STATUS 0x00 /* Offset 0x00: Port Status Register */
#define PORT_STATUS_PAUSE_EN BIT(15) #define MV88E6XXX_PORT_STS 0x00
#define PORT_STATUS_MY_PAUSE BIT(14) #define MV88E6XXX_PORT_STS_PAUSE_EN 0x8000
#define PORT_STATUS_HD_FLOW BIT(13) #define MV88E6XXX_PORT_STS_MY_PAUSE 0x4000
#define PORT_STATUS_PHY_DETECT BIT(12) #define MV88E6XXX_PORT_STS_HD_FLOW 0x2000
#define PORT_STATUS_LINK BIT(11) #define MV88E6XXX_PORT_STS_PHY_DETECT 0x1000
#define PORT_STATUS_DUPLEX BIT(10) #define MV88E6XXX_PORT_STS_LINK 0x0800
#define PORT_STATUS_SPEED_MASK 0x0300 #define MV88E6XXX_PORT_STS_DUPLEX 0x0400
#define PORT_STATUS_SPEED_10 0x0000 #define MV88E6XXX_PORT_STS_SPEED_MASK 0x0300
#define PORT_STATUS_SPEED_100 0x0100 #define MV88E6XXX_PORT_STS_SPEED_10 0x0000
#define PORT_STATUS_SPEED_1000 0x0200 #define MV88E6XXX_PORT_STS_SPEED_100 0x0100
#define PORT_STATUS_EEE BIT(6) /* 6352 */ #define MV88E6XXX_PORT_STS_SPEED_1000 0x0200
#define PORT_STATUS_AM_DIS BIT(6) /* 6165 */ #define MV88E6352_PORT_STS_EEE 0x0040
#define PORT_STATUS_MGMII BIT(6) /* 6185 */ #define MV88E6165_PORT_STS_AM_DIS 0x0040
#define PORT_STATUS_TX_PAUSED BIT(5) #define MV88E6185_PORT_STS_MGMII 0x0040
#define PORT_STATUS_FLOW_CTRL BIT(4) #define MV88E6XXX_PORT_STS_TX_PAUSED 0x0020
#define PORT_STATUS_CMODE_MASK 0x0f #define MV88E6XXX_PORT_STS_FLOW_CTL 0x0010
#define PORT_STATUS_CMODE_100BASE_X 0x8 #define MV88E6XXX_PORT_STS_CMODE_MASK 0x000f
#define PORT_STATUS_CMODE_1000BASE_X 0x9 #define MV88E6XXX_PORT_STS_CMODE_100BASE_X 0x0008
#define PORT_STATUS_CMODE_SGMII 0xa #define MV88E6XXX_PORT_STS_CMODE_1000BASE_X 0x0009
#define PORT_STATUS_CMODE_2500BASEX 0xb #define MV88E6XXX_PORT_STS_CMODE_SGMII 0x000a
#define PORT_STATUS_CMODE_XAUI 0xc #define MV88E6XXX_PORT_STS_CMODE_2500BASEX 0x000b
#define PORT_STATUS_CMODE_RXAUI 0xd #define MV88E6XXX_PORT_STS_CMODE_XAUI 0x000c
#define PORT_PCS_CTRL 0x01 #define MV88E6XXX_PORT_STS_CMODE_RXAUI 0x000d
#define PORT_PCS_CTRL_RGMII_DELAY_RXCLK BIT(15)
#define PORT_PCS_CTRL_RGMII_DELAY_TXCLK BIT(14) /* Offset 0x01: MAC (or PCS or Physical) Control Register */
#define PORT_PCS_CTRL_FORCE_SPEED BIT(13) /* 6390 */ #define MV88E6XXX_PORT_MAC_CTL 0x01
#define PORT_PCS_CTRL_ALTSPEED BIT(12) /* 6390 */ #define MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_RXCLK 0x8000
#define PORT_PCS_CTRL_200BASE BIT(12) /* 6352 */ #define MV88E6XXX_PORT_MAC_CTL_RGMII_DELAY_TXCLK 0x4000
#define PORT_PCS_CTRL_FC BIT(7) #define MV88E6390_PORT_MAC_CTL_FORCE_SPEED 0x2000
#define PORT_PCS_CTRL_FORCE_FC BIT(6) #define MV88E6390_PORT_MAC_CTL_ALTSPEED 0x1000
#define PORT_PCS_CTRL_LINK_UP BIT(5) #define MV88E6352_PORT_MAC_CTL_200BASE 0x1000
#define PORT_PCS_CTRL_FORCE_LINK BIT(4) #define MV88E6XXX_PORT_MAC_CTL_FC 0x0080
#define PORT_PCS_CTRL_DUPLEX_FULL BIT(3) #define MV88E6XXX_PORT_MAC_CTL_FORCE_FC 0x0040
#define PORT_PCS_CTRL_FORCE_DUPLEX BIT(2) #define MV88E6XXX_PORT_MAC_CTL_LINK_UP 0x0020
#define PORT_PCS_CTRL_SPEED_MASK (0x03) #define MV88E6XXX_PORT_MAC_CTL_FORCE_LINK 0x0010
#define PORT_PCS_CTRL_SPEED_10 (0x00) #define MV88E6XXX_PORT_MAC_CTL_DUPLEX_FULL 0x0008
#define PORT_PCS_CTRL_SPEED_100 (0x01) #define MV88E6XXX_PORT_MAC_CTL_FORCE_DUPLEX 0x0004
#define PORT_PCS_CTRL_SPEED_200 (0x02) /* 6065 and non Gb chips */ #define MV88E6XXX_PORT_MAC_CTL_SPEED_MASK 0x0003
#define PORT_PCS_CTRL_SPEED_1000 (0x02) #define MV88E6XXX_PORT_MAC_CTL_SPEED_10 0x0000
#define PORT_PCS_CTRL_SPEED_10000 (0x03) /* 6390X */ #define MV88E6XXX_PORT_MAC_CTL_SPEED_100 0x0001
#define PORT_PCS_CTRL_SPEED_UNFORCED (0x03) #define MV88E6065_PORT_MAC_CTL_SPEED_200 0x0002
#define PORT_PAUSE_CTRL 0x02 #define MV88E6XXX_PORT_MAC_CTL_SPEED_1000 0x0002
#define PORT_FLOW_CTRL_LIMIT_IN ((0x00 << 8) | BIT(15)) #define MV88E6390_PORT_MAC_CTL_SPEED_10000 0x0003
#define PORT_FLOW_CTRL_LIMIT_OUT ((0x01 << 8) | BIT(15)) #define MV88E6XXX_PORT_MAC_CTL_SPEED_UNFORCED 0x0003
#define PORT_SWITCH_ID 0x03
#define PORT_SWITCH_ID_PROD_NUM_6085 0x04a /* Offset 0x02: Jamming Control Register */
#define PORT_SWITCH_ID_PROD_NUM_6095 0x095 #define MV88E6097_PORT_JAM_CTL 0x02
#define PORT_SWITCH_ID_PROD_NUM_6097 0x099 #define MV88E6097_PORT_JAM_CTL_LIMIT_OUT_MASK 0xff00
#define PORT_SWITCH_ID_PROD_NUM_6131 0x106 #define MV88E6097_PORT_JAM_CTL_LIMIT_IN_MASK 0x00ff
#define PORT_SWITCH_ID_PROD_NUM_6320 0x115
#define PORT_SWITCH_ID_PROD_NUM_6123 0x121 /* Offset 0x02: Flow Control Register */
#define PORT_SWITCH_ID_PROD_NUM_6141 0x340 #define MV88E6390_PORT_FLOW_CTL 0x02
#define PORT_SWITCH_ID_PROD_NUM_6161 0x161 #define MV88E6390_PORT_FLOW_CTL_UPDATE 0x8000
#define PORT_SWITCH_ID_PROD_NUM_6165 0x165 #define MV88E6390_PORT_FLOW_CTL_PTR_MASK 0x7f00
#define PORT_SWITCH_ID_PROD_NUM_6171 0x171 #define MV88E6390_PORT_FLOW_CTL_LIMIT_IN 0x0000
#define PORT_SWITCH_ID_PROD_NUM_6172 0x172 #define MV88E6390_PORT_FLOW_CTL_LIMIT_OUT 0x0100
#define PORT_SWITCH_ID_PROD_NUM_6175 0x175 #define MV88E6390_PORT_FLOW_CTL_DATA_MASK 0x00ff
#define PORT_SWITCH_ID_PROD_NUM_6176 0x176
#define PORT_SWITCH_ID_PROD_NUM_6185 0x1a7 /* Offset 0x03: Switch Identifier Register */
#define PORT_SWITCH_ID_PROD_NUM_6190 0x190 #define MV88E6XXX_PORT_SWITCH_ID 0x03
#define PORT_SWITCH_ID_PROD_NUM_6190X 0x0a0 #define MV88E6XXX_PORT_SWITCH_ID_PROD_MASK 0xfff0
#define PORT_SWITCH_ID_PROD_NUM_6191 0x191 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6085 0x04a0
#define PORT_SWITCH_ID_PROD_NUM_6240 0x240 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6095 0x0950
#define PORT_SWITCH_ID_PROD_NUM_6290 0x290 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6097 0x0990
#define PORT_SWITCH_ID_PROD_NUM_6321 0x310 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6190X 0x0a00
#define PORT_SWITCH_ID_PROD_NUM_6341 0x341 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6390X 0x0a10
#define PORT_SWITCH_ID_PROD_NUM_6352 0x352 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6131 0x1060
#define PORT_SWITCH_ID_PROD_NUM_6350 0x371 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6320 0x1150
#define PORT_SWITCH_ID_PROD_NUM_6351 0x375 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6123 0x1210
#define PORT_SWITCH_ID_PROD_NUM_6390 0x390 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6161 0x1610
#define PORT_SWITCH_ID_PROD_NUM_6390X 0x0a1 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6165 0x1650
#define PORT_CONTROL 0x04 #define MV88E6XXX_PORT_SWITCH_ID_PROD_6171 0x1710
#define PORT_CONTROL_USE_CORE_TAG BIT(15) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6172 0x1720
#define PORT_CONTROL_DROP_ON_LOCK BIT(14) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6175 0x1750
#define PORT_CONTROL_EGRESS_UNMODIFIED (0x0 << 12) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6176 0x1760
#define PORT_CONTROL_EGRESS_UNTAGGED (0x1 << 12) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6190 0x1900
#define PORT_CONTROL_EGRESS_TAGGED (0x2 << 12) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6191 0x1910
#define PORT_CONTROL_EGRESS_ADD_TAG (0x3 << 12) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6185 0x1a70
#define PORT_CONTROL_EGRESS_MASK (0x3 << 12) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6240 0x2400
#define PORT_CONTROL_HEADER BIT(11) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6290 0x2900
#define PORT_CONTROL_IGMP_MLD_SNOOP BIT(10) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6321 0x3100
#define PORT_CONTROL_DOUBLE_TAG BIT(9) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6141 0x3400
#define PORT_CONTROL_FRAME_MODE_NORMAL (0x0 << 8) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6341 0x3410
#define PORT_CONTROL_FRAME_MODE_DSA (0x1 << 8) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6352 0x3520
#define PORT_CONTROL_FRAME_MODE_PROVIDER (0x2 << 8) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6350 0x3710
#define PORT_CONTROL_FRAME_ETHER_TYPE_DSA (0x3 << 8) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6351 0x3750
#define PORT_CONTROL_FRAME_MASK (0x3 << 8) #define MV88E6XXX_PORT_SWITCH_ID_PROD_6390 0x3900
#define PORT_CONTROL_DSA_TAG BIT(8) #define MV88E6XXX_PORT_SWITCH_ID_REV_MASK 0x000f
#define PORT_CONTROL_VLAN_TUNNEL BIT(7)
#define PORT_CONTROL_TAG_IF_BOTH BIT(6) /* Offset 0x04: Port Control Register */
#define PORT_CONTROL_USE_IP BIT(5) #define MV88E6XXX_PORT_CTL0 0x04
#define PORT_CONTROL_USE_TAG BIT(4) #define MV88E6XXX_PORT_CTL0_USE_CORE_TAG 0x8000
#define PORT_CONTROL_FORWARD_UNKNOWN BIT(2) #define MV88E6XXX_PORT_CTL0_DROP_ON_LOCK 0x4000
#define PORT_CONTROL_EGRESS_FLOODS_MASK (0x3 << 2) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_MASK 0x3000
#define PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_DA (0x0 << 2) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_UNMODIFIED 0x0000
#define PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_MC_DA (0x1 << 2) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_UNTAGGED 0x1000
#define PORT_CONTROL_EGRESS_FLOODS_NO_UNKNOWN_UC_DA (0x2 << 2) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_TAGGED 0x2000
#define PORT_CONTROL_EGRESS_FLOODS_ALL_UNKNOWN_DA (0x3 << 2) #define MV88E6XXX_PORT_CTL0_EGRESS_MODE_ETHER_TYPE_DSA 0x3000
#define PORT_CONTROL_STATE_MASK 0x03 #define MV88E6XXX_PORT_CTL0_HEADER 0x0800
#define PORT_CONTROL_STATE_DISABLED 0x00 #define MV88E6XXX_PORT_CTL0_IGMP_MLD_SNOOP 0x0400
#define PORT_CONTROL_STATE_BLOCKING 0x01 #define MV88E6XXX_PORT_CTL0_DOUBLE_TAG 0x0200
#define PORT_CONTROL_STATE_LEARNING 0x02 #define MV88E6XXX_PORT_CTL0_FRAME_MODE_MASK 0x0300
#define PORT_CONTROL_STATE_FORWARDING 0x03 #define MV88E6XXX_PORT_CTL0_FRAME_MODE_NORMAL 0x0000
#define PORT_CONTROL_1 0x05 #define MV88E6XXX_PORT_CTL0_FRAME_MODE_DSA 0x0100
#define PORT_CONTROL_1_MESSAGE_PORT BIT(15) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_PROVIDER 0x0200
#define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0) #define MV88E6XXX_PORT_CTL0_FRAME_MODE_ETHER_TYPE_DSA 0x0300
#define PORT_BASE_VLAN 0x06 #define MV88E6XXX_PORT_CTL0_DSA_TAG 0x0100
#define PORT_BASE_VLAN_FID_3_0_MASK (0xf << 12) #define MV88E6XXX_PORT_CTL0_VLAN_TUNNEL 0x0080
#define PORT_DEFAULT_VLAN 0x07 #define MV88E6XXX_PORT_CTL0_TAG_IF_BOTH 0x0040
#define PORT_DEFAULT_VLAN_MASK 0xfff #define MV88E6185_PORT_CTL0_USE_IP 0x0020
#define PORT_CONTROL_2 0x08 #define MV88E6185_PORT_CTL0_USE_TAG 0x0010
#define PORT_CONTROL_2_IGNORE_FCS BIT(15) #define MV88E6185_PORT_CTL0_FORWARD_UNKNOWN 0x0004
#define PORT_CONTROL_2_VTU_PRI_OVERRIDE BIT(14) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_MASK 0x000c
#define PORT_CONTROL_2_SA_PRIO_OVERRIDE BIT(13) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_DA 0x0000
#define PORT_CONTROL_2_DA_PRIO_OVERRIDE BIT(12) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_MC_DA 0x0004
#define PORT_CONTROL_2_JUMBO_MASK (0x03 << 12) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_NO_UNKNOWN_UC_DA 0x0008
#define PORT_CONTROL_2_JUMBO_1522 (0x00 << 12) #define MV88E6352_PORT_CTL0_EGRESS_FLOODS_ALL_UNKNOWN_DA 0x000c
#define PORT_CONTROL_2_JUMBO_2048 (0x01 << 12) #define MV88E6XXX_PORT_CTL0_STATE_MASK 0x0003
#define PORT_CONTROL_2_JUMBO_10240 (0x02 << 12) #define MV88E6XXX_PORT_CTL0_STATE_DISABLED 0x0000
#define PORT_CONTROL_2_8021Q_MASK (0x03 << 10) #define MV88E6XXX_PORT_CTL0_STATE_BLOCKING 0x0001
#define PORT_CONTROL_2_8021Q_DISABLED (0x00 << 10) #define MV88E6XXX_PORT_CTL0_STATE_LEARNING 0x0002
#define PORT_CONTROL_2_8021Q_FALLBACK (0x01 << 10) #define MV88E6XXX_PORT_CTL0_STATE_FORWARDING 0x0003
#define PORT_CONTROL_2_8021Q_CHECK (0x02 << 10)
#define PORT_CONTROL_2_8021Q_SECURE (0x03 << 10) /* Offset 0x05: Port Control 1 */
#define PORT_CONTROL_2_DISCARD_TAGGED BIT(9) #define MV88E6XXX_PORT_CTL1 0x05
#define PORT_CONTROL_2_DISCARD_UNTAGGED BIT(8) #define MV88E6XXX_PORT_CTL1_MESSAGE_PORT 0x8000
#define PORT_CONTROL_2_MAP_DA BIT(7) #define MV88E6XXX_PORT_CTL1_FID_11_4_MASK 0x00ff
#define PORT_CONTROL_2_DEFAULT_FORWARD BIT(6)
#define PORT_CONTROL_2_EGRESS_MONITOR BIT(5) /* Offset 0x06: Port Based VLAN Map */
#define PORT_CONTROL_2_INGRESS_MONITOR BIT(4) #define MV88E6XXX_PORT_BASE_VLAN 0x06
#define PORT_CONTROL_2_UPSTREAM_MASK 0x0f #define MV88E6XXX_PORT_BASE_VLAN_FID_3_0_MASK 0xf000
#define PORT_RATE_CONTROL 0x09
#define PORT_RATE_CONTROL_2 0x0a /* Offset 0x07: Default Port VLAN ID & Priority */
#define PORT_ASSOC_VECTOR 0x0b #define MV88E6XXX_PORT_DEFAULT_VLAN 0x07
#define PORT_ASSOC_VECTOR_HOLD_AT_1 BIT(15) #define MV88E6XXX_PORT_DEFAULT_VLAN_MASK 0x0fff
#define PORT_ASSOC_VECTOR_INT_AGE_OUT BIT(14)
#define PORT_ASSOC_VECTOR_LOCKED_PORT BIT(13) /* Offset 0x08: Port Control 2 Register */
#define PORT_ASSOC_VECTOR_IGNORE_WRONG BIT(12) #define MV88E6XXX_PORT_CTL2 0x08
#define PORT_ASSOC_VECTOR_REFRESH_LOCKED BIT(11) #define MV88E6XXX_PORT_CTL2_IGNORE_FCS 0x8000
#define PORT_ATU_CONTROL 0x0c #define MV88E6XXX_PORT_CTL2_VTU_PRI_OVERRIDE 0x4000
#define PORT_PRI_OVERRIDE 0x0d #define MV88E6XXX_PORT_CTL2_SA_PRIO_OVERRIDE 0x2000
#define PORT_ETH_TYPE 0x0f #define MV88E6XXX_PORT_CTL2_DA_PRIO_OVERRIDE 0x1000
#define PORT_ETH_TYPE_DEFAULT 0x9100 #define MV88E6XXX_PORT_CTL2_JUMBO_MODE_MASK 0x3000
#define PORT_IN_DISCARD_LO 0x10 #define MV88E6XXX_PORT_CTL2_JUMBO_MODE_1522 0x0000
#define PORT_IN_DISCARD_HI 0x11 #define MV88E6XXX_PORT_CTL2_JUMBO_MODE_2048 0x1000
#define PORT_IN_FILTERED 0x12 #define MV88E6XXX_PORT_CTL2_JUMBO_MODE_10240 0x2000
#define PORT_OUT_FILTERED 0x13 #define MV88E6XXX_PORT_CTL2_8021Q_MODE_MASK 0x0c00
#define PORT_TAG_REGMAP_0123 0x18 #define MV88E6XXX_PORT_CTL2_8021Q_MODE_DISABLED 0x0000
#define PORT_TAG_REGMAP_4567 0x19 #define MV88E6XXX_PORT_CTL2_8021Q_MODE_FALLBACK 0x0400
#define PORT_IEEE_PRIO_MAP_TABLE 0x18 /* 6390 */ #define MV88E6XXX_PORT_CTL2_8021Q_MODE_CHECK 0x0800
#define PORT_IEEE_PRIO_MAP_TABLE_UPDATE BIT(15) #define MV88E6XXX_PORT_CTL2_8021Q_MODE_SECURE 0x0c00
#define PORT_IEEE_PRIO_MAP_TABLE_INGRESS_PCP (0x0 << 12) #define MV88E6XXX_PORT_CTL2_DISCARD_TAGGED 0x0200
#define PORT_IEEE_PRIO_MAP_TABLE_EGRESS_GREEN_PCP (0x1 << 12) #define MV88E6XXX_PORT_CTL2_DISCARD_UNTAGGED 0x0100
#define PORT_IEEE_PRIO_MAP_TABLE_EGRESS_YELLOW_PCP (0x2 << 12) #define MV88E6XXX_PORT_CTL2_MAP_DA 0x0080
#define PORT_IEEE_PRIO_MAP_TABLE_EGRESS_AVB_PCP (0x3 << 12) #define MV88E6XXX_PORT_CTL2_DEFAULT_FORWARD 0x0040
#define PORT_IEEE_PRIO_MAP_TABLE_EGRESS_GREEN_DSCP (0x5 << 12) #define MV88E6XXX_PORT_CTL2_EGRESS_MONITOR 0x0020
#define PORT_IEEE_PRIO_MAP_TABLE_EGRESS_YELLOW_DSCP (0x6 << 12) #define MV88E6XXX_PORT_CTL2_INGRESS_MONITOR 0x0010
#define PORT_IEEE_PRIO_MAP_TABLE_EGRESS_AVB_DSCP (0x7 << 12) #define MV88E6095_PORT_CTL2_CPU_PORT_MASK 0x000f
#define PORT_IEEE_PRIO_MAP_TABLE_POINTER_SHIFT 9
/* Offset 0x09: Egress Rate Control */
#define MV88E6XXX_PORT_EGRESS_RATE_CTL1 0x09
/* Offset 0x0A: Egress Rate Control 2 */
#define MV88E6XXX_PORT_EGRESS_RATE_CTL2 0x0a
/* Offset 0x0B: Port Association Vector */
#define MV88E6XXX_PORT_ASSOC_VECTOR 0x0b
#define MV88E6XXX_PORT_ASSOC_VECTOR_HOLD_AT_1 0x8000
#define MV88E6XXX_PORT_ASSOC_VECTOR_INT_AGE_OUT 0x4000
#define MV88E6XXX_PORT_ASSOC_VECTOR_LOCKED_PORT 0x2000
#define MV88E6XXX_PORT_ASSOC_VECTOR_IGNORE_WRONG 0x1000
#define MV88E6XXX_PORT_ASSOC_VECTOR_REFRESH_LOCKED 0x0800
/* Offset 0x0C: Port ATU Control */
#define MV88E6XXX_PORT_ATU_CTL 0x0c
/* Offset 0x0D: Priority Override Register */
#define MV88E6XXX_PORT_PRI_OVERRIDE 0x0d
/* Offset 0x0E: Policy Control Register */
#define MV88E6XXX_PORT_POLICY_CTL 0x0e
/* Offset 0x0F: Port Special Ether Type */
#define MV88E6XXX_PORT_ETH_TYPE 0x0f
#define MV88E6XXX_PORT_ETH_TYPE_DEFAULT 0x9100
/* Offset 0x10: InDiscards Low Counter */
#define MV88E6XXX_PORT_IN_DISCARD_LO 0x10
/* Offset 0x11: InDiscards High Counter */
#define MV88E6XXX_PORT_IN_DISCARD_HI 0x11
/* Offset 0x12: InFiltered Counter */
#define MV88E6XXX_PORT_IN_FILTERED 0x12
/* Offset 0x13: OutFiltered Counter */
#define MV88E6XXX_PORT_OUT_FILTERED 0x13
/* Offset 0x16: LED Control */
#define MV88E6XXX_PORT_LED_CONTROL 0x16
/* Offset 0x18: IEEE Priority Mapping Table */
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE 0x18
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_UPDATE 0x8000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_INGRESS_PCP 0x0000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_GREEN_PCP 0x1000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_YELLOW_PCP 0x2000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_AVB_PCP 0x3000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_GREEN_DSCP 0x5000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_YELLOW_DSCP 0x6000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_EGRESS_AVB_DSCP 0x7000
#define MV88E6390_PORT_IEEE_PRIO_MAP_TABLE_POINTER_SHIFT 9
/* Offset 0x18: Port IEEE Priority Remapping Registers (0-3) */
#define MV88E6095_PORT_IEEE_PRIO_REMAP_0123 0x18
/* Offset 0x19: Port IEEE Priority Remapping Registers (4-7) */
#define MV88E6095_PORT_IEEE_PRIO_REMAP_4567 0x19
int mv88e6xxx_port_read(struct mv88e6xxx_chip *chip, int port, int reg, int mv88e6xxx_port_read(struct mv88e6xxx_chip *chip, int port, int reg,
u16 *val); u16 *val);
......
...@@ -64,9 +64,9 @@ int mv88e6352_serdes_power(struct mv88e6xxx_chip *chip, int port, bool on) ...@@ -64,9 +64,9 @@ int mv88e6352_serdes_power(struct mv88e6xxx_chip *chip, int port, bool on)
if (err) if (err)
return err; return err;
if ((cmode == PORT_STATUS_CMODE_100BASE_X) || if ((cmode == MV88E6XXX_PORT_STS_CMODE_100BASE_X) ||
(cmode == PORT_STATUS_CMODE_1000BASE_X) || (cmode == MV88E6XXX_PORT_STS_CMODE_1000BASE_X) ||
(cmode == PORT_STATUS_CMODE_SGMII)) { (cmode == MV88E6XXX_PORT_STS_CMODE_SGMII)) {
err = mv88e6352_serdes_power_set(chip, on); err = mv88e6352_serdes_power_set(chip, on);
if (err < 0) if (err < 0)
return err; return err;
...@@ -139,15 +139,15 @@ static int mv88e6390_serdes_lower(struct mv88e6xxx_chip *chip, u8 cmode, ...@@ -139,15 +139,15 @@ static int mv88e6390_serdes_lower(struct mv88e6xxx_chip *chip, u8 cmode,
return err; return err;
switch (cmode_donor) { switch (cmode_donor) {
case PORT_STATUS_CMODE_RXAUI: case MV88E6XXX_PORT_STS_CMODE_RXAUI:
if (!rxaui) if (!rxaui)
break; break;
/* Fall through */ /* Fall through */
case PORT_STATUS_CMODE_1000BASE_X: case MV88E6XXX_PORT_STS_CMODE_1000BASE_X:
case PORT_STATUS_CMODE_SGMII: case MV88E6XXX_PORT_STS_CMODE_SGMII:
case PORT_STATUS_CMODE_2500BASEX: case MV88E6XXX_PORT_STS_CMODE_2500BASEX:
if (cmode == PORT_STATUS_CMODE_1000BASE_X || if (cmode == MV88E6XXX_PORT_STS_CMODE_1000BASE_X ||
cmode == PORT_STATUS_CMODE_SGMII) cmode == MV88E6XXX_PORT_STS_CMODE_SGMII)
return mv88e6390_serdes_sgmii(chip, lane, on); return mv88e6390_serdes_sgmii(chip, lane, on);
} }
return 0; return 0;
...@@ -157,12 +157,12 @@ static int mv88e6390_serdes_port9(struct mv88e6xxx_chip *chip, u8 cmode, ...@@ -157,12 +157,12 @@ static int mv88e6390_serdes_port9(struct mv88e6xxx_chip *chip, u8 cmode,
bool on) bool on)
{ {
switch (cmode) { switch (cmode) {
case PORT_STATUS_CMODE_1000BASE_X: case MV88E6XXX_PORT_STS_CMODE_1000BASE_X:
case PORT_STATUS_CMODE_SGMII: case MV88E6XXX_PORT_STS_CMODE_SGMII:
return mv88e6390_serdes_sgmii(chip, MV88E6390_PORT9_LANE0, on); return mv88e6390_serdes_sgmii(chip, MV88E6390_PORT9_LANE0, on);
case PORT_STATUS_CMODE_XAUI: case MV88E6XXX_PORT_STS_CMODE_XAUI:
case PORT_STATUS_CMODE_RXAUI: case MV88E6XXX_PORT_STS_CMODE_RXAUI:
case PORT_STATUS_CMODE_2500BASEX: case MV88E6XXX_PORT_STS_CMODE_2500BASEX:
return mv88e6390_serdes_10g(chip, MV88E6390_PORT9_LANE0, on); return mv88e6390_serdes_10g(chip, MV88E6390_PORT9_LANE0, on);
} }
...@@ -173,12 +173,12 @@ static int mv88e6390_serdes_port10(struct mv88e6xxx_chip *chip, u8 cmode, ...@@ -173,12 +173,12 @@ static int mv88e6390_serdes_port10(struct mv88e6xxx_chip *chip, u8 cmode,
bool on) bool on)
{ {
switch (cmode) { switch (cmode) {
case PORT_STATUS_CMODE_SGMII: case MV88E6XXX_PORT_STS_CMODE_SGMII:
return mv88e6390_serdes_sgmii(chip, MV88E6390_PORT10_LANE0, on); return mv88e6390_serdes_sgmii(chip, MV88E6390_PORT10_LANE0, on);
case PORT_STATUS_CMODE_XAUI: case MV88E6XXX_PORT_STS_CMODE_XAUI:
case PORT_STATUS_CMODE_RXAUI: case MV88E6XXX_PORT_STS_CMODE_RXAUI:
case PORT_STATUS_CMODE_1000BASE_X: case MV88E6XXX_PORT_STS_CMODE_1000BASE_X:
case PORT_STATUS_CMODE_2500BASEX: case MV88E6XXX_PORT_STS_CMODE_2500BASEX:
return mv88e6390_serdes_10g(chip, MV88E6390_PORT10_LANE0, on); return mv88e6390_serdes_10g(chip, MV88E6390_PORT10_LANE0, on);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment