[PATCH v2 3/3] Linux: Add missing scheduler constants to <sched.h>
Carlos O'Donell
carlos@redhat.com
Fri Sep 6 12:19:27 GMT 2024
On 9/5/24 4:24 PM, Florian Weimer wrote:
> And add a test, misc/tst-sched-consts, that checks
> consistency with <sched.h>.
LGTM.
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
> ---
> sysdeps/unix/sysv/linux/Makefile | 10 ++++
> sysdeps/unix/sysv/linux/bits/sched.h | 14 ++++++
> sysdeps/unix/sysv/linux/tst-sched-consts.py | 56 +++++++++++++++++++++
> sysdeps/unix/sysv/linux/tst-sched_setattr.c | 2 +
> 4 files changed, 82 insertions(+)
> create mode 100644 sysdeps/unix/sysv/linux/tst-sched-consts.py
>
> diff --git a/sysdeps/unix/sysv/linux/Makefile b/sysdeps/unix/sysv/linux/Makefile
> index 0b45d4e42b..7df51a325c 100644
> --- a/sysdeps/unix/sysv/linux/Makefile
> +++ b/sysdeps/unix/sysv/linux/Makefile
> @@ -398,6 +398,16 @@ $(objpfx)tst-mount-compile.out: ../sysdeps/unix/sysv/linux/tst-mount-compile.py
> < /dev/null > $@ 2>&1; $(evaluate-test)
> $(objpfx)tst-mount-compile.out: $(sysdeps-linux-python-deps)
>
> +tests-special += \
> + $(objpfx)tst-sched-consts.out \
> + # tests-special
> +$(objpfx)tst-sched-consts.out: ../sysdeps/unix/sysv/linux/tst-sched-consts.py
> + $(sysdeps-linux-python) \
> + ../sysdeps/unix/sysv/linux/tst-sched-consts.py \
> + $(sysdeps-linux-python-cc) \
> + < /dev/null > $@ 2>&1; $(evaluate-test)
> +$(objpfx)tst-sched-consts.out: $(sysdeps-linux-python-deps)
> +
> tst-rseq-disable-ENV = GLIBC_TUNABLES=glibc.pthread.rseq=0
>
> endif # $(subdir) == misc
> diff --git a/sysdeps/unix/sysv/linux/bits/sched.h b/sysdeps/unix/sysv/linux/bits/sched.h
> index e5b7efb887..a02cb69de7 100644
> --- a/sysdeps/unix/sysv/linux/bits/sched.h
> +++ b/sysdeps/unix/sysv/linux/bits/sched.h
> @@ -29,6 +29,7 @@
> #define SCHED_FIFO 1
> #define SCHED_RR 2
> #ifdef __USE_GNU
> +# define SCHED_NORMAL SCHED_OTHER
> # define SCHED_BATCH 3
> # define SCHED_ISO 4
> # define SCHED_IDLE 5
> @@ -37,6 +38,19 @@
> /* Flags that can be used in policy values. */
> # define SCHED_RESET_ON_FORK 0x40000000
>
> +/* Flags for the sched_flags field in struct sched_attr. */
> +#define SCHED_FLAG_RESET_ON_FORK 0x01
> +#define SCHED_FLAG_RECLAIM 0x02
> +#define SCHED_FLAG_DL_OVERRUN 0x04
> +#define SCHED_FLAG_KEEP_POLICY 0x08
> +#define SCHED_FLAG_KEEP_PARAMS 0x10
> +#define SCHED_FLAG_UTIL_CLAMP_MIN 0x20
> +#define SCHED_FLAG_UTIL_CLAMP_MAX 0x40
> +
> +/* Combinations of sched_flags fields. */
> +#define SCHED_FLAG_KEEP_ALL 0x18
> +#define SCHED_FLAG_UTIL_CLAMP 0x60
> +
> /* Use "" to work around incorrect macro expansion of the
> __has_include argument (GCC PR 80005). */
> # ifdef __has_include
> diff --git a/sysdeps/unix/sysv/linux/tst-sched-consts.py b/sysdeps/unix/sysv/linux/tst-sched-consts.py
> new file mode 100644
> index 0000000000..70071dcd97
> --- /dev/null
> +++ b/sysdeps/unix/sysv/linux/tst-sched-consts.py
> @@ -0,0 +1,56 @@
> +#!/usr/bin/python3
> +# Test that glibc's sched.h constants match the kernel's.
> +# Copyright (C) 2018-2024 Free Software Foundation, Inc.
> +# This file is part of the GNU C Library.
> +#
> +# The GNU C Library is free software; you can redistribute it and/or
> +# modify it under the terms of the GNU Lesser General Public
> +# License as published by the Free Software Foundation; either
> +# version 2.1 of the License, or (at your option) any later version.
> +#
> +# The GNU C Library is distributed in the hope that it will be useful,
> +# but WITHOUT ANY WARRANTY; without even the implied warranty of
> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
> +# Lesser General Public License for more details.
> +#
> +# You should have received a copy of the GNU Lesser General Public
> +# License along with the GNU C Library; if not, see
> +# <https://www.gnu.org/licenses/>.
> +
> +import argparse
> +import sys
> +
> +import glibcextract
> +import glibcsyscalls
> +
> +
> +def main():
> + """The main entry point."""
> + parser = argparse.ArgumentParser(
> + description="Test that glibc's sched.h constants "
OK. Fixed description.
> + "match the kernel's.")
> + parser.add_argument('--cc', metavar='CC',
> + help='C compiler (including options) to use')
> + args = parser.parse_args()
> + linux_version_headers = glibcsyscalls.linux_kernel_version(args.cc)
> + linux_version_glibc = (6, 10)
> + sys.exit(glibcextract.compare_macro_consts(
> + '#define _GNU_SOURCE 1\n'
> + '#include <sched.h>\n',
> + '#define _GNU_SOURCE 1\n'
> + '#include <linux/sched.h>\n'
> + '#include <linux/sched/types.h>\n',
> + args.cc,
> + 'SCHED_.*',
> + # SCHED_ISO is reserved, but not implemented in the kernel.
> + # SCHED_OTHER is the standard name for SCHED_NORMAL.
> + # SCHED_FLAG_ALL will receive more and more flags, so
> + # exposing it to userspace does not seem useful.
> + 'SCHED_ISO'
> + '|SCHED_OTHER'
> + '|SCHED_FLAG_ALL',
> + linux_version_glibc > linux_version_headers,
> + linux_version_headers > linux_version_glibc))
> +
> +if __name__ == '__main__':
> + main()
> diff --git a/sysdeps/unix/sysv/linux/tst-sched_setattr.c b/sysdeps/unix/sysv/linux/tst-sched_setattr.c
> index a6288a1a7c..fbb73c31a7 100644
> --- a/sysdeps/unix/sysv/linux/tst-sched_setattr.c
> +++ b/sysdeps/unix/sysv/linux/tst-sched_setattr.c
> @@ -44,6 +44,8 @@ check_unused (void)
> static int
> do_test (void)
> {
> + _Static_assert (SCHED_OTHER == SCHED_NORMAL,
> + "SCHED_OTHER, SCHED_NORMAL values");
> TEST_VERIFY (sizeof (struct sched_attr) < sizeof (u));
>
> /* Check that reading and re-applying the current policy works. */
--
Cheers,
Carlos.
More information about the Libc-alpha
mailing list