Provided by: manpages-ja-dev_0.5.0.0.20140515+dfsg-2_all
名前
mincore - ページがメモリ内にあるかどうかを判定する
書式
#include <unistd.h> #include <sys/mman.h> int mincore(void *addr, size_t length, unsigned char *vec); glibc 向けの機能検査マクロの要件 (feature_test_macros(7) 参照): mincore(): _BSD_SOURCE || _SVID_SOURCE
説明
mincore() は、呼び出し元プロセスの仮想メモリのページがコア (RAM) 内に存在し、 ページ参照 時にディスクアクセス (ページフォールト) を起こさないか どうかを示すベクトルを返す。カーネ ルは、アドレス addr から始まる length バイトの範囲のページに関する存在情報を返す。 addr 引き数はシステムのページサイズの倍数でなければならない。 length 引き数はページサイズ の倍数である必要はないが、 ページ全体に関する存在情報が返されるので、事実上 length はペー ジサイズの倍数に切り上げられることになる。 ページサイズ (PAGE_SIZE) は sysconf(_SC_PAGESIZE) を使って入手できる。 vec 引き数は、少なくとも (length+PAGE_SIZE-1) / PAGE_SIZE バイトが格納できる配列を指してい なければならない。 この呼び出しが返るとき、 各バイトの最下位ビットは、対応するページがメモ リ内にそのとき存在すれば セットされ、そうでない場合はクリアされる (各バイトのその他のビッ トは未定義であり、これらのビットは将来の使用に そなえて予約されている)。 もちろん、 vec で 返された情報はスナップショットでしかない。 メモリ内にロックされていないページは、任意の時 点でメモリ内に 入ったり出たりでき、この呼び出しが返るときには vec の内容はすでに古くなって いるかもしれない。
返り値
成功した場合、 mincore() は 0 を返す。 エラーの場合は -1 を返して、 errno を適切な値に設 定する。
エラー
EAGAIN カーネルが一時的にリソースを使い果たしている。 EFAULT vec が無効なアドレスを指している。 EINVAL addr がページサイズの倍数でない。 ENOMEM length が (TASK_SIZE - addr) より大きい。 (length に負の値が指定された場合、 その 値が大きな符号なし整数として解釈されるために起こることがある。) Linux 2.6.11 以前 では、この条件の場合はエラー EINVAL が返されていた。 ENOMEM addr から addr + length の間にマップされていないメモリがあった。
バージョン
Linux 2.3.99pre1 と glibc 2.2 から利用可能である。
準拠
mincore() は POSIX.1-2001 に記述されておらず、 全ての UNIX 実装で利用可能であるわけではな い。
バグ
カーネル 2.6.21 より前は、 mincore() は、 MAP_PRIVATE マッピングや非線形マッピング (remap_file_pages(2) を使って作成される) について正しい情報を返さなかった。
関連項目
mlock(2), mmap(2)
この文書について
この man ページは Linux man-pages プロジェクトのリリース 3.65 の一部 である。プロジェクト の説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。