- 追加された行はこの色です。
- 削除された行はこの色です。
Open棟梁Project - マイクロソフト系技術情報 Wiki
-[[戻る>メモリ管理]]
* 目次 [#n6f480c5]
#contents
*概要 [#i7fe8b23]
仮想アドレス空間にマッピングされた各コミット済みページは~
-物理メモリ
-物理ストレージ(ページングファイル、メモリマップトファイル)
に支持される。
*ページ [#mb961ea4]
-仮想メモリ、Windows Serverのメモリチューニングで~
ページングファイルなし(Paging file)は選択可能か? - puti se note~
http://www.putise.com/architecture/windows-paging-file
-Windows のユーザープロセスに対する仮想アドレス空間は、3 種類のページに分類できる。
--リザーブ
--コミット
--ワーキングセット
-仮想メモリの各フラグメント(断片)をページといい、サイズは通常 4KBである。
**予約済みページ [#ge05571a]
-VirtualAllocで予約したページ
-将来の使用に備えて予約されたページ。
-予約済みページは、物理ストレージや、物理メモリを占有しない。
-しかし、仮想アドレス空間が予約されるため当該プロセスのみのメモリ・リーク、~
正確には、当該プロセスの仮想アドレス空間のリークが発生することはある。
**コミット済みページ [#vfdb3663]
-プロセスのコミット済みページ
-アプリケーションがコミット済みページにアクセスすると、~
オペレーティングシステムはそのページをワーキング セットに指定する。
**ワーキングセット [#p6d098ad]
仮想アドレスに直接関係しないプロセスの所有する物理メモリ
*32ビットと64ビット [#z6ca0b4d]
-Windows NT系 - Wikipedia
--32ビットと64ビット~
http://ja.wikipedia.org/wiki/Windows_NT%E7%B3%BB#32.E3.83.93.E3.83.83.E3.83.88.E3.81.A864.E3.83.93.E3.83.83.E3.83.88
|32bitの仮想アドレス空間|64bitの仮想アドレス空間|h
|合計4GB|合計16TB|
|2GBがカーネルモード|8TBがカーネルモード|
|2GBがユーザモード|8TBがユーザモード|
**32bit [#vfeb5f76]
***仮想アドレス空間 [#u1cb8a2c]
32bitのデフォルトで
-ユーザモード(0x00000000~0x7fffffff)
-カーネルモード(0x80000000~0xffffffff)
***AWE [#d19fe3d2]
AWEにより、32bitプロセスでも仮想アドレス空間の拡張可能。~
(APPがAWEをサポートしていればAWEのAPIを使用して独自にメモリ管理をする)
また、3GBスイッチでユーザモードをx86:3GB、x64:4GB※に拡張可能。~
※ 32ビットプロセス(WOW64)でアクセス可能な仮想アドレス空間にカーネル空間が存在しないため、4GBをフルに活用できる。
**64bit [#feec8fc1]
*[[カーネルモード・ユーザモード]]の仮想アドレス空間 [#bc7a9316]
**ユーザモード [#o8f91bd4]
**カーネルモード [#zf66d312]
カーネルモードの仮想アドレス空間は、全てのプロセスで共有される。
-スレッドの開始アドレスが0x80000000(デフォルト)より上位にある場合、そのスレッドはカーネルモード・スレッドになる。
-カーネルモード・スレッドを作成したデバイス・ドライバを特定するためには、スレッドの開始アドレスを調べ(Pviewer.exe)、~
そのアドレスの上位で最も近いベースアドレスを持つドライバを探す(Pstat.exe)。
※ これらの調査の操作は、Process Explorerに統合されている(★)。
以下のツールも利用可能。
-Dependency Walker~
http://www.dependencywalker.com/
を使用すると、プロセスで利用されている.sys(ドライバ)を確認できる。
*[[仮想アドレス空間の確保のAPI]] [#f13a7f00]