summaryrefslogtreecommitdiffstats
path: root/librt/mq_send.c
diff options
context:
space:
mode:
Diffstat (limited to 'librt/mq_send.c')
-rw-r--r--librt/mq_send.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/librt/mq_send.c b/librt/mq_send.c
index 947e9fe72..642575915 100644
--- a/librt/mq_send.c
+++ b/librt/mq_send.c
@@ -9,28 +9,33 @@
#include <mqueue.h>
#ifdef __NR_mq_timedsend
-
#define __NR___syscall_mq_timedsend __NR_mq_timedsend
static inline _syscall5(int, __syscall_mq_timedsend, int, mqdes,
const char *, msg_ptr, size_t, msg_len, unsigned int, msg_prio,
const void *, abs_timeout);
+#endif
/*
* Add a message to queue. If O_NONBLOCK is set and queue is full, wait
* for sufficient room in the queue until abs_timeout expires.
*/
-int mq_timedsend(mqd_t mqdes, const char *msg_ptr, size_t msg_len,
+attribute_hidden
+int __mq_timedsend(mqd_t mqdes, const char *msg_ptr, size_t msg_len,
unsigned int msg_prio,
const struct timespec *abs_timeout)
{
- return __syscall_mq_timedsend(mqdes, msg_ptr, msg_len, msg_prio, abs_timeout);
+#ifdef __NR_mq_timedsend
+ return __syscall_mq_timedsend(mqdes, msg_ptr, msg_len, msg_prio, abs_timeout);
+#else
+ errno = ENOSYS;
+ return -1;
+#endif
}
+strong_alias(__mq_timedsend,mq_timedsend)
/* Add a message to queue */
int mq_send(mqd_t mqdes, const char *msg_ptr, size_t msg_len,
unsigned int msg_prio)
{
- return mq_timedsend(mqdes, msg_ptr, msg_len, msg_prio, NULL);
+ return __mq_timedsend(mqdes, msg_ptr, msg_len, msg_prio, NULL);
}
-
-#endif