Linux 上内存映射文件的大页

Joh*_*nck 5 c linux mmap tlb huge-pages

我想在 Linux 3.13 上将大页与内存映射文件一起使用。

首先,在 Ubuntu 上我这样做是为了分配 10 个大页面:

sudo apt-get install hugepages
sudo hugeadm --pool-pages-min=2048K:10
Run Code Online (Sandbox Code Playgroud)

然后我运行了这个测试程序:

#include <assert.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/mman.h>
#include <sys/types.h>
#include <unistd.h>

int main(void)
{
    size_t size = 2 * 1024 * 1024; /* 1 huge page */

    int fd = open("foo.bar", O_RDWR|O_CREAT, 0666);
    assert(fd >= 0);
    int rc = ftruncate(fd, size);
    assert(rc == 0);

    void* hint = 0;
    int flags = MAP_SHARED | MAP_HUGETLB;
    void* data = mmap(hint, size, PROT_READ|PROT_WRITE, flags, fd, 0);
    if (data == MAP_FAILED)
        perror("mmap");
    assert(data != MAP_FAILED);
}
Run Code Online (Sandbox Code Playgroud)

它总是失败并显示 EINVAL。如果你更改flagsMAP_PRIVATE|MAP_ANONYMOUS那么它可以工作,但当然它不会向文件写入任何内容。

我也尝试使用madvise()after mmap()without MAP_HUGETLB

    rc = madvise(data, size, MADV_HUGEPAGE);
    if (rc != 0)
        perror("madvise");
    assert(rc == 0);
Run Code Online (Sandbox Code Playgroud)

如果不使用,这也会失败 ( EINVAL) 。MAP_ANONYMOUS

有什么方法可以在磁盘上启用带有内存映射文件的大页面吗?

需要明确的是,我正在寻找一种在 C 语言中执行此操作的方法 - 我并不是要求一个适用于现有可执行文件的解决方案(那么问题将属于超级用户)。

Nom*_*mal 4

您使用的底层文件系统似乎不支持使用大页面的内存映射文件。

例如,对于 ext4,截至 2017 年 1 月,此支持仍在开发中,尚未包含在内核中(截至 2017 年 5 月 19 日)。

如果您运行应用了该补丁集的内核,请注意您需要在文件系统挂载选项中启用大页面支持,例如添加到所需文件系统的huge=always第四列,或使用./etc/fstabsudo mount -o remount,huge=always /mountpoint