Commit 80c4627b authored by Andrew Lunn's avatar Andrew Lunn Committed by David S. Miller

dsa: mv88x6xxx: Refactor getting a single statistic

Move the code to retrieve a statistics counter into a function of its
own, so it can later be reused.
Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 8a0a265d
...@@ -681,52 +681,61 @@ static void _mv88e6xxx_get_strings(struct dsa_switch *ds, ...@@ -681,52 +681,61 @@ static void _mv88e6xxx_get_strings(struct dsa_switch *ds,
} }
} }
static void _mv88e6xxx_get_ethtool_stats(struct dsa_switch *ds, static uint64_t _mv88e6xxx_get_ethtool_stat(struct dsa_switch *ds,
int nr_stats, int stat,
struct mv88e6xxx_hw_stat *stats, struct mv88e6xxx_hw_stat *stats,
int port, uint64_t *data) int port)
{ {
struct mv88e6xxx_priv_state *ps = ds_to_priv(ds); struct mv88e6xxx_hw_stat *s = stats + stat;
int ret;
int i;
mutex_lock(&ps->smi_mutex);
ret = _mv88e6xxx_stats_snapshot(ds, port);
if (ret < 0) {
mutex_unlock(&ps->smi_mutex);
return;
}
/* Read each of the counters. */
for (i = 0; i < nr_stats; i++) {
struct mv88e6xxx_hw_stat *s = stats + i;
u32 low; u32 low;
u32 high = 0; u32 high = 0;
int ret;
u64 value;
if (s->reg >= 0x100) { if (s->reg >= 0x100) {
ret = _mv88e6xxx_reg_read(ds, REG_PORT(port), ret = _mv88e6xxx_reg_read(ds, REG_PORT(port),
s->reg - 0x100); s->reg - 0x100);
if (ret < 0) if (ret < 0)
goto error; return UINT64_MAX;
low = ret; low = ret;
if (s->sizeof_stat == 4) { if (s->sizeof_stat == 4) {
ret = _mv88e6xxx_reg_read(ds, REG_PORT(port), ret = _mv88e6xxx_reg_read(ds, REG_PORT(port),
s->reg - 0x100 + 1); s->reg - 0x100 + 1);
if (ret < 0) if (ret < 0)
goto error; return UINT64_MAX;
high = ret; high = ret;
} }
data[i] = (((u64)high) << 16) | low; } else {
continue;
}
_mv88e6xxx_stats_read(ds, s->reg, &low); _mv88e6xxx_stats_read(ds, s->reg, &low);
if (s->sizeof_stat == 8) if (s->sizeof_stat == 8)
_mv88e6xxx_stats_read(ds, s->reg + 1, &high); _mv88e6xxx_stats_read(ds, s->reg + 1, &high);
}
value = (((u64)high) << 16) | low;
return value;
}
static void _mv88e6xxx_get_ethtool_stats(struct dsa_switch *ds,
int nr_stats,
struct mv88e6xxx_hw_stat *stats,
int port, uint64_t *data)
{
struct mv88e6xxx_priv_state *ps = ds_to_priv(ds);
int ret;
int i;
mutex_lock(&ps->smi_mutex);
data[i] = (((u64)high) << 32) | low; ret = _mv88e6xxx_stats_snapshot(ds, port);
if (ret < 0) {
mutex_unlock(&ps->smi_mutex);
return;
} }
error:
/* Read each of the counters. */
for (i = 0; i < nr_stats; i++)
data[i] = _mv88e6xxx_get_ethtool_stat(ds, i, stats, port);
mutex_unlock(&ps->smi_mutex); mutex_unlock(&ps->smi_mutex);
} }
......
...@@ -11,6 +11,10 @@ ...@@ -11,6 +11,10 @@
#ifndef __MV88E6XXX_H #ifndef __MV88E6XXX_H
#define __MV88E6XXX_H #define __MV88E6XXX_H
#ifndef UINT64_MAX
#define UINT64_MAX (u64)(~((u64)0))
#endif
#define SMI_CMD 0x00 #define SMI_CMD 0x00
#define SMI_CMD_BUSY BIT(15) #define SMI_CMD_BUSY BIT(15)
#define SMI_CMD_CLAUSE_22 BIT(12) #define SMI_CMD_CLAUSE_22 BIT(12)
......
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