Provided by: manpages-ja-dev_0.5.0.0.20210215+dfsg-1_all bug

名前

       spu_create - 新しい SPU コンテキストを生成する

書式

       #include <sys/types.h>
       #include <sys/spu.h>

       int spu_create(const char *pathname, int flags, mode_t mode);
       int spu_create(const char *pathname, int flags, mode_t mode,
                      int neighbor_fd);

       : このシステムコールには glibc のラッパー関数は存在しない。「注意」の節を参照。

説明

       spu_create() システムコールは、Cell Broadband Engine アーキテクチャーを実装した PowerPC マ
       シンにおいて、Synergistic Processor Unit (SPU) にアクセスするために使用される。 このシステ
       ムコールは、 SPU に対する新しい論理コンテキストを pathname に生成し、 そのコンテキストに関
       連付けられたファイルディスクリプターを返す。 pathname は SPU ファイルシステム (spufs) のマ
       ウントポイント内の存在しないディレクトリを指していなければならない。 spu_create() が成功す
       ると、 pathname にディレクトリが生成され、  そのディレクトリに  spufs(7)  で説明されている
       ファイル群が配置される。

       コンテキストを作成した際、返されたファイルディスクリプターは、  spu_run(2)  に渡すか、 *at
       系のシステムコール (openat(2) など) の dirfd 引き数として使用するか、 クローズするか、しか
       できない。  他の操作は定義されていない。  そのコンテキストへの最後の参照がなくなった際に、
       論理 SPU コンテキストは破棄される  (そのコンテキストの  pathname  ディレクトリに作成された
       ファイルもすべて破棄される)。 通常は spu_create() が返したファイルディスクリプターがクロー
       ズされた際に発生する。

       flags 引き数には 0 か以下の定数の組み合わせ (ビット単位の論理和) を指定できる。

       SPU_CREATE_EVENTS_ENABLED
              DMA エラーを通知するのにシグナルを使うのではなく、 spu_run(2) の event 引き数を使用
              する。

       SPU_CREATE_GANG
              コンテキストの代わりに  SPU  gang  を作成する。  (gang は、機能的に互いに関係してい
              て、スケジューリングパラメーター (優先度とポリシー) を共有する SPU コンテキストのグ
              ループである。 将来、 グループ全体が一つの単位としてスイッチイン/スイッチアウトされ
              る gang スケジューリングが実装されるかもしれない。)

              pathname 引き数で指定された場所に新しいディレクトリが作成される。 この gang  を使っ
              て他の  SPU  コンテキストを保持することができる。 それには、それ以降の spu_create()
              に gang ディレクトリ内のパス名を渡す。

       SPU_CREATE_NOSCHED
              SPU スケジューラーの影響を受けないコンテキストを作成する。 一度実行されると、  呼び
              出したプロセスが破棄されるまでこのコンテキストがスケジューリングで追い出されること
              はない。

              このコンテキストは SPU から削除されることはないので、 SPU_CREATE_NOSCHED コンテキス
              トではいくつかの機能は無効にされる。 spufs のこのコンテキストのディレクトリでは一部
              のファイルだけができる。 また、 SPU_CREATE_NOSCHED コンテキストはクラッシュした際に
              コアファイルをダンプできない。

              SPU_CREATE_NOSCHED コンテキストを作成するには CAP_SYS_NICE ケーパビリティが必要であ
              る。

       SPU_CREATE_ISOLATE
              隔離された  SPU  コンテキストを作成する。  隔離されたコンテキストはいくつかの   PPE
              (PowerPC  Processing  Element) 命令から保護される。 SPU ローカルストアや NPC レジス
              ターへのアクセスなどである。

              SPU_CREATE_ISOLATE コンテキストを作成するには SPU_CREATE_NOSCHED フラグも指定する必
              要がある。

       SPU_CREATE_AFFINITY_SPU
              別の  SPU  コンテキストと  affinity  (親和性) を持ったコンテキストを作成する。 この
              affinity 情報は SPU スケジューリングアルゴリズムで使用される。 このフラグを使う際に
              は、 他の SPU コンテキストを指すファイルディスクリプターを neighbor_fd 引き数を渡す
              必要がある。

       SPU_CREATE_AFFINITY_MEM
              システムメモリーと affinity (親和性) を持ったコンテキストを作成する。 この affinity
              情報は SPU スケジューリングアルゴリズムで使用される。

       mode 引き数 (からプロセスの umask(2) でセットされたビットを除いたもの) により、 spufs に作
       られる新しいディレクトリで使用されるアクセス許可が決まる。 利用できる mode  値の完全なリス
       トについては stat(2) を参照。

返り値

       成功すると、  spu_create()  は新しいファイルディスクリプターを返す。 エラーの場合、-1 を返
       し、 errno に以下のリストに記載のエラーコードのいずれかを設定する。

エラー

       EACCES 現在のユーザーが spufs(7) のマウントポイントへの書き込み許可を持って いない。

       EEXIST 指定されたパス名で SPU コンテキストがすでに生成されている。

       EFAULT pathname が呼び出し元のプロセスのアドレス空間で有効な文字列ポインターではない。

       EINVAL pathname が SPUFS マウントポイント内のディレクトリではない。 または、無効なフラグが
              指定された。

       ELOOP  pathname を解決するまでに辿ったシンボリックリンクが多過ぎた。

       EMFILE そのプロセスがオープンできるファイル数の上限に達していた。

       ENAMETOOLONG
              pathname が長過ぎる。

       ENFILE システム全体でオープンできるファイル数の上限に達していた。

       ENODEV 隔離されたコンテキストが要求されたが、  ハードウェアが SPU アイソレーションをサポー
              トしていない。

       ENOENT pathname の一部が解決できなかった。

       ENOMEM カーネルが必要なリソースの全てを割り当てることができなかった。

       ENOSPC 新しいコンテキストを生成するのに十分な SPU リソースがなかった、 または SPU コンテキ
              スト数がそのユーザーの特定の上限に達していた。

       ENOSYS 機能が動作中のシステムで提供されていない。理由は、  ハードウェアで SPU が提供されて
              いないか、 spufs モジュールがロードされていないか、のどちらかである。

       ENOTDIR
              pathname の一部がディレクトリではない。

       EPERM  SPU_CREATE_NOSCHED フラグが指定されたが、ユーザーが  CAP_SYS_NICE  ケーパビリティを
              持っていない。

ファイル

       pathnamespufs  のマウントポイントの配下の場所を指して  いなければならない。 慣例では
       /spu にマウントされる。

バージョン

       spu_create() システムコールはカーネル 2.6.16 で Linux に追加された。

準拠

       このシステムコールは Linux 固有であり、 PowerPC アーキテクチャーでのみ実装されている。  こ
       のシステムコールを使ったプログラムは移植性がない。

注意

       glibc   はこのシステムコールに対するラッパー関数を提供していない。   syscall(2)   を使うこ
       と。ただし、 spu_create()  は より抽象度の高い SPU  へのインターフェースを実装するライブラ
       リから 利用されることを意図したものであり、通常のアプリケーションから 使用は意図されていな
       い。推奨のライブラリについては ⟨http://www.bsc.es/projects/deepcomputing/linuxoncell/⟩  を
       参照のこと。

       spu_create() の利用例については spu_run(2) を参照。

関連項目

       close(2), spu_run(2), capabilities(7), spufs(7)

この文書について

       この  man ページは Linux man-pages プロジェクトのリリース 3.79 の一部 である。プロジェクト
       の説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。