diff options
author | Carmelo Amoroso <carmelo.amoroso@st.com> | 2008-04-25 17:28:41 +0000 |
---|---|---|
committer | Carmelo Amoroso <carmelo.amoroso@st.com> | 2008-04-25 17:28:41 +0000 |
commit | ffb45327c079ec3d37af737e161ec9e784de0ebf (patch) | |
tree | 42c903fc1046c44101ef4cf7973c526b337c1d1d /librt/mq_unlink.c | |
parent | 963e3742bde1a5c52a67844e144f323e5f996ac0 (diff) | |
download | uClibc-alpine-ffb45327c079ec3d37af737e161ec9e784de0ebf.tar.bz2 uClibc-alpine-ffb45327c079ec3d37af737e161ec9e784de0ebf.tar.xz |
STEP 12: synch librt directory
Signed-off-by: Carmelo Amoroso <carmelo.amoroso@st.com>
Diffstat (limited to 'librt/mq_unlink.c')
-rw-r--r-- | librt/mq_unlink.c | 37 |
1 files changed, 19 insertions, 18 deletions
diff --git a/librt/mq_unlink.c b/librt/mq_unlink.c index aee3478e7..8e89610a3 100644 --- a/librt/mq_unlink.c +++ b/librt/mq_unlink.c @@ -15,24 +15,25 @@ static inline _syscall1(int, __syscall_mq_unlink, const char *, name); /* Remove message queue */ int mq_unlink(const char *name) { - int ret; - if (name[0] != '/') { - __set_errno(EINVAL); - return -1; - } - - ret = __syscall_mq_unlink(name + 1); - - /* While unlink can return either EPERM or EACCES, mq_unlink should return just EACCES. */ - if (ret < 0) { - ret = errno; - if (ret == EPERM) - ret = EACCES; - __set_errno(ret); - ret = -1; - } - - return ret; + int ret; + + if (name[0] != '/') { + __set_errno(EINVAL); + return -1; + } + + ret = __syscall_mq_unlink(name + 1); + + /* While unlink can return either EPERM or EACCES, mq_unlink should return just EACCES. */ + if (ret < 0) { + ret = errno; + if (ret == EPERM) + ret = EACCES; + __set_errno(ret); + ret = -1; + } + + return ret; } #endif |