]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
netfs: Fix missing barriers by using clear_and_wake_up_bit()
authorDavid Howells <dhowells@redhat.com>
Fri, 13 Dec 2024 13:50:07 +0000 (13:50 +0000)
committerChristian Brauner <brauner@kernel.org>
Fri, 20 Dec 2024 21:07:57 +0000 (22:07 +0100)
Use clear_and_wake_up_bit() rather than something like:

clear_bit_unlock(NETFS_RREQ_IN_PROGRESS, &rreq->flags);
wake_up_bit(&rreq->flags, NETFS_RREQ_IN_PROGRESS);

as there needs to be a barrier inserted between which is present in
clear_and_wake_up_bit().

Fixes: 288ace2f57c9 ("netfs: New writeback implementation")
Fixes: ee4cdf7ba857 ("netfs: Speed up buffered reading")
Signed-off-by: David Howells <dhowells@redhat.com>
Link: https://lore.kernel.org/r/20241213135013.2964079-8-dhowells@redhat.com
Reviewed-by: Akira Yokosawa <akiyks@gmail.com>
cc: Zilin Guan <zilin@seu.edu.cn>
cc: Akira Yokosawa <akiyks@gmail.com>
cc: Jeff Layton <jlayton@kernel.org>
cc: netfs@lists.linux.dev
cc: linux-fsdevel@vger.kernel.org
Signed-off-by: Christian Brauner <brauner@kernel.org>
fs/netfs/read_collect.c
fs/netfs/write_collect.c

index b415e39723361151074b3972bb5565bad30b9678..46ce3b7adf07228d435db9a7ef3eabc12bb26537 100644 (file)
@@ -379,8 +379,7 @@ static void netfs_rreq_assess(struct netfs_io_request *rreq)
        task_io_account_read(rreq->transferred);
 
        trace_netfs_rreq(rreq, netfs_rreq_trace_wake_ip);
-       clear_bit_unlock(NETFS_RREQ_IN_PROGRESS, &rreq->flags);
-       wake_up_bit(&rreq->flags, NETFS_RREQ_IN_PROGRESS);
+       clear_and_wake_up_bit(NETFS_RREQ_IN_PROGRESS, &rreq->flags);
 
        trace_netfs_rreq(rreq, netfs_rreq_trace_done);
        netfs_clear_subrequests(rreq, false);
index 1d438be2e1b4b83b60488cf05acab5c6e442b26e..82290c92ba7a2939b2d15701092aa2cc444771e7 100644 (file)
@@ -501,8 +501,7 @@ reassess_streams:
                goto need_retry;
        if ((notes & MADE_PROGRESS) && test_bit(NETFS_RREQ_PAUSE, &wreq->flags)) {
                trace_netfs_rreq(wreq, netfs_rreq_trace_unpause);
-               clear_bit_unlock(NETFS_RREQ_PAUSE, &wreq->flags);
-               wake_up_bit(&wreq->flags, NETFS_RREQ_PAUSE);
+               clear_and_wake_up_bit(NETFS_RREQ_PAUSE, &wreq->flags);
        }
 
        if (notes & NEED_REASSESS) {
@@ -605,8 +604,7 @@ void netfs_write_collection_worker(struct work_struct *work)
 
        _debug("finished");
        trace_netfs_rreq(wreq, netfs_rreq_trace_wake_ip);
-       clear_bit_unlock(NETFS_RREQ_IN_PROGRESS, &wreq->flags);
-       wake_up_bit(&wreq->flags, NETFS_RREQ_IN_PROGRESS);
+       clear_and_wake_up_bit(NETFS_RREQ_IN_PROGRESS, &wreq->flags);
 
        if (wreq->iocb) {
                size_t written = min(wreq->transferred, wreq->len);
@@ -714,8 +712,7 @@ void netfs_write_subrequest_terminated(void *_op, ssize_t transferred_or_error,
 
        trace_netfs_sreq(subreq, netfs_sreq_trace_terminated);
 
-       clear_bit_unlock(NETFS_SREQ_IN_PROGRESS, &subreq->flags);
-       wake_up_bit(&subreq->flags, NETFS_SREQ_IN_PROGRESS);
+       clear_and_wake_up_bit(NETFS_SREQ_IN_PROGRESS, &subreq->flags);
 
        /* If we are at the head of the queue, wake up the collector,
         * transferring a ref to it if we were the ones to do so.