net: sched: move block offload unbind after all chains are flushed
authorJiri Pirko <jiri@mellanox.com>
Thu, 2 Nov 2017 14:07:01 +0000 (15:07 +0100)
committerDavid S. Miller <davem@davemloft.net>
Fri, 3 Nov 2017 06:46:15 +0000 (15:46 +0900)
Currently, the offload unbind is done before the chains are flushed.
That causes driver to unregister block callback before it can get all
the callback calls done during flush, leaving the offloaded tps inside
the HW. So fix the order to prevent this situation and restore the
original behaviour.

Reported-by: Alexander Duyck <alexander.duyck@gmail.com>
Reported-by: Jakub Kicinski <kubakici@wp.pl>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sched/cls_api.c

index a26c690b48ace997d958fa095c163efbeb8cb0c0..3364347bc699a475327c57eeb9a570d74718a7b4 100644 (file)
@@ -343,11 +343,11 @@ void tcf_block_put_ext(struct tcf_block *block,
        if (!block)
                return;
 
-       tcf_block_offload_unbind(block, q, ei);
-
        list_for_each_entry_safe(chain, tmp, &block->chain_list, list)
                tcf_chain_flush(chain);
 
+       tcf_block_offload_unbind(block, q, ei);
+
        INIT_WORK(&block->work, tcf_block_put_final);
        /* Wait for existing RCU callbacks to cool down, make sure their works
         * have been queued before this. We can not flush pending works here