From: Alejandro Colomar <alx.manpages@gmail.com>
To: linux-man@vger.kernel.org, a.clayton@nginx.com
Cc: Alejandro Colomar <alx@kernel.org>, andrew@digital-domain.net
Subject: [PATCH 0/3] Discourage sched_yield(2)
Date: Wed, 3 May 2023 19:03:50 +0200 [thread overview]
Message-ID: <20230503170353.25998-1-alx@kernel.org> (raw)
Hi Andrew,
Here's a patch set for discouraging sched_yield(2). See the formatted
page at the bottom. I also updated some POSIX historic detail.
Cheers,
Alex
Alejandro Colomar (3):
sched_yield.2: HISTORY: POSIX.1-2008 makes this non-optional
sched_yield.2: NOTES: Remove misleading sentence
sched_yield.2: Rename NOTES to CAVEATS, and reorder contents
man2/sched_yield.2 | 41 +++++++++++++++++++----------------------
1 file changed, 19 insertions(+), 22 deletions(-)
---
$ MANWIDTH=72 man ./man2/sched_yield.2 | cat
sched_yield(2) System Calls Manual sched_yield(2)
NAME
sched_yield - yield the processor
LIBRARY
Standard C library (libc, -lc)
SYNOPSIS
#include <sched.h>
int sched_yield(void);
DESCRIPTION
sched_yield() causes the calling thread to relinquish the CPU.
The thread is moved to the end of the queue for its static pri‐
ority and a new thread gets to run.
RETURN VALUE
On success, sched_yield() returns 0. On error, -1 is returned,
and errno is set to indicate the error.
ERRORS
In the Linux implementation, sched_yield() always succeeds.
STANDARDS
POSIX.1‐2008.
HISTORY
POSIX.1‐2001 (but optional). POSIX.1‐2008.
Before POSIX.1‐2008, systems on which sched_yield() is avail‐
able defined _POSIX_PRIORITY_SCHEDULING in <unistd.h>.
CAVEATS
sched_yield() is intended for use with real‐time scheduling
policies (i.e., SCHED_FIFO or SCHED_RR). Use of sched_yield()
with nondeterministic scheduling policies such as SCHED_OTHER
is unspecified and very likely means your application design is
broken.
If the calling thread is the only thread in the highest prior‐
ity list at that time, it will continue to run after a call to
sched_yield().
Avoid calling sched_yield() unnecessarily or inappropriately
(e.g., when resources needed by other schedulable threads are
still held by the caller), since doing so will result in unnec‐
essary context switches, which will degrade system performance.
SEE ALSO
sched(7)
Linux man‐pages (unreleased) (date) sched_yield(2)
--
2.40.1
next reply other threads:[~2023-05-03 17:04 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-05-03 17:03 Alejandro Colomar [this message]
2023-05-03 17:03 ` [PATCH 1/3] sched_yield.2: HISTORY: POSIX.1-2008 makes this non-optional Alejandro Colomar
2023-05-03 17:03 ` [PATCH 2/3] sched_yield.2: NOTES: Remove misleading sentence Alejandro Colomar
2023-05-03 17:03 ` [PATCH 3/3] sched_yield.2: Rename NOTES to CAVEATS, and reorder contents Alejandro Colomar
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=20230503170353.25998-1-alx@kernel.org \
--to=alx.manpages@gmail.com \
--cc=a.clayton@nginx.com \
--cc=alx@kernel.org \
--cc=andrew@digital-domain.net \
--cc=linux-man@vger.kernel.org \
/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