キャッシュ制御用のインテル® ストリーミング SIMD 拡張命令 (インテル® SSE) の組み込み関数のプロトタイプは、ヘッダーファイル xmmintrin.h 内にあります。
組み込み関数名 |
演算子 |
対応する |
---|---|---|
_mm_prefetch |
ロード |
PREFETCH |
_mm_stream_pi |
ストア |
MOVNTQ |
_mm_stream_ps |
ストア |
MOVNTPS |
_mm_sfence |
ストアフェンス |
SFENCE |
void _mm_prefetch(char const*a, int sel)
1 キャッシュライン分のデータを、アドレス a からプロセッサーに近い位置にロードします。sel の値は、プリフェッチ操作のタイプを指定します。IA-32 アーキテクチャー・ベース・システムの場合、この値には、プリフェッチ命令のタイプに応じて、定数 _MM_HINT_T0、_MM_HINT_T1、_MM_HINT_T2、または _MM_HINT_NTA を指定してください。IA-64 アーキテクチャー・ベースのシステムの場合、定数 _MM_HINT_T1、_MM_HINT_NT1、_MM_HINT_NT2、または _MM_HINT_NTA を指定してください。
void _mm_stream_pi(__m64 *p, __m64 a)
a のデータを、キャッシュを介さずに、アドレス p にストアします。この組み込み関数を使用する前に、MMX® レジスターのマルチメディア・ステートを空にする必要があります。詳細については、「EMMS 命令: 必要な理由」を参照してください。
void _mm_stream_ps(float *p, __m128 a)
a のデータを、キャッシュを介さずに、アドレス p にストアします。アドレスは 16 バイトにアライメントが合っていなければなりません。
void _mm_sfence(void)
すべての先行するストアが、後に続くストアより前に、グローバルにアクセス可能になるのを保証します。