]>
Commit | Line | Data |
---|---|---|
1da177e4 LT |
1 | #ifndef _LINUX_VMALLOC_H |
2 | #define _LINUX_VMALLOC_H | |
3 | ||
4 | #include <linux/spinlock.h> | |
5 | #include <asm/page.h> /* pgprot_t */ | |
6 | ||
83342314 NP |
7 | struct vm_area_struct; |
8 | ||
1da177e4 LT |
9 | /* bits in vm_struct->flags */ |
10 | #define VM_IOREMAP 0x00000001 /* ioremap() and friends */ | |
11 | #define VM_ALLOC 0x00000002 /* vmalloc() */ | |
12 | #define VM_MAP 0x00000004 /* vmap()ed pages */ | |
83342314 | 13 | #define VM_USERMAP 0x00000008 /* suitable for remap_vmalloc_range */ |
8757d5fa | 14 | #define VM_VPAGES 0x00000010 /* buffer for pages was vmalloc'ed */ |
1da177e4 LT |
15 | /* bits [20..32] reserved for arch specific ioremap internals */ |
16 | ||
fd195c49 DS |
17 | /* |
18 | * Maximum alignment for ioremap() regions. | |
19 | * Can be overriden by arch-specific value. | |
20 | */ | |
21 | #ifndef IOREMAP_MAX_ORDER | |
22 | #define IOREMAP_MAX_ORDER (7 + PAGE_SHIFT) /* 128 pages */ | |
23 | #endif | |
24 | ||
1da177e4 | 25 | struct vm_struct { |
2b4ac44e ED |
26 | /* keep next,addr,size together to speedup lookups */ |
27 | struct vm_struct *next; | |
1da177e4 LT |
28 | void *addr; |
29 | unsigned long size; | |
30 | unsigned long flags; | |
31 | struct page **pages; | |
32 | unsigned int nr_pages; | |
33 | unsigned long phys_addr; | |
1da177e4 LT |
34 | }; |
35 | ||
36 | /* | |
37 | * Highlevel APIs for driver use | |
38 | */ | |
39 | extern void *vmalloc(unsigned long size); | |
83342314 | 40 | extern void *vmalloc_user(unsigned long size); |
930fc45a | 41 | extern void *vmalloc_node(unsigned long size, int node); |
1da177e4 LT |
42 | extern void *vmalloc_exec(unsigned long size); |
43 | extern void *vmalloc_32(unsigned long size); | |
83342314 | 44 | extern void *vmalloc_32_user(unsigned long size); |
dd0fc66f | 45 | extern void *__vmalloc(unsigned long size, gfp_t gfp_mask, pgprot_t prot); |
930fc45a CL |
46 | extern void *__vmalloc_area(struct vm_struct *area, gfp_t gfp_mask, |
47 | pgprot_t prot); | |
1da177e4 LT |
48 | extern void vfree(void *addr); |
49 | ||
50 | extern void *vmap(struct page **pages, unsigned int count, | |
51 | unsigned long flags, pgprot_t prot); | |
52 | extern void vunmap(void *addr); | |
83342314 NP |
53 | |
54 | extern int remap_vmalloc_range(struct vm_area_struct *vma, void *addr, | |
55 | unsigned long pgoff); | |
1da177e4 LT |
56 | |
57 | /* | |
58 | * Lowlevel-APIs (not for driver use!) | |
59 | */ | |
60 | extern struct vm_struct *get_vm_area(unsigned long size, unsigned long flags); | |
61 | extern struct vm_struct *__get_vm_area(unsigned long size, unsigned long flags, | |
62 | unsigned long start, unsigned long end); | |
930fc45a | 63 | extern struct vm_struct *get_vm_area_node(unsigned long size, |
52fd24ca GP |
64 | unsigned long flags, int node, |
65 | gfp_t gfp_mask); | |
1da177e4 LT |
66 | extern struct vm_struct *remove_vm_area(void *addr); |
67 | extern int map_vm_area(struct vm_struct *area, pgprot_t prot, | |
68 | struct page ***pages); | |
69 | extern void unmap_vm_area(struct vm_struct *area); | |
70 | ||
71 | /* | |
72 | * Internals. Dont't use.. | |
73 | */ | |
74 | extern rwlock_t vmlist_lock; | |
75 | extern struct vm_struct *vmlist; | |
76 | ||
77 | #endif /* _LINUX_VMALLOC_H */ |