Commit a3ee8b3a authored by Randy Dunlap's avatar Randy Dunlap Committed by Jonathan Corbet

sysfs: update Documentation

Make editing corrections and updates to sysfs.rst:

- spell "sysfs" consistently (vs. "Sysfs")
- align field names in a struct
- fix some punctuation and grammar
- list more /sys top-level subdirectories
- change 'fuse.txt' to 'fuse.rst' (although I don't see where the
  example is)
Signed-off-by: default avatarRandy Dunlap <rdunlap@infradead.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Jonathan Corbet <corbet@lwn.net>
Cc: linux-doc@vger.kernel.org
Cc: "Rafael J. Wysocki" <rafael@kernel.org>
Link: https://lore.kernel.org/r/20221104003921.31616-1-rdunlap@infradead.orgSigned-off-by: default avatarJonathan Corbet <corbet@lwn.net>
parent b592f9ee
...@@ -12,10 +12,10 @@ Mike Murphy <mamurph@cs.clemson.edu> ...@@ -12,10 +12,10 @@ Mike Murphy <mamurph@cs.clemson.edu>
:Original: 10 January 2003 :Original: 10 January 2003
What it is: What it is
~~~~~~~~~~~ ~~~~~~~~~~
sysfs is a ram-based filesystem initially based on ramfs. It provides sysfs is a RAM-based filesystem initially based on ramfs. It provides
a means to export kernel data structures, their attributes, and the a means to export kernel data structures, their attributes, and the
linkages between them to userspace. linkages between them to userspace.
...@@ -43,7 +43,7 @@ userspace. Top-level directories in sysfs represent the common ...@@ -43,7 +43,7 @@ userspace. Top-level directories in sysfs represent the common
ancestors of object hierarchies; i.e. the subsystems the objects ancestors of object hierarchies; i.e. the subsystems the objects
belong to. belong to.
Sysfs internally stores a pointer to the kobject that implements a sysfs internally stores a pointer to the kobject that implements a
directory in the kernfs_node object associated with the directory. In directory in the kernfs_node object associated with the directory. In
the past this kobject pointer has been used by sysfs to do reference the past this kobject pointer has been used by sysfs to do reference
counting directly on the kobject whenever the file is opened or closed. counting directly on the kobject whenever the file is opened or closed.
...@@ -55,7 +55,7 @@ Attributes ...@@ -55,7 +55,7 @@ Attributes
~~~~~~~~~~ ~~~~~~~~~~
Attributes can be exported for kobjects in the form of regular files in Attributes can be exported for kobjects in the form of regular files in
the filesystem. Sysfs forwards file I/O operations to methods defined the filesystem. sysfs forwards file I/O operations to methods defined
for the attributes, providing a means to read and write kernel for the attributes, providing a means to read and write kernel
attributes. attributes.
...@@ -72,8 +72,8 @@ you publicly humiliated and your code rewritten without notice. ...@@ -72,8 +72,8 @@ you publicly humiliated and your code rewritten without notice.
An attribute definition is simply:: An attribute definition is simply::
struct attribute { struct attribute {
char * name; char *name;
struct module *owner; struct module *owner;
umode_t mode; umode_t mode;
}; };
...@@ -138,7 +138,7 @@ __ATTR_WO(name): ...@@ -138,7 +138,7 @@ __ATTR_WO(name):
assumes a name_store only and is restricted to mode assumes a name_store only and is restricted to mode
0200 that is root write access only. 0200 that is root write access only.
__ATTR_RO_MODE(name, mode): __ATTR_RO_MODE(name, mode):
fore more restrictive RO access currently for more restrictive RO access; currently
only use case is the EFI System Resource Table only use case is the EFI System Resource Table
(see drivers/firmware/efi/esrt.c) (see drivers/firmware/efi/esrt.c)
__ATTR_RW(name): __ATTR_RW(name):
...@@ -207,7 +207,7 @@ IOW, they should take only an object, an attribute, and a buffer as parameters. ...@@ -207,7 +207,7 @@ IOW, they should take only an object, an attribute, and a buffer as parameters.
sysfs allocates a buffer of size (PAGE_SIZE) and passes it to the sysfs allocates a buffer of size (PAGE_SIZE) and passes it to the
method. Sysfs will call the method exactly once for each read or method. sysfs will call the method exactly once for each read or
write. This forces the following behavior on the method write. This forces the following behavior on the method
implementations: implementations:
...@@ -221,7 +221,7 @@ implementations: ...@@ -221,7 +221,7 @@ implementations:
be called again, rearmed, to fill the buffer. be called again, rearmed, to fill the buffer.
- On write(2), sysfs expects the entire buffer to be passed during the - On write(2), sysfs expects the entire buffer to be passed during the
first write. Sysfs then passes the entire buffer to the store() method. first write. sysfs then passes the entire buffer to the store() method.
A terminating null is added after the data on stores. This makes A terminating null is added after the data on stores. This makes
functions like sysfs_streq() safe to use. functions like sysfs_streq() safe to use.
...@@ -237,7 +237,7 @@ Other notes: ...@@ -237,7 +237,7 @@ Other notes:
- Writing causes the show() method to be rearmed regardless of current - Writing causes the show() method to be rearmed regardless of current
file position. file position.
- The buffer will always be PAGE_SIZE bytes in length. On i386, this - The buffer will always be PAGE_SIZE bytes in length. On x86, this
is 4096. is 4096.
- show() methods should return the number of bytes printed into the - show() methods should return the number of bytes printed into the
...@@ -253,7 +253,7 @@ Other notes: ...@@ -253,7 +253,7 @@ Other notes:
through, be sure to return an error. through, be sure to return an error.
- The object passed to the methods will be pinned in memory via sysfs - The object passed to the methods will be pinned in memory via sysfs
referencing counting its embedded object. However, the physical reference counting its embedded object. However, the physical
entity (e.g. device) the object represents may not be present. Be entity (e.g. device) the object represents may not be present. Be
sure to have a way to check this, if necessary. sure to have a way to check this, if necessary.
...@@ -295,8 +295,12 @@ The top level sysfs directory looks like:: ...@@ -295,8 +295,12 @@ The top level sysfs directory looks like::
dev/ dev/
devices/ devices/
firmware/ firmware/
net/
fs/ fs/
hypervisor/
kernel/
module/
net/
power/
devices/ contains a filesystem representation of the device tree. It maps devices/ contains a filesystem representation of the device tree. It maps
directly to the internal kernel device tree, which is a hierarchy of directly to the internal kernel device tree, which is a hierarchy of
...@@ -317,15 +321,18 @@ span multiple bus types). ...@@ -317,15 +321,18 @@ span multiple bus types).
fs/ contains a directory for some filesystems. Currently each fs/ contains a directory for some filesystems. Currently each
filesystem wanting to export attributes must create its own hierarchy filesystem wanting to export attributes must create its own hierarchy
below fs/ (see ./fuse.txt for an example). below fs/ (see ./fuse.rst for an example).
module/ contains parameter values and state information for all
loaded system modules, for both builtin and loadable modules.
dev/ contains two directories char/ and block/. Inside these two dev/ contains two directories: char/ and block/. Inside these two
directories there are symlinks named <major>:<minor>. These symlinks directories there are symlinks named <major>:<minor>. These symlinks
point to the sysfs directory for the given device. /sys/dev provides a point to the sysfs directory for the given device. /sys/dev provides a
quick way to lookup the sysfs interface for a device from the result of quick way to lookup the sysfs interface for a device from the result of
a stat(2) operation. a stat(2) operation.
More information can driver-model specific features can be found in More information on driver-model specific features can be found in
Documentation/driver-api/driver-model/. Documentation/driver-api/driver-model/.
...@@ -335,7 +342,7 @@ TODO: Finish this section. ...@@ -335,7 +342,7 @@ TODO: Finish this section.
Current Interfaces Current Interfaces
~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~
The following interface layers currently exist in sysfs: The following interface layers currently exist in sysfs.
devices (include/linux/device.h) devices (include/linux/device.h)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment