インテル® C++ コンパイラー XE 13.1 ユーザー・リファレンス・ガイド

非同期計算について

このトピックは、インテル® メニー・インテグレーテッド・コア (インテル® MIC) アーキテクチャーにのみ適用されます。

デフォルトでは、offload プラグマを使用すると、プラグマに到達した CPU スレッドは次の文へ進む前にオフロードの完了を待機します。 CPU がオフロードを開始してすぐに次の文へ進むように指定することで、非同期オフロード計算を実行できます。

非同期オフロード計算を指定するには、offload プラグマsignal 節を指定して計算を開始し、続いて offload_wait プラグマを使用してオフロード計算の完了を待機します。

signal 節と wait 節および offload_wait 構造は、特定のターゲットデバイスに関連するため、target() 節で target-number を指定する必要があります。

シグナルが開始される前にシグナルを照会すると、未定義の動作を引き起こし、アプリケーションはランタイムアボートします。例えば、ターゲットデバイス 1 で開始されたシグナル (SIG1) をターゲットデバイス 0 で照会する場合について考えてみます。シグナルはターゲットデバイス 1 で開始されているため、ターゲットデバイス 0 に関連付けられたシグナル (SIG1) はなく、アプリケーションはアボートします。

例: 非同期計算

次の例では、別の CPU スレッドを追加することなく、CPU はオフロード計算を行い、同時に処理を続行します。

char signal_var;
do {
     #pragma offload target (mic:0) signal(&signal_var)
     {
           long_running_mic_compute();
     }
     concurrent_cpu_activity();
     #pragma offload_wait target (mic:0) (&signal_var)
} while (1);

関連情報


このヘルプトピックについてのフィードバックを送信