Skip to content

Commit 33041a0

Browse files
kiryltorvalds
authored andcommitted
mm: mark remap_file_pages() syscall as deprecated
The remap_file_pages() system call is used to create a nonlinear mapping, that is, a mapping in which the pages of the file are mapped into a nonsequential order in memory. The advantage of using remap_file_pages() over using repeated calls to mmap(2) is that the former approach does not require the kernel to create additional VMA (Virtual Memory Area) data structures. Supporting of nonlinear mapping requires significant amount of non-trivial code in kernel virtual memory subsystem including hot paths. Also to get nonlinear mapping work kernel need a way to distinguish normal page table entries from entries with file offset (pte_file). Kernel reserves flag in PTE for this purpose. PTE flags are scarce resource especially on some CPU architectures. It would be nice to free up the flag for other usage. Fortunately, there are not many users of remap_file_pages() in the wild. It's only known that one enterprise RDBMS implementation uses the syscall on 32-bit systems to map files bigger than can linearly fit into 32-bit virtual address space. This use-case is not critical anymore since 64-bit systems are widely available. The plan is to deprecate the syscall and replace it with an emulation. The emulation will create new VMAs instead of nonlinear mappings. It's going to work slower for rare users of remap_file_pages() but ABI is preserved. One side effect of emulation (apart from performance) is that user can hit vm.max_map_count limit more easily due to additional VMAs. See comment for DEFAULT_MAX_MAP_COUNT for more details on the limit. [[email protected]: fix spello] Signed-off-by: Kirill A. Shutemov <[email protected]> Cc: Peter Zijlstra <[email protected]> Cc: Ingo Molnar <[email protected]> Cc: Dave Jones <[email protected]> Cc: Armin Rigo <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
1 parent cf2c812 commit 33041a0

File tree

2 files changed

+32
-0
lines changed

2 files changed

+32
-0
lines changed

Documentation/vm/remap_file_pages.txt

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
The remap_file_pages() system call is used to create a nonlinear mapping,
2+
that is, a mapping in which the pages of the file are mapped into a
3+
nonsequential order in memory. The advantage of using remap_file_pages()
4+
over using repeated calls to mmap(2) is that the former approach does not
5+
require the kernel to create additional VMA (Virtual Memory Area) data
6+
structures.
7+
8+
Supporting of nonlinear mapping requires significant amount of non-trivial
9+
code in kernel virtual memory subsystem including hot paths. Also to get
10+
nonlinear mapping work kernel need a way to distinguish normal page table
11+
entries from entries with file offset (pte_file). Kernel reserves flag in
12+
PTE for this purpose. PTE flags are scarce resource especially on some CPU
13+
architectures. It would be nice to free up the flag for other usage.
14+
15+
Fortunately, there are not many users of remap_file_pages() in the wild.
16+
It's only known that one enterprise RDBMS implementation uses the syscall
17+
on 32-bit systems to map files bigger than can linearly fit into 32-bit
18+
virtual address space. This use-case is not critical anymore since 64-bit
19+
systems are widely available.
20+
21+
The plan is to deprecate the syscall and replace it with an emulation.
22+
The emulation will create new VMAs instead of nonlinear mappings. It's
23+
going to work slower for rare users of remap_file_pages() but ABI is
24+
preserved.
25+
26+
One side effect of emulation (apart from performance) is that user can hit
27+
vm.max_map_count limit more easily due to additional VMAs. See comment for
28+
DEFAULT_MAX_MAP_COUNT for more details on the limit.

mm/fremap.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -149,6 +149,10 @@ SYSCALL_DEFINE5(remap_file_pages, unsigned long, start, unsigned long, size,
149149
int has_write_lock = 0;
150150
vm_flags_t vm_flags = 0;
151151

152+
pr_warn_once("%s (%d) uses deprecated remap_file_pages() syscall. "
153+
"See Documentation/vm/remap_file_pages.txt.\n",
154+
current->comm, current->pid);
155+
152156
if (prot)
153157
return err;
154158
/*

0 commit comments

Comments
 (0)