io_uring: adjust smp_rmb inside io_cqring_events
authorJackie Liu <liuyun01@kylinos.cn>
Thu, 16 May 2019 03:46:30 +0000 (11:46 +0800)
committerJens Axboe <axboe@kernel.dk>
Thu, 16 May 2019 14:10:25 +0000 (08:10 -0600)
Whenever smp_rmb is required to use io_cqring_events,
keep smp_rmb inside the function io_cqring_events.

Signed-off-by: Jackie Liu <liuyun01@kylinos.cn>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
fs/io_uring.c

index 67d1aae349d7dd6fc2ef4a1ee3b193378bf7d754..9cc7a101ef2a6911d89c28d2b81dab8f9e54625e 100644 (file)
@@ -2167,6 +2167,8 @@ static int io_ring_submit(struct io_ring_ctx *ctx, unsigned int to_submit)
 
 static unsigned io_cqring_events(struct io_cq_ring *ring)
 {
+       /* See comment at the top of this file */
+       smp_rmb();
        return READ_ONCE(ring->r.tail) - READ_ONCE(ring->r.head);
 }
 
@@ -2182,8 +2184,6 @@ static int io_cqring_wait(struct io_ring_ctx *ctx, int min_events,
        DEFINE_WAIT(wait);
        int ret;
 
-       /* See comment at the top of this file */
-       smp_rmb();
        if (io_cqring_events(ring) >= min_events)
                return 0;
 
@@ -2205,8 +2205,6 @@ static int io_cqring_wait(struct io_ring_ctx *ctx, int min_events,
                prepare_to_wait(&ctx->wait, &wait, TASK_INTERRUPTIBLE);
 
                ret = 0;
-               /* See comment at the top of this file */
-               smp_rmb();
                if (io_cqring_events(ring) >= min_events)
                        break;