Merge "Support large errno values on ARM."

This commit is contained in:
Elliott Hughes 2013-03-12 19:08:36 +00:00 committed by Gerrit Code Review
commit 94a34010c1

View File

@ -27,6 +27,9 @@
*/ */
#include <errno.h> #include <errno.h>
#include <linux/err.h>
#define unlikely(x) __builtin_expect((x), false) // Used but not defined by <linux/err.h>.
// These functions are called from our assembler syscall stubs. // These functions are called from our assembler syscall stubs.
// C/C++ code should just assign 'errno' instead. // C/C++ code should just assign 'errno' instead.
@ -39,14 +42,10 @@ extern "C" int __set_errno(int n) {
} }
// TODO: this is only used on ARM, but is exported by NDK on all platforms :-( // TODO: this is only used on ARM, but is exported by NDK on all platforms :-(
extern "C" __LIBC_HIDDEN__ int __set_syscall_errno(int n) { extern "C" __LIBC_HIDDEN__ int __set_syscall_errno(unsigned long n) {
// Some syscalls, mmap() for example, have valid return if (IS_ERR_VALUE(n)) {
// values that are "negative". Since errno values are not errno = -n;
// greater than 131 on Linux, we will just consider return -1;
// anything significantly out of range as not-an-error. }
if(n > -256) {
return __set_errno(-n);
} else {
return n; return n;
} }
}