提交 fe93f0b2 编写于 作者: P Petr Machata 提交者: David S. Miller

net: tc_skbedit: Factor a helper out of is_tcf_skbedit_{mark, ptype}()

The two functions is_tcf_skbedit_mark() and is_tcf_skbedit_ptype() have a
very similar structure. A follow-up patch will add one more such function.
Instead of more cut'n'pasting, extract a helper function that checks
whether a TC action is an skbedit with the required flag. Convert the two
existing functions into thin wrappers around the helper.
Signed-off-by: NPetr Machata <petrm@mellanox.com>
Reviewed-by: NJiri Pirko <jiri@mellanox.com>
Signed-off-by: NIdo Schimmel <idosch@mellanox.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 3fd177cb
...@@ -27,8 +27,8 @@ struct tcf_skbedit { ...@@ -27,8 +27,8 @@ struct tcf_skbedit {
}; };
#define to_skbedit(a) ((struct tcf_skbedit *)a) #define to_skbedit(a) ((struct tcf_skbedit *)a)
/* Return true iff action is mark */ /* Return true iff action is the one identified by FLAG. */
static inline bool is_tcf_skbedit_mark(const struct tc_action *a) static inline bool is_tcf_skbedit_with_flag(const struct tc_action *a, u32 flag)
{ {
#ifdef CONFIG_NET_CLS_ACT #ifdef CONFIG_NET_CLS_ACT
u32 flags; u32 flags;
...@@ -37,12 +37,18 @@ static inline bool is_tcf_skbedit_mark(const struct tc_action *a) ...@@ -37,12 +37,18 @@ static inline bool is_tcf_skbedit_mark(const struct tc_action *a)
rcu_read_lock(); rcu_read_lock();
flags = rcu_dereference(to_skbedit(a)->params)->flags; flags = rcu_dereference(to_skbedit(a)->params)->flags;
rcu_read_unlock(); rcu_read_unlock();
return flags == SKBEDIT_F_MARK; return flags == flag;
} }
#endif #endif
return false; return false;
} }
/* Return true iff action is mark */
static inline bool is_tcf_skbedit_mark(const struct tc_action *a)
{
return is_tcf_skbedit_with_flag(a, SKBEDIT_F_MARK);
}
static inline u32 tcf_skbedit_mark(const struct tc_action *a) static inline u32 tcf_skbedit_mark(const struct tc_action *a)
{ {
u32 mark; u32 mark;
...@@ -57,17 +63,7 @@ static inline u32 tcf_skbedit_mark(const struct tc_action *a) ...@@ -57,17 +63,7 @@ static inline u32 tcf_skbedit_mark(const struct tc_action *a)
/* Return true iff action is ptype */ /* Return true iff action is ptype */
static inline bool is_tcf_skbedit_ptype(const struct tc_action *a) static inline bool is_tcf_skbedit_ptype(const struct tc_action *a)
{ {
#ifdef CONFIG_NET_CLS_ACT return is_tcf_skbedit_with_flag(a, SKBEDIT_F_PTYPE);
u32 flags;
if (a->ops && a->ops->id == TCA_ID_SKBEDIT) {
rcu_read_lock();
flags = rcu_dereference(to_skbedit(a)->params)->flags;
rcu_read_unlock();
return flags == SKBEDIT_F_PTYPE;
}
#endif
return false;
} }
static inline u32 tcf_skbedit_ptype(const struct tc_action *a) static inline u32 tcf_skbedit_ptype(const struct tc_action *a)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册