mprotect syscall は、ページ境界内のメモリ領域を保護します。
int mprotect(void *addr, size_t len, int prot);
これはページサイズの倍数でlen
なければなりません。
ページ境界に揃えられていない連続する少数のアドレスのみを保護する方法はありますlen < pagesize
か?
mprotect syscall は、ページ境界内のメモリ領域を保護します。
int mprotect(void *addr, size_t len, int prot);
これはページサイズの倍数でlen
なければなりません。
ページ境界に揃えられていない連続する少数のアドレスのみを保護する方法はありますlen < pagesize
か?
私はそうは思いません。この制限は、MMUが制御できる粒度のハードウェア制限があるためです。アクセス制限を保持するテーブルがあり、バイトごとにテーブル スロットを持つことはできません。テーブル自体がすべての RAM を使用します。その代わりに、各ページのテーブル エントリを使用して、より粗く作られています。
Linux を使用している場合は、Valgrind を使用して何かを実行できる可能性があります。
いいえ、ありません。OS の仮想メモリ システムは、ページ レベルでのみ動作し、それより小さくはありません。
以下のリンクは U が期待するものだと思いますが、U はそれがリリースされるまで待つ必要があります。
「MPX —— Intel® Memory Protection Extensions」は、すべての C++ プログラマーが望んでいるものです。とても楽しみです。