diff options
Diffstat (limited to 'arch/um/kernel/tlb.c')
-rw-r--r-- | arch/um/kernel/tlb.c | 43 |
1 files changed, 21 insertions, 22 deletions
diff --git a/arch/um/kernel/tlb.c b/arch/um/kernel/tlb.c index 849922fcfb60..081baefb4c0d 100644 --- a/arch/um/kernel/tlb.c +++ b/arch/um/kernel/tlb.c | |||
@@ -14,8 +14,8 @@ | |||
14 | 14 | ||
15 | static int add_mmap(unsigned long virt, unsigned long phys, unsigned long len, | 15 | static int add_mmap(unsigned long virt, unsigned long phys, unsigned long len, |
16 | unsigned int prot, struct host_vm_op *ops, int *index, | 16 | unsigned int prot, struct host_vm_op *ops, int *index, |
17 | int last_filled, union mm_context *mmu, void **flush, | 17 | int last_filled, struct mm_context *mmu, void **flush, |
18 | int (*do_ops)(union mm_context *, struct host_vm_op *, | 18 | int (*do_ops)(struct mm_context *, struct host_vm_op *, |
19 | int, int, void **)) | 19 | int, int, void **)) |
20 | { | 20 | { |
21 | __u64 offset; | 21 | __u64 offset; |
@@ -52,8 +52,8 @@ static int add_mmap(unsigned long virt, unsigned long phys, unsigned long len, | |||
52 | 52 | ||
53 | static int add_munmap(unsigned long addr, unsigned long len, | 53 | static int add_munmap(unsigned long addr, unsigned long len, |
54 | struct host_vm_op *ops, int *index, int last_filled, | 54 | struct host_vm_op *ops, int *index, int last_filled, |
55 | union mm_context *mmu, void **flush, | 55 | struct mm_context *mmu, void **flush, |
56 | int (*do_ops)(union mm_context *, struct host_vm_op *, | 56 | int (*do_ops)(struct mm_context *, struct host_vm_op *, |
57 | int, int, void **)) | 57 | int, int, void **)) |
58 | { | 58 | { |
59 | struct host_vm_op *last; | 59 | struct host_vm_op *last; |
@@ -82,8 +82,8 @@ static int add_munmap(unsigned long addr, unsigned long len, | |||
82 | 82 | ||
83 | static int add_mprotect(unsigned long addr, unsigned long len, | 83 | static int add_mprotect(unsigned long addr, unsigned long len, |
84 | unsigned int prot, struct host_vm_op *ops, int *index, | 84 | unsigned int prot, struct host_vm_op *ops, int *index, |
85 | int last_filled, union mm_context *mmu, void **flush, | 85 | int last_filled, struct mm_context *mmu, void **flush, |
86 | int (*do_ops)(union mm_context *, struct host_vm_op *, | 86 | int (*do_ops)(struct mm_context *, struct host_vm_op *, |
87 | int, int, void **)) | 87 | int, int, void **)) |
88 | { | 88 | { |
89 | struct host_vm_op *last; | 89 | struct host_vm_op *last; |
@@ -117,8 +117,8 @@ static int add_mprotect(unsigned long addr, unsigned long len, | |||
117 | static inline int update_pte_range(pmd_t *pmd, unsigned long addr, | 117 | static inline int update_pte_range(pmd_t *pmd, unsigned long addr, |
118 | unsigned long end, struct host_vm_op *ops, | 118 | unsigned long end, struct host_vm_op *ops, |
119 | int last_op, int *op_index, int force, | 119 | int last_op, int *op_index, int force, |
120 | union mm_context *mmu, void **flush, | 120 | struct mm_context *mmu, void **flush, |
121 | int (*do_ops)(union mm_context *, | 121 | int (*do_ops)(struct mm_context *, |
122 | struct host_vm_op *, int, int, | 122 | struct host_vm_op *, int, int, |
123 | void **)) | 123 | void **)) |
124 | { | 124 | { |
@@ -157,8 +157,8 @@ static inline int update_pte_range(pmd_t *pmd, unsigned long addr, | |||
157 | static inline int update_pmd_range(pud_t *pud, unsigned long addr, | 157 | static inline int update_pmd_range(pud_t *pud, unsigned long addr, |
158 | unsigned long end, struct host_vm_op *ops, | 158 | unsigned long end, struct host_vm_op *ops, |
159 | int last_op, int *op_index, int force, | 159 | int last_op, int *op_index, int force, |
160 | union mm_context *mmu, void **flush, | 160 | struct mm_context *mmu, void **flush, |
161 | int (*do_ops)(union mm_context *, | 161 | int (*do_ops)(struct mm_context *, |
162 | struct host_vm_op *, int, int, | 162 | struct host_vm_op *, int, int, |
163 | void **)) | 163 | void **)) |
164 | { | 164 | { |
@@ -187,8 +187,8 @@ static inline int update_pmd_range(pud_t *pud, unsigned long addr, | |||
187 | static inline int update_pud_range(pgd_t *pgd, unsigned long addr, | 187 | static inline int update_pud_range(pgd_t *pgd, unsigned long addr, |
188 | unsigned long end, struct host_vm_op *ops, | 188 | unsigned long end, struct host_vm_op *ops, |
189 | int last_op, int *op_index, int force, | 189 | int last_op, int *op_index, int force, |
190 | union mm_context *mmu, void **flush, | 190 | struct mm_context *mmu, void **flush, |
191 | int (*do_ops)(union mm_context *, | 191 | int (*do_ops)(struct mm_context *, |
192 | struct host_vm_op *, int, int, | 192 | struct host_vm_op *, int, int, |
193 | void **)) | 193 | void **)) |
194 | { | 194 | { |
@@ -216,11 +216,11 @@ static inline int update_pud_range(pgd_t *pgd, unsigned long addr, | |||
216 | 216 | ||
217 | void fix_range_common(struct mm_struct *mm, unsigned long start_addr, | 217 | void fix_range_common(struct mm_struct *mm, unsigned long start_addr, |
218 | unsigned long end_addr, int force, | 218 | unsigned long end_addr, int force, |
219 | int (*do_ops)(union mm_context *, struct host_vm_op *, | 219 | int (*do_ops)(struct mm_context *, struct host_vm_op *, |
220 | int, int, void **)) | 220 | int, int, void **)) |
221 | { | 221 | { |
222 | pgd_t *pgd; | 222 | pgd_t *pgd; |
223 | union mm_context *mmu = &mm->context; | 223 | struct mm_context *mmu = &mm->context; |
224 | struct host_vm_op ops[1]; | 224 | struct host_vm_op ops[1]; |
225 | unsigned long addr = start_addr, next; | 225 | unsigned long addr = start_addr, next; |
226 | int ret = 0, last_op = ARRAY_SIZE(ops) - 1, op_index = -1; | 226 | int ret = 0, last_op = ARRAY_SIZE(ops) - 1, op_index = -1; |
@@ -375,7 +375,7 @@ void flush_tlb_page(struct vm_area_struct *vma, unsigned long address) | |||
375 | w = 0; | 375 | w = 0; |
376 | } | 376 | } |
377 | 377 | ||
378 | mm_id = &mm->context.skas.id; | 378 | mm_id = &mm->context.id; |
379 | prot = ((r ? UM_PROT_READ : 0) | (w ? UM_PROT_WRITE : 0) | | 379 | prot = ((r ? UM_PROT_READ : 0) | (w ? UM_PROT_WRITE : 0) | |
380 | (x ? UM_PROT_EXEC : 0)); | 380 | (x ? UM_PROT_EXEC : 0)); |
381 | if (pte_newpage(*pte)) { | 381 | if (pte_newpage(*pte)) { |
@@ -453,7 +453,7 @@ void __flush_tlb_one(unsigned long addr) | |||
453 | flush_tlb_kernel_range_common(addr, addr + PAGE_SIZE); | 453 | flush_tlb_kernel_range_common(addr, addr + PAGE_SIZE); |
454 | } | 454 | } |
455 | 455 | ||
456 | static int do_ops(union mm_context *mmu, struct host_vm_op *ops, int last, | 456 | static int do_ops(struct mm_context *mmu, struct host_vm_op *ops, int last, |
457 | int finished, void **flush) | 457 | int finished, void **flush) |
458 | { | 458 | { |
459 | struct host_vm_op *op; | 459 | struct host_vm_op *op; |
@@ -463,17 +463,16 @@ static int do_ops(union mm_context *mmu, struct host_vm_op *ops, int last, | |||
463 | op = &ops[i]; | 463 | op = &ops[i]; |
464 | switch(op->type) { | 464 | switch(op->type) { |
465 | case MMAP: | 465 | case MMAP: |
466 | ret = map(&mmu->skas.id, op->u.mmap.addr, | 466 | ret = map(&mmu->id, op->u.mmap.addr, op->u.mmap.len, |
467 | op->u.mmap.len, op->u.mmap.prot, | 467 | op->u.mmap.prot, op->u.mmap.fd, |
468 | op->u.mmap.fd, op->u.mmap.offset, finished, | 468 | op->u.mmap.offset, finished, flush); |
469 | flush); | ||
470 | break; | 469 | break; |
471 | case MUNMAP: | 470 | case MUNMAP: |
472 | ret = unmap(&mmu->skas.id, op->u.munmap.addr, | 471 | ret = unmap(&mmu->id, op->u.munmap.addr, |
473 | op->u.munmap.len, finished, flush); | 472 | op->u.munmap.len, finished, flush); |
474 | break; | 473 | break; |
475 | case MPROTECT: | 474 | case MPROTECT: |
476 | ret = protect(&mmu->skas.id, op->u.mprotect.addr, | 475 | ret = protect(&mmu->id, op->u.mprotect.addr, |
477 | op->u.mprotect.len, op->u.mprotect.prot, | 476 | op->u.mprotect.len, op->u.mprotect.prot, |
478 | finished, flush); | 477 | finished, flush); |
479 | break; | 478 | break; |