* [LTP] [PATCH] sched_attr: Do not define for glibc >= 2.41
@ 2024-10-30 21:45 Khem Raj
2024-10-31 6:45 ` Petr Vorel
0 siblings, 1 reply; 2+ messages in thread
From: Khem Raj @ 2024-10-30 21:45 UTC (permalink / raw)
To: ltp; +Cc: Khem Raj
glibc 2.41+ has added [1] definitions for sched_setattr and sched_getattr functions
and struct sched_attr. Therefore, it needs to be checked for here as well before
defining sched_attr
Define sched_attr conditionally on SCHED_ATTR_SIZE_VER0
Fixes builds with glibc/trunk
[1] https://sourceware.org/git/?p=glibc.git;a=commitdiff;h=21571ca0d70302909cf72707b2a7736cf12190a0;hp=298bc488fdc047da37482f4003023cb9adef78f8
Signed-off-by: Khem Raj <raj.khem@gmail.com>
---
include/lapi/sched.h | 3 +++
1 file changed, 3 insertions(+)
diff --git a/include/lapi/sched.h b/include/lapi/sched.h
index 26fdb628d..e1c7ff011 100644
--- a/include/lapi/sched.h
+++ b/include/lapi/sched.h
@@ -15,6 +15,8 @@
#include "lapi/syscalls.h"
#include "lapi/sched.h"
+/* sched_attr is not defined in glibc < 2.41 */
+#ifndef SCHED_ATTR_SIZE_VER0
struct sched_attr {
uint32_t size;
@@ -44,6 +46,7 @@ static inline int sched_getattr(pid_t pid, struct sched_attr *attr,
{
return syscall(__NR_sched_getattr, pid, attr, size, flags);
}
+#endif
#ifndef HAVE_CLONE3
struct clone_args {
--
Mailing list info: https://lists.linux.it/listinfo/ltp
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [LTP] [PATCH] sched_attr: Do not define for glibc >= 2.41
2024-10-30 21:45 [LTP] [PATCH] sched_attr: Do not define for glibc >= 2.41 Khem Raj
@ 2024-10-31 6:45 ` Petr Vorel
0 siblings, 0 replies; 2+ messages in thread
From: Petr Vorel @ 2024-10-31 6:45 UTC (permalink / raw)
To: Khem Raj; +Cc: ltp
Hi Khem,
> +/* sched_attr is not defined in glibc < 2.41 */
> +#ifndef SCHED_ATTR_SIZE_VER0
Thank you for the fix.
This is faster than traditional AC_CHECK_MEMBERS(struct sched_attr) check,
that's why I merged it. I suppose once musl adds the struct it also adds
SCHED_ATTR_SIZE_VER0. If not we will need to use AC_CHECK_MEMBERS check.
Bionic uses kernel headers anyway, thus it will work.
Kind regards,
Petr
--
Mailing list info: https://lists.linux.it/listinfo/ltp
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2024-10-31 6:46 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-30 21:45 [LTP] [PATCH] sched_attr: Do not define for glibc >= 2.41 Khem Raj
2024-10-31 6:45 ` Petr Vorel
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox