Commit 4b5baca0 authored by Michael Grzeschik's avatar Michael Grzeschik Committed by David S. Miller

net: dsa: microchip: ksz8795: change drivers prefix to be generic

The driver can be used on other chips of this type. To reflect
this we rename the drivers prefix from ksz8795 to ksz8.
Signed-off-by: default avatarMichael Grzeschik <m.grzeschik@pengutronix.de>
Signed-off-by: default avatarOleksij Rempel <o.rempel@pengutronix.de>
Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent aae0fdac
...@@ -74,7 +74,7 @@ static void ksz_port_cfg(struct ksz_device *dev, int port, int offset, u8 bits, ...@@ -74,7 +74,7 @@ static void ksz_port_cfg(struct ksz_device *dev, int port, int offset, u8 bits,
bits, set ? bits : 0); bits, set ? bits : 0);
} }
static int ksz8795_reset_switch(struct ksz_device *dev) static int ksz8_reset_switch(struct ksz_device *dev)
{ {
/* reset switch */ /* reset switch */
ksz_write8(dev, REG_POWER_MANAGEMENT_1, ksz_write8(dev, REG_POWER_MANAGEMENT_1,
...@@ -117,8 +117,7 @@ static void ksz8795_set_prio_queue(struct ksz_device *dev, int port, int queue) ...@@ -117,8 +117,7 @@ static void ksz8795_set_prio_queue(struct ksz_device *dev, int port, int queue)
true); true);
} }
static void ksz8795_r_mib_cnt(struct ksz_device *dev, int port, u16 addr, static void ksz8_r_mib_cnt(struct ksz_device *dev, int port, u16 addr, u64 *cnt)
u64 *cnt)
{ {
u16 ctrl_addr; u16 ctrl_addr;
u32 data; u32 data;
...@@ -148,8 +147,8 @@ static void ksz8795_r_mib_cnt(struct ksz_device *dev, int port, u16 addr, ...@@ -148,8 +147,8 @@ static void ksz8795_r_mib_cnt(struct ksz_device *dev, int port, u16 addr,
mutex_unlock(&dev->alu_mutex); mutex_unlock(&dev->alu_mutex);
} }
static void ksz8795_r_mib_pkt(struct ksz_device *dev, int port, u16 addr, static void ksz8_r_mib_pkt(struct ksz_device *dev, int port, u16 addr,
u64 *dropped, u64 *cnt) u64 *dropped, u64 *cnt)
{ {
u16 ctrl_addr; u16 ctrl_addr;
u32 data; u32 data;
...@@ -195,7 +194,7 @@ static void ksz8795_r_mib_pkt(struct ksz_device *dev, int port, u16 addr, ...@@ -195,7 +194,7 @@ static void ksz8795_r_mib_pkt(struct ksz_device *dev, int port, u16 addr,
mutex_unlock(&dev->alu_mutex); mutex_unlock(&dev->alu_mutex);
} }
static void ksz8795_freeze_mib(struct ksz_device *dev, int port, bool freeze) static void ksz8_freeze_mib(struct ksz_device *dev, int port, bool freeze)
{ {
/* enable the port for flush/freeze function */ /* enable the port for flush/freeze function */
if (freeze) if (freeze)
...@@ -207,7 +206,7 @@ static void ksz8795_freeze_mib(struct ksz_device *dev, int port, bool freeze) ...@@ -207,7 +206,7 @@ static void ksz8795_freeze_mib(struct ksz_device *dev, int port, bool freeze)
ksz_cfg(dev, REG_SW_CTRL_6, BIT(port), false); ksz_cfg(dev, REG_SW_CTRL_6, BIT(port), false);
} }
static void ksz8795_port_init_cnt(struct ksz_device *dev, int port) static void ksz8_port_init_cnt(struct ksz_device *dev, int port)
{ {
struct ksz_port_mib *mib = &dev->ports[port].mib; struct ksz_port_mib *mib = &dev->ports[port].mib;
...@@ -235,8 +234,7 @@ static void ksz8795_port_init_cnt(struct ksz_device *dev, int port) ...@@ -235,8 +234,7 @@ static void ksz8795_port_init_cnt(struct ksz_device *dev, int port)
memset(mib->counters, 0, dev->mib_cnt * sizeof(u64)); memset(mib->counters, 0, dev->mib_cnt * sizeof(u64));
} }
static void ksz8795_r_table(struct ksz_device *dev, int table, u16 addr, static void ksz8_r_table(struct ksz_device *dev, int table, u16 addr, u64 *data)
u64 *data)
{ {
u16 ctrl_addr; u16 ctrl_addr;
...@@ -248,8 +246,7 @@ static void ksz8795_r_table(struct ksz_device *dev, int table, u16 addr, ...@@ -248,8 +246,7 @@ static void ksz8795_r_table(struct ksz_device *dev, int table, u16 addr,
mutex_unlock(&dev->alu_mutex); mutex_unlock(&dev->alu_mutex);
} }
static void ksz8795_w_table(struct ksz_device *dev, int table, u16 addr, static void ksz8_w_table(struct ksz_device *dev, int table, u16 addr, u64 data)
u64 data)
{ {
u16 ctrl_addr; u16 ctrl_addr;
...@@ -261,7 +258,7 @@ static void ksz8795_w_table(struct ksz_device *dev, int table, u16 addr, ...@@ -261,7 +258,7 @@ static void ksz8795_w_table(struct ksz_device *dev, int table, u16 addr,
mutex_unlock(&dev->alu_mutex); mutex_unlock(&dev->alu_mutex);
} }
static int ksz8795_valid_dyn_entry(struct ksz_device *dev, u8 *data) static int ksz8_valid_dyn_entry(struct ksz_device *dev, u8 *data)
{ {
int timeout = 100; int timeout = 100;
...@@ -284,9 +281,9 @@ static int ksz8795_valid_dyn_entry(struct ksz_device *dev, u8 *data) ...@@ -284,9 +281,9 @@ static int ksz8795_valid_dyn_entry(struct ksz_device *dev, u8 *data)
return 0; return 0;
} }
static int ksz8795_r_dyn_mac_table(struct ksz_device *dev, u16 addr, static int ksz8_r_dyn_mac_table(struct ksz_device *dev, u16 addr,
u8 *mac_addr, u8 *fid, u8 *src_port, u8 *mac_addr, u8 *fid, u8 *src_port,
u8 *timestamp, u16 *entries) u8 *timestamp, u16 *entries)
{ {
u32 data_hi, data_lo; u32 data_hi, data_lo;
u16 ctrl_addr; u16 ctrl_addr;
...@@ -298,7 +295,7 @@ static int ksz8795_r_dyn_mac_table(struct ksz_device *dev, u16 addr, ...@@ -298,7 +295,7 @@ static int ksz8795_r_dyn_mac_table(struct ksz_device *dev, u16 addr,
mutex_lock(&dev->alu_mutex); mutex_lock(&dev->alu_mutex);
ksz_write16(dev, REG_IND_CTRL_0, ctrl_addr); ksz_write16(dev, REG_IND_CTRL_0, ctrl_addr);
rc = ksz8795_valid_dyn_entry(dev, &data); rc = ksz8_valid_dyn_entry(dev, &data);
if (rc == -EAGAIN) { if (rc == -EAGAIN) {
if (addr == 0) if (addr == 0)
*entries = 0; *entries = 0;
...@@ -341,13 +338,13 @@ static int ksz8795_r_dyn_mac_table(struct ksz_device *dev, u16 addr, ...@@ -341,13 +338,13 @@ static int ksz8795_r_dyn_mac_table(struct ksz_device *dev, u16 addr,
return rc; return rc;
} }
static int ksz8795_r_sta_mac_table(struct ksz_device *dev, u16 addr, static int ksz8_r_sta_mac_table(struct ksz_device *dev, u16 addr,
struct alu_struct *alu) struct alu_struct *alu)
{ {
u32 data_hi, data_lo; u32 data_hi, data_lo;
u64 data; u64 data;
ksz8795_r_table(dev, TABLE_STATIC_MAC, addr, &data); ksz8_r_table(dev, TABLE_STATIC_MAC, addr, &data);
data_hi = data >> 32; data_hi = data >> 32;
data_lo = (u32)data; data_lo = (u32)data;
if (data_hi & (STATIC_MAC_TABLE_VALID | STATIC_MAC_TABLE_OVERRIDE)) { if (data_hi & (STATIC_MAC_TABLE_VALID | STATIC_MAC_TABLE_OVERRIDE)) {
...@@ -370,8 +367,8 @@ static int ksz8795_r_sta_mac_table(struct ksz_device *dev, u16 addr, ...@@ -370,8 +367,8 @@ static int ksz8795_r_sta_mac_table(struct ksz_device *dev, u16 addr,
return -ENXIO; return -ENXIO;
} }
static void ksz8795_w_sta_mac_table(struct ksz_device *dev, u16 addr, static void ksz8_w_sta_mac_table(struct ksz_device *dev, u16 addr,
struct alu_struct *alu) struct alu_struct *alu)
{ {
u32 data_hi, data_lo; u32 data_hi, data_lo;
u64 data; u64 data;
...@@ -394,17 +391,17 @@ static void ksz8795_w_sta_mac_table(struct ksz_device *dev, u16 addr, ...@@ -394,17 +391,17 @@ static void ksz8795_w_sta_mac_table(struct ksz_device *dev, u16 addr,
data_hi &= ~STATIC_MAC_TABLE_OVERRIDE; data_hi &= ~STATIC_MAC_TABLE_OVERRIDE;
data = (u64)data_hi << 32 | data_lo; data = (u64)data_hi << 32 | data_lo;
ksz8795_w_table(dev, TABLE_STATIC_MAC, addr, data); ksz8_w_table(dev, TABLE_STATIC_MAC, addr, data);
} }
static void ksz8795_from_vlan(u16 vlan, u8 *fid, u8 *member, u8 *valid) static void ksz8_from_vlan(u16 vlan, u8 *fid, u8 *member, u8 *valid)
{ {
*fid = vlan & VLAN_TABLE_FID; *fid = vlan & VLAN_TABLE_FID;
*member = (vlan & VLAN_TABLE_MEMBERSHIP) >> VLAN_TABLE_MEMBERSHIP_S; *member = (vlan & VLAN_TABLE_MEMBERSHIP) >> VLAN_TABLE_MEMBERSHIP_S;
*valid = !!(vlan & VLAN_TABLE_VALID); *valid = !!(vlan & VLAN_TABLE_VALID);
} }
static void ksz8795_to_vlan(u8 fid, u8 member, u8 valid, u16 *vlan) static void ksz8_to_vlan(u8 fid, u8 member, u8 valid, u16 *vlan)
{ {
*vlan = fid; *vlan = fid;
*vlan |= (u16)member << VLAN_TABLE_MEMBERSHIP_S; *vlan |= (u16)member << VLAN_TABLE_MEMBERSHIP_S;
...@@ -412,12 +409,12 @@ static void ksz8795_to_vlan(u8 fid, u8 member, u8 valid, u16 *vlan) ...@@ -412,12 +409,12 @@ static void ksz8795_to_vlan(u8 fid, u8 member, u8 valid, u16 *vlan)
*vlan |= VLAN_TABLE_VALID; *vlan |= VLAN_TABLE_VALID;
} }
static void ksz8795_r_vlan_entries(struct ksz_device *dev, u16 addr) static void ksz8_r_vlan_entries(struct ksz_device *dev, u16 addr)
{ {
u64 data; u64 data;
int i; int i;
ksz8795_r_table(dev, TABLE_VLAN, addr, &data); ksz8_r_table(dev, TABLE_VLAN, addr, &data);
addr *= dev->phy_port_cnt; addr *= dev->phy_port_cnt;
for (i = 0; i < dev->phy_port_cnt; i++) { for (i = 0; i < dev->phy_port_cnt; i++) {
dev->vlan_cache[addr + i].table[0] = (u16)data; dev->vlan_cache[addr + i].table[0] = (u16)data;
...@@ -425,7 +422,7 @@ static void ksz8795_r_vlan_entries(struct ksz_device *dev, u16 addr) ...@@ -425,7 +422,7 @@ static void ksz8795_r_vlan_entries(struct ksz_device *dev, u16 addr)
} }
} }
static void ksz8795_r_vlan_table(struct ksz_device *dev, u16 vid, u16 *vlan) static void ksz8_r_vlan_table(struct ksz_device *dev, u16 vid, u16 *vlan)
{ {
int index; int index;
u16 *data; u16 *data;
...@@ -435,11 +432,11 @@ static void ksz8795_r_vlan_table(struct ksz_device *dev, u16 vid, u16 *vlan) ...@@ -435,11 +432,11 @@ static void ksz8795_r_vlan_table(struct ksz_device *dev, u16 vid, u16 *vlan)
data = (u16 *)&buf; data = (u16 *)&buf;
addr = vid / dev->phy_port_cnt; addr = vid / dev->phy_port_cnt;
index = vid & 3; index = vid & 3;
ksz8795_r_table(dev, TABLE_VLAN, addr, &buf); ksz8_r_table(dev, TABLE_VLAN, addr, &buf);
*vlan = data[index]; *vlan = data[index];
} }
static void ksz8795_w_vlan_table(struct ksz_device *dev, u16 vid, u16 vlan) static void ksz8_w_vlan_table(struct ksz_device *dev, u16 vid, u16 vlan)
{ {
int index; int index;
u16 *data; u16 *data;
...@@ -449,13 +446,13 @@ static void ksz8795_w_vlan_table(struct ksz_device *dev, u16 vid, u16 vlan) ...@@ -449,13 +446,13 @@ static void ksz8795_w_vlan_table(struct ksz_device *dev, u16 vid, u16 vlan)
data = (u16 *)&buf; data = (u16 *)&buf;
addr = vid / dev->phy_port_cnt; addr = vid / dev->phy_port_cnt;
index = vid & 3; index = vid & 3;
ksz8795_r_table(dev, TABLE_VLAN, addr, &buf); ksz8_r_table(dev, TABLE_VLAN, addr, &buf);
data[index] = vlan; data[index] = vlan;
dev->vlan_cache[vid].table[0] = vlan; dev->vlan_cache[vid].table[0] = vlan;
ksz8795_w_table(dev, TABLE_VLAN, addr, buf); ksz8_w_table(dev, TABLE_VLAN, addr, buf);
} }
static void ksz8795_r_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 *val) static void ksz8_r_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 *val)
{ {
u8 restart, speed, ctrl, link; u8 restart, speed, ctrl, link;
int processed = true; int processed = true;
...@@ -546,7 +543,7 @@ static void ksz8795_r_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 *val) ...@@ -546,7 +543,7 @@ static void ksz8795_r_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 *val)
*val = data; *val = data;
} }
static void ksz8795_w_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 val) static void ksz8_w_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 val)
{ {
u8 p = phy; u8 p = phy;
u8 restart, speed, ctrl, data; u8 restart, speed, ctrl, data;
...@@ -644,15 +641,15 @@ static void ksz8795_w_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 val) ...@@ -644,15 +641,15 @@ static void ksz8795_w_phy(struct ksz_device *dev, u16 phy, u16 reg, u16 val)
} }
} }
static enum dsa_tag_protocol ksz8795_get_tag_protocol(struct dsa_switch *ds, static enum dsa_tag_protocol ksz8_get_tag_protocol(struct dsa_switch *ds,
int port, int port,
enum dsa_tag_protocol mp) enum dsa_tag_protocol mp)
{ {
return DSA_TAG_PROTO_KSZ8795; return DSA_TAG_PROTO_KSZ8795;
} }
static void ksz8795_get_strings(struct dsa_switch *ds, int port, static void ksz8_get_strings(struct dsa_switch *ds, int port,
u32 stringset, uint8_t *buf) u32 stringset, uint8_t *buf)
{ {
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
int i; int i;
...@@ -663,8 +660,7 @@ static void ksz8795_get_strings(struct dsa_switch *ds, int port, ...@@ -663,8 +660,7 @@ static void ksz8795_get_strings(struct dsa_switch *ds, int port,
} }
} }
static void ksz8795_cfg_port_member(struct ksz_device *dev, int port, static void ksz8_cfg_port_member(struct ksz_device *dev, int port, u8 member)
u8 member)
{ {
u8 data; u8 data;
...@@ -675,8 +671,7 @@ static void ksz8795_cfg_port_member(struct ksz_device *dev, int port, ...@@ -675,8 +671,7 @@ static void ksz8795_cfg_port_member(struct ksz_device *dev, int port,
dev->ports[port].member = member; dev->ports[port].member = member;
} }
static void ksz8795_port_stp_state_set(struct dsa_switch *ds, int port, static void ksz8_port_stp_state_set(struct dsa_switch *ds, int port, u8 state)
u8 state)
{ {
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
int forward = dev->member; int forward = dev->member;
...@@ -734,7 +729,7 @@ static void ksz8795_port_stp_state_set(struct dsa_switch *ds, int port, ...@@ -734,7 +729,7 @@ static void ksz8795_port_stp_state_set(struct dsa_switch *ds, int port,
p->stp_state = state; p->stp_state = state;
/* Port membership may share register with STP state. */ /* Port membership may share register with STP state. */
if (member >= 0 && member != p->member) if (member >= 0 && member != p->member)
ksz8795_cfg_port_member(dev, port, (u8)member); ksz8_cfg_port_member(dev, port, (u8)member);
/* Check if forwarding needs to be updated. */ /* Check if forwarding needs to be updated. */
if (state != BR_STATE_FORWARDING) { if (state != BR_STATE_FORWARDING) {
...@@ -749,7 +744,7 @@ static void ksz8795_port_stp_state_set(struct dsa_switch *ds, int port, ...@@ -749,7 +744,7 @@ static void ksz8795_port_stp_state_set(struct dsa_switch *ds, int port,
ksz_update_port_member(dev, port); ksz_update_port_member(dev, port);
} }
static void ksz8795_flush_dyn_mac_table(struct ksz_device *dev, int port) static void ksz8_flush_dyn_mac_table(struct ksz_device *dev, int port)
{ {
u8 learn[DSA_MAX_PORTS]; u8 learn[DSA_MAX_PORTS];
int first, index, cnt; int first, index, cnt;
...@@ -782,9 +777,8 @@ static void ksz8795_flush_dyn_mac_table(struct ksz_device *dev, int port) ...@@ -782,9 +777,8 @@ static void ksz8795_flush_dyn_mac_table(struct ksz_device *dev, int port)
} }
} }
static int ksz8795_port_vlan_filtering(struct dsa_switch *ds, int port, static int ksz8_port_vlan_filtering(struct dsa_switch *ds, int port, bool flag,
bool flag, struct netlink_ext_ack *extack)
struct netlink_ext_ack *extack)
{ {
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
...@@ -793,9 +787,9 @@ static int ksz8795_port_vlan_filtering(struct dsa_switch *ds, int port, ...@@ -793,9 +787,9 @@ static int ksz8795_port_vlan_filtering(struct dsa_switch *ds, int port,
return 0; return 0;
} }
static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port, static int ksz8_port_vlan_add(struct dsa_switch *ds, int port,
const struct switchdev_obj_port_vlan *vlan, const struct switchdev_obj_port_vlan *vlan,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)
{ {
bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED; bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
...@@ -804,8 +798,8 @@ static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port, ...@@ -804,8 +798,8 @@ static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port,
ksz_port_cfg(dev, port, P_TAG_CTRL, PORT_REMOVE_TAG, untagged); ksz_port_cfg(dev, port, P_TAG_CTRL, PORT_REMOVE_TAG, untagged);
ksz8795_r_vlan_table(dev, vlan->vid, &data); ksz8_r_vlan_table(dev, vlan->vid, &data);
ksz8795_from_vlan(data, &fid, &member, &valid); ksz8_from_vlan(data, &fid, &member, &valid);
/* First time to setup the VLAN entry. */ /* First time to setup the VLAN entry. */
if (!valid) { if (!valid) {
...@@ -815,8 +809,8 @@ static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port, ...@@ -815,8 +809,8 @@ static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port,
} }
member |= BIT(port); member |= BIT(port);
ksz8795_to_vlan(fid, member, valid, &data); ksz8_to_vlan(fid, member, valid, &data);
ksz8795_w_vlan_table(dev, vlan->vid, data); ksz8_w_vlan_table(dev, vlan->vid, data);
/* change PVID */ /* change PVID */
if (vlan->flags & BRIDGE_VLAN_INFO_PVID) if (vlan->flags & BRIDGE_VLAN_INFO_PVID)
...@@ -834,8 +828,8 @@ static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port, ...@@ -834,8 +828,8 @@ static int ksz8795_port_vlan_add(struct dsa_switch *ds, int port,
return 0; return 0;
} }
static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port, static int ksz8_port_vlan_del(struct dsa_switch *ds, int port,
const struct switchdev_obj_port_vlan *vlan) const struct switchdev_obj_port_vlan *vlan)
{ {
bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED; bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
...@@ -847,8 +841,8 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port, ...@@ -847,8 +841,8 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port,
ksz_port_cfg(dev, port, P_TAG_CTRL, PORT_REMOVE_TAG, untagged); ksz_port_cfg(dev, port, P_TAG_CTRL, PORT_REMOVE_TAG, untagged);
ksz8795_r_vlan_table(dev, vlan->vid, &data); ksz8_r_vlan_table(dev, vlan->vid, &data);
ksz8795_from_vlan(data, &fid, &member, &valid); ksz8_from_vlan(data, &fid, &member, &valid);
member &= ~BIT(port); member &= ~BIT(port);
...@@ -861,8 +855,8 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port, ...@@ -861,8 +855,8 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port,
if (pvid == vlan->vid) if (pvid == vlan->vid)
new_pvid = 1; new_pvid = 1;
ksz8795_to_vlan(fid, member, valid, &data); ksz8_to_vlan(fid, member, valid, &data);
ksz8795_w_vlan_table(dev, vlan->vid, data); ksz8_w_vlan_table(dev, vlan->vid, data);
if (new_pvid != pvid) if (new_pvid != pvid)
ksz_pwrite16(dev, port, REG_PORT_CTRL_VID, pvid); ksz_pwrite16(dev, port, REG_PORT_CTRL_VID, pvid);
...@@ -870,9 +864,9 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port, ...@@ -870,9 +864,9 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port,
return 0; return 0;
} }
static int ksz8795_port_mirror_add(struct dsa_switch *ds, int port, static int ksz8_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;
...@@ -894,8 +888,8 @@ static int ksz8795_port_mirror_add(struct dsa_switch *ds, int port, ...@@ -894,8 +888,8 @@ static int ksz8795_port_mirror_add(struct dsa_switch *ds, int port,
return 0; return 0;
} }
static void ksz8795_port_mirror_del(struct dsa_switch *ds, int port, static void ksz8_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;
...@@ -915,7 +909,7 @@ static void ksz8795_port_mirror_del(struct dsa_switch *ds, int port, ...@@ -915,7 +909,7 @@ static void ksz8795_port_mirror_del(struct dsa_switch *ds, int port,
PORT_MIRROR_SNIFFER, false); PORT_MIRROR_SNIFFER, false);
} }
static void ksz8795_port_setup(struct ksz_device *dev, int port, bool cpu_port) static void ksz8_port_setup(struct ksz_device *dev, int port, bool cpu_port)
{ {
struct ksz_port *p = &dev->ports[port]; struct ksz_port *p = &dev->ports[port];
u8 data8, member; u8 data8, member;
...@@ -981,10 +975,10 @@ static void ksz8795_port_setup(struct ksz_device *dev, int port, bool cpu_port) ...@@ -981,10 +975,10 @@ static void ksz8795_port_setup(struct ksz_device *dev, int port, bool cpu_port)
} else { } else {
member = dev->host_mask | p->vid_member; member = dev->host_mask | p->vid_member;
} }
ksz8795_cfg_port_member(dev, port, member); ksz8_cfg_port_member(dev, port, member);
} }
static void ksz8795_config_cpu_port(struct dsa_switch *ds) static void ksz8_config_cpu_port(struct dsa_switch *ds)
{ {
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
struct ksz_port *p; struct ksz_port *p;
...@@ -999,7 +993,7 @@ static void ksz8795_config_cpu_port(struct dsa_switch *ds) ...@@ -999,7 +993,7 @@ static void ksz8795_config_cpu_port(struct dsa_switch *ds)
p->vid_member = dev->port_mask; p->vid_member = dev->port_mask;
p->on = 1; p->on = 1;
ksz8795_port_setup(dev, dev->cpu_port, true); ksz8_port_setup(dev, dev->cpu_port, true);
dev->member = dev->host_mask; dev->member = dev->host_mask;
for (i = 0; i < dev->phy_port_cnt; i++) { for (i = 0; i < dev->phy_port_cnt; i++) {
...@@ -1010,7 +1004,7 @@ static void ksz8795_config_cpu_port(struct dsa_switch *ds) ...@@ -1010,7 +1004,7 @@ static void ksz8795_config_cpu_port(struct dsa_switch *ds)
*/ */
p->vid_member = BIT(i); p->vid_member = BIT(i);
p->member = dev->port_mask; p->member = dev->port_mask;
ksz8795_port_stp_state_set(ds, i, BR_STATE_DISABLED); ksz8_port_stp_state_set(ds, i, BR_STATE_DISABLED);
/* Last port may be disabled. */ /* Last port may be disabled. */
if (i == dev->phy_port_cnt) if (i == dev->phy_port_cnt)
...@@ -1034,7 +1028,7 @@ static void ksz8795_config_cpu_port(struct dsa_switch *ds) ...@@ -1034,7 +1028,7 @@ static void ksz8795_config_cpu_port(struct dsa_switch *ds)
} }
} }
static int ksz8795_setup(struct dsa_switch *ds) static int ksz8_setup(struct dsa_switch *ds)
{ {
struct ksz_device *dev = ds->priv; struct ksz_device *dev = ds->priv;
struct alu_struct alu; struct alu_struct alu;
...@@ -1045,7 +1039,7 @@ static int ksz8795_setup(struct dsa_switch *ds) ...@@ -1045,7 +1039,7 @@ static int ksz8795_setup(struct dsa_switch *ds)
if (!dev->vlan_cache) if (!dev->vlan_cache)
return -ENOMEM; return -ENOMEM;
ret = ksz8795_reset_switch(dev); ret = ksz8_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;
...@@ -1068,7 +1062,7 @@ static int ksz8795_setup(struct dsa_switch *ds) ...@@ -1068,7 +1062,7 @@ static int ksz8795_setup(struct dsa_switch *ds)
UNICAST_VLAN_BOUNDARY | NO_EXC_COLLISION_DROP, UNICAST_VLAN_BOUNDARY | NO_EXC_COLLISION_DROP,
UNICAST_VLAN_BOUNDARY | NO_EXC_COLLISION_DROP); UNICAST_VLAN_BOUNDARY | NO_EXC_COLLISION_DROP);
ksz8795_config_cpu_port(ds); ksz8_config_cpu_port(ds);
ksz_cfg(dev, REG_SW_CTRL_2, MULTICAST_STORM_DISABLE, true); ksz_cfg(dev, REG_SW_CTRL_2, MULTICAST_STORM_DISABLE, true);
...@@ -1083,7 +1077,7 @@ static int ksz8795_setup(struct dsa_switch *ds) ...@@ -1083,7 +1077,7 @@ static int ksz8795_setup(struct dsa_switch *ds)
BROADCAST_STORM_PROT_RATE) / 100); BROADCAST_STORM_PROT_RATE) / 100);
for (i = 0; i < (dev->num_vlans / 4); i++) for (i = 0; i < (dev->num_vlans / 4); i++)
ksz8795_r_vlan_entries(dev, i); ksz8_r_vlan_entries(dev, i);
/* Setup STP address for STP operation. */ /* Setup STP address for STP operation. */
memset(&alu, 0, sizeof(alu)); memset(&alu, 0, sizeof(alu));
...@@ -1092,7 +1086,7 @@ static int ksz8795_setup(struct dsa_switch *ds) ...@@ -1092,7 +1086,7 @@ static int ksz8795_setup(struct dsa_switch *ds)
alu.is_override = true; alu.is_override = true;
alu.port_forward = dev->host_mask; alu.port_forward = dev->host_mask;
ksz8795_w_sta_mac_table(dev, 0, &alu); ksz8_w_sta_mac_table(dev, 0, &alu);
ksz_init_mib_timer(dev); ksz_init_mib_timer(dev);
...@@ -1101,36 +1095,36 @@ static int ksz8795_setup(struct dsa_switch *ds) ...@@ -1101,36 +1095,36 @@ static int ksz8795_setup(struct dsa_switch *ds)
return 0; return 0;
} }
static const struct dsa_switch_ops ksz8795_switch_ops = { static const struct dsa_switch_ops ksz8_switch_ops = {
.get_tag_protocol = ksz8795_get_tag_protocol, .get_tag_protocol = ksz8_get_tag_protocol,
.setup = ksz8795_setup, .setup = ksz8_setup,
.phy_read = ksz_phy_read16, .phy_read = ksz_phy_read16,
.phy_write = ksz_phy_write16, .phy_write = ksz_phy_write16,
.phylink_mac_link_down = ksz_mac_link_down, .phylink_mac_link_down = ksz_mac_link_down,
.port_enable = ksz_enable_port, .port_enable = ksz_enable_port,
.get_strings = ksz8795_get_strings, .get_strings = ksz8_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_bridge_join = ksz_port_bridge_join, .port_bridge_join = ksz_port_bridge_join,
.port_bridge_leave = ksz_port_bridge_leave, .port_bridge_leave = ksz_port_bridge_leave,
.port_stp_state_set = ksz8795_port_stp_state_set, .port_stp_state_set = ksz8_port_stp_state_set,
.port_fast_age = ksz_port_fast_age, .port_fast_age = ksz_port_fast_age,
.port_vlan_filtering = ksz8795_port_vlan_filtering, .port_vlan_filtering = ksz8_port_vlan_filtering,
.port_vlan_add = ksz8795_port_vlan_add, .port_vlan_add = ksz8_port_vlan_add,
.port_vlan_del = ksz8795_port_vlan_del, .port_vlan_del = ksz8_port_vlan_del,
.port_fdb_dump = ksz_port_fdb_dump, .port_fdb_dump = ksz_port_fdb_dump,
.port_mdb_add = ksz_port_mdb_add, .port_mdb_add = ksz_port_mdb_add,
.port_mdb_del = ksz_port_mdb_del, .port_mdb_del = ksz_port_mdb_del,
.port_mirror_add = ksz8795_port_mirror_add, .port_mirror_add = ksz8_port_mirror_add,
.port_mirror_del = ksz8795_port_mirror_del, .port_mirror_del = ksz8_port_mirror_del,
}; };
static u32 ksz8795_get_port_addr(int port, int offset) static u32 ksz8_get_port_addr(int port, int offset)
{ {
return PORT_CTRL_ADDR(port, offset); return PORT_CTRL_ADDR(port, offset);
} }
static int ksz8795_switch_detect(struct ksz_device *dev) static int ksz8_switch_detect(struct ksz_device *dev)
{ {
u8 id1, id2; u8 id1, id2;
u16 id16; u16 id16;
...@@ -1174,7 +1168,7 @@ struct ksz_chip_data { ...@@ -1174,7 +1168,7 @@ struct ksz_chip_data {
int port_cnt; int port_cnt;
}; };
static const struct ksz_chip_data ksz8795_switch_chips[] = { static const struct ksz_chip_data ksz8_switch_chips[] = {
{ {
.chip_id = 0x8795, .chip_id = 0x8795,
.dev_name = "KSZ8795", .dev_name = "KSZ8795",
...@@ -1218,14 +1212,14 @@ static const struct ksz_chip_data ksz8795_switch_chips[] = { ...@@ -1218,14 +1212,14 @@ static const struct ksz_chip_data ksz8795_switch_chips[] = {
}, },
}; };
static int ksz8795_switch_init(struct ksz_device *dev) static int ksz8_switch_init(struct ksz_device *dev)
{ {
int i; int i;
dev->ds->ops = &ksz8795_switch_ops; dev->ds->ops = &ksz8_switch_ops;
for (i = 0; i < ARRAY_SIZE(ksz8795_switch_chips); i++) { for (i = 0; i < ARRAY_SIZE(ksz8_switch_chips); i++) {
const struct ksz_chip_data *chip = &ksz8795_switch_chips[i]; const struct ksz_chip_data *chip = &ksz8_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;
...@@ -1272,36 +1266,36 @@ static int ksz8795_switch_init(struct ksz_device *dev) ...@@ -1272,36 +1266,36 @@ static int ksz8795_switch_init(struct ksz_device *dev)
return 0; return 0;
} }
static void ksz8795_switch_exit(struct ksz_device *dev) static void ksz8_switch_exit(struct ksz_device *dev)
{ {
ksz8795_reset_switch(dev); ksz8_reset_switch(dev);
} }
static const struct ksz_dev_ops ksz8795_dev_ops = { static const struct ksz_dev_ops ksz8_dev_ops = {
.get_port_addr = ksz8795_get_port_addr, .get_port_addr = ksz8_get_port_addr,
.cfg_port_member = ksz8795_cfg_port_member, .cfg_port_member = ksz8_cfg_port_member,
.flush_dyn_mac_table = ksz8795_flush_dyn_mac_table, .flush_dyn_mac_table = ksz8_flush_dyn_mac_table,
.port_setup = ksz8795_port_setup, .port_setup = ksz8_port_setup,
.r_phy = ksz8795_r_phy, .r_phy = ksz8_r_phy,
.w_phy = ksz8795_w_phy, .w_phy = ksz8_w_phy,
.r_dyn_mac_table = ksz8795_r_dyn_mac_table, .r_dyn_mac_table = ksz8_r_dyn_mac_table,
.r_sta_mac_table = ksz8795_r_sta_mac_table, .r_sta_mac_table = ksz8_r_sta_mac_table,
.w_sta_mac_table = ksz8795_w_sta_mac_table, .w_sta_mac_table = ksz8_w_sta_mac_table,
.r_mib_cnt = ksz8795_r_mib_cnt, .r_mib_cnt = ksz8_r_mib_cnt,
.r_mib_pkt = ksz8795_r_mib_pkt, .r_mib_pkt = ksz8_r_mib_pkt,
.freeze_mib = ksz8795_freeze_mib, .freeze_mib = ksz8_freeze_mib,
.port_init_cnt = ksz8795_port_init_cnt, .port_init_cnt = ksz8_port_init_cnt,
.shutdown = ksz8795_reset_switch, .shutdown = ksz8_reset_switch,
.detect = ksz8795_switch_detect, .detect = ksz8_switch_detect,
.init = ksz8795_switch_init, .init = ksz8_switch_init,
.exit = ksz8795_switch_exit, .exit = ksz8_switch_exit,
}; };
int ksz8795_switch_register(struct ksz_device *dev) int ksz8_switch_register(struct ksz_device *dev)
{ {
return ksz_switch_register(dev, &ksz8795_dev_ops); return ksz_switch_register(dev, &ksz8_dev_ops);
} }
EXPORT_SYMBOL(ksz8795_switch_register); EXPORT_SYMBOL(ksz8_switch_register);
MODULE_AUTHOR("Tristram Ha <Tristram.Ha@microchip.com>"); MODULE_AUTHOR("Tristram Ha <Tristram.Ha@microchip.com>");
MODULE_DESCRIPTION("Microchip KSZ8795 Series Switch DSA Driver"); MODULE_DESCRIPTION("Microchip KSZ8795 Series Switch DSA Driver");
......
...@@ -55,7 +55,7 @@ static int ksz8795_spi_probe(struct spi_device *spi) ...@@ -55,7 +55,7 @@ static int ksz8795_spi_probe(struct spi_device *spi)
if (ret) if (ret)
return ret; return ret;
ret = ksz8795_switch_register(dev); ret = ksz8_switch_register(dev);
/* Main DSA driver may not be started yet. */ /* Main DSA driver may not be started yet. */
if (ret) if (ret)
......
...@@ -142,7 +142,7 @@ int ksz_switch_register(struct ksz_device *dev, ...@@ -142,7 +142,7 @@ int ksz_switch_register(struct ksz_device *dev,
const struct ksz_dev_ops *ops); const struct ksz_dev_ops *ops);
void ksz_switch_remove(struct ksz_device *dev); void ksz_switch_remove(struct ksz_device *dev);
int ksz8795_switch_register(struct ksz_device *dev); int ksz8_switch_register(struct ksz_device *dev);
int ksz9477_switch_register(struct ksz_device *dev); int ksz9477_switch_register(struct ksz_device *dev);
void ksz_update_port_member(struct ksz_device *dev, int port); void ksz_update_port_member(struct ksz_device *dev, int port);
......
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