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