ma->addr = READ_ONCE(sqe->addr);
        ma->len = READ_ONCE(sqe->len);
        ma->advice = READ_ONCE(sqe->fadvise_advice);
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 #else
        return -EOPNOTSUPP;
        struct io_madvise *ma = io_kiocb_to_cmd(req, struct io_madvise);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_madvise(current->mm, ma->addr, ma->len, ma->advice);
        io_req_set_res(req, ret, 0);
 
        }
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_rename *ren = io_kiocb_to_cmd(req, struct io_rename);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_renameat2(ren->old_dfd, ren->oldpath, ren->new_dfd,
                                ren->newpath, ren->flags);
                return PTR_ERR(un->filename);
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_unlink *un = io_kiocb_to_cmd(req, struct io_unlink);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        if (un->flags & AT_REMOVEDIR)
                ret = do_rmdir(un->dfd, un->filename);
                return PTR_ERR(mkd->filename);
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_mkdir *mkd = io_kiocb_to_cmd(req, struct io_mkdir);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_mkdirat(mkd->dfd, mkd->filename, mkd->mode);
 
        }
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_link *sl = io_kiocb_to_cmd(req, struct io_link);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_symlinkat(sl->oldpath, sl->new_dfd, sl->newpath);
 
        }
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_link *lnk = io_kiocb_to_cmd(req, struct io_link);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_linkat(lnk->old_dfd, lnk->oldpath, lnk->new_dfd,
                                lnk->newpath, lnk->flags);
 
                return -EINVAL;
 
        shutdown->how = READ_ONCE(sqe->len);
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct socket *sock;
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        sock = sock_from_file(req->file);
        if (unlikely(!sock))
 
        if (unlikely(sp->flags & ~valid_flags))
                return -EINVAL;
        sp->splice_fd_in = READ_ONCE(sqe->splice_fd_in);
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct file *in;
        long ret = 0;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        if (sp->flags & SPLICE_F_FD_IN_FIXED)
                in = io_file_get_fixed(req, sp->splice_fd_in, issue_flags);
        struct file *in;
        long ret = 0;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        if (sp->flags & SPLICE_F_FD_IN_FIXED)
                in = io_file_get_fixed(req, sp->splice_fd_in, issue_flags);
 
        }
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_statx *sx = io_kiocb_to_cmd(req, struct io_statx);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_statx(sx->dfd, sx->filename, sx->flags, sx->mask, sx->buffer);
        io_req_set_res(req, ret, 0);
 
        sync->off = READ_ONCE(sqe->off);
        sync->len = READ_ONCE(sqe->len);
        sync->flags = READ_ONCE(sqe->sync_range_flags);
+       req->flags |= REQ_F_FORCE_ASYNC;
+
        return 0;
 }
 
        int ret;
 
        /* sync_file_range always requires a blocking context */
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = sync_file_range(req->file, sync->off, sync->len, sync->flags);
        io_req_set_res(req, ret, 0);
 
        sync->off = READ_ONCE(sqe->off);
        sync->len = READ_ONCE(sqe->len);
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        int ret;
 
        /* fsync always requires a blocking context */
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = vfs_fsync_range(req->file, sync->off, end > 0 ? end : LLONG_MAX,
                                sync->flags & IORING_FSYNC_DATASYNC);
        sync->off = READ_ONCE(sqe->off);
        sync->len = READ_ONCE(sqe->addr);
        sync->mode = READ_ONCE(sqe->len);
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        int ret;
 
        /* fallocate always requiring blocking context */
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
+
        ret = vfs_fallocate(req->file, sync->mode, sync->off, sync->len);
        if (ret >= 0)
                fsnotify_modify(req->file);
 
        }
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
        struct io_xattr *ix = io_kiocb_to_cmd(req, struct io_xattr);
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = do_getxattr(mnt_idmap(req->file->f_path.mnt),
                        req->file->f_path.dentry,
        struct path path;
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
 retry:
        ret = filename_lookup(AT_FDCWD, ix->filename, lookup_flags, &path, NULL);
        }
 
        req->flags |= REQ_F_NEED_CLEANUP;
+       req->flags |= REQ_F_FORCE_ASYNC;
        return 0;
 }
 
 {
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
        ret = __io_setxattr(req, issue_flags, &req->file->f_path);
        io_xattr_finish(req, ret);
        struct path path;
        int ret;
 
-       if (issue_flags & IO_URING_F_NONBLOCK)
-               return -EAGAIN;
+       WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
 
 retry:
        ret = filename_lookup(AT_FDCWD, ix->filename, lookup_flags, &path, NULL);