All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Alejandro Colomar (man-pages)" <alx.manpages@gmail.com>
To: mtk.manpages@gmail.com
Cc: Kurt Kanzenbach <kurt@linutronix.de>, linux-man@vger.kernel.org
Subject: Re: [PATCH 10/32] futex.2: Document FUTEX_LOCK_PI2
Date: Thu, 29 Jul 2021 12:18:07 +0200	[thread overview]
Message-ID: <a0938003-285f-5f2e-3591-4e1923b3be6b@gmail.com> (raw)
In-Reply-To: <20210728202008.3158-11-alx.manpages@gmail.com>

Hi Michael,

On 7/28/21 10:19 PM, Alejandro Colomar wrote:
> From: Kurt Kanzenbach <kurt@linutronix.de>
> 
> FUTEX_LOCK_PI2 is a new futex operation which was recently introduced into the
> Linux kernel. It works exactly like FUTEX_LOCK_PI. However, it has support for
> selectable clocks for timeouts. By default CLOCK_MONOTONIC is used. If
> FUTEX_CLOCK_REALTIME is specified then the timeout is measured against
> CLOCK_REALTIME.
> 
> This new operation addresses an inconsistency in the futex interface:
> FUTEX_LOCK_PI only works with timeouts based on CLOCK_REALTIME in contrast to
> all the other PI operations.
> 
> Document the FUTEX_LOCK_PI2 command.
> 
> Signed-off-by: Kurt Kanzenbach <kurt@linutronix.de>

Please drop this one.  I just found a small typo, and will add a 
Reviewed-by line received today.

Thanks,

Alex

> ---
>   man2/futex.2 | 53 ++++++++++++++++++++++++++++++++++++++++++++++++----
>   1 file changed, 49 insertions(+), 4 deletions(-)
> 
> diff --git a/man2/futex.2 b/man2/futex.2
> index ada96c517..2f340e0e0 100644
> --- a/man2/futex.2
> +++ b/man2/futex.2
> @@ -241,10 +241,13 @@ and so on.
>   This option bit can be employed only with the
>   .BR FUTEX_WAIT_BITSET ,
>   .BR FUTEX_WAIT_REQUEUE_PI ,
> -and
>   (since Linux 4.5)
>   .\" commit 337f13046ff03717a9e99675284a817527440a49
> -.BR FUTEX_WAIT
> +.BR FUTEX_WAIT ,
> +and
> +(since Linux v5.14.0)
> +.\" commit bf22a6976897977b0a3f1aeba6823c959fc4fdae
> +.BR FUTEX_LOCK_PI2
>   operations.
>   .IP
>   If this option is set, the kernel measures the
> @@ -904,7 +907,9 @@ value to 0 if the previous value was the expected TID.
>   If a futex is already acquired (i.e., has a nonzero value),
>   waiters must employ the
>   .B FUTEX_LOCK_PI
> -operation to acquire the lock.
> +or
> +.B FUTEX_LOCK_PI2
> +operations to acquire the lock.
>   If other threads are waiting for the lock, then the
>   .B FUTEX_WAITERS
>   bit is set in the futex value;
> @@ -964,6 +969,8 @@ Note that the PI futex operations must be used as paired operations
>   and are subject to some additional requirements:
>   .IP * 3
>   .B FUTEX_LOCK_PI
> +,
> +.B FUTEX_LOCK_PI2
>   and
>   .B FUTEX_TRYLOCK_PI
>   pair with
> @@ -1122,6 +1129,27 @@ arguments are ignored.
>   .\""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
>   .\"
>   .TP
> +.BR FUTEX_LOCK_PI2 " (since Linux 5.14.0)"
> +.\" commit bf22a6976897977b0a3f1aeba6823c959fc4fdae
> +This operation works similar like
> +.BR FUTEX_LOCK_PI .
> +The only difference is the
> +timeout argument.
> +.BR FUTEX_LOCK_PI2
> +has support for selectable clocks.
> +.IP
> +If
> +.I timeout
> +is not NULL, the structure it points to specifies
> +an absolute timeout.
> +If
> +.I timeout
> +is NULL, the operation can block indefinitely.
> +.IP
> +.\"
> +.\""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
> +.\"
> +.TP
>   .BR FUTEX_TRYLOCK_PI " (since Linux 2.6.18)"
>   .\" commit c87e2837be82df479a6bae9f155c43516d2feebc
>   This operation tries to acquire the lock at
> @@ -1168,6 +1196,8 @@ arguments are ignored.
>   .\" commit c87e2837be82df479a6bae9f155c43516d2feebc
>   This operation wakes the top priority waiter that is waiting in
>   .B FUTEX_LOCK_PI
> +or
> +.B FUTEX_LOCK_PI2
>   on the futex address provided by the
>   .I uaddr
>   argument.
> @@ -1379,6 +1409,9 @@ Returns the number of waiters that were woken up.
>   .B FUTEX_LOCK_PI
>   Returns 0 if the futex was successfully locked.
>   .TP
> +.B FUTEX_LOCK_PI2
> +Returns 0 if the futex was successfully locked.
> +.TP
>   .B FUTEX_TRYLOCK_PI
>   Returns 0 if the futex was successfully locked.
>   .TP
> @@ -1435,6 +1468,7 @@ is not equal to the expected value
>   .TP
>   .BR EAGAIN
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_CMP_REQUEUE_PI )
>   The futex owner thread ID of
> @@ -1448,6 +1482,7 @@ Try again.
>   .TP
>   .BR EDEADLK
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_CMP_REQUEUE_PI )
>   The futex word at
> @@ -1536,11 +1571,14 @@ The kernel detected an inconsistency between the user-space state at
>   .I uaddr
>   and the kernel state\(emthat is, it detected a waiter which waits in
>   .BR FUTEX_LOCK_PI
> +or
> +.BR FUTEX_LOCK_PI2
>   on
>   .IR uaddr .
>   .TP
>   .B EINVAL
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_UNLOCK_PI )
>   The kernel detected an inconsistency between the user-space state at
> @@ -1590,6 +1628,8 @@ that is, the kernel detected a waiter which waits on
>   .I uaddr
>   via
>   .BR FUTEX_LOCK_PI
> +or
> +.BR FUTEX_LOCK_PI2
>   (instead of
>   .BR FUTEX_WAIT_REQUEUE_PI ).
>   .TP
> @@ -1618,6 +1658,7 @@ The system-wide limit on the total number of open files has been reached.
>   .TP
>   .BR ENOMEM
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_CMP_REQUEUE_PI )
>   The kernel could not allocate memory to hold state information.
> @@ -1634,11 +1675,13 @@ option was specified in
>   but the accompanying operation was neither
>   .BR FUTEX_WAIT ,
>   .BR FUTEX_WAIT_BITSET ,
> +.BR FUTEX_WAIT_REQUEUE_PI ,
>   nor
> -.BR FUTEX_WAIT_REQUEUE_PI .
> +.BR FUTEX_LOCK_PI2 .
>   .TP
>   .BR ENOSYS
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_UNLOCK_PI ,
>   .BR FUTEX_CMP_REQUEUE_PI ,
> @@ -1649,6 +1692,7 @@ are not supported on some CPU variants.
>   .TP
>   .BR EPERM
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_CMP_REQUEUE_PI )
>   The caller is not allowed to attach itself to the futex at
> @@ -1665,6 +1709,7 @@ The caller does not own the lock represented by the futex word.
>   .TP
>   .BR ESRCH
>   .RB ( FUTEX_LOCK_PI ,
> +.BR FUTEX_LOCK_PI2 ,
>   .BR FUTEX_TRYLOCK_PI ,
>   .BR FUTEX_CMP_REQUEUE_PI )
>   The thread ID in the futex word at
> 


