From 7406fdf5a18b37330de108abb0106f44ebdae2c6 Mon Sep 17 00:00:00 2001 From: Rich Felker Date: Sat, 10 Aug 2013 21:41:05 -0400 Subject: add pthread_setaffinity_np and pthread_getaffinity_np functions --- include/pthread.h | 3 +++ src/sched/affinity.c | 26 ++++++++++++++++++++++++++ src/sched/sched_getaffinity.c | 10 ---------- src/sched/sched_setaffinity.c | 8 -------- 4 files changed, 29 insertions(+), 18 deletions(-) create mode 100644 src/sched/affinity.c delete mode 100644 src/sched/sched_getaffinity.c delete mode 100644 src/sched/sched_setaffinity.c diff --git a/include/pthread.h b/include/pthread.h index 731bce38..f7c9568c 100644 --- a/include/pthread.h +++ b/include/pthread.h @@ -210,6 +210,9 @@ void _pthread_cleanup_pop(struct __ptcb *, int); #define pthread_cleanup_pop(r) _pthread_cleanup_pop(&__cb, (r)); } while(0) #ifdef _GNU_SOURCE +struct cpu_set_t; +int pthread_getaffinity_np(pthread_t, size_t, struct cpu_set_t *); +int pthread_setaffinity_np(pthread_t, size_t, const struct cpu_set_t *); int pthread_getattr_np(pthread_t, pthread_attr_t *); #endif diff --git a/src/sched/affinity.c b/src/sched/affinity.c new file mode 100644 index 00000000..3b402111 --- /dev/null +++ b/src/sched/affinity.c @@ -0,0 +1,26 @@ +#define _GNU_SOURCE +#include +#include "pthread_impl.h" +#include "syscall.h" + +int sched_setaffinity(pid_t tid, size_t size, const cpu_set_t *set) +{ + return syscall(SYS_sched_setaffinity, tid, size, 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); +} + +int sched_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); +} + +int pthread_getaffinity_np(pthread_t td, size_t size, cpu_set_t *set) +{ + return sched_getaffinity(td->tid, size, set); +} diff --git a/src/sched/sched_getaffinity.c b/src/sched/sched_getaffinity.c deleted file mode 100644 index 0aa4c65a..00000000 --- a/src/sched/sched_getaffinity.c +++ /dev/null @@ -1,10 +0,0 @@ -#define _GNU_SOURCE -#include -#include "syscall.h" - -int sched_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); -} diff --git a/src/sched/sched_setaffinity.c b/src/sched/sched_setaffinity.c deleted file mode 100644 index 4344df17..00000000 --- a/src/sched/sched_setaffinity.c +++ /dev/null @@ -1,8 +0,0 @@ -#define _GNU_SOURCE -#include -#include "syscall.h" - -int sched_setaffinity(pid_t tid, size_t size, const cpu_set_t *set) -{ - return syscall(SYS_sched_setaffinity, tid, size, set); -} -- cgit v1.2.1