mirror of
https://github.com/openwrt/openwrt.git
synced 2025-02-18 16:40:29 +00:00
kernel: update flow offload fix based on upstream suggestions
Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
f7c1631155
commit
07b550890c
@ -14,43 +14,15 @@ 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
|
||||||
@@ -561,6 +561,7 @@ mtk_eth_setup_tc_block(struct net_device
|
@@ -583,6 +583,7 @@ mtk_eth_setup_tc_block(struct net_device
|
||||||
struct mtk_eth *eth = mac->hw;
|
if (IS_ERR(block_cb))
|
||||||
static LIST_HEAD(block_cb_list);
|
return PTR_ERR(block_cb);
|
||||||
struct flow_block_cb *block_cb;
|
|
||||||
+ bool register_block = false;
|
|
||||||
flow_setup_cb_t *cb;
|
|
||||||
|
|
||||||
if (!eth->soc->offload_version)
|
|
||||||
@@ -575,23 +576,27 @@ mtk_eth_setup_tc_block(struct net_device
|
|
||||||
switch (f->command) {
|
|
||||||
case FLOW_BLOCK_BIND:
|
|
||||||
block_cb = flow_block_cb_lookup(f->block, cb, dev);
|
|
||||||
- if (block_cb) {
|
|
||||||
- flow_block_cb_incref(block_cb);
|
|
||||||
- return 0;
|
|
||||||
+ if (!block_cb) {
|
|
||||||
+ block_cb = flow_block_cb_alloc(cb, dev, dev, NULL);
|
|
||||||
+ if (IS_ERR(block_cb))
|
|
||||||
+ return PTR_ERR(block_cb);
|
|
||||||
+
|
|
||||||
+ register_block = true;
|
|
||||||
}
|
|
||||||
- block_cb = flow_block_cb_alloc(cb, dev, dev, NULL);
|
|
||||||
- if (IS_ERR(block_cb))
|
|
||||||
- return PTR_ERR(block_cb);
|
|
||||||
|
|
||||||
- flow_block_cb_add(block_cb, f);
|
|
||||||
- list_add_tail(&block_cb->driver_list, &block_cb_list);
|
|
||||||
+ flow_block_cb_incref(block_cb);
|
+ flow_block_cb_incref(block_cb);
|
||||||
+
|
flow_block_cb_add(block_cb, f);
|
||||||
+ if (register_block) {
|
list_add_tail(&block_cb->driver_list, &block_cb_list);
|
||||||
+ flow_block_cb_add(block_cb, f);
|
|
||||||
+ list_add_tail(&block_cb->driver_list, &block_cb_list);
|
|
||||||
+ }
|
|
||||||
return 0;
|
return 0;
|
||||||
case FLOW_BLOCK_UNBIND:
|
@@ -591,7 +592,7 @@ mtk_eth_setup_tc_block(struct net_device
|
||||||
block_cb = flow_block_cb_lookup(f->block, cb, dev);
|
|
||||||
if (!block_cb)
|
if (!block_cb)
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user