/* protected by ->completion_lock */
        unsigned                        evfd_last_cq_tail;
+       unsigned                        nr_req_allocated;
 
        /*
         * Protection for resize vs mmap races - both the mmap and resize
 
        }
 
        percpu_ref_get_many(&ctx->refs, ret);
+       ctx->nr_req_allocated += ret;
+
        while (ret--) {
                struct io_kiocb *req = reqs[ret];
 
                kmem_cache_free(req_cachep, req);
                nr++;
        }
-       if (nr)
+       if (nr) {
+               ctx->nr_req_allocated -= nr;
                percpu_ref_put_many(&ctx->refs, nr);
+       }
        mutex_unlock(&ctx->uring_lock);
 }
 
        percpu_ref_exit(&ctx->refs);
        free_uid(ctx->user);
        io_req_caches_free(ctx);
+
+       WARN_ON_ONCE(ctx->nr_req_allocated);
+
        if (ctx->hash_map)
                io_wq_put_hash(ctx->hash_map);
        io_napi_free(ctx);