mirror of
https://github.com/coolsnowwolf/lede.git
synced 2025-04-16 04:13:31 +00:00
kernel: update mtk ppe flow accounting patch to the latest version
Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
640d665ce5
commit
991dd40dbc
@ -53,18 +53,18 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||||||
@@ -4321,7 +4321,9 @@ static int mtk_probe(struct platform_dev
|
@@ -4585,8 +4585,8 @@ static int mtk_probe(struct platform_dev
|
||||||
|
for (i = 0; i < num_ppe; i++) {
|
||||||
u32 ppe_addr = eth->soc->reg_map->ppe_base + i * 0x400;
|
u32 ppe_addr = eth->soc->reg_map->ppe_base + i * 0x400;
|
||||||
|
|
||||||
eth->ppe[i] = mtk_ppe_init(eth, eth->base + ppe_addr,
|
- eth->ppe[i] = mtk_ppe_init(eth, eth->base + ppe_addr,
|
||||||
- eth->soc->offload_version, i);
|
- eth->soc->offload_version, i);
|
||||||
+ eth->soc->offload_version, i,
|
+ eth->ppe[i] = mtk_ppe_init(eth, eth->base + ppe_addr, i);
|
||||||
+ eth->soc->has_accounting);
|
|
||||||
+
|
+
|
||||||
if (!eth->ppe[i]) {
|
if (!eth->ppe[i]) {
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
goto err_free_dev;
|
goto err_free_dev;
|
||||||
@@ -4446,6 +4448,7 @@ static const struct mtk_soc_data mt7622_
|
@@ -4711,6 +4711,7 @@ static const struct mtk_soc_data mt7622_
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
.hash_offset = 2,
|
.hash_offset = 2,
|
||||||
@ -72,7 +72,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
.foe_entry_size = sizeof(struct mtk_foe_entry) - 16,
|
.foe_entry_size = sizeof(struct mtk_foe_entry) - 16,
|
||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
@@ -4483,6 +4486,7 @@ static const struct mtk_soc_data mt7629_
|
@@ -4748,6 +4749,7 @@ static const struct mtk_soc_data mt7629_
|
||||||
.hw_features = MTK_HW_FEATURES,
|
.hw_features = MTK_HW_FEATURES,
|
||||||
.required_clks = MT7629_CLKS_BITMAP,
|
.required_clks = MT7629_CLKS_BITMAP,
|
||||||
.required_pctl = false,
|
.required_pctl = false,
|
||||||
@ -80,7 +80,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
.txrx = {
|
.txrx = {
|
||||||
.txd_size = sizeof(struct mtk_tx_dma),
|
.txd_size = sizeof(struct mtk_tx_dma),
|
||||||
.rxd_size = sizeof(struct mtk_rx_dma),
|
.rxd_size = sizeof(struct mtk_rx_dma),
|
||||||
@@ -4503,6 +4507,7 @@ static const struct mtk_soc_data mt7986_
|
@@ -4768,6 +4770,7 @@ static const struct mtk_soc_data mt7986_
|
||||||
.offload_version = 2,
|
.offload_version = 2,
|
||||||
.hash_offset = 4,
|
.hash_offset = 4,
|
||||||
.foe_entry_size = sizeof(struct mtk_foe_entry),
|
.foe_entry_size = sizeof(struct mtk_foe_entry),
|
||||||
@ -90,7 +90,16 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
.rxd_size = sizeof(struct mtk_rx_dma_v2),
|
.rxd_size = sizeof(struct mtk_rx_dma_v2),
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.h
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.h
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.h
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.h
|
||||||
@@ -1008,6 +1008,7 @@ struct mtk_soc_data {
|
@@ -1025,6 +1025,8 @@ struct mtk_reg_map {
|
||||||
|
* the extra setup for those pins used by GMAC.
|
||||||
|
* @hash_offset Flow table hash offset.
|
||||||
|
* @foe_entry_size Foe table entry size.
|
||||||
|
+ * @has_accounting Bool indicating support for accounting of
|
||||||
|
+ * offloaded flows.
|
||||||
|
* @txd_size Tx DMA descriptor size.
|
||||||
|
* @rxd_size Rx DMA descriptor size.
|
||||||
|
* @rx_irq_done_mask Rx irq done register mask.
|
||||||
|
@@ -1042,6 +1044,7 @@ struct mtk_soc_data {
|
||||||
u8 hash_offset;
|
u8 hash_offset;
|
||||||
u16 foe_entry_size;
|
u16 foe_entry_size;
|
||||||
netdev_features_t hw_features;
|
netdev_features_t hw_features;
|
||||||
@ -100,7 +109,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
u32 rxd_size;
|
u32 rxd_size;
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_ppe.c
|
--- a/drivers/net/ethernet/mediatek/mtk_ppe.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_ppe.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_ppe.c
|
||||||
@@ -74,6 +74,46 @@ static int mtk_ppe_wait_busy(struct mtk_
|
@@ -74,6 +74,48 @@ static int mtk_ppe_wait_busy(struct mtk_
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,14 +130,16 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
+
|
+
|
||||||
+static int mtk_mib_entry_read(struct mtk_ppe *ppe, u16 index, u64 *bytes, u64 *packets)
|
+static int mtk_mib_entry_read(struct mtk_ppe *ppe, u16 index, u64 *bytes, u64 *packets)
|
||||||
+{
|
+{
|
||||||
+ u32 val, cnt_r0, cnt_r1, cnt_r2;
|
|
||||||
+ u32 byte_cnt_low, byte_cnt_high, pkt_cnt_low, pkt_cnt_high;
|
+ u32 byte_cnt_low, byte_cnt_high, pkt_cnt_low, pkt_cnt_high;
|
||||||
|
+ u32 val, cnt_r0, cnt_r1, cnt_r2;
|
||||||
|
+ int ret;
|
||||||
+
|
+
|
||||||
+ val = FIELD_PREP(MTK_PPE_MIB_SER_CR_ADDR, index) | MTK_PPE_MIB_SER_CR_ST;
|
+ val = FIELD_PREP(MTK_PPE_MIB_SER_CR_ADDR, index) | MTK_PPE_MIB_SER_CR_ST;
|
||||||
+ ppe_w32(ppe, MTK_PPE_MIB_SER_CR, val);
|
+ ppe_w32(ppe, MTK_PPE_MIB_SER_CR, val);
|
||||||
+
|
+
|
||||||
+ if (mtk_ppe_mib_wait_busy(ppe))
|
+ ret = mtk_ppe_mib_wait_busy(ppe);
|
||||||
+ return -ETIMEDOUT;
|
+ if (ret)
|
||||||
|
+ return ret;
|
||||||
+
|
+
|
||||||
+ cnt_r0 = readl(ppe->base + MTK_PPE_MIB_SER_R0);
|
+ cnt_r0 = readl(ppe->base + MTK_PPE_MIB_SER_R0);
|
||||||
+ cnt_r1 = readl(ppe->base + MTK_PPE_MIB_SER_R1);
|
+ cnt_r1 = readl(ppe->base + MTK_PPE_MIB_SER_R1);
|
||||||
@ -147,7 +158,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
static void mtk_ppe_cache_clear(struct mtk_ppe *ppe)
|
static void mtk_ppe_cache_clear(struct mtk_ppe *ppe)
|
||||||
{
|
{
|
||||||
ppe_set(ppe, MTK_PPE_CACHE_CTL, MTK_PPE_CACHE_CTL_CLEAR);
|
ppe_set(ppe, MTK_PPE_CACHE_CTL, MTK_PPE_CACHE_CTL_CLEAR);
|
||||||
@@ -444,6 +484,13 @@ __mtk_foe_entry_clear(struct mtk_ppe *pp
|
@@ -464,6 +506,13 @@ __mtk_foe_entry_clear(struct mtk_ppe *pp
|
||||||
hwe->ib1 &= ~MTK_FOE_IB1_STATE;
|
hwe->ib1 &= ~MTK_FOE_IB1_STATE;
|
||||||
hwe->ib1 |= FIELD_PREP(MTK_FOE_IB1_STATE, MTK_FOE_STATE_INVALID);
|
hwe->ib1 |= FIELD_PREP(MTK_FOE_IB1_STATE, MTK_FOE_STATE_INVALID);
|
||||||
dma_wmb();
|
dma_wmb();
|
||||||
@ -161,7 +172,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
}
|
}
|
||||||
entry->hash = 0xffff;
|
entry->hash = 0xffff;
|
||||||
|
|
||||||
@@ -551,6 +598,9 @@ __mtk_foe_entry_commit(struct mtk_ppe *p
|
@@ -571,6 +620,9 @@ __mtk_foe_entry_commit(struct mtk_ppe *p
|
||||||
wmb();
|
wmb();
|
||||||
hwe->ib1 = entry->ib1;
|
hwe->ib1 = entry->ib1;
|
||||||
|
|
||||||
@ -171,10 +182,12 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
dma_wmb();
|
dma_wmb();
|
||||||
|
|
||||||
mtk_ppe_cache_clear(ppe);
|
mtk_ppe_cache_clear(ppe);
|
||||||
@@ -742,14 +792,42 @@ int mtk_ppe_prepare_reset(struct mtk_ppe
|
@@ -762,11 +814,39 @@ int mtk_ppe_prepare_reset(struct mtk_ppe
|
||||||
return mtk_ppe_wait_busy(ppe);
|
return mtk_ppe_wait_busy(ppe);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
-struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base,
|
||||||
|
- int version, int index)
|
||||||
+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)
|
||||||
+{
|
+{
|
||||||
@ -201,29 +214,27 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
+ return acct;
|
+ return acct;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base,
|
+struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base, int index)
|
||||||
- int version, int index)
|
|
||||||
+ int version, int index, bool accounting)
|
|
||||||
{
|
{
|
||||||
|
+ bool accounting = eth->soc->has_accounting;
|
||||||
const struct mtk_soc_data *soc = eth->soc;
|
const struct mtk_soc_data *soc = eth->soc;
|
||||||
|
+ struct mtk_foe_accounting *acct;
|
||||||
struct device *dev = eth->dev;
|
struct device *dev = eth->dev;
|
||||||
|
+ struct mtk_mib_entry *mib;
|
||||||
struct mtk_ppe *ppe;
|
struct mtk_ppe *ppe;
|
||||||
u32 foe_flow_size;
|
u32 foe_flow_size;
|
||||||
void *foe;
|
void *foe;
|
||||||
+ struct mtk_mib_entry *mib;
|
@@ -783,7 +863,8 @@ struct mtk_ppe *mtk_ppe_init(struct mtk_
|
||||||
+ struct mtk_foe_accounting *acct;
|
ppe->base = base;
|
||||||
|
|
||||||
ppe = devm_kzalloc(dev, sizeof(*ppe), GFP_KERNEL);
|
|
||||||
if (!ppe)
|
|
||||||
@@ -764,6 +842,7 @@ struct mtk_ppe *mtk_ppe_init(struct mtk_
|
|
||||||
ppe->eth = eth;
|
ppe->eth = eth;
|
||||||
ppe->dev = dev;
|
ppe->dev = dev;
|
||||||
ppe->version = version;
|
- ppe->version = version;
|
||||||
|
+ ppe->version = eth->soc->offload_version;
|
||||||
+ ppe->accounting = accounting;
|
+ ppe->accounting = accounting;
|
||||||
|
|
||||||
foe = dmam_alloc_coherent(ppe->dev,
|
foe = dmam_alloc_coherent(ppe->dev,
|
||||||
MTK_PPE_ENTRIES * soc->foe_entry_size,
|
MTK_PPE_ENTRIES * soc->foe_entry_size,
|
||||||
@@ -779,6 +858,25 @@ struct mtk_ppe *mtk_ppe_init(struct mtk_
|
@@ -799,6 +880,23 @@ struct mtk_ppe *mtk_ppe_init(struct mtk_
|
||||||
if (!ppe->foe_flow)
|
if (!ppe->foe_flow)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -233,8 +244,6 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
+ if (!mib)
|
+ if (!mib)
|
||||||
+ return NULL;
|
+ return NULL;
|
||||||
+
|
+
|
||||||
+ memset(mib, 0, MTK_PPE_ENTRIES * sizeof(*mib));
|
|
||||||
+
|
|
||||||
+ ppe->mib_table = mib;
|
+ ppe->mib_table = mib;
|
||||||
+
|
+
|
||||||
+ acct = devm_kzalloc(dev, MTK_PPE_ENTRIES * sizeof(*acct),
|
+ acct = devm_kzalloc(dev, MTK_PPE_ENTRIES * sizeof(*acct),
|
||||||
@ -249,7 +258,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
mtk_ppe_debugfs_init(ppe, index);
|
mtk_ppe_debugfs_init(ppe, index);
|
||||||
|
|
||||||
return ppe;
|
return ppe;
|
||||||
@@ -893,6 +991,16 @@ void mtk_ppe_start(struct mtk_ppe *ppe)
|
@@ -913,6 +1011,16 @@ void mtk_ppe_start(struct mtk_ppe *ppe)
|
||||||
ppe_w32(ppe, MTK_PPE_DEFAULT_CPU_PORT1, 0xcb777);
|
ppe_w32(ppe, MTK_PPE_DEFAULT_CPU_PORT1, 0xcb777);
|
||||||
ppe_w32(ppe, MTK_PPE_SBW_CTRL, 0x7f);
|
ppe_w32(ppe, MTK_PPE_SBW_CTRL, 0x7f);
|
||||||
}
|
}
|
||||||
@ -276,7 +285,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
#define MTK_FOE_IB2_WDMA_DEVIDX BIT(16)
|
#define MTK_FOE_IB2_WDMA_DEVIDX BIT(16)
|
||||||
#define MTK_FOE_IB2_WDMA_WINFO BIT(17)
|
#define MTK_FOE_IB2_WDMA_WINFO BIT(17)
|
||||||
|
|
||||||
@@ -283,16 +284,34 @@ struct mtk_flow_entry {
|
@@ -285,16 +286,34 @@ struct mtk_flow_entry {
|
||||||
unsigned long cookie;
|
unsigned long cookie;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -311,16 +320,17 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
u16 foe_check_time[MTK_PPE_ENTRIES];
|
u16 foe_check_time[MTK_PPE_ENTRIES];
|
||||||
struct hlist_head *foe_flow;
|
struct hlist_head *foe_flow;
|
||||||
|
|
||||||
@@ -302,7 +321,7 @@ struct mtk_ppe {
|
@@ -303,8 +322,7 @@ struct mtk_ppe {
|
||||||
|
void *acct_table;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base,
|
-struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base,
|
||||||
- int version, int index);
|
- int version, int index);
|
||||||
+ int version, int index, bool accounting);
|
+struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base, int index);
|
||||||
void mtk_ppe_start(struct mtk_ppe *ppe);
|
void mtk_ppe_start(struct mtk_ppe *ppe);
|
||||||
int mtk_ppe_stop(struct mtk_ppe *ppe);
|
int mtk_ppe_stop(struct mtk_ppe *ppe);
|
||||||
int mtk_ppe_prepare_reset(struct mtk_ppe *ppe);
|
int mtk_ppe_prepare_reset(struct mtk_ppe *ppe);
|
||||||
@@ -354,5 +373,7 @@ int mtk_foe_entry_commit(struct mtk_ppe
|
@@ -358,5 +376,7 @@ int mtk_foe_entry_commit(struct mtk_ppe
|
||||||
void mtk_foe_entry_clear(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
|
void mtk_foe_entry_clear(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
|
||||||
int mtk_foe_entry_idle_time(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
|
int mtk_foe_entry_idle_time(struct mtk_ppe *ppe, struct mtk_flow_entry *entry);
|
||||||
int mtk_ppe_debugfs_init(struct mtk_ppe *ppe, int index);
|
int mtk_ppe_debugfs_init(struct mtk_ppe *ppe, int index);
|
||||||
@ -353,7 +363,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
seq_printf(m, " eth=%pM->%pM etype=%04x"
|
seq_printf(m, " eth=%pM->%pM etype=%04x"
|
||||||
- " vlan=%d,%d ib1=%08x ib2=%08x\n",
|
- " vlan=%d,%d ib1=%08x ib2=%08x\n",
|
||||||
+ " vlan=%d,%d ib1=%08x ib2=%08x"
|
+ " vlan=%d,%d ib1=%08x ib2=%08x"
|
||||||
+ " packets=%lld bytes=%lld\n",
|
+ " packets=%llu bytes=%llu\n",
|
||||||
h_source, h_dest, ntohs(l2->etype),
|
h_source, h_dest, ntohs(l2->etype),
|
||||||
- l2->vlan1, l2->vlan2, entry->ib1, ib2);
|
- l2->vlan1, l2->vlan2, entry->ib1, ib2);
|
||||||
+ l2->vlan1, l2->vlan2, entry->ib1, ib2,
|
+ l2->vlan1, l2->vlan2, entry->ib1, ib2,
|
||||||
@ -363,7 +373,7 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
return 0;
|
return 0;
|
||||||
--- 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
|
||||||
@@ -494,6 +494,7 @@ static int
|
@@ -497,6 +497,7 @@ 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;
|
||||||
@ -371,12 +381,13 @@ v2: fix wrong variable name in return value check spotted by Denis Kirjanov
|
|||||||
u32 idle;
|
u32 idle;
|
||||||
|
|
||||||
entry = rhashtable_lookup(ð->flow_table, &f->cookie,
|
entry = rhashtable_lookup(ð->flow_table, &f->cookie,
|
||||||
@@ -504,6 +505,12 @@ mtk_flow_offload_stats(struct mtk_eth *e
|
@@ -507,6 +508,13 @@ mtk_flow_offload_stats(struct mtk_eth *e
|
||||||
idle = mtk_foe_entry_idle_time(eth->ppe[entry->ppe_index], entry);
|
idle = mtk_foe_entry_idle_time(eth->ppe[entry->ppe_index], entry);
|
||||||
f->stats.lastused = jiffies - idle * HZ;
|
f->stats.lastused = jiffies - idle * HZ;
|
||||||
|
|
||||||
+ if (entry->hash != 0xFFFF) {
|
+ if (entry->hash != 0xFFFF &&
|
||||||
+ mtk_foe_entry_get_mib(eth->ppe[entry->ppe_index], entry->hash, &diff);
|
+ mtk_foe_entry_get_mib(eth->ppe[entry->ppe_index], entry->hash,
|
||||||
|
+ &diff)) {
|
||||||
+ f->stats.pkts += diff.packets;
|
+ f->stats.pkts += diff.packets;
|
||||||
+ f->stats.bytes += diff.bytes;
|
+ f->stats.bytes += diff.bytes;
|
||||||
+ }
|
+ }
|
||||||
|
@ -20,7 +20,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
#include <net/dsa.h>
|
#include <net/dsa.h>
|
||||||
#include "mtk_eth_soc.h"
|
#include "mtk_eth_soc.h"
|
||||||
#include "mtk_ppe.h"
|
#include "mtk_ppe.h"
|
||||||
@@ -755,7 +756,9 @@ void __mtk_ppe_check_skb(struct mtk_ppe
|
@@ -757,7 +758,9 @@ void __mtk_ppe_check_skb(struct mtk_ppe
|
||||||
skb->dev->dsa_ptr->tag_ops->proto != DSA_TAG_PROTO_MTK)
|
skb->dev->dsa_ptr->tag_ops->proto != DSA_TAG_PROTO_MTK)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
|
|
||||||
--- 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
|
||||||
@@ -583,6 +583,7 @@ mtk_eth_setup_tc_block(struct net_device
|
@@ -584,6 +584,7 @@ mtk_eth_setup_tc_block(struct net_device
|
||||||
if (IS_ERR(block_cb))
|
if (IS_ERR(block_cb))
|
||||||
return PTR_ERR(block_cb);
|
return PTR_ERR(block_cb);
|
||||||
|
|
||||||
@ -22,7 +22,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
flow_block_cb_add(block_cb, f);
|
flow_block_cb_add(block_cb, f);
|
||||||
list_add_tail(&block_cb->driver_list, &block_cb_list);
|
list_add_tail(&block_cb->driver_list, &block_cb_list);
|
||||||
return 0;
|
return 0;
|
||||||
@@ -591,7 +592,7 @@ mtk_eth_setup_tc_block(struct net_device
|
@@ -592,7 +593,7 @@ mtk_eth_setup_tc_block(struct net_device
|
||||||
if (!block_cb)
|
if (!block_cb)
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
|
|
||||||
|
@ -21,8 +21,6 @@ Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
|
|||||||
drivers/net/ethernet/mediatek/mtk_wed_wo.h | 3 +-
|
drivers/net/ethernet/mediatek/mtk_wed_wo.h | 3 +-
|
||||||
2 files changed, 30 insertions(+), 7 deletions(-)
|
2 files changed, 30 insertions(+), 7 deletions(-)
|
||||||
|
|
||||||
diff --git a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
|
||||||
index 6624f6d6abdd..797c3b412ab6 100644
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
--- a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
||||||
@@ -18,12 +18,23 @@
|
@@ -18,12 +18,23 @@
|
||||||
@ -51,7 +49,7 @@ index 6624f6d6abdd..797c3b412ab6 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct sk_buff *
|
static struct sk_buff *
|
||||||
@@ -316,10 +327,21 @@ mtk_wed_mcu_load_firmware(struct mtk_wed_wo *wo)
|
@@ -316,10 +327,21 @@ mtk_wed_mcu_load_firmware(struct mtk_wed
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,8 +75,6 @@ index 6624f6d6abdd..797c3b412ab6 100644
|
|||||||
|
|
||||||
/* set dummy cr */
|
/* set dummy cr */
|
||||||
wed_w32(wo->hw->wed_dev, MTK_WED_SCR0 + 4 * MTK_WED_DUMMY_CR_FWDL,
|
wed_w32(wo->hw->wed_dev, MTK_WED_SCR0 + 4 * MTK_WED_DUMMY_CR_FWDL,
|
||||||
diff --git a/drivers/net/ethernet/mediatek/mtk_wed_wo.h b/drivers/net/ethernet/mediatek/mtk_wed_wo.h
|
|
||||||
index dbcf42ce9173..c03071203cc0 100644
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_wed_wo.h
|
--- a/drivers/net/ethernet/mediatek/mtk_wed_wo.h
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_wed_wo.h
|
+++ b/drivers/net/ethernet/mediatek/mtk_wed_wo.h
|
||||||
@@ -227,7 +227,8 @@ struct mtk_wed_wo_queue {
|
@@ -227,7 +227,8 @@ struct mtk_wed_wo_queue {
|
||||||
@ -91,6 +87,3 @@ index dbcf42ce9173..c03071203cc0 100644
|
|||||||
|
|
||||||
struct mtk_wed_wo_queue q_tx;
|
struct mtk_wed_wo_queue q_tx;
|
||||||
struct mtk_wed_wo_queue q_rx;
|
struct mtk_wed_wo_queue q_rx;
|
||||||
--
|
|
||||||
2.39.2
|
|
||||||
|
|
||||||
|
@ -18,15 +18,12 @@ Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
|
|||||||
drivers/net/ethernet/mediatek/mtk_wed_mcu.c | 55 ++++++++++++++++++---
|
drivers/net/ethernet/mediatek/mtk_wed_mcu.c | 55 ++++++++++++++++++---
|
||||||
1 file changed, 49 insertions(+), 6 deletions(-)
|
1 file changed, 49 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
diff --git a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
|
||||||
index 797c3b412ab6..976946a3653a 100644
|
|
||||||
--- a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
--- a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
||||||
+++ b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
+++ b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
|
||||||
@@ -299,6 +299,52 @@ mtk_wed_mcu_run_firmware(struct mtk_wed_wo *wo, const struct firmware *fw,
|
@@ -300,6 +300,52 @@ next:
|
||||||
return -EINVAL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
+static int
|
static int
|
||||||
+mtk_wed_mcu_load_memory_regions(struct mtk_wed_wo *wo,
|
+mtk_wed_mcu_load_memory_regions(struct mtk_wed_wo *wo,
|
||||||
+ struct mtk_wed_wo_memory_region *region)
|
+ struct mtk_wed_wo_memory_region *region)
|
||||||
+{
|
+{
|
||||||
@ -72,10 +69,11 @@ index 797c3b412ab6..976946a3653a 100644
|
|||||||
+ ®ion[MTK_WED_WO_REGION_ILM]);
|
+ ®ion[MTK_WED_WO_REGION_ILM]);
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
static int
|
+static int
|
||||||
mtk_wed_mcu_load_firmware(struct mtk_wed_wo *wo)
|
mtk_wed_mcu_load_firmware(struct mtk_wed_wo *wo)
|
||||||
{
|
{
|
||||||
@@ -320,12 +366,9 @@ mtk_wed_mcu_load_firmware(struct mtk_wed_wo *wo)
|
static struct mtk_wed_wo_memory_region mem_region[] = {
|
||||||
|
@@ -320,12 +366,9 @@ mtk_wed_mcu_load_firmware(struct mtk_wed
|
||||||
u32 val, boot_cr;
|
u32 val, boot_cr;
|
||||||
int ret, i;
|
int ret, i;
|
||||||
|
|
||||||
@ -91,6 +89,3 @@ index 797c3b412ab6..976946a3653a 100644
|
|||||||
|
|
||||||
wo->boot_regmap = syscon_regmap_lookup_by_phandle(wo->hw->node,
|
wo->boot_regmap = syscon_regmap_lookup_by_phandle(wo->hw->node,
|
||||||
"mediatek,wo-cpuboot");
|
"mediatek,wo-cpuboot");
|
||||||
--
|
|
||||||
2.39.2
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user