Home
last modified time | relevance | path

Searched refs:block_cb (Results 1 – 22 of 22) sorted by relevance

/openbmc/linux/drivers/net/ethernet/marvell/prestera/
H A Dprestera_flow.c179 struct flow_block_cb *block_cb; in prestera_flow_block_get() local
181 block_cb = flow_block_cb_lookup(f->block, in prestera_flow_block_get()
183 if (!block_cb) { in prestera_flow_block_get()
188 block_cb = flow_block_cb_alloc(prestera_flow_block_cb, in prestera_flow_block_get()
191 if (IS_ERR(block_cb)) { in prestera_flow_block_get()
193 return ERR_CAST(block_cb); in prestera_flow_block_get()
196 block->block_cb = block_cb; in prestera_flow_block_get()
199 block = flow_block_cb_priv(block_cb); in prestera_flow_block_get()
203 flow_block_cb_incref(block_cb); in prestera_flow_block_get()
210 struct flow_block_cb *block_cb = block->block_cb; in prestera_flow_block_put() local
[all …]
H A Dprestera_flow.h23 struct flow_block_cb *block_cb; member
/openbmc/linux/net/core/
H A Dflow_offload.c265 struct flow_block_cb *block_cb; in flow_block_cb_alloc() local
267 block_cb = kzalloc(sizeof(*block_cb), GFP_KERNEL); in flow_block_cb_alloc()
268 if (!block_cb) in flow_block_cb_alloc()
271 block_cb->cb = cb; in flow_block_cb_alloc()
272 block_cb->cb_ident = cb_ident; in flow_block_cb_alloc()
273 block_cb->cb_priv = cb_priv; in flow_block_cb_alloc()
274 block_cb->release = release; in flow_block_cb_alloc()
276 return block_cb; in flow_block_cb_alloc()
280 void flow_block_cb_free(struct flow_block_cb *block_cb) in flow_block_cb_free() argument
282 if (block_cb->release) in flow_block_cb_free()
[all …]
/openbmc/linux/drivers/net/ethernet/mellanox/mlxsw/
H A Dspectrum_flow.c207 struct flow_block_cb *block_cb; in mlxsw_sp_setup_tc_block_bind() local
211 block_cb = flow_block_cb_lookup(f->block, mlxsw_sp_flow_block_cb, in mlxsw_sp_setup_tc_block_bind()
213 if (!block_cb) { in mlxsw_sp_setup_tc_block_bind()
217 block_cb = flow_block_cb_alloc(mlxsw_sp_flow_block_cb, in mlxsw_sp_setup_tc_block_bind()
220 if (IS_ERR(block_cb)) { in mlxsw_sp_setup_tc_block_bind()
222 return PTR_ERR(block_cb); in mlxsw_sp_setup_tc_block_bind()
226 flow_block = flow_block_cb_priv(block_cb); in mlxsw_sp_setup_tc_block_bind()
228 flow_block_cb_incref(block_cb); in mlxsw_sp_setup_tc_block_bind()
240 flow_block_cb_add(block_cb, f); in mlxsw_sp_setup_tc_block_bind()
241 list_add_tail(&block_cb->driver_list, &mlxsw_sp_block_cb_list); in mlxsw_sp_setup_tc_block_bind()
[all …]
H A Dspectrum_qdisc.c2178 struct flow_block_cb *block_cb; in mlxsw_sp_setup_tc_block_qevent_bind() local
2184 block_cb = flow_block_cb_lookup(f->block, mlxsw_sp_qevent_block_cb, mlxsw_sp); in mlxsw_sp_setup_tc_block_qevent_bind()
2185 if (!block_cb) { in mlxsw_sp_setup_tc_block_qevent_bind()
2189 block_cb = flow_block_cb_alloc(mlxsw_sp_qevent_block_cb, mlxsw_sp, qevent_block, in mlxsw_sp_setup_tc_block_qevent_bind()
2191 if (IS_ERR(block_cb)) { in mlxsw_sp_setup_tc_block_qevent_bind()
2193 return PTR_ERR(block_cb); in mlxsw_sp_setup_tc_block_qevent_bind()
2197 qevent_block = flow_block_cb_priv(block_cb); in mlxsw_sp_setup_tc_block_qevent_bind()
2199 flow_block_cb_incref(block_cb); in mlxsw_sp_setup_tc_block_qevent_bind()
2233 flow_block_cb_add(block_cb, f); in mlxsw_sp_setup_tc_block_qevent_bind()
2234 list_add_tail(&block_cb->driver_list, &mlxsw_sp_qevent_block_cb_list); in mlxsw_sp_setup_tc_block_qevent_bind()
[all …]
/openbmc/linux/drivers/net/ethernet/sfc/
H A Dtc_bindings.c78 struct flow_block_cb *block_cb; in efx_tc_setup_block() local
92 block_cb = flow_block_cb_alloc(efx_tc_block_cb, binding, in efx_tc_setup_block()
94 rc = PTR_ERR_OR_ZERO(block_cb); in efx_tc_setup_block()
104 flow_block_cb_add(block_cb, tcb); in efx_tc_setup_block()
110 block_cb = flow_block_cb_lookup(tcb->block, in efx_tc_setup_block()
113 if (block_cb) { in efx_tc_setup_block()
114 flow_block_cb_remove(block_cb, tcb); in efx_tc_setup_block()
142 void (*cleanup)(struct flow_block_cb *block_cb)) in efx_tc_indr_setup_cb() argument
146 struct flow_block_cb *block_cb; in efx_tc_indr_setup_cb() local
173 block_cb = flow_indr_block_cb_alloc(efx_tc_block_cb, binding, in efx_tc_indr_setup_cb()
[all …]
H A Dtc_bindings.h29 void (*cleanup)(struct flow_block_cb *block_cb));
/openbmc/linux/include/net/netfilter/
H A Dnf_flow_table.h228 struct flow_block_cb *block_cb; in nf_flow_table_offload_add_cb() local
232 block_cb = flow_block_cb_lookup(block, cb, cb_priv); in nf_flow_table_offload_add_cb()
233 if (block_cb) { in nf_flow_table_offload_add_cb()
238 block_cb = flow_block_cb_alloc(cb, cb_priv, cb_priv, NULL); in nf_flow_table_offload_add_cb()
239 if (IS_ERR(block_cb)) { in nf_flow_table_offload_add_cb()
240 err = PTR_ERR(block_cb); in nf_flow_table_offload_add_cb()
244 list_add_tail(&block_cb->list, &block->cb_list); in nf_flow_table_offload_add_cb()
261 struct flow_block_cb *block_cb; in nf_flow_table_offload_del_cb() local
264 block_cb = flow_block_cb_lookup(block, cb, cb_priv); in nf_flow_table_offload_del_cb()
265 if (block_cb) { in nf_flow_table_offload_del_cb()
[all …]
/openbmc/linux/include/net/
H A Dflow_offload.h525 void (*cleanup)(struct flow_block_cb *block_cb);
549 void (*cleanup)(struct flow_block_cb *block_cb));
550 void flow_block_cb_free(struct flow_block_cb *block_cb);
555 void *flow_block_cb_priv(struct flow_block_cb *block_cb);
556 void flow_block_cb_incref(struct flow_block_cb *block_cb);
557 unsigned int flow_block_cb_decref(struct flow_block_cb *block_cb);
559 static inline void flow_block_cb_add(struct flow_block_cb *block_cb, in flow_block_cb_add() argument
562 list_add_tail(&block_cb->list, &offload->cb_list); in flow_block_cb_add()
565 static inline void flow_block_cb_remove(struct flow_block_cb *block_cb, in flow_block_cb_remove() argument
568 list_move(&block_cb->list, &offload->cb_list); in flow_block_cb_remove()
[all …]
/openbmc/linux/drivers/net/ethernet/mediatek/
H A Dmtk_ppe_offload.c578 struct flow_block_cb *block_cb; in mtk_eth_setup_tc_block() local
592 block_cb = flow_block_cb_lookup(f->block, cb, dev); in mtk_eth_setup_tc_block()
593 if (block_cb) { in mtk_eth_setup_tc_block()
594 flow_block_cb_incref(block_cb); in mtk_eth_setup_tc_block()
597 block_cb = flow_block_cb_alloc(cb, dev, dev, NULL); in mtk_eth_setup_tc_block()
598 if (IS_ERR(block_cb)) in mtk_eth_setup_tc_block()
599 return PTR_ERR(block_cb); in mtk_eth_setup_tc_block()
601 flow_block_cb_incref(block_cb); in mtk_eth_setup_tc_block()
602 flow_block_cb_add(block_cb, f); in mtk_eth_setup_tc_block()
603 list_add_tail(&block_cb->driver_list, &block_cb_list); in mtk_eth_setup_tc_block()
[all …]
H A Dmtk_wed.c1783 struct flow_block_cb *block_cb; in mtk_wed_setup_tc_block() local
1798 block_cb = flow_block_cb_lookup(f->block, cb, dev); in mtk_wed_setup_tc_block()
1799 if (block_cb) { in mtk_wed_setup_tc_block()
1800 flow_block_cb_incref(block_cb); in mtk_wed_setup_tc_block()
1810 block_cb = flow_block_cb_alloc(cb, dev, priv, NULL); in mtk_wed_setup_tc_block()
1811 if (IS_ERR(block_cb)) { in mtk_wed_setup_tc_block()
1813 return PTR_ERR(block_cb); in mtk_wed_setup_tc_block()
1816 flow_block_cb_incref(block_cb); in mtk_wed_setup_tc_block()
1817 flow_block_cb_add(block_cb, f); in mtk_wed_setup_tc_block()
1818 list_add_tail(&block_cb->driver_list, &block_cb_list); in mtk_wed_setup_tc_block()
[all …]
/openbmc/linux/net/netfilter/
H A Dnf_tables_offload.c201 struct flow_block_cb *block_cb; in nft_setup_cb_call() local
204 list_for_each_entry(block_cb, cb_list, list) { in nft_setup_cb_call()
205 err = block_cb->cb(type, type_data, block_cb->cb_priv); in nft_setup_cb_call()
324 struct flow_block_cb *block_cb, *next; in nft_flow_offload_unbind() local
338 list_for_each_entry_safe(block_cb, next, &bo->cb_list, list) { in nft_flow_offload_unbind()
339 list_del(&block_cb->list); in nft_flow_offload_unbind()
340 flow_block_cb_free(block_cb); in nft_flow_offload_unbind()
400 static void nft_indr_block_cleanup(struct flow_block_cb *block_cb) in nft_indr_block_cleanup() argument
402 struct nft_base_chain *basechain = block_cb->indr.data; in nft_indr_block_cleanup()
403 struct net_device *dev = block_cb->indr.dev; in nft_indr_block_cleanup()
[all …]
H A Dnf_flow_table_offload.c845 struct flow_block_cb *block_cb; in nf_flow_offload_tuple() local
855 list_for_each_entry(block_cb, block_cb_list, list) { in nf_flow_offload_tuple()
856 err = block_cb->cb(TC_SETUP_CLSFLOWER, &cls_flow, in nf_flow_offload_tuple()
857 block_cb->cb_priv); in nf_flow_offload_tuple()
1102 struct flow_block_cb *block_cb, *next; in nf_flow_table_block_setup() local
1111 list_for_each_entry_safe(block_cb, next, &bo->cb_list, list) { in nf_flow_table_block_setup()
1112 list_del(&block_cb->list); in nf_flow_table_block_setup()
1113 flow_block_cb_free(block_cb); in nf_flow_table_block_setup()
1141 static void nf_flow_table_indr_cleanup(struct flow_block_cb *block_cb) in nf_flow_table_indr_cleanup() argument
1143 struct nf_flowtable *flowtable = block_cb->indr.data; in nf_flow_table_indr_cleanup()
[all …]
/openbmc/linux/drivers/net/ethernet/mellanox/mlx5/core/en/rep/
H A Dtc.c475 void (*cleanup)(struct flow_block_cb *block_cb)) in mlx5e_rep_indr_setup_block() argument
478 struct flow_block_cb *block_cb; in mlx5e_rep_indr_setup_block() local
502 block_cb = flow_indr_block_cb_alloc(setup_cb, indr_priv, indr_priv, in mlx5e_rep_indr_setup_block()
506 if (IS_ERR(block_cb)) { in mlx5e_rep_indr_setup_block()
509 return PTR_ERR(block_cb); in mlx5e_rep_indr_setup_block()
511 flow_block_cb_add(block_cb, f); in mlx5e_rep_indr_setup_block()
512 list_add_tail(&block_cb->driver_list, &mlx5e_block_cb_list); in mlx5e_rep_indr_setup_block()
520 block_cb = flow_block_cb_lookup(f->block, setup_cb, indr_priv); in mlx5e_rep_indr_setup_block()
521 if (!block_cb) in mlx5e_rep_indr_setup_block()
524 flow_indr_block_cb_remove(block_cb, f); in mlx5e_rep_indr_setup_block()
[all …]
/openbmc/linux/drivers/net/ethernet/netronome/nfp/flower/
H A Doffload.c1782 struct flow_block_cb *block_cb; in nfp_flower_setup_tc_block() local
1798 block_cb = flow_block_cb_alloc(nfp_flower_setup_tc_block_cb, in nfp_flower_setup_tc_block()
1800 if (IS_ERR(block_cb)) in nfp_flower_setup_tc_block()
1801 return PTR_ERR(block_cb); in nfp_flower_setup_tc_block()
1803 flow_block_cb_add(block_cb, f); in nfp_flower_setup_tc_block()
1804 list_add_tail(&block_cb->driver_list, &nfp_block_cb_list); in nfp_flower_setup_tc_block()
1807 block_cb = flow_block_cb_lookup(f->block, in nfp_flower_setup_tc_block()
1810 if (!block_cb) in nfp_flower_setup_tc_block()
1813 flow_block_cb_remove(block_cb, f); in nfp_flower_setup_tc_block()
1814 list_del(&block_cb->driver_list); in nfp_flower_setup_tc_block()
[all …]
H A Dmain.h679 void (*cleanup)(struct flow_block_cb *block_cb));
/openbmc/linux/net/sched/
H A Dcls_api.c768 static void tc_block_indr_cleanup(struct flow_block_cb *block_cb) in tc_block_indr_cleanup() argument
770 struct tcf_block *block = block_cb->indr.data; in tc_block_indr_cleanup()
771 struct net_device *dev = block_cb->indr.dev; in tc_block_indr_cleanup()
772 struct Qdisc *sch = block_cb->indr.sch; in tc_block_indr_cleanup()
777 block_cb->indr.binder_type, in tc_block_indr_cleanup()
782 list_del(&block_cb->driver_list); in tc_block_indr_cleanup()
783 list_move(&block_cb->list, &bo.cb_list); in tc_block_indr_cleanup()
1575 struct flow_block_cb *block_cb, *next; in tcf_block_bind() local
1580 list_for_each_entry(block_cb, &bo->cb_list, list) { in tcf_block_bind()
1581 err = tcf_block_playback_offloads(block, block_cb->cb, in tcf_block_bind()
[all …]
/openbmc/linux/drivers/net/ethernet/freescale/dpaa2/
H A Ddpaa2-switch.c1313 struct flow_block_cb *block_cb; in dpaa2_switch_setup_tc_block_bind() local
1317 block_cb = flow_block_cb_lookup(f->block, in dpaa2_switch_setup_tc_block_bind()
1321 if (!block_cb) { in dpaa2_switch_setup_tc_block_bind()
1328 block_cb = flow_block_cb_alloc(dpaa2_switch_port_setup_tc_block_cb_ig, in dpaa2_switch_setup_tc_block_bind()
1330 if (IS_ERR(block_cb)) in dpaa2_switch_setup_tc_block_bind()
1331 return PTR_ERR(block_cb); in dpaa2_switch_setup_tc_block_bind()
1335 filter_block = flow_block_cb_priv(block_cb); in dpaa2_switch_setup_tc_block_bind()
1338 flow_block_cb_incref(block_cb); in dpaa2_switch_setup_tc_block_bind()
1344 flow_block_cb_add(block_cb, f); in dpaa2_switch_setup_tc_block_bind()
1345 list_add_tail(&block_cb->driver_list, in dpaa2_switch_setup_tc_block_bind()
[all …]
/openbmc/linux/drivers/net/ethernet/broadcom/bnxt/
H A Dbnxt_tc.c1904 void (*cleanup)(struct flow_block_cb *block_cb)) in bnxt_tc_setup_indr_block() argument
1907 struct flow_block_cb *block_cb; in bnxt_tc_setup_indr_block() local
1922 block_cb = flow_indr_block_cb_alloc(bnxt_tc_setup_indr_block_cb, in bnxt_tc_setup_indr_block()
1926 if (IS_ERR(block_cb)) { in bnxt_tc_setup_indr_block()
1929 return PTR_ERR(block_cb); in bnxt_tc_setup_indr_block()
1932 flow_block_cb_add(block_cb, f); in bnxt_tc_setup_indr_block()
1933 list_add_tail(&block_cb->driver_list, &bnxt_block_cb_list); in bnxt_tc_setup_indr_block()
1940 block_cb = flow_block_cb_lookup(f->block, in bnxt_tc_setup_indr_block()
1943 if (!block_cb) in bnxt_tc_setup_indr_block()
1946 flow_indr_block_cb_remove(block_cb, f); in bnxt_tc_setup_indr_block()
[all …]
/openbmc/linux/drivers/net/ethernet/mscc/
H A Docelot_net.c439 struct flow_block_cb *block_cb; in ocelot_setup_tc_block() local
458 block_cb = flow_block_cb_alloc(cb, priv, priv, NULL); in ocelot_setup_tc_block()
459 if (IS_ERR(block_cb)) in ocelot_setup_tc_block()
460 return PTR_ERR(block_cb); in ocelot_setup_tc_block()
462 flow_block_cb_add(block_cb, f); in ocelot_setup_tc_block()
463 list_add_tail(&block_cb->driver_list, f->driver_block_list); in ocelot_setup_tc_block()
466 block_cb = flow_block_cb_lookup(f->block, cb, priv); in ocelot_setup_tc_block()
467 if (!block_cb) in ocelot_setup_tc_block()
470 flow_block_cb_remove(block_cb, f); in ocelot_setup_tc_block()
471 list_del(&block_cb->driver_list); in ocelot_setup_tc_block()
/openbmc/linux/net/dsa/
H A Dslave.c1651 struct flow_block_cb *block_cb; in dsa_slave_setup_tc_block() local
1668 block_cb = flow_block_cb_alloc(cb, dev, dev, NULL); in dsa_slave_setup_tc_block()
1669 if (IS_ERR(block_cb)) in dsa_slave_setup_tc_block()
1670 return PTR_ERR(block_cb); in dsa_slave_setup_tc_block()
1672 flow_block_cb_add(block_cb, f); in dsa_slave_setup_tc_block()
1673 list_add_tail(&block_cb->driver_list, &dsa_slave_block_cb_list); in dsa_slave_setup_tc_block()
1676 block_cb = flow_block_cb_lookup(f->block, cb, dev); in dsa_slave_setup_tc_block()
1677 if (!block_cb) in dsa_slave_setup_tc_block()
1680 flow_block_cb_remove(block_cb, f); in dsa_slave_setup_tc_block()
1681 list_del(&block_cb->driver_list); in dsa_slave_setup_tc_block()
/openbmc/linux/drivers/net/ethernet/intel/ice/
H A Dice_main.c83 void (*cleanup)(struct flow_block_cb *block_cb));
9021 void (*cleanup)(struct flow_block_cb *block_cb)) in ice_indr_setup_tc_block() argument
9024 struct flow_block_cb *block_cb; in ice_indr_setup_tc_block() local
9048 block_cb = in ice_indr_setup_tc_block()
9055 if (IS_ERR(block_cb)) { in ice_indr_setup_tc_block()
9058 return PTR_ERR(block_cb); in ice_indr_setup_tc_block()
9060 flow_block_cb_add(block_cb, f); in ice_indr_setup_tc_block()
9061 list_add_tail(&block_cb->driver_list, &ice_block_cb_list); in ice_indr_setup_tc_block()
9068 block_cb = flow_block_cb_lookup(f->block, in ice_indr_setup_tc_block()
9071 if (!block_cb) in ice_indr_setup_tc_block()
[all …]