kazmax - Linux で自宅サーバー

sysfs - システムコールの説明 - Linux コマンド集 一覧表

  1. 名前
  2. 書式
  3. 説明
  4. 返り値
  5. エラー
  6. 準拠
  7. 注意
  8. バグ

名前

sysfs - ファイル・システム (file system) の情報を取得する

書式

int sysfs(int option , const char * fsname );
int sysfs(int option , unsigned int fs_index , char * buf );
int sysfs(int option );

説明

sysfs ()は現在カーネル (kernel) に存在しているファイル・システムの型 (type) 情報を返す。 それぞれの sysfs ()コールの形式と返される情報は option に依存しており、それは:

1
ファイル・システム識別文字列 (identifier string) fsname をファイル・システムの型インデックス (type index) に翻訳する。
2
ファイル・システムの型インデックス fs_index を NULL 終端されたファイル・システム識別文字列に翻訳する。 この文字列は buf で指定されたバッファーへ書き込まれる。 buf に文字列を入れるだけの十分な容量があることを確かめること。
3
現在カーネルに存在するファイル・システム型の数の合計を返す。

ファイル・システムの型インデックスの数はゼロから始まる。

返り値

成功した場合 sysfs ()は、 オプション 1 では ファイル・システムのインデックスを返す。 オプション 2 ではゼロを返す。 オプション 3 は現在設定されているファイル・システムの数を返す。 エラーの場合は、-1 が返され、 errno が適切に設定される。

エラー

EFAULT
fsnamebuf のどちらかがアクセス可能なアドレス空間の外にある。
EINVAL
fsname が正しいファイル・システムの型識別子ではない; fs_index が範囲の外にある; option が正しくない。

準拠

SVr4.

注意

Linux では /proc にマウントされる proc ファイルシステムを使って、 /proc/filesystems より同じ情報を得ることができる。

バグ

libc または glibc のサポートは存在しない。 buf の大きさがどれだけ必要かを推測する方法がない。