名前
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 | fsname と buf のどちらかがアクセス可能なアドレス空間の外にある。 |
EINVAL | fsname が正しいファイル・システムの型識別子ではない; fs_index が範囲の外にある; option が正しくない。 |
準拠
SVr4.
注意
Linux では /proc にマウントされる proc ファイルシステムを使って、 /proc/filesystems より同じ情報を得ることができる。
バグ
libc または glibc のサポートは存在しない。 buf の大きさがどれだけ必要かを推測する方法がない。