mirror of https://gitee.com/openkylin/linux.git
net: dsa: microchip: rename some functions with ksz9477 prefix
Rename some functions with ksz9477 prefix to separate chip specific code from common code. Signed-off-by: Tristram Ha <Tristram.Ha@microchip.com> Reviewed-by: Woojung Huh <Woojung.Huh@microchip.com> Reviewed-by: Pavel Machek <pavel@ucw.cz> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
9bc981c355
commit
353592781d
|
@ -253,9 +253,8 @@ static int wait_alu_sta_ready(struct ksz_device *dev, u32 waiton, int timeout)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_reset_switch(struct dsa_switch *ds)
|
static int ksz9477_reset_switch(struct ksz_device *dev)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
|
||||||
u8 data8;
|
u8 data8;
|
||||||
u16 data16;
|
u16 data16;
|
||||||
u32 data32;
|
u32 data32;
|
||||||
|
@ -288,7 +287,7 @@ static int ksz_reset_switch(struct dsa_switch *ds)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void port_setup(struct ksz_device *dev, int port, bool cpu_port)
|
static void ksz9477_port_setup(struct ksz_device *dev, int port, bool cpu_port)
|
||||||
{
|
{
|
||||||
u8 data8;
|
u8 data8;
|
||||||
u16 data16;
|
u16 data16;
|
||||||
|
@ -334,7 +333,7 @@ static void port_setup(struct ksz_device *dev, int port, bool cpu_port)
|
||||||
ksz_pread16(dev, port, REG_PORT_PHY_INT_ENABLE, &data16);
|
ksz_pread16(dev, port, REG_PORT_PHY_INT_ENABLE, &data16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ksz_config_cpu_port(struct dsa_switch *ds)
|
static void ksz9477_config_cpu_port(struct dsa_switch *ds)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
int i;
|
int i;
|
||||||
|
@ -346,12 +345,12 @@ static void ksz_config_cpu_port(struct dsa_switch *ds)
|
||||||
dev->cpu_port = i;
|
dev->cpu_port = i;
|
||||||
|
|
||||||
/* enable cpu port */
|
/* enable cpu port */
|
||||||
port_setup(dev, i, true);
|
ksz9477_port_setup(dev, i, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_setup(struct dsa_switch *ds)
|
static int ksz9477_setup(struct dsa_switch *ds)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
@ -361,7 +360,7 @@ static int ksz_setup(struct dsa_switch *ds)
|
||||||
if (!dev->vlan_cache)
|
if (!dev->vlan_cache)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
ret = ksz_reset_switch(ds);
|
ret = ksz9477_reset_switch(dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(ds->dev, "failed to reset switch\n");
|
dev_err(ds->dev, "failed to reset switch\n");
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -370,7 +369,7 @@ static int ksz_setup(struct dsa_switch *ds)
|
||||||
/* accept packet up to 2000bytes */
|
/* accept packet up to 2000bytes */
|
||||||
ksz_cfg(dev, REG_SW_MAC_CTRL_1, SW_LEGAL_PACKET_DISABLE, true);
|
ksz_cfg(dev, REG_SW_MAC_CTRL_1, SW_LEGAL_PACKET_DISABLE, true);
|
||||||
|
|
||||||
ksz_config_cpu_port(ds);
|
ksz9477_config_cpu_port(ds);
|
||||||
|
|
||||||
ksz_cfg(dev, REG_SW_MAC_CTRL_1, MULTICAST_STORM_DISABLE, true);
|
ksz_cfg(dev, REG_SW_MAC_CTRL_1, MULTICAST_STORM_DISABLE, true);
|
||||||
|
|
||||||
|
@ -383,13 +382,13 @@ static int ksz_setup(struct dsa_switch *ds)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static enum dsa_tag_protocol ksz_get_tag_protocol(struct dsa_switch *ds,
|
static enum dsa_tag_protocol ksz9477_get_tag_protocol(struct dsa_switch *ds,
|
||||||
int port)
|
int port)
|
||||||
{
|
{
|
||||||
return DSA_TAG_PROTO_KSZ;
|
return DSA_TAG_PROTO_KSZ;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_phy_read16(struct dsa_switch *ds, int addr, int reg)
|
static int ksz9477_phy_read16(struct dsa_switch *ds, int addr, int reg)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u16 val = 0;
|
u16 val = 0;
|
||||||
|
@ -399,7 +398,8 @@ static int ksz_phy_read16(struct dsa_switch *ds, int addr, int reg)
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_phy_write16(struct dsa_switch *ds, int addr, int reg, u16 val)
|
static int ksz9477_phy_write16(struct dsa_switch *ds, int addr, int reg,
|
||||||
|
u16 val)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
|
|
||||||
|
@ -414,7 +414,7 @@ static int ksz_enable_port(struct dsa_switch *ds, int port,
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
|
|
||||||
/* setup slave port */
|
/* setup slave port */
|
||||||
port_setup(dev, port, false);
|
ksz9477_port_setup(dev, port, false);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -436,8 +436,8 @@ static int ksz_sset_count(struct dsa_switch *ds, int port, int sset)
|
||||||
return TOTAL_SWITCH_COUNTER_NUM;
|
return TOTAL_SWITCH_COUNTER_NUM;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ksz_get_strings(struct dsa_switch *ds, int port,
|
static void ksz9477_get_strings(struct dsa_switch *ds, int port,
|
||||||
u32 stringset, uint8_t *buf)
|
u32 stringset, uint8_t *buf)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -490,7 +490,8 @@ static void ksz_get_ethtool_stats(struct dsa_switch *ds, int port,
|
||||||
mutex_unlock(&dev->stats_mutex);
|
mutex_unlock(&dev->stats_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ksz_port_stp_state_set(struct dsa_switch *ds, int port, u8 state)
|
static void ksz9477_port_stp_state_set(struct dsa_switch *ds, int port,
|
||||||
|
u8 state)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u8 data;
|
u8 data;
|
||||||
|
@ -535,7 +536,8 @@ static void ksz_port_fast_age(struct dsa_switch *ds, int port)
|
||||||
ksz_write8(dev, REG_SW_LUE_CTRL_1, data8);
|
ksz_write8(dev, REG_SW_LUE_CTRL_1, data8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_port_vlan_filtering(struct dsa_switch *ds, int port, bool flag)
|
static int ksz9477_port_vlan_filtering(struct dsa_switch *ds, int port,
|
||||||
|
bool flag)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
|
|
||||||
|
@ -562,8 +564,8 @@ static int ksz_port_vlan_prepare(struct dsa_switch *ds, int port,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ksz_port_vlan_add(struct dsa_switch *ds, int port,
|
static void ksz9477_port_vlan_add(struct dsa_switch *ds, int port,
|
||||||
const struct switchdev_obj_port_vlan *vlan)
|
const struct switchdev_obj_port_vlan *vlan)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u32 vlan_table[3];
|
u32 vlan_table[3];
|
||||||
|
@ -596,8 +598,8 @@ static void ksz_port_vlan_add(struct dsa_switch *ds, int port,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_port_vlan_del(struct dsa_switch *ds, int port,
|
static int ksz9477_port_vlan_del(struct dsa_switch *ds, int port,
|
||||||
const struct switchdev_obj_port_vlan *vlan)
|
const struct switchdev_obj_port_vlan *vlan)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
|
bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
|
||||||
|
@ -652,8 +654,8 @@ struct alu_struct {
|
||||||
u8 mac[ETH_ALEN];
|
u8 mac[ETH_ALEN];
|
||||||
};
|
};
|
||||||
|
|
||||||
static int ksz_port_fdb_add(struct dsa_switch *ds, int port,
|
static int ksz9477_port_fdb_add(struct dsa_switch *ds, int port,
|
||||||
const unsigned char *addr, u16 vid)
|
const unsigned char *addr, u16 vid)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u32 alu_table[4];
|
u32 alu_table[4];
|
||||||
|
@ -709,8 +711,8 @@ static int ksz_port_fdb_add(struct dsa_switch *ds, int port,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_port_fdb_del(struct dsa_switch *ds, int port,
|
static int ksz9477_port_fdb_del(struct dsa_switch *ds, int port,
|
||||||
const unsigned char *addr, u16 vid)
|
const unsigned char *addr, u16 vid)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u32 alu_table[4];
|
u32 alu_table[4];
|
||||||
|
@ -799,8 +801,8 @@ static void convert_alu(struct alu_struct *alu, u32 *alu_table)
|
||||||
alu->mac[5] = alu_table[3] & 0xFF;
|
alu->mac[5] = alu_table[3] & 0xFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_port_fdb_dump(struct dsa_switch *ds, int port,
|
static int ksz9477_port_fdb_dump(struct dsa_switch *ds, int port,
|
||||||
dsa_fdb_dump_cb_t *cb, void *data)
|
dsa_fdb_dump_cb_t *cb, void *data)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
@ -858,8 +860,8 @@ static int ksz_port_mdb_prepare(struct dsa_switch *ds, int port,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ksz_port_mdb_add(struct dsa_switch *ds, int port,
|
static void ksz9477_port_mdb_add(struct dsa_switch *ds, int port,
|
||||||
const struct switchdev_obj_port_mdb *mdb)
|
const struct switchdev_obj_port_mdb *mdb)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u32 static_table[4];
|
u32 static_table[4];
|
||||||
|
@ -928,8 +930,8 @@ static void ksz_port_mdb_add(struct dsa_switch *ds, int port,
|
||||||
mutex_unlock(&dev->alu_mutex);
|
mutex_unlock(&dev->alu_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_port_mdb_del(struct dsa_switch *ds, int port,
|
static int ksz9477_port_mdb_del(struct dsa_switch *ds, int port,
|
||||||
const struct switchdev_obj_port_mdb *mdb)
|
const struct switchdev_obj_port_mdb *mdb)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u32 static_table[4];
|
u32 static_table[4];
|
||||||
|
@ -1005,9 +1007,9 @@ static int ksz_port_mdb_del(struct dsa_switch *ds, int port,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz_port_mirror_add(struct dsa_switch *ds, int port,
|
static int ksz9477_port_mirror_add(struct dsa_switch *ds, int port,
|
||||||
struct dsa_mall_mirror_tc_entry *mirror,
|
struct dsa_mall_mirror_tc_entry *mirror,
|
||||||
bool ingress)
|
bool ingress)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
|
|
||||||
|
@ -1027,8 +1029,8 @@ static int ksz_port_mirror_add(struct dsa_switch *ds, int port,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ksz_port_mirror_del(struct dsa_switch *ds, int port,
|
static void ksz9477_port_mirror_del(struct dsa_switch *ds, int port,
|
||||||
struct dsa_mall_mirror_tc_entry *mirror)
|
struct dsa_mall_mirror_tc_entry *mirror)
|
||||||
{
|
{
|
||||||
struct ksz_device *dev = ds->priv;
|
struct ksz_device *dev = ds->priv;
|
||||||
u8 data;
|
u8 data;
|
||||||
|
@ -1046,29 +1048,29 @@ static void ksz_port_mirror_del(struct dsa_switch *ds, int port,
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct dsa_switch_ops ksz_switch_ops = {
|
static const struct dsa_switch_ops ksz_switch_ops = {
|
||||||
.get_tag_protocol = ksz_get_tag_protocol,
|
.get_tag_protocol = ksz9477_get_tag_protocol,
|
||||||
.setup = ksz_setup,
|
.setup = ksz9477_setup,
|
||||||
.phy_read = ksz_phy_read16,
|
.phy_read = ksz9477_phy_read16,
|
||||||
.phy_write = ksz_phy_write16,
|
.phy_write = ksz9477_phy_write16,
|
||||||
.port_enable = ksz_enable_port,
|
.port_enable = ksz_enable_port,
|
||||||
.port_disable = ksz_disable_port,
|
.port_disable = ksz_disable_port,
|
||||||
.get_strings = ksz_get_strings,
|
.get_strings = ksz9477_get_strings,
|
||||||
.get_ethtool_stats = ksz_get_ethtool_stats,
|
.get_ethtool_stats = ksz_get_ethtool_stats,
|
||||||
.get_sset_count = ksz_sset_count,
|
.get_sset_count = ksz_sset_count,
|
||||||
.port_stp_state_set = ksz_port_stp_state_set,
|
.port_stp_state_set = ksz9477_port_stp_state_set,
|
||||||
.port_fast_age = ksz_port_fast_age,
|
.port_fast_age = ksz_port_fast_age,
|
||||||
.port_vlan_filtering = ksz_port_vlan_filtering,
|
.port_vlan_filtering = ksz9477_port_vlan_filtering,
|
||||||
.port_vlan_prepare = ksz_port_vlan_prepare,
|
.port_vlan_prepare = ksz_port_vlan_prepare,
|
||||||
.port_vlan_add = ksz_port_vlan_add,
|
.port_vlan_add = ksz9477_port_vlan_add,
|
||||||
.port_vlan_del = ksz_port_vlan_del,
|
.port_vlan_del = ksz9477_port_vlan_del,
|
||||||
.port_fdb_dump = ksz_port_fdb_dump,
|
.port_fdb_dump = ksz9477_port_fdb_dump,
|
||||||
.port_fdb_add = ksz_port_fdb_add,
|
.port_fdb_add = ksz9477_port_fdb_add,
|
||||||
.port_fdb_del = ksz_port_fdb_del,
|
.port_fdb_del = ksz9477_port_fdb_del,
|
||||||
.port_mdb_prepare = ksz_port_mdb_prepare,
|
.port_mdb_prepare = ksz_port_mdb_prepare,
|
||||||
.port_mdb_add = ksz_port_mdb_add,
|
.port_mdb_add = ksz9477_port_mdb_add,
|
||||||
.port_mdb_del = ksz_port_mdb_del,
|
.port_mdb_del = ksz9477_port_mdb_del,
|
||||||
.port_mirror_add = ksz_port_mirror_add,
|
.port_mirror_add = ksz9477_port_mirror_add,
|
||||||
.port_mirror_del = ksz_port_mirror_del,
|
.port_mirror_del = ksz9477_port_mirror_del,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ksz_chip_data {
|
struct ksz_chip_data {
|
||||||
|
@ -1081,7 +1083,7 @@ struct ksz_chip_data {
|
||||||
int port_cnt;
|
int port_cnt;
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct ksz_chip_data ksz_switch_chips[] = {
|
static const struct ksz_chip_data ksz9477_switch_chips[] = {
|
||||||
{
|
{
|
||||||
.chip_id = 0x00947700,
|
.chip_id = 0x00947700,
|
||||||
.dev_name = "KSZ9477",
|
.dev_name = "KSZ9477",
|
||||||
|
@ -1102,14 +1104,14 @@ static const struct ksz_chip_data ksz_switch_chips[] = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static int ksz_switch_init(struct ksz_device *dev)
|
static int ksz9477_switch_init(struct ksz_device *dev)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
dev->ds->ops = &ksz_switch_ops;
|
dev->ds->ops = &ksz_switch_ops;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(ksz_switch_chips); i++) {
|
for (i = 0; i < ARRAY_SIZE(ksz9477_switch_chips); i++) {
|
||||||
const struct ksz_chip_data *chip = &ksz_switch_chips[i];
|
const struct ksz_chip_data *chip = &ksz9477_switch_chips[i];
|
||||||
|
|
||||||
if (dev->chip_id == chip->chip_id) {
|
if (dev->chip_id == chip->chip_id) {
|
||||||
dev->name = chip->dev_name;
|
dev->name = chip->dev_name;
|
||||||
|
@ -1198,7 +1200,7 @@ int ksz_switch_register(struct ksz_device *dev)
|
||||||
if (ksz_switch_detect(dev))
|
if (ksz_switch_detect(dev))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
ret = ksz_switch_init(dev);
|
ret = ksz9477_switch_init(dev);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue