linux-rt-users.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Alison Chaiken <alison@she-devel.com>
To: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Cc: corbet@lwn.net, gratian.crisan@ni.com, triegel@redhat.com,
	rostedt@goodmis.org, linux-kernel@vger.kernel.org,
	linux-rt-users@vger.kernel.org, achaiken@aurora.tech
Subject: Re: [PATCH] Documentation: locking: update libc support status of PI futexes
Date: Sat, 11 Jan 2025 10:55:55 -0800	[thread overview]
Message-ID: <619bfa123308eeb3a548fae36a3f9e4c@she-devel.com> (raw)
In-Reply-To: <20250107153121.wAL-TfKG@linutronix.de>

On 2025-01-07 07:31, Sebastian Andrzej Siewior wrote:
> On 2024-12-28 10:15:46 [-0800], alison@she-devel.com wrote:
>> From: Alison Chaiken <alison@she-devel.com>
>> 
>> Update the text of futex-requeue-pi.rst to explain that, because of a
>> conflict between POSIX requirements and ABI constraints, glibc does
>> not support requeueing of PI futexes.  Add some information about
>> librtpi, a library which provides an implementation of condition
>> variables which supports priority inheritance.
> 
> Are you sure? My memory is that glibc avoided using the internal mutex.
> The old problem should be gone and pthread_cond_signal() and
> pthread_cond_wait() should work.

Ignoring support for 64-bit time, the last substantive change to 
pthread_cond_wait() and pthread_cond_signal() was Torvald Riegel's  
commit ed19993b5b0d05d62cc883571519a67dae481a14 "New condvar 
implementation that provides stronger ordering guarantees," which fixed 
problems with waking of ineligible futex waiters and with ABA issues 
concerning the futex word.    What the patch does not do is made clear 
by the commit message:

      This condvar doesn't yet use a requeue optimization (ie, on a 
broadcast,
      waking just one thread and requeueing all others on the futex of 
the
      mutex supplied by the program).

What futex-requeue-pi.rst directs is

      In order to support PI-aware pthread_condvar's, the kernel needs to
      be able to requeue tasks to PI futexes.

Riegel and Darren Hart discussed Riegel's patch in at length at the 2016 
RT Summit:

     
https://wiki.linuxfoundation.org/realtime/events/rt-summit2016/schedule

The related glibc bug report by Darren may be found at

     https://sourceware.org/bugzilla/show_bug.cgi?id=11588

The last comment on the bug from 2017 is by Riegel:

     So far, there is no known solution for how to achieve PI support 
given the current constraints we have (eg, available futex operations, 
POSIX requirements, ...).

I ran the bug reproducer posted by Darren in Qemu and found that it did 
not fail.   I'm not sure if the result is valid given the peculiarities 
of Qemu, or whether I made some other mistake.

> 
>> Signed-off-by: Alison Chaiken <alison@she-devel.com>
> 
> Sebastian

-- Alison Chaiken
     Aurora Innovation

  reply	other threads:[~2025-01-11 19:04 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-12-28 18:15 [PATCH] Documentation: locking: update libc support status of PI futexes alison
2025-01-07 15:31 ` Sebastian Andrzej Siewior
2025-01-11 18:55   ` Alison Chaiken [this message]
2025-05-23 15:00     ` Sebastian Andrzej Siewior
2025-05-23 16:11       ` Jan Kiszka
2025-05-24 22:09       ` Alison Chaiken

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=619bfa123308eeb3a548fae36a3f9e4c@she-devel.com \
    --to=alison@she-devel.com \
    --cc=achaiken@aurora.tech \
    --cc=bigeasy@linutronix.de \
    --cc=corbet@lwn.net \
    --cc=gratian.crisan@ni.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-rt-users@vger.kernel.org \
    --cc=rostedt@goodmis.org \
    --cc=triegel@redhat.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).