summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>2022-06-30 09:08:31 -0300
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>2022-06-30 10:46:47 -0300
commitd44e1a0740066416d3c331a3022ead5a7c4155ad (patch)
tree1c4b0a8d25730bcced4309cd03330e9999c90e6a
parent82c7441f04e3c2a653ee29672731e040a1799c6b (diff)
downloadglibc-d44e1a0740066416d3c331a3022ead5a7c4155ad.tar.gz
linux: Fix mq_timereceive check for 32 bit fallback code (BZ 29304)
On success, mq_receive() and mq_timedreceive() return the number of bytes in the received message, so it requires to check if the value is larger than 0. Checked on i686-linux-gnu. (cherry picked from commit 71d87d85bf54f6522813aec97c19bdd24997341e)
-rw-r--r--sysdeps/unix/sysv/linux/mq_timedreceive.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/sysdeps/unix/sysv/linux/mq_timedreceive.c b/sysdeps/unix/sysv/linux/mq_timedreceive.c
index eb948ccc18..d3dde7a586 100644
--- a/sysdeps/unix/sysv/linux/mq_timedreceive.c
+++ b/sysdeps/unix/sysv/linux/mq_timedreceive.c
@@ -33,7 +33,7 @@ __mq_timedreceive_time64 (mqd_t mqdes, char *__restrict msg_ptr, size_t msg_len,
msg_prio, abs_timeout);
#ifndef __ASSUME_TIME64_SYSCALLS
- if (ret == 0 || errno != ENOSYS)
+ if (ret >= 0 || errno != ENOSYS)
return ret;
struct timespec ts32;