forked from luck/tmp_suning_uos_patched
9f8a739e72
tcfm_dev always points to the correct netdev and we already hold a refcnt, so no need to use tcfm_ifindex to lookup again. If we would support moving target netdev across netns, using pointer would be better than ifindex. This also fixes dumping obsolete ifindex, now after the target device is gone we just dump 0 as ifindex. Cc: Jiri Pirko <jiri@mellanox.com> Cc: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com> Acked-by: Jiri Pirko <jiri@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
41 lines
983 B
C
41 lines
983 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __NET_TC_MIR_H
|
|
#define __NET_TC_MIR_H
|
|
|
|
#include <net/act_api.h>
|
|
#include <linux/tc_act/tc_mirred.h>
|
|
|
|
struct tcf_mirred {
|
|
struct tc_action common;
|
|
int tcfm_eaction;
|
|
bool tcfm_mac_header_xmit;
|
|
struct net_device __rcu *tcfm_dev;
|
|
struct list_head tcfm_list;
|
|
};
|
|
#define to_mirred(a) ((struct tcf_mirred *)a)
|
|
|
|
static inline bool is_tcf_mirred_egress_redirect(const struct tc_action *a)
|
|
{
|
|
#ifdef CONFIG_NET_CLS_ACT
|
|
if (a->ops && a->ops->type == TCA_ACT_MIRRED)
|
|
return to_mirred(a)->tcfm_eaction == TCA_EGRESS_REDIR;
|
|
#endif
|
|
return false;
|
|
}
|
|
|
|
static inline bool is_tcf_mirred_egress_mirror(const struct tc_action *a)
|
|
{
|
|
#ifdef CONFIG_NET_CLS_ACT
|
|
if (a->ops && a->ops->type == TCA_ACT_MIRRED)
|
|
return to_mirred(a)->tcfm_eaction == TCA_EGRESS_MIRROR;
|
|
#endif
|
|
return false;
|
|
}
|
|
|
|
static inline struct net_device *tcf_mirred_dev(const struct tc_action *a)
|
|
{
|
|
return rtnl_dereference(to_mirred(a)->tcfm_dev);
|
|
}
|
|
|
|
#endif /* __NET_TC_MIR_H */
|