インテル® C++ コンパイラー 17.0 デベロッパー・ガイドおよびリファレンス
インテル® C++ コンパイラーでは、キャリーなし乗算を行う組込み関数と、AES (Advanced Encryption Standard) 規格に基づいた暗号化を行う組込み関数が提供されています。キャリーなし乗算組込み関数は、新しい命令 PCLMULQDQ に対応します。 AES 拡張組込み関数は、AES 拡張命令に対応します。
AES 拡張命令と PCLMULQDQ 命令の XMM ステートサポートおよび SIMD (single-instruction multiple data) 浮動小数点例外サポートのソフトウェア要件は、インテル® ストリーミング SIMD 拡張命令 2 (インテル® SSE2)、インテル® ストリーミング SIMD 拡張命令 3 (インテル® SSE3)、インテル® ストリーミング SIMD 拡張命令 3 補足命令 (インテル® SSSE3)、インテル® ストリーミング SIMD 拡張命令 4 (インテル® SSE4) と同じです。
32nm プロセス技術で製造されるインテル®64 対応プロセッサーは、AES 拡張命令および PCLMULQDQ 命令をサポートしています。
AES 暗号化には、128 ビットの入力データ (プレーンテキスト) を 128 ビットの暗号化されたブロック (暗号文) にする、有限数の反復処理が含まれています。この処理を AES ラウンドと呼びます。暗号解読は、"Inverse Cipher" の代わりに "Equivalent Inverse Cipher" を使用して、この反復処理を逆方向に行います。
各ラウンドの暗号処理には、"状態" と "ラウンドキー" という 2 つの入力データがあります。"ラウンドキー" はラウンドごとに異なります。ラウンドキーは、"キー・スケジュール" アルゴリズムを使用して暗号鍵から生成されます。"キー・スケジュール" アルゴリズムは、暗号/復号のデータ処理から独立しており、暗号/復号フェーズとは別に実行することができます。
AES 規格では、128、192、および 256 ビットの暗号鍵をサポートしています。暗号鍵のサイズは、それぞれ 10、12、および 14 ラウンドの反復に対応しています。
PCLMULQDQ 命令は、最大 64 ビットの 2 つの 2 進数のキャリーなし乗算を実行します。
AES 拡張には次のものが含まれます。
アプリケーションで PCLMULQDQ や AES 拡張命令を使用する前に、プロセッサーでその命令がサポートされているかどうかを調べる必要があります。
PCLMULQDQ 命令がサポートされているかどうかを調べるには、アプリケーションで次のことを確認する必要があります。
CPUID.01H:ECX.PCLMULQDQ[bit 1] = 1.
AES 拡張命令がサポートされているかどうかを調べるには、アプリケーションで次のことを確認する必要があります。
CPUID.01H:ECX.AES[bit 25] = 1.
SSE ステートをサポートしているオペレーティング・システムは、AES 拡張命令および PCLMULQDQ 命令を使用するアプリケーションもサポートしています。