|
@@ -17,7 +17,7 @@
|
|
|
|
|
|
static int mv88e6xxx_g1_atu_fid_write(struct mv88e6xxx_chip *chip, u16 fid)
|
|
|
{
|
|
|
- return mv88e6xxx_g1_write(chip, GLOBAL_ATU_FID, fid & 0xfff);
|
|
|
+ return mv88e6xxx_g1_write(chip, MV88E6352_G1_ATU_FID, fid & 0xfff);
|
|
|
}
|
|
|
|
|
|
/* Offset 0x0A: ATU Control Register */
|
|
@@ -27,16 +27,16 @@ int mv88e6xxx_g1_atu_set_learn2all(struct mv88e6xxx_chip *chip, bool learn2all)
|
|
|
u16 val;
|
|
|
int err;
|
|
|
|
|
|
- err = mv88e6xxx_g1_read(chip, GLOBAL_ATU_CONTROL, &val);
|
|
|
+ err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_ATU_CTL, &val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
|
if (learn2all)
|
|
|
- val |= GLOBAL_ATU_CONTROL_LEARN2ALL;
|
|
|
+ val |= MV88E6XXX_G1_ATU_CTL_LEARN2ALL;
|
|
|
else
|
|
|
- val &= ~GLOBAL_ATU_CONTROL_LEARN2ALL;
|
|
|
+ val &= ~MV88E6XXX_G1_ATU_CTL_LEARN2ALL;
|
|
|
|
|
|
- return mv88e6xxx_g1_write(chip, GLOBAL_ATU_CONTROL, val);
|
|
|
+ return mv88e6xxx_g1_write(chip, MV88E6XXX_G1_ATU_CTL, val);
|
|
|
}
|
|
|
|
|
|
int mv88e6xxx_g1_atu_set_age_time(struct mv88e6xxx_chip *chip,
|
|
@@ -55,7 +55,7 @@ int mv88e6xxx_g1_atu_set_age_time(struct mv88e6xxx_chip *chip,
|
|
|
/* Round to nearest multiple of coeff */
|
|
|
age_time = (msecs + coeff / 2) / coeff;
|
|
|
|
|
|
- err = mv88e6xxx_g1_read(chip, GLOBAL_ATU_CONTROL, &val);
|
|
|
+ err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_ATU_CTL, &val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
@@ -63,7 +63,7 @@ int mv88e6xxx_g1_atu_set_age_time(struct mv88e6xxx_chip *chip,
|
|
|
val &= ~0xff0;
|
|
|
val |= age_time << 4;
|
|
|
|
|
|
- err = mv88e6xxx_g1_write(chip, GLOBAL_ATU_CONTROL, val);
|
|
|
+ err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_ATU_CTL, val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
@@ -77,7 +77,8 @@ int mv88e6xxx_g1_atu_set_age_time(struct mv88e6xxx_chip *chip,
|
|
|
|
|
|
static int mv88e6xxx_g1_atu_op_wait(struct mv88e6xxx_chip *chip)
|
|
|
{
|
|
|
- return mv88e6xxx_g1_wait(chip, GLOBAL_ATU_OP, GLOBAL_ATU_OP_BUSY);
|
|
|
+ return mv88e6xxx_g1_wait(chip, MV88E6XXX_G1_ATU_OP,
|
|
|
+ MV88E6XXX_G1_ATU_OP_BUSY);
|
|
|
}
|
|
|
|
|
|
static int mv88e6xxx_g1_atu_op(struct mv88e6xxx_chip *chip, u16 fid, u16 op)
|
|
@@ -93,12 +94,14 @@ static int mv88e6xxx_g1_atu_op(struct mv88e6xxx_chip *chip, u16 fid, u16 op)
|
|
|
} else {
|
|
|
if (mv88e6xxx_num_databases(chip) > 16) {
|
|
|
/* ATU DBNum[7:4] are located in ATU Control 15:12 */
|
|
|
- err = mv88e6xxx_g1_read(chip, GLOBAL_ATU_CONTROL, &val);
|
|
|
+ err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_ATU_CTL,
|
|
|
+ &val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
|
val = (val & 0x0fff) | ((fid << 8) & 0xf000);
|
|
|
- err = mv88e6xxx_g1_write(chip, GLOBAL_ATU_CONTROL, val);
|
|
|
+ err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_ATU_CTL,
|
|
|
+ val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
}
|
|
@@ -107,7 +110,8 @@ static int mv88e6xxx_g1_atu_op(struct mv88e6xxx_chip *chip, u16 fid, u16 op)
|
|
|
op |= fid & 0xf;
|
|
|
}
|
|
|
|
|
|
- err = mv88e6xxx_g1_write(chip, GLOBAL_ATU_OP, op);
|
|
|
+ err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_ATU_OP,
|
|
|
+ MV88E6XXX_G1_ATU_OP_BUSY | op);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
@@ -122,13 +126,13 @@ static int mv88e6xxx_g1_atu_data_read(struct mv88e6xxx_chip *chip,
|
|
|
u16 val;
|
|
|
int err;
|
|
|
|
|
|
- err = mv88e6xxx_g1_read(chip, GLOBAL_ATU_DATA, &val);
|
|
|
+ err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_ATU_DATA, &val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
|
entry->state = val & 0xf;
|
|
|
- if (entry->state != GLOBAL_ATU_DATA_STATE_UNUSED) {
|
|
|
- entry->trunk = !!(val & GLOBAL_ATU_DATA_TRUNK);
|
|
|
+ if (entry->state != MV88E6XXX_G1_ATU_DATA_STATE_UNUSED) {
|
|
|
+ entry->trunk = !!(val & MV88E6XXX_G1_ATU_DATA_TRUNK);
|
|
|
entry->portvec = (val >> 4) & mv88e6xxx_port_mask(chip);
|
|
|
}
|
|
|
|
|
@@ -140,14 +144,14 @@ static int mv88e6xxx_g1_atu_data_write(struct mv88e6xxx_chip *chip,
|
|
|
{
|
|
|
u16 data = entry->state & 0xf;
|
|
|
|
|
|
- if (entry->state != GLOBAL_ATU_DATA_STATE_UNUSED) {
|
|
|
+ if (entry->state != MV88E6XXX_G1_ATU_DATA_STATE_UNUSED) {
|
|
|
if (entry->trunk)
|
|
|
- data |= GLOBAL_ATU_DATA_TRUNK;
|
|
|
+ data |= MV88E6XXX_G1_ATU_DATA_TRUNK;
|
|
|
|
|
|
data |= (entry->portvec & mv88e6xxx_port_mask(chip)) << 4;
|
|
|
}
|
|
|
|
|
|
- return mv88e6xxx_g1_write(chip, GLOBAL_ATU_DATA, data);
|
|
|
+ return mv88e6xxx_g1_write(chip, MV88E6XXX_G1_ATU_DATA, data);
|
|
|
}
|
|
|
|
|
|
/* Offset 0x0D: ATU MAC Address Register Bytes 0 & 1
|
|
@@ -162,7 +166,7 @@ static int mv88e6xxx_g1_atu_mac_read(struct mv88e6xxx_chip *chip,
|
|
|
int i, err;
|
|
|
|
|
|
for (i = 0; i < 3; i++) {
|
|
|
- err = mv88e6xxx_g1_read(chip, GLOBAL_ATU_MAC_01 + i, &val);
|
|
|
+ err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_ATU_MAC01 + i, &val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
@@ -181,7 +185,7 @@ static int mv88e6xxx_g1_atu_mac_write(struct mv88e6xxx_chip *chip,
|
|
|
|
|
|
for (i = 0; i < 3; i++) {
|
|
|
val = (entry->mac[i * 2] << 8) | entry->mac[i * 2 + 1];
|
|
|
- err = mv88e6xxx_g1_write(chip, GLOBAL_ATU_MAC_01 + i, val);
|
|
|
+ err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_ATU_MAC01 + i, val);
|
|
|
if (err)
|
|
|
return err;
|
|
|
}
|
|
@@ -201,13 +205,13 @@ int mv88e6xxx_g1_atu_getnext(struct mv88e6xxx_chip *chip, u16 fid,
|
|
|
return err;
|
|
|
|
|
|
/* Write the MAC address to iterate from only once */
|
|
|
- if (entry->state == GLOBAL_ATU_DATA_STATE_UNUSED) {
|
|
|
+ if (entry->state == MV88E6XXX_G1_ATU_DATA_STATE_UNUSED) {
|
|
|
err = mv88e6xxx_g1_atu_mac_write(chip, entry);
|
|
|
if (err)
|
|
|
return err;
|
|
|
}
|
|
|
|
|
|
- err = mv88e6xxx_g1_atu_op(chip, fid, GLOBAL_ATU_OP_GET_NEXT_DB);
|
|
|
+ err = mv88e6xxx_g1_atu_op(chip, fid, MV88E6XXX_G1_ATU_OP_GET_NEXT_DB);
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
@@ -235,7 +239,7 @@ int mv88e6xxx_g1_atu_loadpurge(struct mv88e6xxx_chip *chip, u16 fid,
|
|
|
if (err)
|
|
|
return err;
|
|
|
|
|
|
- return mv88e6xxx_g1_atu_op(chip, fid, GLOBAL_ATU_OP_LOAD_DB);
|
|
|
+ return mv88e6xxx_g1_atu_op(chip, fid, MV88E6XXX_G1_ATU_OP_LOAD_DB);
|
|
|
}
|
|
|
|
|
|
static int mv88e6xxx_g1_atu_flushmove(struct mv88e6xxx_chip *chip, u16 fid,
|
|
@@ -255,13 +259,13 @@ static int mv88e6xxx_g1_atu_flushmove(struct mv88e6xxx_chip *chip, u16 fid,
|
|
|
|
|
|
/* Flush/Move all or non-static entries from all or a given database */
|
|
|
if (all && fid)
|
|
|
- op = GLOBAL_ATU_OP_FLUSH_MOVE_ALL_DB;
|
|
|
+ op = MV88E6XXX_G1_ATU_OP_FLUSH_MOVE_ALL_DB;
|
|
|
else if (fid)
|
|
|
- op = GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC_DB;
|
|
|
+ op = MV88E6XXX_G1_ATU_OP_FLUSH_MOVE_NON_STATIC_DB;
|
|
|
else if (all)
|
|
|
- op = GLOBAL_ATU_OP_FLUSH_MOVE_ALL;
|
|
|
+ op = MV88E6XXX_G1_ATU_OP_FLUSH_MOVE_ALL;
|
|
|
else
|
|
|
- op = GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC;
|
|
|
+ op = MV88E6XXX_G1_ATU_OP_FLUSH_MOVE_NON_STATIC;
|
|
|
|
|
|
return mv88e6xxx_g1_atu_op(chip, fid, op);
|
|
|
}
|