X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fconf%2Fsysconf.c;h=9f0d97b28c528ba0908aa329bc0617de57211e3d;hp=5b6c14e520f2c97e93bfc753e632cd6ae76221e9;hb=7df42e8744d384c975b28192f66ab4c5e4c1fd90;hpb=2e0c1fed36be1f1435de79bfc7cdc34824cb5614 diff --git a/src/conf/sysconf.c b/src/conf/sysconf.c index 5b6c14e5..9f0d97b2 100644 --- a/src/conf/sysconf.c +++ b/src/conf/sysconf.c @@ -6,6 +6,7 @@ #define VER (-2) #define OFLOW (-3) +#define CPUCNT (-4) #define RLIM(x) (-32768|(RLIMIT_ ## x)) long sysconf(int name) @@ -88,14 +89,14 @@ long sysconf(int name) [_SC_THREAD_KEYS_MAX] = PTHREAD_KEYS_MAX, [_SC_THREAD_STACK_MIN] = PTHREAD_STACK_MIN, [_SC_THREAD_THREADS_MAX] = -1, - [_SC_THREAD_ATTR_STACKADDR] = -1, + [_SC_THREAD_ATTR_STACKADDR] = VER, [_SC_THREAD_ATTR_STACKSIZE] = VER, - [_SC_THREAD_PRIORITY_SCHEDULING] = -1, + [_SC_THREAD_PRIORITY_SCHEDULING] = VER, [_SC_THREAD_PRIO_INHERIT] = -1, [_SC_THREAD_PRIO_PROTECT] = -1, [_SC_THREAD_PROCESS_SHARED] = VER, - [_SC_NPROCESSORS_CONF] = -1, - [_SC_NPROCESSORS_ONLN] = -1, + [_SC_NPROCESSORS_CONF] = CPUCNT, + [_SC_NPROCESSORS_ONLN] = CPUCNT, [_SC_PHYS_PAGES] = -1, [_SC_AVPHYS_PAGES] = -1, [_SC_ATEXIT_MAX] = -1, @@ -220,7 +221,14 @@ long sysconf(int name) } else if (values[name] == OFLOW) { if (name == _SC_ARG_MAX) return ARG_MAX; if (name == _SC_SEM_VALUE_MAX) return SEM_VALUE_MAX; - } else if (values[name] < 0) { + } else if (values[name] == CPUCNT) { + unsigned char set[128] = {1}; + int i, cnt; + __syscall(SYS_sched_getaffinity, 0, sizeof set, set); + for (i=cnt=0; i