-- 
Alejandro Colomar
Linux man-pages comaintainer; https://www.kernel.org/doc/man-pages/
http://www.alejandro-colomar.es/

  reply	other threads:[~2021-07-29 10:18 UTC|newest]

Thread overview: 92+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-07-28 20:19 [PATCH 00/32] Patches from others Alejandro Colomar
2021-07-28 20:19 ` [PATCH 01/32] readv2: Note preadv2(..., RWF_NOWAIT) bug in BUGS section Alejandro Colomar
2021-08-08  2:29   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 02/32] readv.2: Minor tweaks to Will's patch Alejandro Colomar
2021-08-08  2:30   ` Michael Kerrisk (man-pages)
2021-08-08  2:42     ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 03/32] vdso.7: Remove outdated limitation for powerpc Alejandro Colomar
2021-08-08  0:17   ` Michael Kerrisk (man-pages)
2021-08-08  0:21     ` Alejandro Colomar (man-pages)
2021-07-28 20:19 ` [PATCH 04/32] vdso.7: Add y2038 compliant gettime for ppc/32 Alejandro Colomar
2021-08-08  0:48   ` Michael Kerrisk (man-pages)
2021-08-08  1:01     ` Alejandro Colomar (man-pages)
2021-08-08  2:25       ` Michael Kerrisk (man-pages)
2021-08-08  2:22   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 05/32] posixoptions.7: Fix legacy functions list (s/getcwd/getwd/) Alejandro Colomar
2021-08-08  0:55   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 06/32] man2/fallocate.2: tfix documentation of shared blocks Alejandro Colomar
2021-08-08  0:54   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 07/32] printf.3: wfix Alejandro Colomar
2021-08-07 21:34   ` Michael Kerrisk (man-pages)
2021-08-07 22:20     ` Alejandro Colomar (man-pages)
2021-08-07 22:32       ` Alejandro Colomar (man-pages)
2021-08-07 23:10         ` Michael Kerrisk (man-pages)
2021-08-11 20:55           ` Sergey Petrakov
2021-08-11 22:33             ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 08/32] Various pages: Consistently use '*argv[]' Alejandro Colomar
2021-08-07 21:35   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 09/32] path_resolution.7: tfix Alejandro Colomar
2021-08-07 21:37   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 10/32] futex.2: Document FUTEX_LOCK_PI2 Alejandro Colomar
2021-07-29 10:18   ` Alejandro Colomar (man-pages) [this message]
2021-08-07 21:38     ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 11/32] futex.2: Minor tweaks to Kurt's patch Alejandro Colomar
2021-07-29 10:24   ` Alejandro Colomar (man-pages)
2021-08-07 21:38     ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 12/32] capabilities.7: tfix Alejandro Colomar
2021-08-07 21:39   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 13/32] user_namespaces.7: fix a ref Alejandro Colomar
2021-08-07 21:40   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 14/32] capabilities.7, user_namespaces.7: describe CAP_SETFCAP Alejandro Colomar
2021-08-08  2:54   ` Michael Kerrisk (man-pages)
2021-08-08  9:09   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 15/32] capabilities.7: Minor tweaks to Kir's patch Alejandro Colomar
2021-07-29 11:16   ` Alejandro Colomar (man-pages)
2021-08-08  3:03   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 16/32] seccomp_unotify.2: Add doc for SECCOMP_ADDFD_FLAG_SEND Alejandro Colomar
2021-08-08  1:01   ` Michael Kerrisk (man-pages)
2021-08-09  9:42     ` Rodrigo Campos
2021-07-28 20:19 ` [PATCH 17/32] seccomp_unotify.2: Minor tweaks to Rodrigo's patch Alejandro Colomar
2021-07-29 11:15   ` Alejandro Colomar (man-pages)
2021-08-08  1:13   ` Michael Kerrisk (man-pages)
2021-08-08  1:22     ` Alejandro Colomar (man-pages)
2021-07-28 20:19 ` [PATCH 18/32] recv.2: tfix Alejandro Colomar
2021-08-07 21:43   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 19/32] ascii.7: add vertical rule to separate the two columns Alejandro Colomar
2021-08-07 22:46   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 20/32] wait.2: Add ESRCH for when pid == INT_MIN Alejandro Colomar
2021-08-07 23:05   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 21/32] seccomp_unotify.2: tfix Alejandro Colomar
2021-08-08  1:13   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 22/32] proc.5: tfix Alejandro Colomar
2021-08-07 22:55   ` Michael Kerrisk (man-pages)
2021-07-28 20:19 ` [PATCH 23/32] scripts/bash_aliases: tfix Alejandro Colomar
2021-08-07 22:47   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 24/32] namespaces.7: fix confusion caused by text reorganization Alejandro Colomar
2021-08-07 23:48   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 25/32] pipe.7: also mention writev(2) in atomicity sexion Alejandro Colomar
2021-08-08  9:30   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 26/32] tkill.2: tfix Alejandro Colomar
2021-08-07 22:48   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 27/32] strstr.3: Add special case for empty needle Alejandro Colomar
2021-08-07 23:53   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 28/32] sigaction.2: Document SA_EXPOSE_TAGBITS and the flag support detection protocol Alejandro Colomar
2021-08-08 21:32   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 29/32] sigaction.2: Apply minor tweaks to Peter's patch Alejandro Colomar
2021-07-29 11:14   ` Alejandro Colomar (man-pages)
2021-08-08 21:32   ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 30/32] strlen.3, wcslen.3: Add recommendations for safer variants Alejandro Colomar
2021-08-07 23:45   ` Michael Kerrisk (man-pages)
2021-08-08  0:04     ` Alejandro Colomar (man-pages)
2021-08-08  0:16     ` Alejandro Colomar (man-pages)
2021-08-08  1:20       ` Michael Kerrisk (man-pages)
2021-08-08  1:24         ` Alejandro Colomar (man-pages)
2021-08-08  2:18           ` Michael Kerrisk (man-pages)
2021-08-08 19:44       ` Jonny Grant
2021-07-28 20:20 ` [PATCH 31/32] time.2: wfix regarding year-2038 Alejandro Colomar
2021-07-29 10:45   ` G. Branden Robinson
2021-07-30  1:25     ` Viet Than
2021-08-07 23:59       ` Michael Kerrisk (man-pages)
2021-07-28 20:20 ` [PATCH 32/32] execve.2: Fix absolute/relative pathname Alejandro Colomar
2021-08-08  2:02   ` Michael Kerrisk (man-pages)
2021-08-08 21:34 ` [PATCH 00/32] Patches from others Michael Kerrisk (man-pages)

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=a0938003-285f-5f2e-3591-4e1923b3be6b@gmail.com \
    --to=alx.manpages@gmail.com \
    --cc=kurt@linutronix.de \
    --cc=linux-man@vger.kernel.org \
    --cc=mtk.manpages@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.