[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
<sched.h> on Haiku
From: |
Bruno Haible |
Subject: |
<sched.h> on Haiku |
Date: |
Sat, 15 Nov 2008 13:08:03 +0100 |
User-agent: |
KMail/1.5.4 |
On Haiku I'm seeing these errors:
/data/testdir1/gllib/spawn.h:110: field `_sp' has incomplete type
/data/testdir1/gllib/spawnattr_setschedpolicy.c: In function
`posix_spawnattr_setschedpolicy':
/data/testdir1/gllib/spawnattr_setschedpolicy.c:28: `SCHED_OTHER' undeclared
(first use in this function)
/data/testdir1/gllib/spawnattr_setschedpolicy.c:28: (Each undeclared identifier
is reported only once
/data/testdir1/gllib/spawnattr_setschedpolicy.c:28: for each function it
appears in.)
/data/testdir1/gllib/spawnattr_setschedpolicy.c:29: `SCHED_FIFO' undeclared
(first use in this function)
/data/testdir1/gllib/spawnattr_setschedpolicy.c:29: `SCHED_RR' undeclared
(first use in this function)
The reason is that <sched.h> exists but does not have the 'struct sched_param'
type nor the SCHED_* macros. This fixes it.
2008-11-15 Bruno Haible <address@hidden>
Make the 'sched' module work on platforms where <sched.h> exists but
is incomplete (such as Haiku).
* lib/sched.in.h; Include the system's <sched.h> if it exists.
(SCHED_FIFO, SCHED_RR, SCHED_OTHER): New macros.
* m4/sched_h.m4 (gl_SCHED_H): Test whether <sched.h> exists and also
defines SCHED_FIFO, SCHED_RR, SCHED_OTHER. Set HAVE_SCHED_H,
HAVE_STRUCT_SCHED_PARAM.
* modules/sched (Depends-on): Add include_next.
(Makefile.am): Substitute HAVE_SCHED_H, INCLUDE_NEXT,
PRAGMA_SYSTEM_HEADER, NEXT_SCHED_H, HAVE_STRUCT_SCHED_PARAM.
* doc/posix-headers/sched.texi: Document the issue.
--- doc/posix-headers/sched.texi.orig 2008-11-15 13:05:35.000000000 +0100
+++ doc/posix-headers/sched.texi 2008-11-15 13:05:20.000000000 +0100
@@ -10,6 +10,13 @@
@item
This header file is missing on some platforms:
mingw, BeOS.
address@hidden
address@hidden sched_param} is not defined on some platforms:
+Haiku.
address@hidden
address@hidden, @code{SCHED_RR}, @code{SCHED_OTHER} are not defined on
+some platforms:
+Haiku.
@end itemize
Portability problems not fixed by Gnulib:
--- lib/sched.in.h.orig 2008-11-15 13:05:35.000000000 +0100
+++ lib/sched.in.h 2008-11-15 12:26:54.000000000 +0100
@@ -15,11 +15,33 @@
along with this program. If not, see <http://www.gnu.org/licenses/>. */
#ifndef _GL_SCHED_H
+
+#if __GNUC__ >= 3
address@hidden@
+#endif
+
+/* The include_next requires a split double-inclusion guard. */
+#if @HAVE_SCHED_H@
+# @INCLUDE_NEXT@ @NEXT_SCHED_H@
+#endif
+
+#ifndef _GL_SCHED_H
#define _GL_SCHED_H
+#if address@hidden@
+
struct sched_param
{
int sched_priority;
};
+#endif
+
+#if !(defined SCHED_FIFO && defined SCHED_RR && defined SCHED_OTHER)
+# define SCHED_FIFO 1
+# define SCHED_RR 2
+# define SCHED_OTHER 0
+#endif
+
+#endif /* _GL_SCHED_H */
#endif /* _GL_SCHED_H */
--- m4/sched_h.m4.orig 2008-11-15 13:05:35.000000000 +0100
+++ m4/sched_h.m4 2008-11-11 02:39:20.000000000 +0100
@@ -1,4 +1,4 @@
-# sched_h.m4 serial 1
+# sched_h.m4 serial 2
dnl Copyright (C) 2008 Free Software Foundation, Inc.
dnl This file is free software; the Free Software Foundation
dnl gives unlimited permission to copy and/or distribute it,
@@ -8,11 +8,29 @@
AC_DEFUN([gl_SCHED_H],
[
- AC_CHECK_HEADERS_ONCE([sched.h])
- if test $ac_cv_header_sched_h = yes; then
- SCHED_H=''
- else
- SCHED_H='sched.h'
- fi
+ AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM([[
+ #include <sched.h>
+ struct sched_param a;
+ int b[] = { SCHED_FIFO, SCHED_RR, SCHED_OTHER };
+ ]])],
+ [SCHED_H=''],
+ [SCHED_H='sched.h'
+
+ gl_CHECK_NEXT_HEADERS([sched.h])
+
+ AC_CHECK_HEADERS_ONCE([sched.h])
+ if test $ac_cv_header_sched_h = yes; then
+ HAVE_SCHED_H=1
+ else
+ HAVE_SCHED_H=0
+ fi
+ AC_SUBST([HAVE_SCHED_H])
+
+ AC_CHECK_TYPE([struct sched_param],
+ [HAVE_STRUCT_SCHED_PARAM=1], [HAVE_STRUCT_SCHED_PARAM=0],
+ [#include <sched.h>])
+ AC_SUBST([HAVE_STRUCT_SCHED_PARAM])
+ ])
AC_SUBST([SCHED_H])
])
--- modules/sched.orig 2008-11-15 13:05:35.000000000 +0100
+++ modules/sched 2008-11-11 02:40:02.000000000 +0100
@@ -6,6 +6,7 @@
m4/sched_h.m4
Depends-on:
+include_next
configure.ac:
gl_SCHED_H
@@ -18,7 +19,12 @@
sched.h: sched.in.h
rm -f address@hidden $@
{ echo '/* DO NOT EDIT! GENERATED AUTOMATICALLY! */'; \
- cat < $(srcdir)/sched.in.h; \
+ sed -e 's|@''HAVE_SCHED_H''@|$(HAVE_SCHED_H)|g' \
+ -e 's|@''INCLUDE_NEXT''@|$(INCLUDE_NEXT)|g' \
+ -e 's|@''PRAGMA_SYSTEM_HEADER''@|@PRAGMA_SYSTEM_HEADER@|g' \
+ -e 's|@''NEXT_SCHED_H''@|$(NEXT_SCHED_H)|g' \
+ -e 's|@''HAVE_STRUCT_SCHED_PARAM''@|$(HAVE_STRUCT_SCHED_PARAM)|g'
\
+ < $(srcdir)/sched.in.h; \
} > address@hidden
mv address@hidden $@
MOSTLYCLEANFILES += sched.h sched.h-t
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- <sched.h> on Haiku,
Bruno Haible <=