aboutsummaryrefslogtreecommitdiff
path: root/arch/um/include/tlb.h
blob: c6f9628f39bfd159a87df0dd19c07053b536142e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/* 
 * Copyright (C) 2002 Jeff Dike (jdike@karaya.com)
 * Licensed under the GPL
 */

#ifndef __TLB_H__
#define __TLB_H__

#include "um_mmu.h"

struct host_vm_op {
	enum { MMAP, MUNMAP, MPROTECT } type;
	union {
		struct {
			unsigned long addr;
			unsigned long len;
			unsigned int r:1;
			unsigned int w:1;
			unsigned int x:1;
			int fd;
			__u64 offset;
		} mmap;
		struct {
			unsigned long addr;
			unsigned long len;
		} munmap;
		struct {
			unsigned long addr;
			unsigned long len;
			unsigned int r:1;
			unsigned int w:1;
			unsigned int x:1;
		} mprotect;
	} u;
};

extern void mprotect_kernel_vm(int w);
extern void force_flush_all(void);
extern void fix_range_common(struct mm_struct *mm, unsigned long start_addr,
                             unsigned long end_addr, int force,
                             void (*do_ops)(union mm_context *,
                                            struct host_vm_op *, int));
extern int flush_tlb_kernel_range_common(unsigned long start,
					 unsigned long end);

extern int add_mmap(unsigned long virt, unsigned long phys, unsigned long len,
		    int r, int w, int x, struct host_vm_op *ops, int index,
                    int last_filled, union mm_context *mmu,
                    void (*do_ops)(union mm_context *, struct host_vm_op *,
                                   int));
extern int add_munmap(unsigned long addr, unsigned long len,
		      struct host_vm_op *ops, int index, int last_filled,
                      union mm_context *mmu,
                      void (*do_ops)(union mm_context *, struct host_vm_op *,
                                     int));
extern int add_mprotect(unsigned long addr, unsigned long len, int r, int w,
			int x, struct host_vm_op *ops, int index,
                        int last_filled, union mm_context *mmu,
                        void (*do_ops)(union mm_context *, struct host_vm_op *,
                                       int));
#endif