a5d2f46a97
Two small TLS fixes - arch/um/os-Linux/sys-i386/tls.c uses errno and -E* so it should include errno.h __setup_host_supports_tls returns 1, but as an initcall, it should return 0 Signed-off-by: Jeff Dike <jdike@addtoit.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
35 lines
832 B
C
35 lines
832 B
C
#include <errno.h>
|
|
#include <linux/unistd.h>
|
|
#include "sysdep/tls.h"
|
|
#include "user_util.h"
|
|
|
|
static _syscall1(int, get_thread_area, user_desc_t *, u_info);
|
|
|
|
/* Checks whether host supports TLS, and sets *tls_min according to the value
|
|
* valid on the host.
|
|
* i386 host have it == 6; x86_64 host have it == 12, for i386 emulation. */
|
|
void check_host_supports_tls(int *supports_tls, int *tls_min) {
|
|
/* Values for x86 and x86_64.*/
|
|
int val[] = {GDT_ENTRY_TLS_MIN_I386, GDT_ENTRY_TLS_MIN_X86_64};
|
|
int i;
|
|
|
|
for (i = 0; i < ARRAY_SIZE(val); i++) {
|
|
user_desc_t info;
|
|
info.entry_number = val[i];
|
|
|
|
if (get_thread_area(&info) == 0) {
|
|
*tls_min = val[i];
|
|
*supports_tls = 1;
|
|
return;
|
|
} else {
|
|
if (errno == EINVAL)
|
|
continue;
|
|
else if (errno == ENOSYS)
|
|
*supports_tls = 0;
|
|
return;
|
|
}
|
|
}
|
|
|
|
*supports_tls = 0;
|
|
}
|