aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/generic/files/drivers/net
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2012-03-18 22:06:39 +0000
committerGabor Juhos <juhosg@openwrt.org>2012-03-18 22:06:39 +0000
commit2ce9e4753c6e10cf46fe2af571044fbe01d515e2 (patch)
tree2deb4f8354dfb58123d1a8c542b66fd1127f7dbc /target/linux/generic/files/drivers/net
parent01cad79e03658964eccfe0cdab5bfff882bee2f5 (diff)
downloadupstream-2ce9e4753c6e10cf46fe2af571044fbe01d515e2.tar.gz
upstream-2ce9e4753c6e10cf46fe2af571044fbe01d515e2.tar.bz2
upstream-2ce9e4753c6e10cf46fe2af571044fbe01d515e2.zip
generic: ar8216: add read_port_status field to ar8xxx_chip
SVN-Revision: 31005
Diffstat (limited to 'target/linux/generic/files/drivers/net')
-rw-r--r--target/linux/generic/files/drivers/net/phy/ar8216.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/target/linux/generic/files/drivers/net/phy/ar8216.c b/target/linux/generic/files/drivers/net/phy/ar8216.c
index 6abb431948..019d527b71 100644
--- a/target/linux/generic/files/drivers/net/phy/ar8216.c
+++ b/target/linux/generic/files/drivers/net/phy/ar8216.c
@@ -48,6 +48,7 @@ struct ar8xxx_chip {
void (*init_port)(struct ar8216_priv *priv, int port);
void (*setup_port)(struct ar8216_priv *priv, int port, u32 egress,
u32 ingress, u32 members, u32 pvid);
+ u32 (*read_port_status)(struct ar8216_priv *priv, int port);
int (*atu_flush)(struct ar8216_priv *priv);
void (*vtu_flush)(struct ar8216_priv *priv);
void (*vtu_load_vlan)(struct ar8216_priv *priv, u32 vid, u32 port_mask);
@@ -177,7 +178,7 @@ ar8216_read_port_link(struct ar8216_priv *priv, int port,
memset(link, '\0', sizeof(*link));
- status = priv->read(priv, AR8216_REG_PORT_STATUS(port));
+ status = priv->chip->read_port_status(priv, port);
link->aneg = !!(status & AR8216_PORT_STATUS_LINK_AUTO);
if (link->aneg) {
@@ -521,6 +522,12 @@ ar8216_atu_flush(struct ar8216_priv *priv)
return ret;
}
+static u32
+ar8216_read_port_status(struct ar8216_priv *priv, int port)
+{
+ return priv->read(priv, AR8216_REG_PORT_STATUS(port));
+}
+
static void
ar8216_setup_port(struct ar8216_priv *priv, int port, u32 egress, u32 ingress,
u32 members, u32 pvid)
@@ -790,6 +797,7 @@ static const struct ar8xxx_chip ar8216_chip = {
.init_globals = ar8216_init_globals,
.init_port = ar8216_init_port,
.setup_port = ar8216_setup_port,
+ .read_port_status = ar8216_read_port_status,
.atu_flush = ar8216_atu_flush,
.vtu_flush = ar8216_vtu_flush,
.vtu_load_vlan = ar8216_vtu_load_vlan,
@@ -800,6 +808,7 @@ static const struct ar8xxx_chip ar8236_chip = {
.init_globals = ar8236_init_globals,
.init_port = ar8216_init_port,
.setup_port = ar8236_setup_port,
+ .read_port_status = ar8216_read_port_status,
.atu_flush = ar8216_atu_flush,
.vtu_flush = ar8216_vtu_flush,
.vtu_load_vlan = ar8216_vtu_load_vlan,
@@ -811,6 +820,7 @@ static const struct ar8xxx_chip ar8316_chip = {
.init_globals = ar8316_init_globals,
.init_port = ar8216_init_port,
.setup_port = ar8216_setup_port,
+ .read_port_status = ar8216_read_port_status,
.atu_flush = ar8216_atu_flush,
.vtu_flush = ar8216_vtu_flush,
.vtu_load_vlan = ar8216_vtu_load_vlan,