summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--librt/Makefile.in1
-rw-r--r--librt/mq_receive.c7
-rw-r--r--librt/mq_send.c6
3 files changed, 12 insertions, 2 deletions
diff --git a/librt/Makefile.in b/librt/Makefile.in
index 857efb517..8555e94db 100644
--- a/librt/Makefile.in
+++ b/librt/Makefile.in
@@ -28,6 +28,7 @@ librt_filter_SRC :=
ifeq ($(UCLIBC_HAS_THREADS_NATIVE),y)
librt_filter_SRC += mq_notify.c timer_create.c timer_delete.c \
timer_getoverr.c timer_gettime.c timer_settime.c
+# these should really be guarded by ADVANCED_REALTIME, we use them in mq_send.c/mq_receive.c
librt_SSRC := $(wildcard $(librt_DIR)/*.S)
else
librt_filter_SRC += clock_nanosleep.c clock_getcpuclockid.c clock_gettime.c
diff --git a/librt/mq_receive.c b/librt/mq_receive.c
index 26fc45194..2be1c1a98 100644
--- a/librt/mq_receive.c
+++ b/librt/mq_receive.c
@@ -10,13 +10,18 @@
#include <mqueue.h>
#ifdef __UCLIBC_HAS_THREADS_NATIVE__
+# ifndef __UCLIBC_HAS_ADVANCED_REALTIME__
+extern ssize_t mq_timedreceive(mqd_t mqdes, char *msg_ptr, size_t msg_len,
+ unsigned int *msg_prio,
+ const struct timespec *abs_timeout);
+# endif
librt_hidden_proto(mq_timedreceive)
#else
# define __NR___syscall_mq_timedreceive __NR_mq_timedreceive
static _syscall5(int, __syscall_mq_timedreceive, int, mqdes,
char *, msg_ptr, size_t, msg_len, unsigned int *,
- msg_prio, const void *, abs_timeout);
+ msg_prio, const void *, abs_timeout)
# ifdef __UCLIBC_HAS_ADVANCED_REALTIME__
/*
diff --git a/librt/mq_send.c b/librt/mq_send.c
index 78308d8d9..5e50d1a19 100644
--- a/librt/mq_send.c
+++ b/librt/mq_send.c
@@ -10,13 +10,17 @@
#include <mqueue.h>
#ifdef __UCLIBC_HAS_THREADS_NATIVE__
+# ifndef __UCLIBC_HAS_ADVANCED_REALTIME__
+extern int mq_timedsend(mqd_t mqdes, const char *msg_ptr, size_t msg_len,
+ unsigned int msg_prio, const struct timespec *abs_timeout);
+# endif
librt_hidden_proto(mq_timedsend)
#else
# define __NR___syscall_mq_timedsend __NR_mq_timedsend
static _syscall5(int, __syscall_mq_timedsend, int, mqdes,
const char *, msg_ptr, size_t, msg_len, unsigned int,
- msg_prio, const void *, abs_timeout);
+ msg_prio, const void *, abs_timeout)
# ifdef __UCLIBC_HAS_ADVANCED_REALTIME__
/*