843e79d05a
Return dev directly, NULL if not possible. That is enough. Makes no sense to pass struct net * to get_dev op, as there is only one net possible, the one the action was created in. So just store it in mirred priv and use directly. Rename the mirred op callback function. Signed-off-by: Jiri Pirko <jiri@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
42 lines
959 B
C
42 lines
959 B
C
#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;
|
|
int tcfm_ifindex;
|
|
bool tcfm_mac_header_xmit;
|
|
struct net_device __rcu *tcfm_dev;
|
|
struct net *net;
|
|
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 int tcf_mirred_ifindex(const struct tc_action *a)
|
|
{
|
|
return to_mirred(a)->tcfm_ifindex;
|
|
}
|
|
|
|
#endif /* __NET_TC_MIR_H */
|