diff options
author | Jeff Dike <jdike@addtoit.com> | 2007-10-16 04:27:12 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-16 12:43:06 -0400 |
commit | 1466abf2d03207b42980ddf8cde1fba17b7cd301 (patch) | |
tree | 402f8a77f5b08c3a9130e341df402fb6c02b5c02 /arch/um/include/tlb.h | |
parent | 512b6fb1c14d4c34f23a3419b0789ad01914a899 (diff) |
uml: clean up tlb flush path
Tidy the tlb flushing code.
With tt mode gone, there is no reason to have the capability to have
called directly from do_mmap, do_mprotect, and do_munmap, rather than
calling a function pointer that it is given.
There was a large amount of data that was passed from function to
function, being used at the lowest level, without being changed. This
stuff is now encapsulated in a structure which is initialized at the
top layer and passed down. This simplifies the code, reduces the
amount of code needed to pass the parameters around, and saves on
stack space.
A somewhat more subtle change is the meaning of the current operation
index. It used to start at -1, being pre-incremented when adding an
operation. It now starts at 0, being post-incremented, with
associated adjustments of +/- 1 on comparisons.
In addition, tlb.h contained a couple of declarations which had no
users outside of tlb.c, so they could be moved or deleted.
Signed-off-by: Jeff Dike <jdike@linux.intel.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/um/include/tlb.h')
-rw-r--r-- | arch/um/include/tlb.h | 27 |
1 files changed, 0 insertions, 27 deletions
diff --git a/arch/um/include/tlb.h b/arch/um/include/tlb.h index 46cf0057a1c5..ecd2265b301b 100644 --- a/arch/um/include/tlb.h +++ b/arch/um/include/tlb.h | |||
@@ -8,34 +8,7 @@ | |||
8 | 8 | ||
9 | #include "um_mmu.h" | 9 | #include "um_mmu.h" |
10 | 10 | ||
11 | struct host_vm_op { | ||
12 | enum { NONE, MMAP, MUNMAP, MPROTECT } type; | ||
13 | union { | ||
14 | struct { | ||
15 | unsigned long addr; | ||
16 | unsigned long len; | ||
17 | unsigned int prot; | ||
18 | int fd; | ||
19 | __u64 offset; | ||
20 | } mmap; | ||
21 | struct { | ||
22 | unsigned long addr; | ||
23 | unsigned long len; | ||
24 | } munmap; | ||
25 | struct { | ||
26 | unsigned long addr; | ||
27 | unsigned long len; | ||
28 | unsigned int prot; | ||
29 | } mprotect; | ||
30 | } u; | ||
31 | }; | ||
32 | |||
33 | extern void force_flush_all(void); | 11 | extern void force_flush_all(void); |
34 | extern void fix_range_common(struct mm_struct *mm, unsigned long start_addr, | ||
35 | unsigned long end_addr, int force, | ||
36 | int (*do_ops)(struct mm_context *, | ||
37 | struct host_vm_op *, int, int, | ||
38 | void **)); | ||
39 | extern int flush_tlb_kernel_range_common(unsigned long start, | 12 | extern int flush_tlb_kernel_range_common(unsigned long start, |
40 | unsigned long end); | 13 | unsigned long end); |
41 | 14 | ||