OSDN Git Service

- only compile them if the respective syscalls are available
authorBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Wed, 24 Sep 2008 16:31:29 +0000 (16:31 -0000)
committerBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Wed, 24 Sep 2008 16:31:29 +0000 (16:31 -0000)
libc/sysdeps/linux/common/sched_getaffinity.c
libc/sysdeps/linux/common/sched_setaffinity.c

index 6785712..b3256c2 100644 (file)
@@ -26,8 +26,7 @@
 #include <string.h>
 #include <sys/param.h>
 
-/* Experimentally off - libc_hidden_proto(memset) */
-
+#if defined __NR_sched_getaffinity
 #define __NR___syscall_sched_getaffinity __NR_sched_getaffinity
 static __inline__ _syscall3(int, __syscall_sched_getaffinity, __kernel_pid_t, pid,
                        size_t, cpusetsize, cpu_set_t *, cpuset);
@@ -45,5 +44,11 @@ int sched_getaffinity(pid_t pid, size_t cpusetsize, cpu_set_t *cpuset)
        }
        return res;
 }
-
+#elif defined __UCLIBC_HAS_STUBS__
+int sched_getaffinity(pid_t pid, size_t cpusetsize, cpu_set_t *cpuset)
+{
+    __set_errno(ENOSYS);
+    return -1;
+}
+#endif
 #endif
index 7a854a8..004ec9d 100644 (file)
@@ -30,6 +30,7 @@
 #include <sys/param.h>
 #include <alloca.h>
 
+#if defined __NR_sched_setaffinity
 libc_hidden_proto(getpid)
 
 #define __NR___syscall_sched_setaffinity __NR_sched_setaffinity
@@ -73,5 +74,19 @@ int sched_setaffinity(pid_t pid, size_t cpusetsize, const cpu_set_t *cpuset)
 
        return INLINE_SYSCALL (sched_setaffinity, 3, pid, cpusetsize, cpuset);
 }
+#else
+#define ___HAVE_NO_sched_setaffinity
 #endif
+#else
+#define ___HAVE_NO_sched_setaffinity
 #endif
+
+#if defined ___HAVE_NO_sched_setaffinity && defined __UCLIBC_HAS_STUBS__
+int sched_setaffinity(pid_t pid, size_t cpusetsize, cpu_set_t *cpuset)
+{
+    __set_errno(ENOSYS);
+    return -1;
+}
+#endif
+
+#endif /* __USE_GNU */