X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fsched%2Faffinity.c;h=948ece413fd45dc9569d183112c04df0de13d2ab;hb=0ea78a6421322cab24d448670006ee2f99af3ac9;hp=3b402111935768f8794c80349ee0538b7152d9f9;hpb=7406fdf5a18b37330de108abb0106f44ebdae2c6;p=musl diff --git a/src/sched/affinity.c b/src/sched/affinity.c index 3b402111..948ece41 100644 --- a/src/sched/affinity.c +++ b/src/sched/affinity.c @@ -1,5 +1,6 @@ #define _GNU_SOURCE #include +#include #include "pthread_impl.h" #include "syscall.h" @@ -10,17 +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) 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); }