summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2014-12-02 22:17:52 -0500
committerRich Felker <dalias@aerifal.cx>2015-03-30 01:41:33 -0400
commit051a8fdda8a08bcbea8d5a148fe26fa73adc58b8 (patch)
tree9c002d8854ac0aad33d2d7d7c13f74d355c475b2
parent65a0ee3a52246878c15f62770dd9fe51b60aa08e (diff)
downloadmusl-051a8fdda8a08bcbea8d5a148fe26fa73adc58b8.tar.gz
musl-051a8fdda8a08bcbea8d5a148fe26fa73adc58b8.tar.bz2
musl-051a8fdda8a08bcbea8d5a148fe26fa73adc58b8.tar.xz
musl-051a8fdda8a08bcbea8d5a148fe26fa73adc58b8.zip
fix return value of pthread_getaffinity_np and pthread_setaffinity_np
these functions are expected to return an error code rather than setting errno and returning -1. (cherry picked from commit 66140b0c926ed097f2cb7474863523e4af351f5b)
-rw-r--r--src/sched/affinity.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/src/sched/affinity.c b/src/sched/affinity.c
index 737e41b5..948ece41 100644
--- a/src/sched/affinity.c
+++ b/src/sched/affinity.c
@@ -11,20 +11,23 @@ int sched_setaffinity(pid_t tid, size_t size, const cpu_set_t *set)
int pthread_setaffinity_np(pthread_t td, size_t size, const cpu_set_t *set)
{
- return syscall(SYS_sched_setaffinity, td->tid, size, set);
+ return -__syscall(SYS_sched_setaffinity, td->tid, size, set);
}
-int sched_getaffinity(pid_t tid, size_t size, cpu_set_t *set)
+static int do_getaffinity(pid_t tid, size_t size, cpu_set_t *set)
{
long ret = __syscall(SYS_sched_getaffinity, tid, size, set);
- if (ret > 0) {
- if (ret < size) memset((char *)set+ret, 0, size-ret);
- ret = 0;
- }
- return __syscall_ret(ret);
+ if (ret < 0) return ret;
+ if (ret < size) memset((char *)set+ret, 0, size-ret);
+ return 0;
+}
+
+int sched_getaffinity(pid_t tid, size_t size, cpu_set_t *set)
+{
+ return __syscall_ret(do_getaffinity(tid, size, set));
}
int pthread_getaffinity_np(pthread_t td, size_t size, cpu_set_t *set)
{
- return sched_getaffinity(td->tid, size, set);
+ return -do_getaffinity(td->tid, size, set);
}