mirror of
https://github.com/torvalds/linux.git
synced 2026-06-01 19:13:47 +02:00
net: airoha: Add airoha_ppe_get_num_stats_entries() and airoha_ppe_get_num_total_stats_entries()
Introduce airoha_ppe_get_num_stats_entries and airoha_ppe_get_num_total_stats_entries routines in order to make the code more readable controlling if CONFIG_NET_AIROHA_FLOW_STATS is enabled or disabled. Modify airoha_ppe_foe_get_flow_stats_index routine signature relying on airoha_ppe_get_num_total_stats_entries(). Reviewed-by: Simon Horman <horms@kernel.org> Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org> Link: https://patch.msgid.link/20251017-an7583-eth-support-v3-3-f28319666667@kernel.org Signed-off-by: Paolo Abeni <pabeni@redhat.com>
This commit is contained in:
parent
6d5b601d52
commit
15f357cd45
|
|
@ -50,15 +50,9 @@
|
|||
|
||||
#define PPE_NUM 2
|
||||
#define PPE1_SRAM_NUM_ENTRIES (8 * 1024)
|
||||
#define PPE_SRAM_NUM_ENTRIES (2 * PPE1_SRAM_NUM_ENTRIES)
|
||||
#ifdef CONFIG_NET_AIROHA_FLOW_STATS
|
||||
#define PPE_SRAM_NUM_ENTRIES (PPE_NUM * PPE1_SRAM_NUM_ENTRIES)
|
||||
#define PPE1_STATS_NUM_ENTRIES (4 * 1024)
|
||||
#else
|
||||
#define PPE1_STATS_NUM_ENTRIES 0
|
||||
#endif /* CONFIG_NET_AIROHA_FLOW_STATS */
|
||||
#define PPE_STATS_NUM_ENTRIES (2 * PPE1_STATS_NUM_ENTRIES)
|
||||
#define PPE1_SRAM_NUM_DATA_ENTRIES (PPE1_SRAM_NUM_ENTRIES - PPE1_STATS_NUM_ENTRIES)
|
||||
#define PPE_SRAM_NUM_DATA_ENTRIES (2 * PPE1_SRAM_NUM_DATA_ENTRIES)
|
||||
#define PPE_STATS_NUM_ENTRIES (PPE_NUM * PPE1_STATS_NUM_ENTRIES)
|
||||
#define PPE_DRAM_NUM_ENTRIES (16 * 1024)
|
||||
#define PPE_NUM_ENTRIES (PPE_SRAM_NUM_ENTRIES + PPE_DRAM_NUM_ENTRIES)
|
||||
#define PPE_HASH_MASK (PPE_NUM_ENTRIES - 1)
|
||||
|
|
|
|||
|
|
@ -32,6 +32,24 @@ static const struct rhashtable_params airoha_l2_flow_table_params = {
|
|||
.automatic_shrinking = true,
|
||||
};
|
||||
|
||||
static int airoha_ppe_get_num_stats_entries(struct airoha_ppe *ppe)
|
||||
{
|
||||
if (!IS_ENABLED(CONFIG_NET_AIROHA_FLOW_STATS))
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
return PPE1_STATS_NUM_ENTRIES;
|
||||
}
|
||||
|
||||
static int airoha_ppe_get_total_num_stats_entries(struct airoha_ppe *ppe)
|
||||
{
|
||||
int num_stats = airoha_ppe_get_num_stats_entries(ppe);
|
||||
|
||||
if (num_stats > 0)
|
||||
num_stats = num_stats * PPE_NUM;
|
||||
|
||||
return num_stats;
|
||||
}
|
||||
|
||||
static bool airoha_ppe2_is_enabled(struct airoha_eth *eth)
|
||||
{
|
||||
return airoha_fe_rr(eth, REG_PPE_GLO_CFG(1)) & PPE_GLO_CFG_EN_MASK;
|
||||
|
|
@ -48,7 +66,7 @@ static void airoha_ppe_hw_init(struct airoha_ppe *ppe)
|
|||
{
|
||||
u32 sram_tb_size, sram_num_entries, dram_num_entries;
|
||||
struct airoha_eth *eth = ppe->eth;
|
||||
int i;
|
||||
int i, sram_num_stats_entries;
|
||||
|
||||
sram_tb_size = PPE_SRAM_NUM_ENTRIES * sizeof(struct airoha_foe_entry);
|
||||
dram_num_entries = PPE_RAM_NUM_ENTRIES_SHIFT(PPE_DRAM_NUM_ENTRIES);
|
||||
|
|
@ -103,8 +121,13 @@ static void airoha_ppe_hw_init(struct airoha_ppe *ppe)
|
|||
}
|
||||
|
||||
if (airoha_ppe2_is_enabled(eth)) {
|
||||
sram_num_entries =
|
||||
PPE_RAM_NUM_ENTRIES_SHIFT(PPE1_SRAM_NUM_DATA_ENTRIES);
|
||||
sram_num_entries = PPE1_SRAM_NUM_ENTRIES;
|
||||
sram_num_stats_entries =
|
||||
airoha_ppe_get_num_stats_entries(ppe);
|
||||
if (sram_num_stats_entries > 0)
|
||||
sram_num_entries -= sram_num_stats_entries;
|
||||
sram_num_entries = PPE_RAM_NUM_ENTRIES_SHIFT(sram_num_entries);
|
||||
|
||||
airoha_fe_rmw(eth, REG_PPE_TB_CFG(0),
|
||||
PPE_SRAM_TB_NUM_ENTRY_MASK |
|
||||
PPE_DRAM_TB_NUM_ENTRY_MASK,
|
||||
|
|
@ -120,8 +143,13 @@ static void airoha_ppe_hw_init(struct airoha_ppe *ppe)
|
|||
FIELD_PREP(PPE_DRAM_TB_NUM_ENTRY_MASK,
|
||||
dram_num_entries));
|
||||
} else {
|
||||
sram_num_entries =
|
||||
PPE_RAM_NUM_ENTRIES_SHIFT(PPE_SRAM_NUM_DATA_ENTRIES);
|
||||
sram_num_entries = PPE_SRAM_NUM_ENTRIES;
|
||||
sram_num_stats_entries =
|
||||
airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (sram_num_stats_entries > 0)
|
||||
sram_num_entries -= sram_num_stats_entries;
|
||||
sram_num_entries = PPE_RAM_NUM_ENTRIES_SHIFT(sram_num_entries);
|
||||
|
||||
airoha_fe_rmw(eth, REG_PPE_TB_CFG(0),
|
||||
PPE_SRAM_TB_NUM_ENTRY_MASK |
|
||||
PPE_DRAM_TB_NUM_ENTRY_MASK,
|
||||
|
|
@ -480,13 +508,21 @@ static u32 airoha_ppe_foe_get_entry_hash(struct airoha_foe_entry *hwe)
|
|||
return hash;
|
||||
}
|
||||
|
||||
static u32 airoha_ppe_foe_get_flow_stats_index(struct airoha_ppe *ppe, u32 hash)
|
||||
static int airoha_ppe_foe_get_flow_stats_index(struct airoha_ppe *ppe,
|
||||
u32 hash, u32 *index)
|
||||
{
|
||||
if (!airoha_ppe2_is_enabled(ppe->eth))
|
||||
return hash;
|
||||
int ppe_num_stats_entries;
|
||||
|
||||
return hash >= PPE_STATS_NUM_ENTRIES ? hash - PPE1_STATS_NUM_ENTRIES
|
||||
: hash;
|
||||
ppe_num_stats_entries = airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (ppe_num_stats_entries < 0)
|
||||
return ppe_num_stats_entries;
|
||||
|
||||
*index = hash;
|
||||
if (airoha_ppe2_is_enabled(ppe->eth) &&
|
||||
hash >= ppe_num_stats_entries)
|
||||
*index = *index - PPE_STATS_NUM_ENTRIES;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void airoha_ppe_foe_flow_stat_entry_reset(struct airoha_ppe *ppe,
|
||||
|
|
@ -500,9 +536,13 @@ static void airoha_ppe_foe_flow_stat_entry_reset(struct airoha_ppe *ppe,
|
|||
static void airoha_ppe_foe_flow_stats_reset(struct airoha_ppe *ppe,
|
||||
struct airoha_npu *npu)
|
||||
{
|
||||
int i;
|
||||
int i, ppe_num_stats_entries;
|
||||
|
||||
for (i = 0; i < PPE_STATS_NUM_ENTRIES; i++)
|
||||
ppe_num_stats_entries = airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (ppe_num_stats_entries < 0)
|
||||
return;
|
||||
|
||||
for (i = 0; i < ppe_num_stats_entries; i++)
|
||||
airoha_ppe_foe_flow_stat_entry_reset(ppe, npu, i);
|
||||
}
|
||||
|
||||
|
|
@ -513,10 +553,17 @@ static void airoha_ppe_foe_flow_stats_update(struct airoha_ppe *ppe,
|
|||
{
|
||||
int type = FIELD_GET(AIROHA_FOE_IB1_BIND_PACKET_TYPE, hwe->ib1);
|
||||
u32 index, pse_port, val, *data, *ib2, *meter;
|
||||
int ppe_num_stats_entries;
|
||||
u8 nbq;
|
||||
|
||||
index = airoha_ppe_foe_get_flow_stats_index(ppe, hash);
|
||||
if (index >= PPE_STATS_NUM_ENTRIES)
|
||||
ppe_num_stats_entries = airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (ppe_num_stats_entries < 0)
|
||||
return;
|
||||
|
||||
if (airoha_ppe_foe_get_flow_stats_index(ppe, hash, &index))
|
||||
return;
|
||||
|
||||
if (index >= ppe_num_stats_entries)
|
||||
return;
|
||||
|
||||
if (type == PPE_PKT_TYPE_BRIDGE) {
|
||||
|
|
@ -1158,11 +1205,19 @@ static int airoha_ppe_flow_offload_destroy(struct airoha_eth *eth,
|
|||
void airoha_ppe_foe_entry_get_stats(struct airoha_ppe *ppe, u32 hash,
|
||||
struct airoha_foe_stats64 *stats)
|
||||
{
|
||||
u32 index = airoha_ppe_foe_get_flow_stats_index(ppe, hash);
|
||||
struct airoha_eth *eth = ppe->eth;
|
||||
int ppe_num_stats_entries;
|
||||
struct airoha_npu *npu;
|
||||
u32 index;
|
||||
|
||||
if (index >= PPE_STATS_NUM_ENTRIES)
|
||||
ppe_num_stats_entries = airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (ppe_num_stats_entries < 0)
|
||||
return;
|
||||
|
||||
if (airoha_ppe_foe_get_flow_stats_index(ppe, hash, &index))
|
||||
return;
|
||||
|
||||
if (index >= ppe_num_stats_entries)
|
||||
return;
|
||||
|
||||
rcu_read_lock();
|
||||
|
|
@ -1257,7 +1312,7 @@ static int airoha_ppe_offload_setup(struct airoha_eth *eth)
|
|||
{
|
||||
struct airoha_npu *npu = airoha_ppe_npu_get(eth);
|
||||
struct airoha_ppe *ppe = eth->ppe;
|
||||
int err;
|
||||
int err, ppe_num_stats_entries;
|
||||
|
||||
if (IS_ERR(npu))
|
||||
return PTR_ERR(npu);
|
||||
|
|
@ -1266,9 +1321,10 @@ static int airoha_ppe_offload_setup(struct airoha_eth *eth)
|
|||
if (err)
|
||||
goto error_npu_put;
|
||||
|
||||
if (PPE_STATS_NUM_ENTRIES) {
|
||||
ppe_num_stats_entries = airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (ppe_num_stats_entries > 0) {
|
||||
err = npu->ops.ppe_init_stats(npu, ppe->foe_stats_dma,
|
||||
PPE_STATS_NUM_ENTRIES);
|
||||
ppe_num_stats_entries);
|
||||
if (err)
|
||||
goto error_npu_put;
|
||||
}
|
||||
|
|
@ -1405,8 +1461,8 @@ EXPORT_SYMBOL_GPL(airoha_ppe_put_dev);
|
|||
|
||||
int airoha_ppe_init(struct airoha_eth *eth)
|
||||
{
|
||||
int foe_size, err, ppe_num_stats_entries;
|
||||
struct airoha_ppe *ppe;
|
||||
int foe_size, err;
|
||||
|
||||
ppe = devm_kzalloc(eth->dev, sizeof(*ppe), GFP_KERNEL);
|
||||
if (!ppe)
|
||||
|
|
@ -1431,8 +1487,9 @@ int airoha_ppe_init(struct airoha_eth *eth)
|
|||
if (!ppe->foe_flow)
|
||||
return -ENOMEM;
|
||||
|
||||
foe_size = PPE_STATS_NUM_ENTRIES * sizeof(*ppe->foe_stats);
|
||||
if (foe_size) {
|
||||
ppe_num_stats_entries = airoha_ppe_get_total_num_stats_entries(ppe);
|
||||
if (ppe_num_stats_entries > 0) {
|
||||
foe_size = ppe_num_stats_entries * sizeof(*ppe->foe_stats);
|
||||
ppe->foe_stats = dmam_alloc_coherent(eth->dev, foe_size,
|
||||
&ppe->foe_stats_dma,
|
||||
GFP_KERNEL);
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user