Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/shaggy...
[linux-2.6] / arch / um / os-Linux / tls.c
1 #include <errno.h>
2 #include <sys/ptrace.h>
3 #include <sys/syscall.h>
4 #include <asm/ldt.h>
5 #include "sysdep/tls.h"
6 #include "uml-config.h"
7
8 /* TLS support - we basically rely on the host's one.*/
9
10 /* In TT mode, this should be called only by the tracing thread, and makes sense
11  * only for PTRACE_SET_THREAD_AREA. In SKAS mode, it's used normally.
12  *
13  */
14
15 #ifndef PTRACE_GET_THREAD_AREA
16 #define PTRACE_GET_THREAD_AREA 25
17 #endif
18
19 #ifndef PTRACE_SET_THREAD_AREA
20 #define PTRACE_SET_THREAD_AREA 26
21 #endif
22
23 int os_set_thread_area(user_desc_t *info, int pid)
24 {
25         int ret;
26
27         ret = ptrace(PTRACE_SET_THREAD_AREA, pid, info->entry_number,
28                      (unsigned long) info);
29         if (ret < 0)
30                 ret = -errno;
31         return ret;
32 }
33
34 #ifdef UML_CONFIG_MODE_SKAS
35
36 int os_get_thread_area(user_desc_t *info, int pid)
37 {
38         int ret;
39
40         ret = ptrace(PTRACE_GET_THREAD_AREA, pid, info->entry_number,
41                      (unsigned long) info);
42         if (ret < 0)
43                 ret = -errno;
44         return ret;
45 }
46
47 #endif
48
49 #ifdef UML_CONFIG_MODE_TT
50 #include "linux/unistd.h"
51
52 int do_set_thread_area_tt(user_desc_t *info)
53 {
54         int ret;
55
56         ret = syscall(__NR_set_thread_area,info);
57         if (ret < 0) {
58                 ret = -errno;
59         }
60         return ret;
61 }
62
63 int do_get_thread_area_tt(user_desc_t *info)
64 {
65         int ret;
66
67         ret = syscall(__NR_get_thread_area,info);
68         if (ret < 0) {
69                 ret = -errno;
70         }
71         return ret;
72 }
73
74 #endif /* UML_CONFIG_MODE_TT */