From: Robert Beckett <bob.beckett@collabora.com>
To: netdev@vger.kernel.org
Cc: Robert Beckett <bob.beckett@collabora.com>,
Andrew Lunn <andrew@lunn.ch>,
Vivien Didelot <vivien.didelot@gmail.com>,
Florian Fainelli <f.fainelli@gmail.com>,
"David S. Miller" <davem@davemloft.net>
Subject: [PATCH 6/7] net: dsa: mv88e6xxx: add egress rate limiting
Date: Tue, 10 Sep 2019 16:41:52 +0100 [thread overview]
Message-ID: <20190910154238.9155-7-bob.beckett@collabora.com> (raw)
In-Reply-To: <20190910154238.9155-1-bob.beckett@collabora.com>
Add code for specifying egress rate limiting per port.
The rate can be specified as ethernet frames or bits per second.
Signed-off-by: Robert Beckett <bob.beckett@collabora.com>
---
drivers/net/dsa/mv88e6xxx/chip.c | 72 ++++++++++++++-------
drivers/net/dsa/mv88e6xxx/chip.h | 3 +-
drivers/net/dsa/mv88e6xxx/port.c | 106 ++++++++++++++++++++++++++++---
drivers/net/dsa/mv88e6xxx/port.h | 14 +++-
4 files changed, 158 insertions(+), 37 deletions(-)
diff --git a/drivers/net/dsa/mv88e6xxx/chip.c b/drivers/net/dsa/mv88e6xxx/chip.c
index 2bc22c59200c..8c116496ab2f 100644
--- a/drivers/net/dsa/mv88e6xxx/chip.c
+++ b/drivers/net/dsa/mv88e6xxx/chip.c
@@ -2120,6 +2120,32 @@ static int mv88e6xxx_set_port_sched(struct mv88e6xxx_chip *chip, int port)
return chip->info->ops->port_set_sched(chip, port, (u16)sched);
}
+static int mv88e6xxx_set_port_egress_rate_limiting(struct mv88e6xxx_chip *chip,
+ int port)
+{
+ struct dsa_switch *ds = chip->ds;
+ struct device_node *dn = ds->ports[port].dn;
+ int err;
+ u32 mode, count;
+
+ if (!dn || !chip->info->ops->port_egress_rate_limiting)
+ return 0;
+
+ err = of_property_read_u32(dn, "egress-limit-mode", &mode);
+ if (err < 0)
+ goto disable;
+
+ err = of_property_read_u32(dn, "egress-limit-count", &count);
+ if (err < 0)
+ goto disable;
+
+ return chip->info->ops->port_egress_rate_limiting(chip, port, count,
+ mode);
+
+disable:
+ return chip->info->ops->port_egress_rate_limiting(chip, port, 0, 0);
+}
+
static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
{
struct dsa_switch *ds = chip->ds;
@@ -2263,11 +2289,9 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
return err;
}
- if (chip->info->ops->port_egress_rate_limiting) {
- err = chip->info->ops->port_egress_rate_limiting(chip, port);
- if (err)
- return err;
- }
+ err = mv88e6xxx_set_port_egress_rate_limiting(chip, port);
+ if (err)
+ return err;
err = mv88e6xxx_setup_message_port(chip, port);
if (err)
@@ -2809,7 +2833,7 @@ static const struct mv88e6xxx_ops mv88e6085_ops = {
.port_set_frame_mode = mv88e6351_port_set_frame_mode,
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -2879,7 +2903,7 @@ static const struct mv88e6xxx_ops mv88e6097_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6095_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -2951,7 +2975,7 @@ static const struct mv88e6xxx_ops mv88e6131_ops = {
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_upstream_port = mv88e6095_port_set_upstream_port,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_set_pause = mv88e6185_port_set_pause,
.port_link_state = mv88e6352_port_link_state,
@@ -2994,7 +3018,7 @@ static const struct mv88e6xxx_ops mv88e6141_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3034,7 +3058,7 @@ static const struct mv88e6xxx_ops mv88e6161_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3108,7 +3132,7 @@ static const struct mv88e6xxx_ops mv88e6171_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3150,7 +3174,7 @@ static const struct mv88e6xxx_ops mv88e6172_ops = {
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
.port_set_defqpri = mv88e6xxx_port_set_defqpri,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_set_sched = mv88e6xxx_port_set_sched,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
@@ -3193,7 +3217,7 @@ static const struct mv88e6xxx_ops mv88e6175_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3235,7 +3259,7 @@ static const struct mv88e6xxx_ops mv88e6176_ops = {
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
.port_set_defqpri = mv88e6xxx_port_set_defqpri,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_set_sched = mv88e6xxx_port_set_sched,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
@@ -3275,7 +3299,7 @@ static const struct mv88e6xxx_ops mv88e6185_ops = {
.port_set_speed = mv88e6185_port_set_speed,
.port_set_frame_mode = mv88e6085_port_set_frame_mode,
.port_set_egress_floods = mv88e6185_port_set_egress_floods,
- .port_egress_rate_limiting = mv88e6095_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_set_upstream_port = mv88e6095_port_set_upstream_port,
.port_set_pause = mv88e6185_port_set_pause,
.port_link_state = mv88e6185_port_link_state,
@@ -3454,7 +3478,7 @@ static const struct mv88e6xxx_ops mv88e6240_ops = {
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
.port_set_defqpri = mv88e6xxx_port_set_defqpri,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_set_sched = mv88e6xxx_port_set_sched,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
@@ -3587,7 +3611,7 @@ static const struct mv88e6xxx_ops mv88e6320_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3630,7 +3654,7 @@ static const struct mv88e6xxx_ops mv88e6321_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3673,7 +3697,7 @@ static const struct mv88e6xxx_ops mv88e6341_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3716,7 +3740,7 @@ static const struct mv88e6xxx_ops mv88e6350_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3755,7 +3779,7 @@ static const struct mv88e6xxx_ops mv88e6351_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3799,7 +3823,7 @@ static const struct mv88e6xxx_ops mv88e6352_ops = {
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
.port_set_defqpri = mv88e6xxx_port_set_defqpri,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_set_sched = mv88e6xxx_port_set_sched,
.port_pause_limit = mv88e6097_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
@@ -3851,7 +3875,7 @@ static const struct mv88e6xxx_ops mv88e6390_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6390_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
@@ -3900,7 +3924,7 @@ static const struct mv88e6xxx_ops mv88e6390x_ops = {
.port_set_egress_floods = mv88e6352_port_set_egress_floods,
.port_set_ether_type = mv88e6351_port_set_ether_type,
.port_set_jumbo_size = mv88e6165_port_set_jumbo_size,
- .port_egress_rate_limiting = mv88e6097_port_egress_rate_limiting,
+ .port_egress_rate_limiting = mv88e6xxx_port_egress_rate_limiting,
.port_pause_limit = mv88e6390_port_pause_limit,
.port_disable_learn_limit = mv88e6xxx_port_disable_learn_limit,
.port_disable_pri_override = mv88e6xxx_port_disable_pri_override,
diff --git a/drivers/net/dsa/mv88e6xxx/chip.h b/drivers/net/dsa/mv88e6xxx/chip.h
index ff3e35eceee0..75fbd5df4aae 100644
--- a/drivers/net/dsa/mv88e6xxx/chip.h
+++ b/drivers/net/dsa/mv88e6xxx/chip.h
@@ -385,7 +385,8 @@ struct mv88e6xxx_ops {
size_t size);
int (*port_set_defqpri)(struct mv88e6xxx_chip *chip, int port, u16 pri);
- int (*port_egress_rate_limiting)(struct mv88e6xxx_chip *chip, int port);
+ int (*port_egress_rate_limiting)(struct mv88e6xxx_chip *chip, int port,
+ u32 count, u32 mode);
int (*port_set_sched)(struct mv88e6xxx_chip *chip, int port, u16 sched);
int (*port_pause_limit)(struct mv88e6xxx_chip *chip, int port, u8 in,
u8 out);
diff --git a/drivers/net/dsa/mv88e6xxx/port.c b/drivers/net/dsa/mv88e6xxx/port.c
index 236732fc598d..41418cfaca56 100644
--- a/drivers/net/dsa/mv88e6xxx/port.c
+++ b/drivers/net/dsa/mv88e6xxx/port.c
@@ -1166,21 +1166,107 @@ int mv88e6xxx_port_set_defqpri(struct mv88e6xxx_chip *chip, int port, u16 pri)
return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_CTL2, reg);
}
-/* Offset 0x09: Port Rate Control */
+/* Offset 0x09: Port Rate Control
+ * Offset 0x0A: Egress Rate Control 2
+ */
-int mv88e6095_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port)
+#define Kb 1000
+#define Mb (1000 * Kb)
+#define Gb (1000ull * Mb)
+#define EGRESS_FRAME_RATE_MIN 7632
+#define EGRESS_FRAME_RATE_MAX 31250000
+#define EGRESS_BPS_RATE_MIN (64 * Kb)
+#define EGRESS_BPS_RATE_MAX (1 * Gb)
+#define EGRESS_RATE_PERIOD 32
+int mv88e6xxx_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port,
+ u32 count, u32 mode)
{
- return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL1,
- 0x0000);
-}
+ u16 reg1, reg2;
+ int err;
-int mv88e6097_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port)
-{
- return mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL1,
- 0x0001);
+ /* quick exit for disabling */
+ if (count == 0) {
+ err = mv88e6xxx_port_read(chip, port,
+ MV88E6XXX_PORT_EGRESS_RATE_CTL2,
+ ®2);
+ if (err)
+ return err;
+ reg2 &= ~MV88E6XXX_PORT_EGRESS_RATE_MASK;
+ err = mv88e6xxx_port_write(chip, port,
+ MV88E6XXX_PORT_EGRESS_RATE_CTL2,
+ reg2);
+ return err;
+ }
+
+ if (mode > MV88E6XXX_PORT_EGRESS_COUNT_MODE_L3)
+ return -EINVAL;
+
+ if (mode == MV88E6XXX_PORT_EGRESS_COUNT_MODE_FRAMES &&
+ (count < EGRESS_FRAME_RATE_MIN || count > EGRESS_FRAME_RATE_MAX))
+ return -EINVAL;
+
+ if (mode != MV88E6XXX_PORT_EGRESS_COUNT_MODE_FRAMES &&
+ (count < EGRESS_BPS_RATE_MIN || count > EGRESS_BPS_RATE_MAX))
+ return -EINVAL;
+
+ err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL1,
+ ®1);
+ if (err)
+ return err;
+
+ err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL2,
+ ®2);
+ if (err)
+ return err;
+
+ reg1 &= ~MV88E6XXX_PORT_EGRESS_DEC_MASK;
+ reg2 &= ~MV88E6XXX_PORT_EGRESS_COUNT_MODE_MASK;
+
+ if (mode == MV88E6XXX_PORT_EGRESS_COUNT_MODE_FRAMES) {
+ u32 val;
+
+ /* recommended to use dec of 1 for frame based */
+ reg1 |= 1 << MV88E6XXX_PORT_EGRESS_DEC_SHIFT;
+
+ reg2 |= mode << MV88E6XXX_PORT_EGRESS_COUNT_MODE_SHIFT;
+ reg2 &= ~MV88E6XXX_PORT_EGRESS_RATE_MASK;
+
+ val = NSEC_PER_SEC / (EGRESS_RATE_PERIOD * count);
+ if (NSEC_PER_SEC % (EGRESS_RATE_PERIOD * count))
+ val++;
+ reg2 |= (u16)(val << MV88E6XXX_PORT_EGRESS_RATE_SHIFT);
+ } else {
+ u16 egress_dec, egress_rate;
+ u64 dec_bytes, ns_bits;
+
+ if (count < (1 * Mb))
+ egress_dec = (u16)roundup(count, (64 * Kb));
+ else if (count < (100 * Mb))
+ egress_dec = (u16)roundup(count, (1 * Mb));
+ else
+ egress_dec = (u16)roundup(count, (10 * Mb));
+
+ reg1 |= egress_dec;
+
+ dec_bytes = 8ull * NSEC_PER_SEC * egress_dec;
+ ns_bits = 32ull * count;
+ egress_rate = (u16)div64_u64(dec_bytes, ns_bits);
+ reg2 |= egress_rate;
+ }
+
+ err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL1,
+ reg1);
+ if (err)
+ return err;
+
+ err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_EGRESS_RATE_CTL2,
+ reg2);
+ if (err)
+ return err;
+
+ return 0;
}
-/* Offset 0x0A: Egress Rate Control 2 */
int mv88e6xxx_port_set_sched(struct mv88e6xxx_chip *chip, int port, u16 sched)
{
u16 reg;
diff --git a/drivers/net/dsa/mv88e6xxx/port.h b/drivers/net/dsa/mv88e6xxx/port.h
index 710d6eccafae..724f839c570a 100644
--- a/drivers/net/dsa/mv88e6xxx/port.h
+++ b/drivers/net/dsa/mv88e6xxx/port.h
@@ -205,13 +205,23 @@
/* Offset 0x09: Egress Rate Control */
#define MV88E6XXX_PORT_EGRESS_RATE_CTL1 0x09
+#define MV88E6XXX_PORT_EGRESS_DEC_SHIFT 0
+#define MV88E6XXX_PORT_EGRESS_DEC_MASK 0x7f
/* Offset 0x0A: Egress Rate Control 2 */
#define MV88E6XXX_PORT_EGRESS_RATE_CTL2 0x0a
+#define MV88E6XXX_PORT_EGRESS_COUNT_MODE_SHIFT 14
+#define MV88E6XXX_PORT_EGRESS_COUNT_MODE_MASK \
+ (0x3 << MV88E6XXX_PORT_EGRESS_COUNT_MODE_SHIFT)
+/* see MV88E6XXX_PORT_EGRESS_COUNT_* in
+ * include/dt-bindings/net/dsa-mv88e6xxx.h
+ */
#define MV88E6XXX_PORT_SCHED_SHIFT 12
#define MV88E6XXX_PORT_SCHED_MASK \
(0x3 << MV88E6XXX_PORT_SCHED_SHIFT)
/* see MV88E6XXX_PORT_SCHED_* in include/dt-bindings/net/dsa-mv88e6xxx.h */
+#define MV88E6XXX_PORT_EGRESS_RATE_SHIFT 0
+#define MV88E6XXX_PORT_EGRESS_RATE_MASK 0xfff
/* Offset 0x0B: Port Association Vector */
#define MV88E6XXX_PORT_ASSOC_VECTOR 0x0b
@@ -335,8 +345,8 @@ int mv88e6xxx_port_set_message_port(struct mv88e6xxx_chip *chip, int port,
int mv88e6165_port_set_jumbo_size(struct mv88e6xxx_chip *chip, int port,
size_t size);
int mv88e6xxx_port_set_defqpri(struct mv88e6xxx_chip *chip, int port, u16 pri);
-int mv88e6095_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port);
-int mv88e6097_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port);
+int mv88e6xxx_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port,
+ u32 count, u32 mode);
int mv88e6xxx_port_set_sched(struct mv88e6xxx_chip *chip, int port, u16 sched);
int mv88e6097_port_pause_limit(struct mv88e6xxx_chip *chip, int port, u8 in,
u8 out);
--
2.18.0
next prev parent reply other threads:[~2019-09-10 15:45 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-09-10 15:41 [PATCH 0/7] net: dsa: mv88e6xxx: features to handle network storms Robert Beckett
2019-09-10 15:41 ` [PATCH 1/7] net/dsa: configure autoneg for CPU port Robert Beckett
2019-09-10 16:14 ` Vivien Didelot
2019-09-10 16:56 ` Florian Fainelli
2019-09-10 18:26 ` Andrew Lunn
2019-09-10 18:29 ` Florian Fainelli
2019-09-11 9:16 ` Robert Beckett
2019-09-11 9:54 ` Robert Beckett
2019-09-11 22:52 ` Andrew Lunn
2019-09-12 10:14 ` Robert Beckett
2019-09-12 10:43 ` Andrew Lunn
2019-09-11 11:43 ` kbuild test robot
2019-09-14 7:16 ` kbuild test robot
2019-09-10 15:41 ` [PATCH 2/7] net: dsa: mv88e6xxx: add ability to set default queue priorities per port Robert Beckett
2019-09-10 16:43 ` Vivien Didelot
2019-09-10 15:41 ` [PATCH 3/7] dt-bindings: " Robert Beckett
2019-09-10 16:42 ` Florian Fainelli
2019-09-10 16:49 ` Vivien Didelot
2019-09-10 20:46 ` Vladimir Oltean
2019-09-10 15:41 ` [PATCH 4/7] net: dsa: mv88e6xxx: add ability to set queue scheduling Robert Beckett
2019-09-10 17:18 ` Vivien Didelot
2019-09-10 15:41 ` [PATCH 5/7] dt-bindings: " Robert Beckett
2019-09-10 15:41 ` Robert Beckett [this message]
2019-09-10 17:13 ` [PATCH 6/7] net: dsa: mv88e6xxx: add egress rate limiting Vivien Didelot
2019-09-11 12:26 ` kbuild test robot
2019-09-10 15:41 ` [PATCH 7/7] dt-bindings: " Robert Beckett
2019-09-10 16:49 ` [PATCH 0/7] net: dsa: mv88e6xxx: features to handle network storms Florian Fainelli
2019-09-11 9:43 ` Robert Beckett
2019-09-11 11:21 ` Ido Schimmel
2019-09-11 11:49 ` Robert Beckett
2019-09-11 22:58 ` Andrew Lunn
2019-09-12 9:05 ` Ido Schimmel
2019-09-12 9:03 ` Ido Schimmel
2019-09-12 9:21 ` Andrew Lunn
2019-09-12 16:25 ` Florian Fainelli
2019-09-12 16:46 ` Robert Beckett
2019-09-12 17:41 ` Florian Fainelli
2019-09-13 12:47 ` Robert Beckett
2019-09-10 17:19 ` Vivien Didelot
2019-09-11 9:46 ` Robert Beckett
2019-09-11 15:31 ` Vivien Didelot
2019-09-11 23:01 ` Andrew Lunn
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20190910154238.9155-7-bob.beckett@collabora.com \
--to=bob.beckett@collabora.com \
--cc=andrew@lunn.ch \
--cc=davem@davemloft.net \
--cc=f.fainelli@gmail.com \
--cc=netdev@vger.kernel.org \
--cc=vivien.didelot@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).