コプロセッサーで実行するコードのセクションを指定する

このステップでは、ホスト CPU とコプロセッサーの両方で実行するように定義されているソースコードのセクションを確認します。

次のソースコードを探します。

  !DIR$ OFFLOAD BEGIN target(mic : target_id) &
                             inout(numEs) in(all_Vals) out(E_vals)
      do k = 1, MAXSZ
         if ( MODULO(all_Vals(k),2) == 0 ) then
             numEs = numEs + 1
             E_vals(numEs) = all_Vals(k)
         endif
      enddo
  !DIR$ END OFFLOAD

このコードブロックは、最初の 10 個の偶数を検索して配列に格納します。コードブロックの先頭および終了OFFLOAD 宣言子です。 コンパイラーは、この宣言子で指定されたコードブロックを、CPU とコプロセッサーの両方で実行するようにコンパイルします。

ホスト CPU とコプロセッサーの命令セットは似ていますが、同じシステムメモリーを共有しません。このため、コードブロックで使用する変数は、ホスト CPU とコプロセッサーの両方に存在していなければなりません。変数がホスト CPU とコプロセッサーの両方に存在することを保証するため、宣言子は、パラメーター指定子を使用してホスト CPU とコプロセッサー間でコピーする変数を定義しています。

宣言子には、複数のコプロセッサーが含まれるシステムの特定のコプロセッサーを指定する target パラメーターも含まれています。

デフォルトでは、コンパイラーは CPU とコプロセッサーの両方で実行するアプリケーションを生成しますが、同じソースコードを使用して CPU でのみ実行するアプリケーションを生成することもできます。次のステップでは、同じソースコードをコンパイルして CPU でのみ実行するアプリケーションを生成します。

戻る: ガイド付き自動並列化について 次へ: ガイド付き自動並列化を実行する


このヘルプトピックについてのフィードバックを送信
その他の入門チュートリアルを表示