diff options
Diffstat (limited to 'mm/nommu.c')
-rw-r--r-- | mm/nommu.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/mm/nommu.c b/mm/nommu.c index 23fb033e596d..1f60194d9b9b 100644 --- a/mm/nommu.c +++ b/mm/nommu.c | |||
@@ -45,6 +45,7 @@ int heap_stack_gap = 0; | |||
45 | 45 | ||
46 | EXPORT_SYMBOL(mem_map); | 46 | EXPORT_SYMBOL(mem_map); |
47 | EXPORT_SYMBOL(__vm_enough_memory); | 47 | EXPORT_SYMBOL(__vm_enough_memory); |
48 | EXPORT_SYMBOL(num_physpages); | ||
48 | 49 | ||
49 | /* list of shareable VMAs */ | 50 | /* list of shareable VMAs */ |
50 | struct rb_root nommu_vma_tree = RB_ROOT; | 51 | struct rb_root nommu_vma_tree = RB_ROOT; |
@@ -826,6 +827,11 @@ unsigned long do_mmap_pgoff(struct file *file, | |||
826 | unsigned long pglen = (len + PAGE_SIZE - 1) >> PAGE_SHIFT; | 827 | unsigned long pglen = (len + PAGE_SIZE - 1) >> PAGE_SHIFT; |
827 | unsigned long vmpglen; | 828 | unsigned long vmpglen; |
828 | 829 | ||
830 | /* suppress VMA sharing for shared regions */ | ||
831 | if (vm_flags & VM_SHARED && | ||
832 | capabilities & BDI_CAP_MAP_DIRECT) | ||
833 | goto dont_share_VMAs; | ||
834 | |||
829 | for (rb = rb_first(&nommu_vma_tree); rb; rb = rb_next(rb)) { | 835 | for (rb = rb_first(&nommu_vma_tree); rb; rb = rb_next(rb)) { |
830 | vma = rb_entry(rb, struct vm_area_struct, vm_rb); | 836 | vma = rb_entry(rb, struct vm_area_struct, vm_rb); |
831 | 837 | ||
@@ -859,6 +865,7 @@ unsigned long do_mmap_pgoff(struct file *file, | |||
859 | goto shared; | 865 | goto shared; |
860 | } | 866 | } |
861 | 867 | ||
868 | dont_share_VMAs: | ||
862 | vma = NULL; | 869 | vma = NULL; |
863 | 870 | ||
864 | /* obtain the address at which to make a shared mapping | 871 | /* obtain the address at which to make a shared mapping |
@@ -1193,6 +1200,28 @@ void unmap_mapping_range(struct address_space *mapping, | |||
1193 | EXPORT_SYMBOL(unmap_mapping_range); | 1200 | EXPORT_SYMBOL(unmap_mapping_range); |
1194 | 1201 | ||
1195 | /* | 1202 | /* |
1203 | * ask for an unmapped area at which to create a mapping on a file | ||
1204 | */ | ||
1205 | unsigned long get_unmapped_area(struct file *file, unsigned long addr, | ||
1206 | unsigned long len, unsigned long pgoff, | ||
1207 | unsigned long flags) | ||
1208 | { | ||
1209 | unsigned long (*get_area)(struct file *, unsigned long, unsigned long, | ||
1210 | unsigned long, unsigned long); | ||
1211 | |||
1212 | get_area = current->mm->get_unmapped_area; | ||
1213 | if (file && file->f_op && file->f_op->get_unmapped_area) | ||
1214 | get_area = file->f_op->get_unmapped_area; | ||
1215 | |||
1216 | if (!get_area) | ||
1217 | return -ENOSYS; | ||
1218 | |||
1219 | return get_area(file, addr, len, pgoff, flags); | ||
1220 | } | ||
1221 | |||
1222 | EXPORT_SYMBOL(get_unmapped_area); | ||
1223 | |||
1224 | /* | ||
1196 | * Check that a process has enough memory to allocate a new virtual | 1225 | * Check that a process has enough memory to allocate a new virtual |
1197 | * mapping. 0 means there is enough memory for the allocation to | 1226 | * mapping. 0 means there is enough memory for the allocation to |
1198 | * succeed and -ENOMEM implies there is not. | 1227 | * succeed and -ENOMEM implies there is not. |