mirror of
https://github.com/openwrt/openwrt.git
synced 2025-02-18 16:40:29 +00:00
kernel: report mediatek ppe flow stats incrementally
Fixes wrong counter values in conntrack stats Fixes: aa2777145f8d ("kernel: improve mtk ppe flow accounting") Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
eeaa71a3de
commit
be54fa2680
@ -91,7 +91,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
}
|
}
|
||||||
entry->hash = 0xffff;
|
entry->hash = 0xffff;
|
||||||
|
|
||||||
@@ -540,8 +548,10 @@ static int __mtk_foe_entry_idle_time(str
|
@@ -540,11 +548,14 @@ static int __mtk_foe_entry_idle_time(str
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
@ -103,68 +103,77 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
struct mtk_foe_entry foe = {};
|
struct mtk_foe_entry foe = {};
|
||||||
struct mtk_foe_entry *hwe;
|
struct mtk_foe_entry *hwe;
|
||||||
u16 hash = entry->hash;
|
u16 hash = entry->hash;
|
||||||
@@ -555,16 +565,29 @@ mtk_flow_entry_update(struct mtk_ppe *pp
|
+ bool ret = false;
|
||||||
|
int len;
|
||||||
|
|
||||||
|
if (hash == 0xffff)
|
||||||
|
@@ -555,18 +566,35 @@ mtk_flow_entry_update(struct mtk_ppe *pp
|
||||||
memcpy(&foe, hwe, len);
|
memcpy(&foe, hwe, len);
|
||||||
|
|
||||||
if (!mtk_flow_entry_match(ppe->eth, entry, &foe, len) ||
|
if (!mtk_flow_entry_match(ppe->eth, entry, &foe, len) ||
|
||||||
- FIELD_GET(MTK_FOE_IB1_STATE, foe.ib1) != MTK_FOE_STATE_BIND)
|
- FIELD_GET(MTK_FOE_IB1_STATE, foe.ib1) != MTK_FOE_STATE_BIND)
|
||||||
|
- return false;
|
||||||
+ FIELD_GET(MTK_FOE_IB1_STATE, foe.ib1) != MTK_FOE_STATE_BIND) {
|
+ FIELD_GET(MTK_FOE_IB1_STATE, foe.ib1) != MTK_FOE_STATE_BIND) {
|
||||||
+ acct = mtk_ppe_acct_data(ppe, hash);
|
+ acct = mtk_ppe_acct_data(ppe, hash);
|
||||||
+ if (acct) {
|
+ if (acct) {
|
||||||
+ entry->packets += acct->packets;
|
+ entry->prev_packets += acct->packets;
|
||||||
+ entry->bytes += acct->bytes;
|
+ entry->prev_bytes += acct->bytes;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
return false;
|
+ goto out;
|
||||||
+ }
|
+ }
|
||||||
|
|
||||||
entry->data.ib1 = foe.ib1;
|
entry->data.ib1 = foe.ib1;
|
||||||
+ acct = mtk_ppe_mib_entry_read(ppe, hash);
|
+ acct = mtk_ppe_mib_entry_read(ppe, hash);
|
||||||
|
+ ret = true;
|
||||||
|
+
|
||||||
|
+out:
|
||||||
+ if (acct) {
|
+ if (acct) {
|
||||||
+ *packets += acct->packets;
|
+ *packets += acct->packets;
|
||||||
+ *bytes += acct->bytes;
|
+ *bytes += acct->bytes;
|
||||||
+ }
|
+ }
|
||||||
|
|
||||||
return true;
|
- return true;
|
||||||
|
+ return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
-mtk_flow_entry_update_l2(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
|
mtk_flow_entry_update_l2(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
|
||||||
+mtk_flow_entry_update_l2(struct mtk_ppe *ppe, struct mtk_flow_entry *entry,
|
|
||||||
+ u64 *packets, u64 *bytes)
|
|
||||||
{
|
{
|
||||||
u32 ib1_ts_mask = mtk_get_ib1_ts_mask(ppe->eth);
|
u32 ib1_ts_mask = mtk_get_ib1_ts_mask(ppe->eth);
|
||||||
|
+ u64 *packets = &entry->packets;
|
||||||
|
+ u64 *bytes = &entry->bytes;
|
||||||
struct mtk_flow_entry *cur;
|
struct mtk_flow_entry *cur;
|
||||||
@@ -575,7 +598,9 @@ mtk_flow_entry_update_l2(struct mtk_ppe
|
struct hlist_node *tmp;
|
||||||
|
int idle;
|
||||||
|
@@ -575,7 +603,9 @@ mtk_flow_entry_update_l2(struct mtk_ppe
|
||||||
hlist_for_each_entry_safe(cur, tmp, &entry->l2_flows, list) {
|
hlist_for_each_entry_safe(cur, tmp, &entry->l2_flows, list) {
|
||||||
int cur_idle;
|
int cur_idle;
|
||||||
|
|
||||||
- if (!mtk_flow_entry_update(ppe, cur)) {
|
- if (!mtk_flow_entry_update(ppe, cur)) {
|
||||||
+ if (!mtk_flow_entry_update(ppe, cur, packets, bytes)) {
|
+ if (!mtk_flow_entry_update(ppe, cur, packets, bytes)) {
|
||||||
+ entry->packets += cur->packets;
|
+ entry->prev_packets += cur->prev_packets;
|
||||||
+ entry->bytes += cur->bytes;
|
+ entry->prev_bytes += cur->prev_bytes;
|
||||||
__mtk_foe_entry_clear(ppe, entry, false);
|
__mtk_foe_entry_clear(ppe, entry, false);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@@ -590,10 +615,31 @@ mtk_flow_entry_update_l2(struct mtk_ppe
|
@@ -590,10 +620,29 @@ mtk_flow_entry_update_l2(struct mtk_ppe
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
+void mtk_foe_entry_get_stats(struct mtk_ppe *ppe, struct mtk_flow_entry *entry,
|
+void mtk_foe_entry_get_stats(struct mtk_ppe *ppe, struct mtk_flow_entry *entry,
|
||||||
+ int *idle, u64 *packets, u64 *bytes)
|
+ int *idle)
|
||||||
+{
|
+{
|
||||||
+ *packets = 0;
|
+ entry->packets = entry->prev_packets;
|
||||||
+ *bytes = 0;
|
+ entry->bytes = entry->prev_bytes;
|
||||||
+
|
+
|
||||||
+ spin_lock_bh(&ppe_lock);
|
+ spin_lock_bh(&ppe_lock);
|
||||||
+
|
+
|
||||||
+ if (entry->type == MTK_FLOW_TYPE_L2)
|
+ if (entry->type == MTK_FLOW_TYPE_L2)
|
||||||
+ mtk_flow_entry_update_l2(ppe, entry, packets, bytes);
|
+ mtk_flow_entry_update_l2(ppe, entry);
|
||||||
+ else
|
+ else
|
||||||
+ mtk_flow_entry_update(ppe, entry, packets, bytes);
|
+ mtk_flow_entry_update(ppe, entry, &entry->packets, &entry->bytes);
|
||||||
+
|
+
|
||||||
+ *packets += entry->packets;
|
|
||||||
+ *bytes += entry->bytes;
|
|
||||||
+ *idle = __mtk_foe_entry_idle_time(ppe, entry->data.ib1);
|
+ *idle = __mtk_foe_entry_idle_time(ppe, entry->data.ib1);
|
||||||
+
|
+
|
||||||
+ spin_unlock_bh(&ppe_lock);
|
+ spin_unlock_bh(&ppe_lock);
|
||||||
@ -178,7 +187,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
struct mtk_eth *eth = ppe->eth;
|
struct mtk_eth *eth = ppe->eth;
|
||||||
u16 timestamp = mtk_eth_timestamp(eth);
|
u16 timestamp = mtk_eth_timestamp(eth);
|
||||||
struct mtk_foe_entry *hwe;
|
struct mtk_foe_entry *hwe;
|
||||||
@@ -618,6 +664,12 @@ __mtk_foe_entry_commit(struct mtk_ppe *p
|
@@ -618,6 +667,12 @@ __mtk_foe_entry_commit(struct mtk_ppe *p
|
||||||
|
|
||||||
dma_wmb();
|
dma_wmb();
|
||||||
|
|
||||||
@ -191,7 +200,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
mtk_ppe_cache_clear(ppe);
|
mtk_ppe_cache_clear(ppe);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -782,21 +834,6 @@ out:
|
@@ -782,21 +837,6 @@ out:
|
||||||
spin_unlock_bh(&ppe_lock);
|
spin_unlock_bh(&ppe_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -213,7 +222,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
int mtk_ppe_prepare_reset(struct mtk_ppe *ppe)
|
int mtk_ppe_prepare_reset(struct mtk_ppe *ppe)
|
||||||
{
|
{
|
||||||
if (!ppe)
|
if (!ppe)
|
||||||
@@ -824,32 +861,6 @@ int mtk_ppe_prepare_reset(struct mtk_ppe
|
@@ -824,32 +864,6 @@ int mtk_ppe_prepare_reset(struct mtk_ppe
|
||||||
return mtk_ppe_wait_busy(ppe);
|
return mtk_ppe_wait_busy(ppe);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -252,8 +261,8 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
struct mtk_foe_entry data;
|
struct mtk_foe_entry data;
|
||||||
struct rhash_head node;
|
struct rhash_head node;
|
||||||
unsigned long cookie;
|
unsigned long cookie;
|
||||||
+ u64 packets;
|
+ u64 prev_packets, prev_bytes;
|
||||||
+ u64 bytes;
|
+ u64 packets, bytes;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct mtk_mib_entry {
|
struct mtk_mib_entry {
|
||||||
@ -274,7 +283,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
-struct mtk_foe_accounting *mtk_foe_entry_get_mib(struct mtk_ppe *ppe, u32 index,
|
-struct mtk_foe_accounting *mtk_foe_entry_get_mib(struct mtk_ppe *ppe, u32 index,
|
||||||
- struct mtk_foe_accounting *diff);
|
- struct mtk_foe_accounting *diff);
|
||||||
+void mtk_foe_entry_get_stats(struct mtk_ppe *ppe, struct mtk_flow_entry *entry,
|
+void mtk_foe_entry_get_stats(struct mtk_ppe *ppe, struct mtk_flow_entry *entry,
|
||||||
+ int *idle, u64 *packets, u64 *bytes);
|
+ int *idle);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_ppe_debugfs.c
|
--- a/drivers/net/ethernet/mediatek/mtk_ppe_debugfs.c
|
||||||
@ -290,12 +299,13 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
seq_printf(m, "%05x %s %7s", i,
|
seq_printf(m, "%05x %s %7s", i,
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_ppe_offload.c
|
--- a/drivers/net/ethernet/mediatek/mtk_ppe_offload.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_ppe_offload.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_ppe_offload.c
|
||||||
@@ -499,24 +499,17 @@ static int
|
@@ -499,24 +499,21 @@ static int
|
||||||
mtk_flow_offload_stats(struct mtk_eth *eth, struct flow_cls_offload *f)
|
mtk_flow_offload_stats(struct mtk_eth *eth, struct flow_cls_offload *f)
|
||||||
{
|
{
|
||||||
struct mtk_flow_entry *entry;
|
struct mtk_flow_entry *entry;
|
||||||
- struct mtk_foe_accounting diff;
|
- struct mtk_foe_accounting diff;
|
||||||
- u32 idle;
|
- u32 idle;
|
||||||
|
+ u64 packets, bytes;
|
||||||
+ int idle;
|
+ int idle;
|
||||||
|
|
||||||
entry = rhashtable_lookup(ð->flow_table, &f->cookie,
|
entry = rhashtable_lookup(ð->flow_table, &f->cookie,
|
||||||
@ -304,8 +314,11 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
|
|
||||||
- idle = mtk_foe_entry_idle_time(eth->ppe[entry->ppe_index], entry);
|
- idle = mtk_foe_entry_idle_time(eth->ppe[entry->ppe_index], entry);
|
||||||
+ mtk_foe_entry_get_stats(eth->ppe[entry->ppe_index], entry, &idle,
|
+ packets = entry->packets;
|
||||||
+ &f->stats.pkts, &f->stats.bytes);
|
+ bytes = entry->bytes;
|
||||||
|
+ mtk_foe_entry_get_stats(eth->ppe[entry->ppe_index], entry, &idle);
|
||||||
|
+ f->stats.pkts += entry->packets - packets;
|
||||||
|
+ f->stats.bytes += entry->bytes - bytes;
|
||||||
f->stats.lastused = jiffies - idle * HZ;
|
f->stats.lastused = jiffies - idle * HZ;
|
||||||
|
|
||||||
- if (entry->hash != 0xFFFF &&
|
- if (entry->hash != 0xFFFF &&
|
||||||
|
Loading…
x
Reference in New Issue
Block a user