 a5d2f46a97
			
		
	
	
	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>
		
	
			
		
			
				
	
	
		
			34 lines
		
	
	
	
		
			832 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			34 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;
 | |
| }
 |