RDMA/bnxt_re: Wait for delayed work to finish before device removal
authorSelvin Xavier <selvin.xavier@broadcom.com>
Mon, 8 Oct 2018 10:28:03 +0000 (03:28 -0700)
committerJason Gunthorpe <jgg@mellanox.com>
Tue, 16 Oct 2018 06:03:51 +0000 (00:03 -0600)
Delayed work bnxt_re_worker would be still running even after
cancel_delayed_work returns. This causes crash as the driver proceeds with
device removal. To make sure that the work is finished before returning,
use cancel_delayed_work_sync.

Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/hw/bnxt_re/main.c

index 2b1d00d78ad17a326c76471ba315cf7c22e7ca1f..75a54c58fdc68856203808f01faf34cfd1c8f197 100644 (file)
@@ -1203,7 +1203,7 @@ static void bnxt_re_ib_unreg(struct bnxt_re_dev *rdev)
                bnxt_re_unregister_ib(rdev);
        }
        if (test_and_clear_bit(BNXT_RE_FLAG_QOS_WORK_REG, &rdev->flags))
-               cancel_delayed_work(&rdev->worker);
+               cancel_delayed_work_sync(&rdev->worker);
 
        bnxt_re_cleanup_res(rdev);
        bnxt_re_free_res(rdev);