「削除できない」メモリが「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
「必須」メモリへの背景リンク:
カーネルコンパイル時間のサポート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()
。 2つの状況で使用されるそうです。
inode のアドレス空間は作成時に ramfs で表示され、その表示は inode の存続期間中は変更されません。
SHM_LOCK'dアドレス空間は、SHM_UNLOCKが呼び出されるまでSYSV SHMによって表されます。
ロックされたページが置き換えられる場合、そのページをページングするためにSHM_LOCKは必要ありません。そのページがメモリに残っていることを確認するには、アプリケーションがページを手動でタッチする必要があります。
これで3番目のケースに使用されます。 i915グラフィックバッファで動作します(GPUによってマッピングされている場合)。
https://elixir.bootlin.com/linux/v5.0.17/ident/mapping_set_unevictable
4つの文書から引用:
- drivers/gpu/drm/i915/i915_gem.c、ライン 2589[i915_gem_object_get_pages_gtt()から]
「GTT(Global Graphics Translation Table)[...]は、GPU仮想アドレス空間から物理アドレスへのアドレスマッピングを担当します。」。