}
                if (!worker->creds)
                        worker->creds = override_creds(wq->creds);
+               /*
+                * OK to set IO_WQ_WORK_CANCEL even for uncancellable work,
+                * the worker function will do the right thing.
+                */
                if (test_bit(IO_WQ_BIT_CANCEL, &wq->state))
                        work->flags |= IO_WQ_WORK_CANCEL;
                if (worker->mm)
         */
        spin_lock_irqsave(&worker->lock, flags);
        if (worker->cur_work &&
+           !(worker->cur_work->flags & IO_WQ_WORK_NO_CANCEL) &&
            data->cancel(worker->cur_work, data->caller_data)) {
                send_sig(SIGINT, worker->task, 1);
                ret = true;
                return false;
 
        spin_lock_irqsave(&worker->lock, flags);
-       if (worker->cur_work == work) {
+       if (worker->cur_work == work &&
+           !(worker->cur_work->flags & IO_WQ_WORK_NO_CANCEL)) {
                send_sig(SIGINT, worker->task, 1);
                ret = true;
        }
 
        IO_WQ_WORK_UNBOUND      = 32,
        IO_WQ_WORK_INTERNAL     = 64,
        IO_WQ_WORK_CB           = 128,
+       IO_WQ_WORK_NO_CANCEL    = 256,
 
        IO_WQ_HASH_SHIFT        = 24,   /* upper 8 bits are used for hash key */
 };
 
        struct io_kiocb *nxt = NULL;
        int ret = 0;
 
-       if (work->flags & IO_WQ_WORK_CANCEL)
+       /* if NO_CANCEL is set, we must still run the work */
+       if ((work->flags & (IO_WQ_WORK_CANCEL|IO_WQ_WORK_NO_CANCEL)) ==
+                               IO_WQ_WORK_CANCEL) {
                ret = -ECANCELED;
+       }
 
        if (!ret) {
                req->has_user = (work->flags & IO_WQ_WORK_HAS_MM) != 0;