mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-11 04:18:39 +08:00
net_sched: act_gact: read tcfg_ptype once
Third step for gact RCU operation : Following patch will get rid of spinlock protection, so we need to read tcfg_ptype once. Signed-off-by: Eric Dumazet <edumazet@google.com> Cc: Alexei Starovoitov <ast@plumgrid.com> Acked-by: Jamal Hadi Salim <jhs@mojatatu.com> Acked-by: John Fastabend <john.fastabend@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
cc6510a950
commit
8f2ae965b7
@ -127,16 +127,16 @@ static int tcf_gact(struct sk_buff *skb, const struct tc_action *a,
|
||||
struct tcf_result *res)
|
||||
{
|
||||
struct tcf_gact *gact = a->priv;
|
||||
int action = TC_ACT_SHOT;
|
||||
int action = gact->tcf_action;
|
||||
|
||||
spin_lock(&gact->tcf_lock);
|
||||
#ifdef CONFIG_GACT_PROB
|
||||
if (gact->tcfg_ptype)
|
||||
action = gact_rand[gact->tcfg_ptype](gact);
|
||||
else
|
||||
action = gact->tcf_action;
|
||||
#else
|
||||
action = gact->tcf_action;
|
||||
{
|
||||
u32 ptype = READ_ONCE(gact->tcfg_ptype);
|
||||
|
||||
if (ptype)
|
||||
action = gact_rand[ptype](gact);
|
||||
}
|
||||
#endif
|
||||
gact->tcf_bstats.bytes += qdisc_pkt_len(skb);
|
||||
gact->tcf_bstats.packets++;
|
||||
|
Loading…
Reference in New Issue
Block a user