From 355b5406fafe0d45285e70a0b01d5e674d6a2c16 Mon Sep 17 00:00:00 2001 From: Michael Sevakis Date: Mon, 28 Apr 2014 09:15:06 -0400 Subject: Make errno a thread-local variable. errno is supposed to be thread local and we do that here in a rather makeshift way by implementing a function that returns a pointer to the __errno variable in the thread block. If more serious TLS is required, perhaps it would be worthwhile implementing it using the linker and the "__thread" storage attribute. That's a bit overkill just for this. I'm also not liking what I saw the compiler producing. Change-Id: I03bc0bd6a89f6e3d6bae7653284ee01054614f9a Reviewed-on: http://gerrit.rockbox.org/803 Reviewed-by: Michael Sevakis Tested: Michael Sevakis --- firmware/libc/include/errno.h | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'firmware/libc/include') diff --git a/firmware/libc/include/errno.h b/firmware/libc/include/errno.h index 6a24a19..9df261d 100644 --- a/firmware/libc/include/errno.h +++ b/firmware/libc/include/errno.h @@ -10,10 +10,12 @@ #ifndef _SYS_ERRNO_H_ +extern int * __errno(void); + #ifdef PLUGIN -#define errno (*rb->__errno) +#define errno (*rb->__errno()) #else -extern int errno; +#define errno (*__errno()) #endif #define EPERM 1 /* Not super-user */ -- cgit v1.1