]> git.itanic.dy.fi Git - linux-stable/commitdiff
futex: make the vectored futex operations available
authorJens Axboe <axboe@kernel.dk>
Tue, 13 Jun 2023 14:34:08 +0000 (08:34 -0600)
committerJens Axboe <axboe@kernel.dk>
Fri, 29 Sep 2023 08:37:07 +0000 (02:37 -0600)
Rename unqueue_multiple() as futex_unqueue_multiple(), and make both
that and futex_wait_multiple_setup() available for external users. This
is in preparation for wiring up vectored waits in io_uring.

Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
kernel/futex/futex.h
kernel/futex/waitwake.c

index 6b6a6b3da103c7465e6515baecfcf52fffbf7510..8b195d06f4e8edcb6ebc84925e2ddc25334e51a7 100644 (file)
@@ -366,6 +366,11 @@ extern int futex_parse_waitv(struct futex_vector *futexv,
                             unsigned int nr_futexes, futex_wake_fn *wake,
                             void *wake_data);
 
+extern int futex_wait_multiple_setup(struct futex_vector *vs, int count,
+                                    int *woken);
+
+extern int futex_unqueue_multiple(struct futex_vector *v, int count);
+
 extern int futex_wait_multiple(struct futex_vector *vs, unsigned int count,
                               struct hrtimer_sleeper *to);
 
index 6fcf5f7237199f2e9f217c1f37d5faab5cd4f4c5..61b112897a84a088591fb0d19146273a5bda0507 100644 (file)
@@ -372,7 +372,7 @@ void futex_wait_queue(struct futex_hash_bucket *hb, struct futex_q *q,
 }
 
 /**
- * unqueue_multiple - Remove various futexes from their hash bucket
+ * futex_unqueue_multiple - Remove various futexes from their hash bucket
  * @v:    The list of futexes to unqueue
  * @count: Number of futexes in the list
  *
@@ -382,7 +382,7 @@ void futex_wait_queue(struct futex_hash_bucket *hb, struct futex_q *q,
  *  - >=0 - Index of the last futex that was awoken;
  *  - -1  - No futex was awoken
  */
-static int unqueue_multiple(struct futex_vector *v, int count)
+int futex_unqueue_multiple(struct futex_vector *v, int count)
 {
        int ret = -1, i;
 
@@ -410,7 +410,7 @@ static int unqueue_multiple(struct futex_vector *v, int count)
  *  -  0 - Success
  *  - <0 - -EFAULT, -EWOULDBLOCK or -EINVAL
  */
-static int futex_wait_multiple_setup(struct futex_vector *vs, int count, int *woken)
+int futex_wait_multiple_setup(struct futex_vector *vs, int count, int *woken)
 {
        struct futex_hash_bucket *hb;
        bool retry = false;
@@ -472,7 +472,7 @@ static int futex_wait_multiple_setup(struct futex_vector *vs, int count, int *wo
                 * was woken, we don't return error and return this index to
                 * userspace
                 */
-               *woken = unqueue_multiple(vs, i);
+               *woken = futex_unqueue_multiple(vs, i);
                if (*woken >= 0)
                        return 1;
 
@@ -557,7 +557,7 @@ int futex_wait_multiple(struct futex_vector *vs, unsigned int count,
 
                __set_current_state(TASK_RUNNING);
 
-               ret = unqueue_multiple(vs, count);
+               ret = futex_unqueue_multiple(vs, count);
                if (ret >= 0)
                        return ret;