| #include <errno.h> |
| #include <unistd.h> |
| #include <sys/ptrace.h> |
| #include <sys/syscall.h> |
| #include <asm/ldt.h> |
| #include "sysdep/tls.h" |
| #include "uml-config.h" |
| |
| /* TLS support - we basically rely on the host's one.*/ |
| |
| /* In TT mode, this should be called only by the tracing thread, and makes sense |
| * only for PTRACE_SET_THREAD_AREA. In SKAS mode, it's used normally. |
| * |
| */ |
| |
| #ifndef PTRACE_GET_THREAD_AREA |
| #define PTRACE_GET_THREAD_AREA 25 |
| #endif |
| |
| #ifndef PTRACE_SET_THREAD_AREA |
| #define PTRACE_SET_THREAD_AREA 26 |
| #endif |
| |
| int os_set_thread_area(user_desc_t *info, int pid) |
| { |
| int ret; |
| |
| ret = ptrace(PTRACE_SET_THREAD_AREA, pid, info->entry_number, |
| (unsigned long) info); |
| if (ret < 0) |
| ret = -errno; |
| return ret; |
| } |
| |
| #ifdef UML_CONFIG_MODE_SKAS |
| |
| int os_get_thread_area(user_desc_t *info, int pid) |
| { |
| int ret; |
| |
| ret = ptrace(PTRACE_GET_THREAD_AREA, pid, info->entry_number, |
| (unsigned long) info); |
| if (ret < 0) |
| ret = -errno; |
| return ret; |
| } |
| |
| #endif |
| |
| #ifdef UML_CONFIG_MODE_TT |
| #include "linux/unistd.h" |
| |
| int do_set_thread_area_tt(user_desc_t *info) |
| { |
| int ret; |
| |
| ret = syscall(__NR_set_thread_area,info); |
| if (ret < 0) { |
| ret = -errno; |
| } |
| return ret; |
| } |
| |
| int do_get_thread_area_tt(user_desc_t *info) |
| { |
| int ret; |
| |
| ret = syscall(__NR_get_thread_area,info); |
| if (ret < 0) { |
| ret = -errno; |
| } |
| return ret; |
| } |
| |
| #endif /* UML_CONFIG_MODE_TT */ |