diff options
| author | Richard Weinberger <richard@nod.at> | 2015-03-18 16:31:27 -0400 |
|---|---|---|
| committer | Richard Weinberger <richard@nod.at> | 2015-04-13 15:00:53 -0400 |
| commit | d0b5e15f0c0fdd759dd3dd48dc2dc2e7199e0da0 (patch) | |
| tree | 7b833b85c0e2eabf6b38d8b94875b430554afae7 /arch/um/include/shared | |
| parent | aaeac66b1a02d399ec8ee63e8d617c1d601ea353 (diff) | |
um: Remove SKAS3/4 support
Before we had SKAS0 UML had two modes of operation
TT (tracing thread) and SKAS3/4 (separated kernel address space).
TT was known to be insecure and got removed a long time ago.
SKAS3/4 required a few (3 or 4) patches on the host side which never went
mainline. The last host patch is 10 years old.
With SKAS0 mode (separated kernel address space using 0 host patches),
default since 2005, SKAS3/4 is obsolete and can be removed.
Signed-off-by: Richard Weinberger <richard@nod.at>
Diffstat (limited to 'arch/um/include/shared')
| -rw-r--r-- | arch/um/include/shared/os.h | 2 | ||||
| -rw-r--r-- | arch/um/include/shared/skas/proc_mm.h | 44 | ||||
| -rw-r--r-- | arch/um/include/shared/skas/skas.h | 3 | ||||
| -rw-r--r-- | arch/um/include/shared/skas_ptrace.h | 14 |
4 files changed, 0 insertions, 63 deletions
diff --git a/arch/um/include/shared/os.h b/arch/um/include/shared/os.h index 08eec0b691b0..d824528f6f62 100644 --- a/arch/um/include/shared/os.h +++ b/arch/um/include/shared/os.h | |||
| @@ -174,7 +174,6 @@ extern unsigned long long os_makedev(unsigned major, unsigned minor); | |||
| 174 | 174 | ||
| 175 | /* start_up.c */ | 175 | /* start_up.c */ |
| 176 | extern void os_early_checks(void); | 176 | extern void os_early_checks(void); |
| 177 | extern void can_do_skas(void); | ||
| 178 | extern void os_check_bugs(void); | 177 | extern void os_check_bugs(void); |
| 179 | extern void check_host_supports_tls(int *supports_tls, int *tls_min); | 178 | extern void check_host_supports_tls(int *supports_tls, int *tls_min); |
| 180 | 179 | ||
| @@ -187,7 +186,6 @@ extern int os_process_parent(int pid); | |||
| 187 | extern void os_stop_process(int pid); | 186 | extern void os_stop_process(int pid); |
| 188 | extern void os_kill_process(int pid, int reap_child); | 187 | extern void os_kill_process(int pid, int reap_child); |
| 189 | extern void os_kill_ptraced_process(int pid, int reap_child); | 188 | extern void os_kill_ptraced_process(int pid, int reap_child); |
| 190 | extern long os_ptrace_ldt(long pid, long addr, long data); | ||
| 191 | 189 | ||
| 192 | extern int os_getpid(void); | 190 | extern int os_getpid(void); |
| 193 | extern int os_getpgrp(void); | 191 | extern int os_getpgrp(void); |
diff --git a/arch/um/include/shared/skas/proc_mm.h b/arch/um/include/shared/skas/proc_mm.h deleted file mode 100644 index 902809209603..000000000000 --- a/arch/um/include/shared/skas/proc_mm.h +++ /dev/null | |||
| @@ -1,44 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 2002 Jeff Dike (jdike@karaya.com) | ||
| 3 | * Licensed under the GPL | ||
| 4 | */ | ||
| 5 | |||
| 6 | #ifndef __SKAS_PROC_MM_H | ||
| 7 | #define __SKAS_PROC_MM_H | ||
| 8 | |||
| 9 | #define MM_MMAP 54 | ||
| 10 | #define MM_MUNMAP 55 | ||
| 11 | #define MM_MPROTECT 56 | ||
| 12 | #define MM_COPY_SEGMENTS 57 | ||
| 13 | |||
| 14 | struct mm_mmap { | ||
| 15 | unsigned long addr; | ||
| 16 | unsigned long len; | ||
| 17 | unsigned long prot; | ||
| 18 | unsigned long flags; | ||
| 19 | unsigned long fd; | ||
| 20 | unsigned long offset; | ||
| 21 | }; | ||
| 22 | |||
| 23 | struct mm_munmap { | ||
| 24 | unsigned long addr; | ||
| 25 | unsigned long len; | ||
| 26 | }; | ||
| 27 | |||
| 28 | struct mm_mprotect { | ||
| 29 | unsigned long addr; | ||
| 30 | unsigned long len; | ||
| 31 | unsigned int prot; | ||
| 32 | }; | ||
| 33 | |||
| 34 | struct proc_mm_op { | ||
| 35 | int op; | ||
| 36 | union { | ||
| 37 | struct mm_mmap mmap; | ||
| 38 | struct mm_munmap munmap; | ||
| 39 | struct mm_mprotect mprotect; | ||
| 40 | int copy_segments; | ||
| 41 | } u; | ||
| 42 | }; | ||
| 43 | |||
| 44 | #endif | ||
diff --git a/arch/um/include/shared/skas/skas.h b/arch/um/include/shared/skas/skas.h index c45df961c874..911f3c45ad1f 100644 --- a/arch/um/include/shared/skas/skas.h +++ b/arch/um/include/shared/skas/skas.h | |||
| @@ -9,13 +9,10 @@ | |||
| 9 | #include <sysdep/ptrace.h> | 9 | #include <sysdep/ptrace.h> |
| 10 | 10 | ||
| 11 | extern int userspace_pid[]; | 11 | extern int userspace_pid[]; |
| 12 | extern int proc_mm, ptrace_faultinfo, ptrace_ldt; | ||
| 13 | extern int skas_needs_stub; | ||
| 14 | 12 | ||
| 15 | extern int user_thread(unsigned long stack, int flags); | 13 | extern int user_thread(unsigned long stack, int flags); |
| 16 | extern void new_thread_handler(void); | 14 | extern void new_thread_handler(void); |
| 17 | extern void handle_syscall(struct uml_pt_regs *regs); | 15 | extern void handle_syscall(struct uml_pt_regs *regs); |
| 18 | extern int new_mm(unsigned long stack); | ||
| 19 | extern long execute_syscall_skas(void *r); | 16 | extern long execute_syscall_skas(void *r); |
| 20 | extern unsigned long current_stub_stack(void); | 17 | extern unsigned long current_stub_stack(void); |
| 21 | 18 | ||
diff --git a/arch/um/include/shared/skas_ptrace.h b/arch/um/include/shared/skas_ptrace.h deleted file mode 100644 index 630a9c92b93c..000000000000 --- a/arch/um/include/shared/skas_ptrace.h +++ /dev/null | |||
| @@ -1,14 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com) | ||
| 3 | * Licensed under the GPL | ||
| 4 | */ | ||
| 5 | |||
| 6 | #ifndef __SKAS_PTRACE_H | ||
| 7 | #define __SKAS_PTRACE_H | ||
| 8 | |||
| 9 | #define PTRACE_FAULTINFO 52 | ||
| 10 | #define PTRACE_SWITCH_MM 55 | ||
| 11 | |||
| 12 | #include <sysdep/skas_ptrace.h> | ||
| 13 | |||
| 14 | #endif | ||
