• Cong Wang's avatar
    net_sched: fix reference counting of tc filter chain · e2ef7544
    Cong Wang authored
    This patch fixes the following ugliness of tc filter chain refcnt:
    
    a) tp proto should hold a refcnt to the chain too. This significantly
       simplifies the logic.
    
    b) Chain 0 is no longer special, it is created with refcnt=1 like any
       other chains. All the ugliness in tcf_chain_put() can be gone!
    
    c) No need to handle the flushing oddly, because block still holds
       chain 0, it can not be released, this guarantees block is the last
       user.
    
    d) The race condition with RCU callbacks is easier to handle with just
       a rcu_barrier(). Much easier to understand, nothing to hide. Thanks
       to the previous patch. Please see also the comments in code.
    
    e) Make the code understandable by humans, much less error-prone.
    
    Fixes: 744a4cf6 ("net: sched: fix use after free when tcf_chain_destroy is called multiple times")
    Fixes: 5bc17018 ("net: sched: introduce multichain support for filters")
    Cc: Jiri Pirko <jiri@mellanox.com>
    Cc: Jamal Hadi Salim <jhs@mojatatu.com>
    Signed-off-by: default avatarCong Wang <xiyou.wangcong@gmail.com>
    Acked-by: default avatarJiri Pirko <jiri@mellanox.com>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    e2ef7544
cls_api.c 23.1 KB