Commit 57d1ef38 authored by Vivien Didelot's avatar Vivien Didelot Committed by David S. Miller

net: dsa: mv88e6xxx: prefix Global Stats macros

Prefix and document the Global Stats Operation and Counter registers and
give them a clear 16-bit registers representation.
Signed-off-by: default avatarVivien Didelot <vivien.didelot@savoirfairelinux.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 101515c8
...@@ -725,7 +725,7 @@ static void mv88e6095_stats_get_stats(struct mv88e6xxx_chip *chip, int port, ...@@ -725,7 +725,7 @@ static void mv88e6095_stats_get_stats(struct mv88e6xxx_chip *chip, int port,
{ {
return mv88e6xxx_stats_get_stats(chip, port, data, return mv88e6xxx_stats_get_stats(chip, port, data,
STATS_TYPE_BANK0 | STATS_TYPE_PORT, STATS_TYPE_BANK0 | STATS_TYPE_PORT,
0, GLOBAL_STATS_OP_HIST_RX_TX); 0, MV88E6XXX_G1_STATS_OP_HIST_RX_TX);
} }
static void mv88e6320_stats_get_stats(struct mv88e6xxx_chip *chip, int port, static void mv88e6320_stats_get_stats(struct mv88e6xxx_chip *chip, int port,
...@@ -733,8 +733,8 @@ static void mv88e6320_stats_get_stats(struct mv88e6xxx_chip *chip, int port, ...@@ -733,8 +733,8 @@ static void mv88e6320_stats_get_stats(struct mv88e6xxx_chip *chip, int port,
{ {
return mv88e6xxx_stats_get_stats(chip, port, data, return mv88e6xxx_stats_get_stats(chip, port, data,
STATS_TYPE_BANK0 | STATS_TYPE_BANK1, STATS_TYPE_BANK0 | STATS_TYPE_BANK1,
GLOBAL_STATS_OP_BANK_1_BIT_9, MV88E6XXX_G1_STATS_OP_BANK_1_BIT_9,
GLOBAL_STATS_OP_HIST_RX_TX); MV88E6XXX_G1_STATS_OP_HIST_RX_TX);
} }
static void mv88e6390_stats_get_stats(struct mv88e6xxx_chip *chip, int port, static void mv88e6390_stats_get_stats(struct mv88e6xxx_chip *chip, int port,
...@@ -742,7 +742,8 @@ static void mv88e6390_stats_get_stats(struct mv88e6xxx_chip *chip, int port, ...@@ -742,7 +742,8 @@ static void mv88e6390_stats_get_stats(struct mv88e6xxx_chip *chip, int port,
{ {
return mv88e6xxx_stats_get_stats(chip, port, data, return mv88e6xxx_stats_get_stats(chip, port, data,
STATS_TYPE_BANK0 | STATS_TYPE_BANK1, STATS_TYPE_BANK0 | STATS_TYPE_BANK1,
GLOBAL_STATS_OP_BANK_1_BIT_10, 0); MV88E6XXX_G1_STATS_OP_BANK_1_BIT_10,
0);
} }
static void mv88e6xxx_get_stats(struct mv88e6xxx_chip *chip, int port, static void mv88e6xxx_get_stats(struct mv88e6xxx_chip *chip, int port,
...@@ -2057,8 +2058,9 @@ static int mv88e6xxx_g1_setup(struct mv88e6xxx_chip *chip) ...@@ -2057,8 +2058,9 @@ static int mv88e6xxx_g1_setup(struct mv88e6xxx_chip *chip)
return err; return err;
/* Clear the statistics counters for all ports */ /* Clear the statistics counters for all ports */
err = mv88e6xxx_g1_write(chip, GLOBAL_STATS_OP, err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_STATS_OP,
GLOBAL_STATS_OP_FLUSH_ALL); MV88E6XXX_G1_STATS_OP_BUSY |
MV88E6XXX_G1_STATS_OP_FLUSH_ALL);
if (err) if (err)
return err; return err;
......
...@@ -370,7 +370,8 @@ int mv88e6390_g1_stats_set_histogram(struct mv88e6xxx_chip *chip) ...@@ -370,7 +370,8 @@ int mv88e6390_g1_stats_set_histogram(struct mv88e6xxx_chip *chip)
int mv88e6xxx_g1_stats_wait(struct mv88e6xxx_chip *chip) int mv88e6xxx_g1_stats_wait(struct mv88e6xxx_chip *chip)
{ {
return mv88e6xxx_g1_wait(chip, GLOBAL_STATS_OP, GLOBAL_STATS_OP_BUSY); return mv88e6xxx_g1_wait(chip, MV88E6XXX_G1_STATS_OP,
MV88E6XXX_G1_STATS_OP_BUSY);
} }
int mv88e6xxx_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port) int mv88e6xxx_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port)
...@@ -378,9 +379,10 @@ int mv88e6xxx_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port) ...@@ -378,9 +379,10 @@ int mv88e6xxx_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port)
int err; int err;
/* Snapshot the hardware statistics counters for this port. */ /* Snapshot the hardware statistics counters for this port. */
err = mv88e6xxx_g1_write(chip, GLOBAL_STATS_OP, err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_STATS_OP,
GLOBAL_STATS_OP_CAPTURE_PORT | MV88E6XXX_G1_STATS_OP_BUSY |
GLOBAL_STATS_OP_HIST_RX_TX | port); MV88E6XXX_G1_STATS_OP_CAPTURE_PORT |
MV88E6XXX_G1_STATS_OP_HIST_RX_TX | port);
if (err) if (err)
return err; return err;
...@@ -402,8 +404,9 @@ int mv88e6390_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port) ...@@ -402,8 +404,9 @@ int mv88e6390_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port)
port = (port + 1) << 5; port = (port + 1) << 5;
/* Snapshot the hardware statistics counters for this port. */ /* Snapshot the hardware statistics counters for this port. */
err = mv88e6xxx_g1_write(chip, GLOBAL_STATS_OP, err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_STATS_OP,
GLOBAL_STATS_OP_CAPTURE_PORT | port); MV88E6XXX_G1_STATS_OP_BUSY |
MV88E6XXX_G1_STATS_OP_CAPTURE_PORT | port);
if (err) if (err)
return err; return err;
...@@ -419,8 +422,9 @@ void mv88e6xxx_g1_stats_read(struct mv88e6xxx_chip *chip, int stat, u32 *val) ...@@ -419,8 +422,9 @@ void mv88e6xxx_g1_stats_read(struct mv88e6xxx_chip *chip, int stat, u32 *val)
*val = 0; *val = 0;
err = mv88e6xxx_g1_write(chip, GLOBAL_STATS_OP, err = mv88e6xxx_g1_write(chip, MV88E6XXX_G1_STATS_OP,
GLOBAL_STATS_OP_READ_CAPTURED | stat); MV88E6XXX_G1_STATS_OP_BUSY |
MV88E6XXX_G1_STATS_OP_READ_CAPTURED | stat);
if (err) if (err)
return; return;
...@@ -428,13 +432,13 @@ void mv88e6xxx_g1_stats_read(struct mv88e6xxx_chip *chip, int stat, u32 *val) ...@@ -428,13 +432,13 @@ void mv88e6xxx_g1_stats_read(struct mv88e6xxx_chip *chip, int stat, u32 *val)
if (err) if (err)
return; return;
err = mv88e6xxx_g1_read(chip, GLOBAL_STATS_COUNTER_32, &reg); err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_STATS_COUNTER_32, &reg);
if (err) if (err)
return; return;
value = reg << 16; value = reg << 16;
err = mv88e6xxx_g1_read(chip, GLOBAL_STATS_COUNTER_01, &reg); err = mv88e6xxx_g1_read(chip, MV88E6XXX_G1_STATS_COUNTER_01, &reg);
if (err) if (err)
return; return;
......
...@@ -186,20 +186,25 @@ ...@@ -186,20 +186,25 @@
#define MV88E6XXX_G1_CTL2_HIST_TX 0x0080 #define MV88E6XXX_G1_CTL2_HIST_TX 0x0080
#define MV88E6XXX_G1_CTL2_HIST_RX_TX 0x00c0 #define MV88E6XXX_G1_CTL2_HIST_RX_TX 0x00c0
#define GLOBAL_STATS_OP 0x1d /* Offset 0x1D: Stats Operation Register */
#define GLOBAL_STATS_OP_BUSY BIT(15) #define MV88E6XXX_G1_STATS_OP 0x1d
#define GLOBAL_STATS_OP_NOP (0 << 12) #define MV88E6XXX_G1_STATS_OP_BUSY 0x8000
#define GLOBAL_STATS_OP_FLUSH_ALL ((1 << 12) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_NOP 0x0000
#define GLOBAL_STATS_OP_FLUSH_PORT ((2 << 12) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_FLUSH_ALL 0x1000
#define GLOBAL_STATS_OP_READ_CAPTURED ((4 << 12) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_FLUSH_PORT 0x2000
#define GLOBAL_STATS_OP_CAPTURE_PORT ((5 << 12) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_READ_CAPTURED 0x4000
#define GLOBAL_STATS_OP_HIST_RX ((1 << 10) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_CAPTURE_PORT 0x5000
#define GLOBAL_STATS_OP_HIST_TX ((2 << 10) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_HIST_RX 0x0400
#define GLOBAL_STATS_OP_HIST_RX_TX ((3 << 10) | GLOBAL_STATS_OP_BUSY) #define MV88E6XXX_G1_STATS_OP_HIST_TX 0x0800
#define GLOBAL_STATS_OP_BANK_1_BIT_9 BIT(9) #define MV88E6XXX_G1_STATS_OP_HIST_RX_TX 0x0c00
#define GLOBAL_STATS_OP_BANK_1_BIT_10 BIT(10) #define MV88E6XXX_G1_STATS_OP_BANK_1_BIT_9 0x0200
#define GLOBAL_STATS_COUNTER_32 0x1e #define MV88E6XXX_G1_STATS_OP_BANK_1_BIT_10 0x0400
#define GLOBAL_STATS_COUNTER_01 0x1f
/* Offset 0x1E: Stats Counter Register Bytes 3 & 2
* Offset 0x1F: Stats Counter Register Bytes 1 & 0
*/
#define MV88E6XXX_G1_STATS_COUNTER_32 0x1e
#define MV88E6XXX_G1_STATS_COUNTER_01 0x1f
int mv88e6xxx_g1_read(struct mv88e6xxx_chip *chip, int reg, u16 *val); int mv88e6xxx_g1_read(struct mv88e6xxx_chip *chip, int reg, u16 *val);
int mv88e6xxx_g1_write(struct mv88e6xxx_chip *chip, int reg, u16 val); int mv88e6xxx_g1_write(struct mv88e6xxx_chip *chip, int reg, u16 val);
......
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