MESIプロトコル
MESIプロトコル(別名、イリノイ・プロトコル)とは、マルチプロセッサシステムでメモリやキャッシュメモリの同期をとるキャッシュコヒーレンシとメモリ一貫性のプロトコルであり、ライトバック方式のキャッシュで広く使われている。イリノイ・プロトコルという別名はイリノイ大学アーバナ・シャンペーン校で開発されたことに由来する。
インテルは、「486プロセッサで以前から使われていたライトスルーキャッシュに加えて、より効率的なライトバックキャッシュをサポートする」[1]としてPentiumプロセッサでMESIプロトコルを採用した。そのためパーソナルコンピュータでも広く使われている。
概要
[編集]各キャッシュラインは以下の4状態のいずれかにある。状態はキャッシュラインのタグに含まれる(2bitで表される)。
- M - Modified(変更): 当該キャッシュだけに存在し、主記憶上の値から変更されている(dirty)。他のCPUがこのキャッシュラインに相当する主記憶をリードするのを許可する前に、キャッシュ機構はこのキャッシュラインをいずれかの時点で主記憶に書き戻さなければならない。
- E - Exclusive(排他): 当該キャッシュだけに存在するが、主記憶上の値と一致している(clean)。
- S - Shared(共有): システム内の他のキャッシュにも同じキャッシュラインが存在している(主記憶とも内容が一致)。
- I - Invalid(無効): このキャッシュラインは無効。
任意の2つのキャッシュがあるとき、それぞれの対応するキャッシュラインがとりうる状態の組合せは次のようになる。
M | E | S | I | |
---|---|---|---|---|
M | ||||
E | ||||
S | ||||
I |
動作
[編集]典型的システムでは、複数のキャッシュがメインメモリの接続されたバスを共有している。それぞれのキャッシュにはCPUが接続されており、それがリード要求やライト要求を発行する。このようなシステムで全体として共有している主記憶へのアクセスを最小にすることが目的である。
Invalid状態以外のキャッシュラインはリード要求を満たすことができる。Invalid状態のラインにリード要求が来た場合、主記憶から内容を読み込む必要がある(Shared か Exclusive 状態に遷移する)。
ライト要求を実行できるのは、Modified状態かExclusive状態の場合のみである。Shared状態なら、書き込みを行う前にシステム内の他のキャッシュ(の該当するキャッシュライン)を Invalid 状態にしなければならない。これは、通常ブロードキャスト操作で実行され、その操作を Read For Ownership (RFO) と呼ぶ。
キャッシュ機構は Modified状態以外のキャッシュラインをいつでも捨てて Invalid状態にすることができる。Modified状態のラインは必ず主記憶に書き戻さなければならない。
Modified状態のキャッシュラインを持つキャッシュ機構は、バス上の流れを監視して(バススヌープ)、対応する主記憶上の位置へのリード要求をインターセプトして、それを再試行状態にする。そして自身の持つキャッシュラインの内容を主記憶に書き戻し、そのキャッシュラインの状態を Shared に遷移させる。
Shared 状態のキャッシュラインを持つキャッシュ機構もバススヌープによって他のCPUからの無効化要求を受け取り、対応するラインを捨てる(Invalid状態に遷移させる)。
Exclusive状態のキャッシュラインを持つキャッシュ機構もバススヌープで他のCPUのトランザクションを監視し、対応するアドレス範囲へのアクセスがあったら Shared 状態へ遷移させる。
Modified状態とExclusive状態は、システム内のそのキャッシュラインの所有権を有しているため、明確である。Shared 状態はあいまいなところがあり、他のCPUのキャッシュが該当キャッシュラインを捨てたときに実際には Exclusive状態になるべき場合があるが、そのような遷移は通常行われない(そのためにはブロードキャストが必要だが、実際問題としてあまり意味が無い)。
そういった意味では Exclusive状態というのは若干日和見的な最適化である。Shared状態のキャッシュラインに変更を加える場合、無効化要求をブロードキャストする必要があると規定することで、Exclusive状態のキャッシュラインの更新はトランザクションを必要としないのである。
Read For Ownership
[編集]Read For Ownership (RFO) はキャッシュコヒーレンシプロトコルの操作の1つで、リードと無効化ブロードキャストを組み合わせたものである。これはあるキャッシュラインに書き込む際、そのキャッシュの当該キャッシュラインがExclusive状態でもModified状態でもないときに行うもので、つまりそのキャッシュラインはMESIプロトコルではShared状態かInvalid状態である。この操作により他の全プロセッサの当該キャッシュラインはInvalid状態へと遷移させられる。RFOトランザクションはそのメモリアドレスに書き込むことを前提としたリード操作である。したがってこの操作は排他的である。それによりそのキャッシュにはデータがもたらされ、他の全プロセッサの当該キャッシュラインは無効化される。
その他のキャッシュプロトコル
[編集]MSIプロトコル
[編集]MSIプロトコルはExclusive状態を持たないキャッシュプロトコル。MESIプロトコルでExclusive状態となるような状況では、Shared状態となる。
Invalid状態のキャッシュラインにCPUからリードを行う場合、他のキャッシュの当該キャッシュラインがModified状態でないことを保証しなければならないが、その方式はアーキテクチャによって異なる。一般的な方式としてはリード要求のブロードキャストがないかバススヌーピングで監視する。また、キャッシュ内に各キャッシュラインを最近リードしたキャッシュがどれかを示す情報を格納しておく方式もある。Modified状態のキャッシュラインを別のキャッシュが持っていた場合、その内容を主記憶に書き戻し、キャッシュライン自体はShared状態かInvalid状態へと遷移しなければならない。Modified状態のキャッシュラインが書き戻されると、当該キャッシュラインへは主記憶か他のShared状態のキャッシュから内容を読み込み、Shared状態へと遷移する。
ライト要求は当該キャッシュラインがModified状態ならローカルにキャッシュに書き込むだけで済む。Shared状態なら、他のキャッシュのShared状態のキャッシュラインを無効化する必要がある。これもリードと同様にバススヌーピングなどで実現する。その上でModified状態に遷移してローカルにキャッシュにライトを行う。Invalid状態の場合、他のキャッシュのShared状態とModified状態のキャッシュラインを無効化しなければならない。別のキャッシュの当該キャッシュラインがModified状態なら、そのキャッシュラインの内容を主記憶に書き戻すか、ライト要求したキャッシュに対して内容を送る。なお、一般にCPUのライト要求はせいぜいワード単位までであり、キャッシュラインは複数ワードという構成が一般的であるため、Invalid状態でのライト要求の場合、書き込みの前に当該キャッシュライン全体を読み込んでおく必要がある。
任意の2つのキャッシュがあるとき、それぞれの対応するキャッシュラインがとりうる状態の組合せは次のようになる。
M | S | I | |
---|---|---|---|
M | |||
S | |||
I |
MOSIプロトコル
[編集]MOSIプロトコルはExclusive状態の代わりに Owned(所有)状態のあるキャッシュプロトコル。Exclusive状態がないため、MSIプロトコルにOwned状態を加えたものと見たほうがよい(つまりExclusive状態はShared状態に包含されている)。
Owned状態のキャッシュラインは dirty であり、主記憶への書き戻しが必要である。Modified状態のキャッシュラインに相当するアドレスに他のCPUがリード要求を発行したときに、Owned状態に遷移する。Owned状態のキャッシュラインを持つキャッシュ機構は、当該アドレス範囲へのリード要求に対して主記憶の代わりに応答する。すなわち、そのキャッシュラインは他のCPUでは Shared 状態となっている。Owned状態でさらに変更を加える際には、他のキャッシュのShared状態の当該キャッシュラインを無効化して自身はModified状態へ遷移するか、他のキャッシュに更新内容を送ってShared状態を維持させる(アーキテクチャによって異なる)。
任意の2つのキャッシュがあるとき、それぞれの対応するキャッシュラインがとりうる状態の組合せは次のようになる。
M | O | S | I | |
---|---|---|---|---|
M | ||||
O | ||||
S | ||||
I |
MOESIプロトコル
[編集]MOESIプロトコルはMESIプロトコルに Owned状態を加えたキャッシュプロトコル。AMD64で採用されている[2]。
任意の2つのキャッシュがあるとき、それぞれの対応するキャッシュラインがとりうる状態の組合せは次のようになる。
M | O | E | S | I | |
---|---|---|---|---|---|
M | |||||
O | |||||
E | |||||
S | |||||
I |
MESIプロトコルに比べると、dirtyなキャッシュラインを持っている状態で他のキャッシュからリード要求があっても主記憶に書き戻す必要がないという点が優れている。代わりにOwned状態のキャッシュラインは他のプロセッサに直接変更の加わったデータを送ることができる。これは、キャッシュ間のやりとりが主記憶とのやりとりよりも高速な場合に有利で、例えばマルチコアCPUでCPU毎にL2キャッシュがある場合などが相当する。
しかし、キャッシュラインが clean な場合、Invalid状態のキャッシュがリード要求したとき応答するのは主記憶であり、Shared状態やExclusive状態のキャッシュラインは応答しない。
関連項目
[編集]脚注・出典
[編集]- ^ IA-32 Intel Architecture Software Developers Manual
- ^ AMD64 Architecture Programmer's Manual Vol 2 'System Programming' p.167