为什么“Unevictable”内存比“Mlocked”内存大?

为什么“Unevictable”内存比“Mlocked”内存大?

为什么“Unevictable”内存比“Mlocked”内存大?

$ cp /proc/meminfo meminfo
$ grep -iE "lock|evictable" meminfo
Unevictable:      161436 kB
Mlocked:           12772 kB

$ uname -r  # My kernel version
5.0.17-200.fc29.x86_64

“不可避免”内存的背景链接:

https://superuser.com/questions/1135809/odd-behaviour-with-unevictable-cache-linux-kernel/1449088#1449088

内核编译时支持tmpfs.我看不到任何ramfs(即任何不可交换的 RAM 文件系统)。

$ df -t ramfs
df: no file systems processed

$ cat meminfo
MemTotal:        8042664 kB
MemFree:         3733932 kB
MemAvailable:    5175960 kB
Buffers:          193684 kB
Cached:          1810672 kB
SwapCached:        14628 kB
Active:          2020900 kB
Inactive:        1644208 kB
Active(anon):    1127976 kB
Inactive(anon):   945940 kB
Active(file):     892924 kB
Inactive(file):   698268 kB
Unevictable:      161436 kB
Mlocked:           12772 kB
SwapTotal:       2097148 kB
SwapFree:        1465180 kB
Dirty:               312 kB
Writeback:             0 kB
AnonPages:       1813196 kB
Mapped:           539216 kB
Shmem:            408808 kB
KReclaimable:     160752 kB
Slab:             320584 kB
SReclaimable:     160752 kB
SUnreclaim:       159832 kB
KernelStack:       17792 kB
PageTables:        37288 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:     6118480 kB
Committed_AS:   11410784 kB
VmallocTotal:   34359738367 kB
VmallocUsed:           0 kB
VmallocChunk:          0 kB
Percpu:             3424 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
ShmemHugePages:        0 kB
ShmemPmdMapped:        0 kB
CmaTotal:              0 kB
CmaFree:               0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
Hugetlb:               0 kB
DirectMap4k:      492084 kB
DirectMap2M:     7774208 kB
DirectMap1G:     1048576 kB
[alan@alan-laptop ~]$ 

答案1

文档背景材料中提到mapping_set_unevictable()。它说它被用于两种情况:

  1. 由 ramfs 在创建其 inode 时对其地址空间进行标记,并且该标记在 inode 的生命周期内保持不变。

  2. 通过 SYSV SHM 来标记 SHM_LOCK'd 地址空间,直到调用 SHM_UNLOCK。

    请注意,如果锁定的页面被换出,则不需要 SHM_LOCK 对其进行分页;如果应用程序想要确保页面位于内存中,则必须手动触摸这些页面。

现在它被用于第三种情况。它适用于 i915 图形缓冲区(如果它们由 GPU 映射):

https://elixir.bootlin.com/linux/v5.0.17/ident/mapping_set_unevictable

4个文件中引用:

“全局图形转换表 (GTT) [...] 负责从 GPU 虚拟地址空间到物理地址的地址映射。”

相关内容