It's a somewhat calmer cycle for docs this time, as the churn of the mass
RST conversion is happily mostly behind us.
- A new document on reproducible builds.
- We finally got around to zapping the documentation for hardware support
that was removed in 2004; one doesn't want to rush these things.
- The usual assortment of fixes, typo corrections, etc.
You'll still find a handful of annoying conflicts against other trees,
mostly tied to the last RST conversions; resolutions are straightforward
and the linux-next ones are good.
-----BEGIN PGP SIGNATURE-----
iQEzBAABCAAdFiEEIw+MvkEiF49krdp9F0NaE2wMflgFAl1/J4IACgkQF0NaE2wM
flhYogf9EgYozCe8RocSq+JjJpZOSFjIGDQv+GwTjOBIdqgO9tSIaY/p0wSkYKil
jYXyMDF+Xwr8podsUep2F7akBM7j9XJ+XBGJcfOna0ypC9xoejMgWt9fU3YvaWge
dQJxIQ/iwkDlKNx6uOYgKysLUWFS0EP/nzPhqBo4bZZzhugvrR46D/nQqFNmGihd
l9yLalJtP5mC0XRUv3hpdAFFFKxdC0R3BGOel2V+slSClp0LEgpdMAuMaKydEDI3
Ch9ZpIp8fB8kqONCs9/X6083WRsDOMe28KgeGrGHo4Jla6u51QBLQjSVKttFv7xk
051yNJwDWMxgl+A4gyNLDPXM7Gd7HQ==
=v4dp
-----END PGP SIGNATURE-----
Merge tag 'docs-5.4' of git://git.lwn.net/linux
Pull documentation updates from Jonathan Corbet:
"It's a somewhat calmer cycle for docs this time, as the churn of the
mass RST conversion is happily mostly behind us.
- A new document on reproducible builds.
- We finally got around to zapping the documentation for hardware
support that was removed in 2004; one doesn't want to rush these
things.
- The usual assortment of fixes, typo corrections, etc"
* tag 'docs-5.4' of git://git.lwn.net/linux: (67 commits)
Documentation: kbuild: Add document about reproducible builds
docs: printk-formats: Stop encouraging use of unnecessary %h[xudi] and %hh[xudi]
Documentation: Add "earlycon=sbi" to the admin guide
doc🔒 remove reference to clever use of read-write lock
devices.txt: improve entry for comedi (char major 98)
docs: mtd: Update spi nor reference driver
doc: arm64: fix grammar dtb placed in no attributes region
Documentation: sysrq: don't recommend 'S' 'U' before 'B'
mailmap: Update email address for Quentin Perret
docs: ftrace: clarify when tracing is disabled by the trace file
docs: process: fix broken link
Documentation/arm/samsung-s3c24xx: Remove stray U+FEFF character to fix title
Documentation/arm/sa1100/assabet: Fix 'make assabet_defconfig' command
Documentation/arm/sa1100: Remove some obsolete documentation
docs/zh_CN: update Chinese howto.rst for latexdocs making
Documentation: virt: Fix broken reference to virt tree's index
docs: Fix typo on pull requests guide
kernel-doc: Allow anonymous enum
Documentation: sphinx: Don't parse socket() as identifier reference
Documentation: sphinx: Add missing comma to list of strings
...
This commit is contained in:
commit
7c672abc12
19
.mailmap
19
.mailmap
@ -47,6 +47,8 @@ Boris Brezillon <bbrezillon@kernel.org> <b.brezillon.dev@gmail.com>
|
|||||||
Boris Brezillon <bbrezillon@kernel.org> <b.brezillon@overkiz.com>
|
Boris Brezillon <bbrezillon@kernel.org> <b.brezillon@overkiz.com>
|
||||||
Brian Avery <b.avery@hp.com>
|
Brian Avery <b.avery@hp.com>
|
||||||
Brian King <brking@us.ibm.com>
|
Brian King <brking@us.ibm.com>
|
||||||
|
Chao Yu <chao@kernel.org> <chao2.yu@samsung.com>
|
||||||
|
Chao Yu <chao@kernel.org> <yuchao0@huawei.com>
|
||||||
Christoph Hellwig <hch@lst.de>
|
Christoph Hellwig <hch@lst.de>
|
||||||
Christophe Ricard <christophe.ricard@gmail.com>
|
Christophe Ricard <christophe.ricard@gmail.com>
|
||||||
Corey Minyard <minyard@acm.org>
|
Corey Minyard <minyard@acm.org>
|
||||||
@ -80,6 +82,8 @@ Frank Rowand <frowand.list@gmail.com> <frowand@mvista.com>
|
|||||||
Frank Rowand <frowand.list@gmail.com> <frank.rowand@am.sony.com>
|
Frank Rowand <frowand.list@gmail.com> <frank.rowand@am.sony.com>
|
||||||
Frank Rowand <frowand.list@gmail.com> <frank.rowand@sonymobile.com>
|
Frank Rowand <frowand.list@gmail.com> <frank.rowand@sonymobile.com>
|
||||||
Frank Zago <fzago@systemfabricworks.com>
|
Frank Zago <fzago@systemfabricworks.com>
|
||||||
|
Gao Xiang <xiang@kernel.org> <gaoxiang25@huawei.com>
|
||||||
|
Gao Xiang <xiang@kernel.org> <hsiangkao@aol.com>
|
||||||
Greg Kroah-Hartman <greg@echidna.(none)>
|
Greg Kroah-Hartman <greg@echidna.(none)>
|
||||||
Greg Kroah-Hartman <gregkh@suse.de>
|
Greg Kroah-Hartman <gregkh@suse.de>
|
||||||
Greg Kroah-Hartman <greg@kroah.com>
|
Greg Kroah-Hartman <greg@kroah.com>
|
||||||
@ -90,6 +94,9 @@ Henrik Kretzschmar <henne@nachtwindheim.de>
|
|||||||
Henrik Rydberg <rydberg@bitmath.org>
|
Henrik Rydberg <rydberg@bitmath.org>
|
||||||
Herbert Xu <herbert@gondor.apana.org.au>
|
Herbert Xu <herbert@gondor.apana.org.au>
|
||||||
Jacob Shin <Jacob.Shin@amd.com>
|
Jacob Shin <Jacob.Shin@amd.com>
|
||||||
|
Jaegeuk Kim <jaegeuk@kernel.org> <jaegeuk@google.com>
|
||||||
|
Jaegeuk Kim <jaegeuk@kernel.org> <jaegeuk@motorola.com>
|
||||||
|
Jaegeuk Kim <jaegeuk@kernel.org> <jaegeuk.kim@samsung.com>
|
||||||
James Bottomley <jejb@mulgrave.(none)>
|
James Bottomley <jejb@mulgrave.(none)>
|
||||||
James Bottomley <jejb@titanic.il.steeleye.com>
|
James Bottomley <jejb@titanic.il.steeleye.com>
|
||||||
James E Wilson <wilson@specifix.com>
|
James E Wilson <wilson@specifix.com>
|
||||||
@ -181,6 +188,11 @@ Nguyen Anh Quynh <aquynh@gmail.com>
|
|||||||
Nicolas Ferre <nicolas.ferre@microchip.com> <nicolas.ferre@atmel.com>
|
Nicolas Ferre <nicolas.ferre@microchip.com> <nicolas.ferre@atmel.com>
|
||||||
Nicolas Pitre <nico@fluxnic.net> <nicolas.pitre@linaro.org>
|
Nicolas Pitre <nico@fluxnic.net> <nicolas.pitre@linaro.org>
|
||||||
Nicolas Pitre <nico@fluxnic.net> <nico@linaro.org>
|
Nicolas Pitre <nico@fluxnic.net> <nico@linaro.org>
|
||||||
|
Oleksij Rempel <linux@rempel-privat.de> <bug-track@fisher-privat.net>
|
||||||
|
Oleksij Rempel <linux@rempel-privat.de> <external.Oleksij.Rempel@de.bosch.com>
|
||||||
|
Oleksij Rempel <linux@rempel-privat.de> <fixed-term.Oleksij.Rempel@de.bosch.com>
|
||||||
|
Oleksij Rempel <linux@rempel-privat.de> <o.rempel@pengutronix.de>
|
||||||
|
Oleksij Rempel <linux@rempel-privat.de> <ore@pengutronix.de>
|
||||||
Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
|
Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
|
||||||
Patrick Mochel <mochel@digitalimplant.org>
|
Patrick Mochel <mochel@digitalimplant.org>
|
||||||
Paul Burton <paul.burton@mips.com> <paul.burton@imgtec.com>
|
Paul Burton <paul.burton@mips.com> <paul.burton@imgtec.com>
|
||||||
@ -191,11 +203,7 @@ Pratyush Anand <pratyush.anand@gmail.com> <pratyush.anand@st.com>
|
|||||||
Praveen BP <praveenbp@ti.com>
|
Praveen BP <praveenbp@ti.com>
|
||||||
Punit Agrawal <punitagrawal@gmail.com> <punit.agrawal@arm.com>
|
Punit Agrawal <punitagrawal@gmail.com> <punit.agrawal@arm.com>
|
||||||
Qais Yousef <qsyousef@gmail.com> <qais.yousef@imgtec.com>
|
Qais Yousef <qsyousef@gmail.com> <qais.yousef@imgtec.com>
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <bug-track@fisher-privat.net>
|
Quentin Perret <qperret@qperret.net> <quentin.perret@arm.com>
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <external.Oleksij.Rempel@de.bosch.com>
|
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <fixed-term.Oleksij.Rempel@de.bosch.com>
|
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <o.rempel@pengutronix.de>
|
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <ore@pengutronix.de>
|
|
||||||
Rajesh Shah <rajesh.shah@intel.com>
|
Rajesh Shah <rajesh.shah@intel.com>
|
||||||
Ralf Baechle <ralf@linux-mips.org>
|
Ralf Baechle <ralf@linux-mips.org>
|
||||||
Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
|
Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
|
||||||
@ -230,6 +238,7 @@ Sumit Semwal <sumit.semwal@ti.com>
|
|||||||
Tejun Heo <htejun@gmail.com>
|
Tejun Heo <htejun@gmail.com>
|
||||||
Thomas Graf <tgraf@suug.ch>
|
Thomas Graf <tgraf@suug.ch>
|
||||||
Thomas Pedersen <twp@codeaurora.org>
|
Thomas Pedersen <twp@codeaurora.org>
|
||||||
|
Todor Tomov <todor.too@gmail.com> <todor.tomov@linaro.org>
|
||||||
Tony Luck <tony.luck@intel.com>
|
Tony Luck <tony.luck@intel.com>
|
||||||
TripleX Chung <xxx.phy@gmail.com> <zhongyu@18mail.cn>
|
TripleX Chung <xxx.phy@gmail.com> <zhongyu@18mail.cn>
|
||||||
TripleX Chung <xxx.phy@gmail.com> <triplex@zh-kernel.org>
|
TripleX Chung <xxx.phy@gmail.com> <triplex@zh-kernel.org>
|
||||||
|
@ -6,6 +6,6 @@ Description: Bus scanning interval, microseconds component.
|
|||||||
control systems are attached/generate presence for as short as
|
control systems are attached/generate presence for as short as
|
||||||
100 ms - hence the tens-to-hundreds milliseconds scan intervals
|
100 ms - hence the tens-to-hundreds milliseconds scan intervals
|
||||||
are required.
|
are required.
|
||||||
see Documentation/w1/w1.generic for detailed information.
|
see Documentation/w1/w1-generic.rst for detailed information.
|
||||||
Users: any user space application which wants to know bus scanning
|
Users: any user space application which wants to know bus scanning
|
||||||
interval
|
interval
|
||||||
|
@ -2,7 +2,7 @@ What: /sys/bus/w1/devices/.../pio
|
|||||||
Date: May 2012
|
Date: May 2012
|
||||||
Contact: Markus Franke <franm@hrz.tu-chemnitz.de>
|
Contact: Markus Franke <franm@hrz.tu-chemnitz.de>
|
||||||
Description: read/write the contents of the two PIO's of the DS28E04-100
|
Description: read/write the contents of the two PIO's of the DS28E04-100
|
||||||
see Documentation/w1/slaves/w1_ds28e04 for detailed information
|
see Documentation/w1/slaves/w1_ds28e04.rst for detailed information
|
||||||
Users: any user space application which wants to communicate with DS28E04-100
|
Users: any user space application which wants to communicate with DS28E04-100
|
||||||
|
|
||||||
|
|
||||||
@ -11,5 +11,5 @@ What: /sys/bus/w1/devices/.../eeprom
|
|||||||
Date: May 2012
|
Date: May 2012
|
||||||
Contact: Markus Franke <franm@hrz.tu-chemnitz.de>
|
Contact: Markus Franke <franm@hrz.tu-chemnitz.de>
|
||||||
Description: read/write the contents of the EEPROM memory of the DS28E04-100
|
Description: read/write the contents of the EEPROM memory of the DS28E04-100
|
||||||
see Documentation/w1/slaves/w1_ds28e04 for detailed information
|
see Documentation/w1/slaves/w1_ds28e04.rst for detailed information
|
||||||
Users: any user space application which wants to communicate with DS28E04-100
|
Users: any user space application which wants to communicate with DS28E04-100
|
||||||
|
@ -2,5 +2,5 @@ What: /sys/bus/w1/devices/.../w1_seq
|
|||||||
Date: Apr 2015
|
Date: Apr 2015
|
||||||
Contact: Matt Campbell <mattrcampbell@gmail.com>
|
Contact: Matt Campbell <mattrcampbell@gmail.com>
|
||||||
Description: Support for the DS28EA00 chain sequence function
|
Description: Support for the DS28EA00 chain sequence function
|
||||||
see Documentation/w1/slaves/w1_therm for detailed information
|
see Documentation/w1/slaves/w1_therm.rst for detailed information
|
||||||
Users: any user space application which wants to communicate with DS28EA00
|
Users: any user space application which wants to communicate with DS28EA00
|
||||||
|
98
Documentation/admin-guide/auxdisplay/cfag12864b.rst
Normal file
98
Documentation/admin-guide/auxdisplay/cfag12864b.rst
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
===================================
|
||||||
|
cfag12864b LCD Driver Documentation
|
||||||
|
===================================
|
||||||
|
|
||||||
|
:License: GPLv2
|
||||||
|
:Author & Maintainer: Miguel Ojeda Sandonis
|
||||||
|
:Date: 2006-10-27
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.. INDEX
|
||||||
|
|
||||||
|
1. DRIVER INFORMATION
|
||||||
|
2. DEVICE INFORMATION
|
||||||
|
3. WIRING
|
||||||
|
4. USERSPACE PROGRAMMING
|
||||||
|
|
||||||
|
1. Driver Information
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
This driver supports a cfag12864b LCD.
|
||||||
|
|
||||||
|
|
||||||
|
2. Device Information
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
:Manufacturer: Crystalfontz
|
||||||
|
:Device Name: Crystalfontz 12864b LCD Series
|
||||||
|
:Device Code: cfag12864b
|
||||||
|
:Webpage: http://www.crystalfontz.com
|
||||||
|
:Device Webpage: http://www.crystalfontz.com/products/12864b/
|
||||||
|
:Type: LCD (Liquid Crystal Display)
|
||||||
|
:Width: 128
|
||||||
|
:Height: 64
|
||||||
|
:Colors: 2 (B/N)
|
||||||
|
:Controller: ks0108
|
||||||
|
:Controllers: 2
|
||||||
|
:Pages: 8 each controller
|
||||||
|
:Addresses: 64 each page
|
||||||
|
:Data size: 1 byte each address
|
||||||
|
:Memory size: 2 * 8 * 64 * 1 = 1024 bytes = 1 Kbyte
|
||||||
|
|
||||||
|
|
||||||
|
3. Wiring
|
||||||
|
---------
|
||||||
|
|
||||||
|
The cfag12864b LCD Series don't have official wiring.
|
||||||
|
|
||||||
|
The common wiring is done to the parallel port as shown::
|
||||||
|
|
||||||
|
Parallel Port cfag12864b
|
||||||
|
|
||||||
|
Name Pin# Pin# Name
|
||||||
|
|
||||||
|
Strobe ( 1)------------------------------(17) Enable
|
||||||
|
Data 0 ( 2)------------------------------( 4) Data 0
|
||||||
|
Data 1 ( 3)------------------------------( 5) Data 1
|
||||||
|
Data 2 ( 4)------------------------------( 6) Data 2
|
||||||
|
Data 3 ( 5)------------------------------( 7) Data 3
|
||||||
|
Data 4 ( 6)------------------------------( 8) Data 4
|
||||||
|
Data 5 ( 7)------------------------------( 9) Data 5
|
||||||
|
Data 6 ( 8)------------------------------(10) Data 6
|
||||||
|
Data 7 ( 9)------------------------------(11) Data 7
|
||||||
|
(10) [+5v]---( 1) Vdd
|
||||||
|
(11) [GND]---( 2) Ground
|
||||||
|
(12) [+5v]---(14) Reset
|
||||||
|
(13) [GND]---(15) Read / Write
|
||||||
|
Line (14)------------------------------(13) Controller Select 1
|
||||||
|
(15)
|
||||||
|
Init (16)------------------------------(12) Controller Select 2
|
||||||
|
Select (17)------------------------------(16) Data / Instruction
|
||||||
|
Ground (18)---[GND] [+5v]---(19) LED +
|
||||||
|
Ground (19)---[GND]
|
||||||
|
Ground (20)---[GND] E A Values:
|
||||||
|
Ground (21)---[GND] [GND]---[P1]---(18) Vee - R = Resistor = 22 ohm
|
||||||
|
Ground (22)---[GND] | - P1 = Preset = 10 Kohm
|
||||||
|
Ground (23)---[GND] ---- S ------( 3) V0 - P2 = Preset = 1 Kohm
|
||||||
|
Ground (24)---[GND] | |
|
||||||
|
Ground (25)---[GND] [GND]---[P2]---[R]---(20) LED -
|
||||||
|
|
||||||
|
|
||||||
|
4. Userspace Programming
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
The cfag12864bfb describes a framebuffer device (/dev/fbX).
|
||||||
|
|
||||||
|
It has a size of 1024 bytes = 1 Kbyte.
|
||||||
|
Each bit represents one pixel. If the bit is high, the pixel will
|
||||||
|
turn on. If the pixel is low, the pixel will turn off.
|
||||||
|
|
||||||
|
You can use the framebuffer as a file: fopen, fwrite, fclose...
|
||||||
|
Although the LCD won't get updated until the next refresh time arrives.
|
||||||
|
|
||||||
|
Also, you can mmap the framebuffer: open & mmap, munmap & close...
|
||||||
|
which is the best option for most uses.
|
||||||
|
|
||||||
|
Check samples/auxdisplay/cfag12864b-example.c
|
||||||
|
for a real working userspace complete program with usage examples.
|
16
Documentation/admin-guide/auxdisplay/index.rst
Normal file
16
Documentation/admin-guide/auxdisplay/index.rst
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
=========================
|
||||||
|
Auxiliary Display Support
|
||||||
|
=========================
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
ks0108.rst
|
||||||
|
cfag12864b.rst
|
||||||
|
|
||||||
|
.. only:: subproject and html
|
||||||
|
|
||||||
|
Indices
|
||||||
|
=======
|
||||||
|
|
||||||
|
* :ref:`genindex`
|
50
Documentation/admin-guide/auxdisplay/ks0108.rst
Normal file
50
Documentation/admin-guide/auxdisplay/ks0108.rst
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
==========================================
|
||||||
|
ks0108 LCD Controller Driver Documentation
|
||||||
|
==========================================
|
||||||
|
|
||||||
|
:License: GPLv2
|
||||||
|
:Author & Maintainer: Miguel Ojeda Sandonis
|
||||||
|
:Date: 2006-10-27
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.. INDEX
|
||||||
|
|
||||||
|
1. DRIVER INFORMATION
|
||||||
|
2. DEVICE INFORMATION
|
||||||
|
3. WIRING
|
||||||
|
|
||||||
|
|
||||||
|
1. Driver Information
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
This driver supports the ks0108 LCD controller.
|
||||||
|
|
||||||
|
|
||||||
|
2. Device Information
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
:Manufacturer: Samsung
|
||||||
|
:Device Name: KS0108 LCD Controller
|
||||||
|
:Device Code: ks0108
|
||||||
|
:Webpage: -
|
||||||
|
:Device Webpage: -
|
||||||
|
:Type: LCD Controller (Liquid Crystal Display Controller)
|
||||||
|
:Width: 64
|
||||||
|
:Height: 64
|
||||||
|
:Colors: 2 (B/N)
|
||||||
|
:Pages: 8
|
||||||
|
:Addresses: 64 each page
|
||||||
|
:Data size: 1 byte each address
|
||||||
|
:Memory size: 8 * 64 * 1 = 512 bytes
|
||||||
|
|
||||||
|
|
||||||
|
3. Wiring
|
||||||
|
---------
|
||||||
|
|
||||||
|
The driver supports data parallel port wiring.
|
||||||
|
|
||||||
|
If you aren't building LCD related hardware, you should check
|
||||||
|
your LCD specific wiring information in the same folder.
|
||||||
|
|
||||||
|
For example, check Documentation/admin-guide/auxdisplay/cfag12864b.rst
|
@ -130,12 +130,6 @@ Proportional weight policy files
|
|||||||
dev weight
|
dev weight
|
||||||
8:16 300
|
8:16 300
|
||||||
|
|
||||||
- blkio.leaf_weight[_device]
|
|
||||||
- Equivalents of blkio.weight[_device] for the purpose of
|
|
||||||
deciding how much weight tasks in the given cgroup has while
|
|
||||||
competing with the cgroup's child cgroups. For details,
|
|
||||||
please refer to Documentation/block/cfq-iosched.txt.
|
|
||||||
|
|
||||||
- blkio.time
|
- blkio.time
|
||||||
- disk time allocated to cgroup per device in milliseconds. First
|
- disk time allocated to cgroup per device in milliseconds. First
|
||||||
two fields specify the major and minor number of the device and
|
two fields specify the major and minor number of the device and
|
||||||
|
@ -1,5 +1,10 @@
|
|||||||
|
=======
|
||||||
|
Authors
|
||||||
|
=======
|
||||||
|
|
||||||
Original Author
|
Original Author
|
||||||
===============
|
---------------
|
||||||
|
|
||||||
Steve French (sfrench@samba.org)
|
Steve French (sfrench@samba.org)
|
||||||
|
|
||||||
The author wishes to express his appreciation and thanks to:
|
The author wishes to express his appreciation and thanks to:
|
||||||
@ -20,33 +25,34 @@ thanks to the Samba team for their technical advice and encouragement.
|
|||||||
|
|
||||||
Patch Contributors
|
Patch Contributors
|
||||||
------------------
|
------------------
|
||||||
Zwane Mwaikambo
|
|
||||||
Andi Kleen
|
- Zwane Mwaikambo
|
||||||
Amrut Joshi
|
- Andi Kleen
|
||||||
Shobhit Dayal
|
- Amrut Joshi
|
||||||
Sergey Vlasov
|
- Shobhit Dayal
|
||||||
Richard Hughes
|
- Sergey Vlasov
|
||||||
Yury Umanets
|
- Richard Hughes
|
||||||
Mark Hamzy (for some of the early cifs IPv6 work)
|
- Yury Umanets
|
||||||
Domen Puncer
|
- Mark Hamzy (for some of the early cifs IPv6 work)
|
||||||
Jesper Juhl (in particular for lots of whitespace/formatting cleanup)
|
- Domen Puncer
|
||||||
Vince Negri and Dave Stahl (for finding an important caching bug)
|
- Jesper Juhl (in particular for lots of whitespace/formatting cleanup)
|
||||||
Adrian Bunk (kcalloc cleanups)
|
- Vince Negri and Dave Stahl (for finding an important caching bug)
|
||||||
Miklos Szeredi
|
- Adrian Bunk (kcalloc cleanups)
|
||||||
Kazeon team for various fixes especially for 2.4 version.
|
- Miklos Szeredi
|
||||||
Asser Ferno (Change Notify support)
|
- Kazeon team for various fixes especially for 2.4 version.
|
||||||
Shaggy (Dave Kleikamp) for innumerable small fs suggestions and some good cleanup
|
- Asser Ferno (Change Notify support)
|
||||||
Gunter Kukkukk (testing and suggestions for support of old servers)
|
- Shaggy (Dave Kleikamp) for innumerable small fs suggestions and some good cleanup
|
||||||
Igor Mammedov (DFS support)
|
- Gunter Kukkukk (testing and suggestions for support of old servers)
|
||||||
Jeff Layton (many, many fixes, as well as great work on the cifs Kerberos code)
|
- Igor Mammedov (DFS support)
|
||||||
Scott Lovenberg
|
- Jeff Layton (many, many fixes, as well as great work on the cifs Kerberos code)
|
||||||
Pavel Shilovsky (for great work adding SMB2 support, and various SMB3 features)
|
- Scott Lovenberg
|
||||||
Aurelien Aptel (for DFS SMB3 work and some key bug fixes)
|
- Pavel Shilovsky (for great work adding SMB2 support, and various SMB3 features)
|
||||||
Ronnie Sahlberg (for SMB3 xattr work, bug fixes, and lots of great work on compounding)
|
- Aurelien Aptel (for DFS SMB3 work and some key bug fixes)
|
||||||
Shirish Pargaonkar (for many ACL patches over the years)
|
- Ronnie Sahlberg (for SMB3 xattr work, bug fixes, and lots of great work on compounding)
|
||||||
Sachin Prabhu (many bug fixes, including for reconnect, copy offload and security)
|
- Shirish Pargaonkar (for many ACL patches over the years)
|
||||||
Paulo Alcantara
|
- Sachin Prabhu (many bug fixes, including for reconnect, copy offload and security)
|
||||||
Long Li (some great work on RDMA, SMB Direct)
|
- Paulo Alcantara
|
||||||
|
- Long Li (some great work on RDMA, SMB Direct)
|
||||||
|
|
||||||
|
|
||||||
Test case and Bug Report contributors
|
Test case and Bug Report contributors
|
@ -1,3 +1,7 @@
|
|||||||
|
=======
|
||||||
|
Changes
|
||||||
|
=======
|
||||||
|
|
||||||
See https://wiki.samba.org/index.php/LinuxCIFSKernel for summary
|
See https://wiki.samba.org/index.php/LinuxCIFSKernel for summary
|
||||||
information (that may be easier to read than parsing the output of
|
information (that may be easier to read than parsing the output of
|
||||||
"git log fs/cifs") about fixes/improvements to CIFS/SMB2/SMB3 support (changes
|
"git log fs/cifs") about fixes/improvements to CIFS/SMB2/SMB3 support (changes
|
21
Documentation/admin-guide/cifs/index.rst
Normal file
21
Documentation/admin-guide/cifs/index.rst
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
====
|
||||||
|
CIFS
|
||||||
|
====
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 2
|
||||||
|
|
||||||
|
introduction
|
||||||
|
usage
|
||||||
|
todo
|
||||||
|
changes
|
||||||
|
authors
|
||||||
|
|
||||||
|
.. only:: subproject and html
|
||||||
|
|
||||||
|
Indices
|
||||||
|
=======
|
||||||
|
|
||||||
|
* :ref:`genindex`
|
@ -1,3 +1,7 @@
|
|||||||
|
============
|
||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
This is the client VFS module for the SMB3 NAS protocol as well
|
This is the client VFS module for the SMB3 NAS protocol as well
|
||||||
as for older dialects such as the Common Internet File System (CIFS)
|
as for older dialects such as the Common Internet File System (CIFS)
|
||||||
protocol which was the successor to the Server Message Block
|
protocol which was the successor to the Server Message Block
|
||||||
@ -33,7 +37,9 @@
|
|||||||
tools (including smbinfo and setcifsacl) that can be obtained from
|
tools (including smbinfo and setcifsacl) that can be obtained from
|
||||||
|
|
||||||
https://git.samba.org/?p=cifs-utils.git
|
https://git.samba.org/?p=cifs-utils.git
|
||||||
|
|
||||||
or
|
or
|
||||||
|
|
||||||
git://git.samba.org/cifs-utils.git
|
git://git.samba.org/cifs-utils.git
|
||||||
|
|
||||||
mount.cifs should be installed in the directory with the other mount helpers.
|
mount.cifs should be installed in the directory with the other mount helpers.
|
||||||
@ -41,5 +47,7 @@
|
|||||||
For more information on the module see the project wiki page at
|
For more information on the module see the project wiki page at
|
||||||
|
|
||||||
https://wiki.samba.org/index.php/LinuxCIFS
|
https://wiki.samba.org/index.php/LinuxCIFS
|
||||||
|
|
||||||
and
|
and
|
||||||
|
|
||||||
https://wiki.samba.org/index.php/LinuxCIFS_utils
|
https://wiki.samba.org/index.php/LinuxCIFS_utils
|
@ -1,3 +1,7 @@
|
|||||||
|
====
|
||||||
|
TODO
|
||||||
|
====
|
||||||
|
|
||||||
Version 2.14 December 21, 2018
|
Version 2.14 December 21, 2018
|
||||||
|
|
||||||
A Partial List of Missing Features
|
A Partial List of Missing Features
|
||||||
@ -8,6 +12,7 @@ for visible, important contributions to this module. Here
|
|||||||
is a partial list of the known problems and missing features:
|
is a partial list of the known problems and missing features:
|
||||||
|
|
||||||
a) SMB3 (and SMB3.1.1) missing optional features:
|
a) SMB3 (and SMB3.1.1) missing optional features:
|
||||||
|
|
||||||
- multichannel (started), integration with RDMA
|
- multichannel (started), integration with RDMA
|
||||||
- directory leases (improved metadata caching), started (root dir only)
|
- directory leases (improved metadata caching), started (root dir only)
|
||||||
- T10 copy offload ie "ODX" (copy chunk, and "Duplicate Extents" ioctl
|
- T10 copy offload ie "ODX" (copy chunk, and "Duplicate Extents" ioctl
|
||||||
@ -22,13 +27,14 @@ using Directory Leases, currently only the root file handle is cached longer
|
|||||||
d) quota support (needs minor kernel change since quota calls
|
d) quota support (needs minor kernel change since quota calls
|
||||||
to make it to network filesystems or deviceless filesystems)
|
to make it to network filesystems or deviceless filesystems)
|
||||||
|
|
||||||
e) Additional use cases can be optimized to use "compounding"
|
e) Additional use cases can be optimized to use "compounding" (e.g.
|
||||||
(e.g. open/query/close and open/setinfo/close) to reduce the number
|
open/query/close and open/setinfo/close) to reduce the number of
|
||||||
of roundtrips to the server and improve performance. Various cases
|
roundtrips to the server and improve performance. Various cases
|
||||||
(stat, statfs, create, unlink, mkdir) already have been improved by
|
(stat, statfs, create, unlink, mkdir) already have been improved by
|
||||||
using compounding but more can be done. In addition we could significantly
|
using compounding but more can be done. In addition we could
|
||||||
reduce redundant opens by using deferred close (with handle caching leases)
|
significantly reduce redundant opens by using deferred close (with
|
||||||
and better using reference counters on file handles.
|
handle caching leases) and better using reference counters on file
|
||||||
|
handles.
|
||||||
|
|
||||||
f) Finish inotify support so kde and gnome file list windows
|
f) Finish inotify support so kde and gnome file list windows
|
||||||
will autorefresh (partially complete by Asser). Needs minor kernel
|
will autorefresh (partially complete by Asser). Needs minor kernel
|
||||||
@ -48,10 +54,11 @@ mount or a per server basis to client UIDs or nobody if no mapping
|
|||||||
exists. Also better integration with winbind for resolving SID owners
|
exists. Also better integration with winbind for resolving SID owners
|
||||||
|
|
||||||
k) Add tools to take advantage of more smb3 specific ioctls and features
|
k) Add tools to take advantage of more smb3 specific ioctls and features
|
||||||
(passthrough ioctl/fsctl is now implemented in cifs.ko to allow sending
|
(passthrough ioctl/fsctl is now implemented in cifs.ko to allow
|
||||||
various SMB3 fsctls and query info and set info calls directly from user space)
|
sending various SMB3 fsctls and query info and set info calls
|
||||||
Add tools to make setting various non-POSIX metadata attributes easier
|
directly from user space) Add tools to make setting various non-POSIX
|
||||||
from tools (e.g. extending what was done in smb-info tool).
|
metadata attributes easier from tools (e.g. extending what was done
|
||||||
|
in smb-info tool).
|
||||||
|
|
||||||
l) encrypted file support
|
l) encrypted file support
|
||||||
|
|
||||||
@ -88,8 +95,9 @@ authentication mechanisms (see MS-SMB2)
|
|||||||
|
|
||||||
x) Finish support for SMB3.1.1 compression
|
x) Finish support for SMB3.1.1 compression
|
||||||
|
|
||||||
KNOWN BUGS
|
Known Bugs
|
||||||
====================================
|
==========
|
||||||
|
|
||||||
See http://bugzilla.samba.org - search on product "CifsVFS" for
|
See http://bugzilla.samba.org - search on product "CifsVFS" for
|
||||||
current bug list. Also check http://bugzilla.kernel.org (Product = File System, Component = CIFS)
|
current bug list. Also check http://bugzilla.kernel.org (Product = File System, Component = CIFS)
|
||||||
|
|
@ -1,3 +1,7 @@
|
|||||||
|
=====
|
||||||
|
Usage
|
||||||
|
=====
|
||||||
|
|
||||||
This module supports the SMB3 family of advanced network protocols (as well
|
This module supports the SMB3 family of advanced network protocols (as well
|
||||||
as older dialects, originally called "CIFS" or SMB1).
|
as older dialects, originally called "CIFS" or SMB1).
|
||||||
|
|
||||||
@ -18,13 +22,16 @@ for more details.
|
|||||||
|
|
||||||
|
|
||||||
For questions or bug reports please contact:
|
For questions or bug reports please contact:
|
||||||
|
|
||||||
smfrench@gmail.com
|
smfrench@gmail.com
|
||||||
|
|
||||||
See the project page at: https://wiki.samba.org/index.php/LinuxCIFS_utils
|
See the project page at: https://wiki.samba.org/index.php/LinuxCIFS_utils
|
||||||
|
|
||||||
Build instructions:
|
Build instructions
|
||||||
==================
|
==================
|
||||||
|
|
||||||
For Linux:
|
For Linux:
|
||||||
|
|
||||||
1) Download the kernel (e.g. from http://www.kernel.org)
|
1) Download the kernel (e.g. from http://www.kernel.org)
|
||||||
and change directory into the top of the kernel directory tree
|
and change directory into the top of the kernel directory tree
|
||||||
(e.g. /usr/src/linux-2.5.73)
|
(e.g. /usr/src/linux-2.5.73)
|
||||||
@ -34,20 +41,21 @@ and change directory into the top of the kernel directory tree
|
|||||||
5) make
|
5) make
|
||||||
|
|
||||||
|
|
||||||
Installation instructions:
|
Installation instructions
|
||||||
=========================
|
=========================
|
||||||
|
|
||||||
If you have built the CIFS vfs as module (successfully) simply
|
If you have built the CIFS vfs as module (successfully) simply
|
||||||
type "make modules_install" (or if you prefer, manually copy the file to
|
type ``make modules_install`` (or if you prefer, manually copy the file to
|
||||||
the modules directory e.g. /lib/modules/2.4.10-4GB/kernel/fs/cifs/cifs.ko).
|
the modules directory e.g. /lib/modules/2.4.10-4GB/kernel/fs/cifs/cifs.ko).
|
||||||
|
|
||||||
If you have built the CIFS vfs into the kernel itself, follow the instructions
|
If you have built the CIFS vfs into the kernel itself, follow the instructions
|
||||||
for your distribution on how to install a new kernel (usually you
|
for your distribution on how to install a new kernel (usually you
|
||||||
would simply type "make install").
|
would simply type ``make install``).
|
||||||
|
|
||||||
If you do not have the utility mount.cifs (in the Samba 4.x source tree and on
|
If you do not have the utility mount.cifs (in the Samba 4.x source tree and on
|
||||||
the CIFS VFS web site) copy it to the same directory in which mount helpers
|
the CIFS VFS web site) copy it to the same directory in which mount helpers
|
||||||
reside (usually /sbin). Although the helper software is not
|
reside (usually /sbin). Although the helper software is not
|
||||||
required, mount.cifs is recommended. Most distros include a "cifs-utils"
|
required, mount.cifs is recommended. Most distros include a ``cifs-utils``
|
||||||
package that includes this utility so it is recommended to install this.
|
package that includes this utility so it is recommended to install this.
|
||||||
|
|
||||||
Note that running the Winbind pam/nss module (logon service) on all of your
|
Note that running the Winbind pam/nss module (logon service) on all of your
|
||||||
@ -57,13 +65,16 @@ found at cifs-utils.git on git.samba.org
|
|||||||
|
|
||||||
If cifs is built as a module, then the size and number of network buffers
|
If cifs is built as a module, then the size and number of network buffers
|
||||||
and maximum number of simultaneous requests to one server can be configured.
|
and maximum number of simultaneous requests to one server can be configured.
|
||||||
Changing these from their defaults is not recommended. By executing modinfo
|
Changing these from their defaults is not recommended. By executing modinfo::
|
||||||
|
|
||||||
modinfo kernel/fs/cifs/cifs.ko
|
modinfo kernel/fs/cifs/cifs.ko
|
||||||
|
|
||||||
on kernel/fs/cifs/cifs.ko the list of configuration changes that can be made
|
on kernel/fs/cifs/cifs.ko the list of configuration changes that can be made
|
||||||
at module initialization time (by running insmod cifs.ko) can be seen.
|
at module initialization time (by running insmod cifs.ko) can be seen.
|
||||||
|
|
||||||
Recommendations
|
Recommendations
|
||||||
===============
|
===============
|
||||||
|
|
||||||
To improve security the SMB2.1 dialect or later (usually will get SMB3) is now
|
To improve security the SMB2.1 dialect or later (usually will get SMB3) is now
|
||||||
the new default. To use old dialects (e.g. to mount Windows XP) use "vers=1.0"
|
the new default. To use old dialects (e.g. to mount Windows XP) use "vers=1.0"
|
||||||
on mount (or vers=2.0 for Windows Vista). Note that the CIFS (vers=1.0) is
|
on mount (or vers=2.0 for Windows Vista). Note that the CIFS (vers=1.0) is
|
||||||
@ -72,26 +83,30 @@ many advanced security features such as downgrade attack detection
|
|||||||
and encrypted shares and stronger signing and authentication algorithms.
|
and encrypted shares and stronger signing and authentication algorithms.
|
||||||
There are additional mount options that may be helpful for SMB3 to get
|
There are additional mount options that may be helpful for SMB3 to get
|
||||||
improved POSIX behavior (NB: can use vers=3.0 to force only SMB3, never 2.1):
|
improved POSIX behavior (NB: can use vers=3.0 to force only SMB3, never 2.1):
|
||||||
"mfsymlinks" and "cifsacl" and "idsfromsid"
|
|
||||||
|
``mfsymlinks`` and ``cifsacl`` and ``idsfromsid``
|
||||||
|
|
||||||
Allowing User Mounts
|
Allowing User Mounts
|
||||||
====================
|
====================
|
||||||
|
|
||||||
To permit users to mount and unmount over directories they own is possible
|
To permit users to mount and unmount over directories they own is possible
|
||||||
with the cifs vfs. A way to enable such mounting is to mark the mount.cifs
|
with the cifs vfs. A way to enable such mounting is to mark the mount.cifs
|
||||||
utility as suid (e.g. "chmod +s /sbin/mount.cifs). To enable users to
|
utility as suid (e.g. ``chmod +s /sbin/mount.cifs``). To enable users to
|
||||||
umount shares they mount requires
|
umount shares they mount requires
|
||||||
|
|
||||||
1) mount.cifs version 1.4 or later
|
1) mount.cifs version 1.4 or later
|
||||||
2) an entry for the share in /etc/fstab indicating that a user may
|
2) an entry for the share in /etc/fstab indicating that a user may
|
||||||
unmount it e.g.
|
unmount it e.g.::
|
||||||
|
|
||||||
//server/usersharename /mnt/username cifs user 0 0
|
//server/usersharename /mnt/username cifs user 0 0
|
||||||
|
|
||||||
Note that when the mount.cifs utility is run suid (allowing user mounts),
|
Note that when the mount.cifs utility is run suid (allowing user mounts),
|
||||||
in order to reduce risks, the "nosuid" mount flag is passed in on mount to
|
in order to reduce risks, the ``nosuid`` mount flag is passed in on mount to
|
||||||
disallow execution of an suid program mounted on the remote target.
|
disallow execution of an suid program mounted on the remote target.
|
||||||
When mount is executed as root, nosuid is not passed in by default,
|
When mount is executed as root, nosuid is not passed in by default,
|
||||||
and execution of suid programs on the remote target would be enabled
|
and execution of suid programs on the remote target would be enabled
|
||||||
by default. This can be changed, as with nfs and other filesystems,
|
by default. This can be changed, as with nfs and other filesystems,
|
||||||
by simply specifying "nosuid" among the mount options. For user mounts
|
by simply specifying ``nosuid`` among the mount options. For user mounts
|
||||||
though to be able to pass the suid flag to mount requires rebuilding
|
though to be able to pass the suid flag to mount requires rebuilding
|
||||||
mount.cifs with the following flag: CIFS_ALLOW_USR_SUID
|
mount.cifs with the following flag: CIFS_ALLOW_USR_SUID
|
||||||
|
|
||||||
@ -100,13 +115,14 @@ later source tree in docs/manpages/mount.cifs.8
|
|||||||
|
|
||||||
Allowing User Unmounts
|
Allowing User Unmounts
|
||||||
======================
|
======================
|
||||||
|
|
||||||
To permit users to ummount directories that they have user mounted (see above),
|
To permit users to ummount directories that they have user mounted (see above),
|
||||||
the utility umount.cifs may be used. It may be invoked directly, or if
|
the utility umount.cifs may be used. It may be invoked directly, or if
|
||||||
umount.cifs is placed in /sbin, umount can invoke the cifs umount helper
|
umount.cifs is placed in /sbin, umount can invoke the cifs umount helper
|
||||||
(at least for most versions of the umount utility) for umount of cifs
|
(at least for most versions of the umount utility) for umount of cifs
|
||||||
mounts, unless umount is invoked with -i (which will avoid invoking a umount
|
mounts, unless umount is invoked with -i (which will avoid invoking a umount
|
||||||
helper). As with mount.cifs, to enable user unmounts umount.cifs must be marked
|
helper). As with mount.cifs, to enable user unmounts umount.cifs must be marked
|
||||||
as suid (e.g. "chmod +s /sbin/umount.cifs") or equivalent (some distributions
|
as suid (e.g. ``chmod +s /sbin/umount.cifs``) or equivalent (some distributions
|
||||||
allow adding entries to a file to the /etc/permissions file to achieve the
|
allow adding entries to a file to the /etc/permissions file to achieve the
|
||||||
equivalent suid effect). For this utility to succeed the target path
|
equivalent suid effect). For this utility to succeed the target path
|
||||||
must be a cifs mount, and the uid of the current user must match the uid
|
must be a cifs mount, and the uid of the current user must match the uid
|
||||||
@ -120,6 +136,7 @@ or unpredictable UNC names.
|
|||||||
|
|
||||||
Samba Considerations
|
Samba Considerations
|
||||||
====================
|
====================
|
||||||
|
|
||||||
Most current servers support SMB2.1 and SMB3 which are more secure,
|
Most current servers support SMB2.1 and SMB3 which are more secure,
|
||||||
but there are useful protocol extensions for the older less secure CIFS
|
but there are useful protocol extensions for the older less secure CIFS
|
||||||
dialect, so to get the maximum benefit if mounting using the older dialect
|
dialect, so to get the maximum benefit if mounting using the older dialect
|
||||||
@ -129,13 +146,13 @@ Unix Extensions standard (e.g. almost any version of Samba ie version
|
|||||||
Note that uid, gid and file permissions will display default values if you do
|
Note that uid, gid and file permissions will display default values if you do
|
||||||
not have a server that supports the Unix extensions for CIFS (such as Samba
|
not have a server that supports the Unix extensions for CIFS (such as Samba
|
||||||
2.2.5 or later). To enable the Unix CIFS Extensions in the Samba server, add
|
2.2.5 or later). To enable the Unix CIFS Extensions in the Samba server, add
|
||||||
the line:
|
the line::
|
||||||
|
|
||||||
unix extensions = yes
|
unix extensions = yes
|
||||||
|
|
||||||
to your smb.conf file on the server. Note that the following smb.conf settings
|
to your smb.conf file on the server. Note that the following smb.conf settings
|
||||||
are also useful (on the Samba server) when the majority of clients are Unix or
|
are also useful (on the Samba server) when the majority of clients are Unix or
|
||||||
Linux:
|
Linux::
|
||||||
|
|
||||||
case sensitive = yes
|
case sensitive = yes
|
||||||
delete readonly = yes
|
delete readonly = yes
|
||||||
@ -147,31 +164,33 @@ cifs client, and that EA support is present in later versions of Samba (e.g.
|
|||||||
shares on NTFS filesystems). Extended Attribute (xattr) support is an optional
|
shares on NTFS filesystems). Extended Attribute (xattr) support is an optional
|
||||||
feature of most Linux filesystems which may require enabling via
|
feature of most Linux filesystems which may require enabling via
|
||||||
make menuconfig. Client support for extended attributes (user xattr) can be
|
make menuconfig. Client support for extended attributes (user xattr) can be
|
||||||
disabled on a per-mount basis by specifying "nouser_xattr" on mount.
|
disabled on a per-mount basis by specifying ``nouser_xattr`` on mount.
|
||||||
|
|
||||||
The CIFS client can get and set POSIX ACLs (getfacl, setfacl) to Samba servers
|
The CIFS client can get and set POSIX ACLs (getfacl, setfacl) to Samba servers
|
||||||
version 3.10 and later. Setting POSIX ACLs requires enabling both XATTR and
|
version 3.10 and later. Setting POSIX ACLs requires enabling both XATTR and
|
||||||
then POSIX support in the CIFS configuration options when building the cifs
|
then POSIX support in the CIFS configuration options when building the cifs
|
||||||
module. POSIX ACL support can be disabled on a per mount basic by specifying
|
module. POSIX ACL support can be disabled on a per mount basic by specifying
|
||||||
"noacl" on mount.
|
``noacl`` on mount.
|
||||||
|
|
||||||
Some administrators may want to change Samba's smb.conf "map archive" and
|
Some administrators may want to change Samba's smb.conf ``map archive`` and
|
||||||
"create mask" parameters from the default. Unless the create mask is changed
|
``create mask`` parameters from the default. Unless the create mask is changed
|
||||||
newly created files can end up with an unnecessarily restrictive default mode,
|
newly created files can end up with an unnecessarily restrictive default mode,
|
||||||
which may not be what you want, although if the CIFS Unix extensions are
|
which may not be what you want, although if the CIFS Unix extensions are
|
||||||
enabled on the server and client, subsequent setattr calls (e.g. chmod) can
|
enabled on the server and client, subsequent setattr calls (e.g. chmod) can
|
||||||
fix the mode. Note that creating special devices (mknod) remotely
|
fix the mode. Note that creating special devices (mknod) remotely
|
||||||
may require specifying a mkdev function to Samba if you are not using
|
may require specifying a mkdev function to Samba if you are not using
|
||||||
Samba 3.0.6 or later. For more information on these see the manual pages
|
Samba 3.0.6 or later. For more information on these see the manual pages
|
||||||
("man smb.conf") on the Samba server system. Note that the cifs vfs,
|
(``man smb.conf``) on the Samba server system. Note that the cifs vfs,
|
||||||
unlike the smbfs vfs, does not read the smb.conf on the client system
|
unlike the smbfs vfs, does not read the smb.conf on the client system
|
||||||
(the few optional settings are passed in on mount via -o parameters instead).
|
(the few optional settings are passed in on mount via -o parameters instead).
|
||||||
Note that Samba 2.2.7 or later includes a fix that allows the CIFS VFS to delete
|
Note that Samba 2.2.7 or later includes a fix that allows the CIFS VFS to delete
|
||||||
open files (required for strict POSIX compliance). Windows Servers already
|
open files (required for strict POSIX compliance). Windows Servers already
|
||||||
supported this feature. Samba server does not allow symlinks that refer to files
|
supported this feature. Samba server does not allow symlinks that refer to files
|
||||||
outside of the share, so in Samba versions prior to 3.0.6, most symlinks to
|
outside of the share, so in Samba versions prior to 3.0.6, most symlinks to
|
||||||
files with absolute paths (ie beginning with slash) such as:
|
files with absolute paths (ie beginning with slash) such as::
|
||||||
|
|
||||||
ln -s /mnt/foo bar
|
ln -s /mnt/foo bar
|
||||||
|
|
||||||
would be forbidden. Samba 3.0.6 server or later includes the ability to create
|
would be forbidden. Samba 3.0.6 server or later includes the ability to create
|
||||||
such symlinks safely by converting unsafe symlinks (ie symlinks to server
|
such symlinks safely by converting unsafe symlinks (ie symlinks to server
|
||||||
files that are outside of the share) to a samba specific format on the server
|
files that are outside of the share) to a samba specific format on the server
|
||||||
@ -182,18 +201,19 @@ later, but only for remote clients using the CIFS Unix extensions, and will
|
|||||||
be invisbile to Windows clients and typically will not affect local
|
be invisbile to Windows clients and typically will not affect local
|
||||||
applications running on the same server as Samba.
|
applications running on the same server as Samba.
|
||||||
|
|
||||||
Use instructions:
|
Use instructions
|
||||||
================
|
================
|
||||||
|
|
||||||
Once the CIFS VFS support is built into the kernel or installed as a module
|
Once the CIFS VFS support is built into the kernel or installed as a module
|
||||||
(cifs.ko), you can use mount syntax like the following to access Samba or
|
(cifs.ko), you can use mount syntax like the following to access Samba or
|
||||||
Mac or Windows servers:
|
Mac or Windows servers::
|
||||||
|
|
||||||
mount -t cifs //9.53.216.11/e$ /mnt -o username=myname,password=mypassword
|
mount -t cifs //9.53.216.11/e$ /mnt -o username=myname,password=mypassword
|
||||||
|
|
||||||
Before -o the option -v may be specified to make the mount.cifs
|
Before -o the option -v may be specified to make the mount.cifs
|
||||||
mount helper display the mount steps more verbosely.
|
mount helper display the mount steps more verbosely.
|
||||||
After -o the following commonly used cifs vfs specific options
|
After -o the following commonly used cifs vfs specific options
|
||||||
are supported:
|
are supported::
|
||||||
|
|
||||||
username=<username>
|
username=<username>
|
||||||
password=<password>
|
password=<password>
|
||||||
@ -203,23 +223,26 @@ Other cifs mount options are described below. Use of TCP names (in addition to
|
|||||||
ip addresses) is available if the mount helper (mount.cifs) is installed. If
|
ip addresses) is available if the mount helper (mount.cifs) is installed. If
|
||||||
you do not trust the server to which are mounted, or if you do not have
|
you do not trust the server to which are mounted, or if you do not have
|
||||||
cifs signing enabled (and the physical network is insecure), consider use
|
cifs signing enabled (and the physical network is insecure), consider use
|
||||||
of the standard mount options "noexec" and "nosuid" to reduce the risk of
|
of the standard mount options ``noexec`` and ``nosuid`` to reduce the risk of
|
||||||
running an altered binary on your local system (downloaded from a hostile server
|
running an altered binary on your local system (downloaded from a hostile server
|
||||||
or altered by a hostile router).
|
or altered by a hostile router).
|
||||||
|
|
||||||
Although mounting using format corresponding to the CIFS URL specification is
|
Although mounting using format corresponding to the CIFS URL specification is
|
||||||
not possible in mount.cifs yet, it is possible to use an alternate format
|
not possible in mount.cifs yet, it is possible to use an alternate format
|
||||||
for the server and sharename (which is somewhat similar to NFS style mount
|
for the server and sharename (which is somewhat similar to NFS style mount
|
||||||
syntax) instead of the more widely used UNC format (i.e. \\server\share):
|
syntax) instead of the more widely used UNC format (i.e. \\server\share)::
|
||||||
|
|
||||||
mount -t cifs tcp_name_of_server:share_name /mnt -o user=myname,pass=mypasswd
|
mount -t cifs tcp_name_of_server:share_name /mnt -o user=myname,pass=mypasswd
|
||||||
|
|
||||||
When using the mount helper mount.cifs, passwords may be specified via alternate
|
When using the mount helper mount.cifs, passwords may be specified via alternate
|
||||||
mechanisms, instead of specifying it after -o using the normal "pass=" syntax
|
mechanisms, instead of specifying it after -o using the normal ``pass=`` syntax
|
||||||
on the command line:
|
on the command line:
|
||||||
1) By including it in a credential file. Specify credentials=filename as one
|
1) By including it in a credential file. Specify credentials=filename as one
|
||||||
of the mount options. Credential files contain two lines
|
of the mount options. Credential files contain two lines::
|
||||||
|
|
||||||
username=someuser
|
username=someuser
|
||||||
password=your_password
|
password=your_password
|
||||||
|
|
||||||
2) By specifying the password in the PASSWD environment variable (similarly
|
2) By specifying the password in the PASSWD environment variable (similarly
|
||||||
the user name can be taken from the USER environment variable).
|
the user name can be taken from the USER environment variable).
|
||||||
3) By specifying the password in a file by name via PASSWD_FILE
|
3) By specifying the password in a file by name via PASSWD_FILE
|
||||||
@ -229,6 +252,7 @@ If no password is provided, mount.cifs will prompt for password entry
|
|||||||
|
|
||||||
Restrictions
|
Restrictions
|
||||||
============
|
============
|
||||||
|
|
||||||
Servers must support either "pure-TCP" (port 445 TCP/IP CIFS connections) or RFC
|
Servers must support either "pure-TCP" (port 445 TCP/IP CIFS connections) or RFC
|
||||||
1001/1002 support for "Netbios-Over-TCP/IP." This is not likely to be a
|
1001/1002 support for "Netbios-Over-TCP/IP." This is not likely to be a
|
||||||
problem as most servers support this.
|
problem as most servers support this.
|
||||||
@ -243,25 +267,32 @@ filenames (ie those which contain valid Linux characters, which normally
|
|||||||
would be forbidden for Windows/CIFS semantics) as long as the server is
|
would be forbidden for Windows/CIFS semantics) as long as the server is
|
||||||
configured for Unix Extensions (and the client has not disabled
|
configured for Unix Extensions (and the client has not disabled
|
||||||
/proc/fs/cifs/LinuxExtensionsEnabled). In addition the mount option
|
/proc/fs/cifs/LinuxExtensionsEnabled). In addition the mount option
|
||||||
"mapposix" can be used on CIFS (vers=1.0) to force the mapping of
|
``mapposix`` can be used on CIFS (vers=1.0) to force the mapping of
|
||||||
illegal Windows/NTFS/SMB characters to a remap range (this mount parm
|
illegal Windows/NTFS/SMB characters to a remap range (this mount parm
|
||||||
is the default for SMB3). This remap ("mapposix") range is also
|
is the default for SMB3). This remap (``mapposix``) range is also
|
||||||
compatible with Mac (and "Services for Mac" on some older Windows).
|
compatible with Mac (and "Services for Mac" on some older Windows).
|
||||||
|
|
||||||
CIFS VFS Mount Options
|
CIFS VFS Mount Options
|
||||||
======================
|
======================
|
||||||
A partial list of the supported mount options follows:
|
A partial list of the supported mount options follows:
|
||||||
username The user name to use when trying to establish
|
|
||||||
|
username
|
||||||
|
The user name to use when trying to establish
|
||||||
the CIFS session.
|
the CIFS session.
|
||||||
password The user password. If the mount helper is
|
password
|
||||||
|
The user password. If the mount helper is
|
||||||
installed, the user will be prompted for password
|
installed, the user will be prompted for password
|
||||||
if not supplied.
|
if not supplied.
|
||||||
ip The ip address of the target server
|
ip
|
||||||
unc The target server Universal Network Name (export) to
|
The ip address of the target server
|
||||||
|
unc
|
||||||
|
The target server Universal Network Name (export) to
|
||||||
mount.
|
mount.
|
||||||
domain Set the SMB/CIFS workgroup name prepended to the
|
domain
|
||||||
|
Set the SMB/CIFS workgroup name prepended to the
|
||||||
username during CIFS session establishment
|
username during CIFS session establishment
|
||||||
forceuid Set the default uid for inodes to the uid
|
forceuid
|
||||||
|
Set the default uid for inodes to the uid
|
||||||
passed in on mount. For mounts to servers
|
passed in on mount. For mounts to servers
|
||||||
which do support the CIFS Unix extensions, such as a
|
which do support the CIFS Unix extensions, such as a
|
||||||
properly configured Samba server, the server provides
|
properly configured Samba server, the server provides
|
||||||
@ -276,7 +307,7 @@ A partial list of the supported mount options follows:
|
|||||||
extensions, the default uid (and gid) returned on lookup
|
extensions, the default uid (and gid) returned on lookup
|
||||||
of existing files will be the uid (gid) of the person
|
of existing files will be the uid (gid) of the person
|
||||||
who executed the mount (root, except when mount.cifs
|
who executed the mount (root, except when mount.cifs
|
||||||
is configured setuid for user mounts) unless the "uid="
|
is configured setuid for user mounts) unless the ``uid=``
|
||||||
(gid) mount option is specified. Also note that permission
|
(gid) mount option is specified. Also note that permission
|
||||||
checks (authorization checks) on accesses to a file occur
|
checks (authorization checks) on accesses to a file occur
|
||||||
at the server, but there are cases in which an administrator
|
at the server, but there are cases in which an administrator
|
||||||
@ -286,21 +317,28 @@ A partial list of the supported mount options follows:
|
|||||||
client, and a crude form of client side permission checking
|
client, and a crude form of client side permission checking
|
||||||
can be enabled by specifying file_mode and dir_mode on
|
can be enabled by specifying file_mode and dir_mode on
|
||||||
the client. (default)
|
the client. (default)
|
||||||
forcegid (similar to above but for the groupid instead of uid) (default)
|
forcegid
|
||||||
noforceuid Fill in file owner information (uid) by requesting it from
|
(similar to above but for the groupid instead of uid) (default)
|
||||||
|
noforceuid
|
||||||
|
Fill in file owner information (uid) by requesting it from
|
||||||
the server if possible. With this option, the value given in
|
the server if possible. With this option, the value given in
|
||||||
the uid= option (on mount) will only be used if the server
|
the uid= option (on mount) will only be used if the server
|
||||||
can not support returning uids on inodes.
|
can not support returning uids on inodes.
|
||||||
noforcegid (similar to above but for the group owner, gid, instead of uid)
|
noforcegid
|
||||||
uid Set the default uid for inodes, and indicate to the
|
(similar to above but for the group owner, gid, instead of uid)
|
||||||
|
uid
|
||||||
|
Set the default uid for inodes, and indicate to the
|
||||||
cifs kernel driver which local user mounted. If the server
|
cifs kernel driver which local user mounted. If the server
|
||||||
supports the unix extensions the default uid is
|
supports the unix extensions the default uid is
|
||||||
not used to fill in the owner fields of inodes (files)
|
not used to fill in the owner fields of inodes (files)
|
||||||
unless the "forceuid" parameter is specified.
|
unless the ``forceuid`` parameter is specified.
|
||||||
gid Set the default gid for inodes (similar to above).
|
gid
|
||||||
file_mode If CIFS Unix extensions are not supported by the server
|
Set the default gid for inodes (similar to above).
|
||||||
|
file_mode
|
||||||
|
If CIFS Unix extensions are not supported by the server
|
||||||
this overrides the default mode for file inodes.
|
this overrides the default mode for file inodes.
|
||||||
fsc Enable local disk caching using FS-Cache (off by default). This
|
fsc
|
||||||
|
Enable local disk caching using FS-Cache (off by default). This
|
||||||
option could be useful to improve performance on a slow link,
|
option could be useful to improve performance on a slow link,
|
||||||
heavily loaded server and/or network where reading from the
|
heavily loaded server and/or network where reading from the
|
||||||
disk is faster than reading from the server (over the network).
|
disk is faster than reading from the server (over the network).
|
||||||
@ -310,18 +348,22 @@ A partial list of the supported mount options follows:
|
|||||||
type workloads. So, you need to consider carefully your
|
type workloads. So, you need to consider carefully your
|
||||||
workload/scenario before using this option. Currently, local
|
workload/scenario before using this option. Currently, local
|
||||||
disk caching is functional for CIFS files opened as read-only.
|
disk caching is functional for CIFS files opened as read-only.
|
||||||
dir_mode If CIFS Unix extensions are not supported by the server
|
dir_mode
|
||||||
|
If CIFS Unix extensions are not supported by the server
|
||||||
this overrides the default mode for directory inodes.
|
this overrides the default mode for directory inodes.
|
||||||
port attempt to contact the server on this tcp port, before
|
port
|
||||||
|
attempt to contact the server on this tcp port, before
|
||||||
trying the usual ports (port 445, then 139).
|
trying the usual ports (port 445, then 139).
|
||||||
iocharset Codepage used to convert local path names to and from
|
iocharset
|
||||||
|
Codepage used to convert local path names to and from
|
||||||
Unicode. Unicode is used by default for network path
|
Unicode. Unicode is used by default for network path
|
||||||
names if the server supports it. If iocharset is
|
names if the server supports it. If iocharset is
|
||||||
not specified then the nls_default specified
|
not specified then the nls_default specified
|
||||||
during the local client kernel build will be used.
|
during the local client kernel build will be used.
|
||||||
If server does not support Unicode, this parameter is
|
If server does not support Unicode, this parameter is
|
||||||
unused.
|
unused.
|
||||||
rsize default read size (usually 16K). The client currently
|
rsize
|
||||||
|
default read size (usually 16K). The client currently
|
||||||
can not use rsize larger than CIFSMaxBufSize. CIFSMaxBufSize
|
can not use rsize larger than CIFSMaxBufSize. CIFSMaxBufSize
|
||||||
defaults to 16K and may be changed (from 8K to the maximum
|
defaults to 16K and may be changed (from 8K to the maximum
|
||||||
kmalloc size allowed by your kernel) at module install time
|
kmalloc size allowed by your kernel) at module install time
|
||||||
@ -333,10 +375,12 @@ A partial list of the supported mount options follows:
|
|||||||
newer servers (e.g. Samba 3.0.26 or later) do. rsize can be
|
newer servers (e.g. Samba 3.0.26 or later) do. rsize can be
|
||||||
set from a minimum of 2048 to a maximum of 130048 (127K or
|
set from a minimum of 2048 to a maximum of 130048 (127K or
|
||||||
CIFSMaxBufSize, whichever is smaller)
|
CIFSMaxBufSize, whichever is smaller)
|
||||||
wsize default write size (default 57344)
|
wsize
|
||||||
|
default write size (default 57344)
|
||||||
maximum wsize currently allowed by CIFS is 57344 (fourteen
|
maximum wsize currently allowed by CIFS is 57344 (fourteen
|
||||||
4096 byte pages)
|
4096 byte pages)
|
||||||
actimeo=n attribute cache timeout in seconds (default 1 second).
|
actimeo=n
|
||||||
|
attribute cache timeout in seconds (default 1 second).
|
||||||
After this timeout, the cifs client requests fresh attribute
|
After this timeout, the cifs client requests fresh attribute
|
||||||
information from the server. This option allows to tune the
|
information from the server. This option allows to tune the
|
||||||
attribute cache timeout to suit the workload needs. Shorter
|
attribute cache timeout to suit the workload needs. Shorter
|
||||||
@ -345,49 +389,67 @@ A partial list of the supported mount options follows:
|
|||||||
of calls to the server at the expense of less stricter cache
|
of calls to the server at the expense of less stricter cache
|
||||||
coherency checks (i.e. incorrect attribute cache for a short
|
coherency checks (i.e. incorrect attribute cache for a short
|
||||||
period of time).
|
period of time).
|
||||||
rw mount the network share read-write (note that the
|
rw
|
||||||
|
mount the network share read-write (note that the
|
||||||
server may still consider the share read-only)
|
server may still consider the share read-only)
|
||||||
ro mount network share read-only
|
ro
|
||||||
version used to distinguish different versions of the
|
mount network share read-only
|
||||||
|
version
|
||||||
|
used to distinguish different versions of the
|
||||||
mount helper utility (not typically needed)
|
mount helper utility (not typically needed)
|
||||||
sep if first mount option (after the -o), overrides
|
sep
|
||||||
|
if first mount option (after the -o), overrides
|
||||||
the comma as the separator between the mount
|
the comma as the separator between the mount
|
||||||
parms. e.g.
|
parms. e.g.::
|
||||||
|
|
||||||
-o user=myname,password=mypassword,domain=mydom
|
-o user=myname,password=mypassword,domain=mydom
|
||||||
could be passed instead with period as the separator by
|
|
||||||
|
could be passed instead with period as the separator by::
|
||||||
|
|
||||||
-o sep=.user=myname.password=mypassword.domain=mydom
|
-o sep=.user=myname.password=mypassword.domain=mydom
|
||||||
|
|
||||||
this might be useful when comma is contained within username
|
this might be useful when comma is contained within username
|
||||||
or password or domain. This option is less important
|
or password or domain. This option is less important
|
||||||
when the cifs mount helper cifs.mount (version 1.1 or later)
|
when the cifs mount helper cifs.mount (version 1.1 or later)
|
||||||
is used.
|
is used.
|
||||||
nosuid Do not allow remote executables with the suid bit
|
nosuid
|
||||||
|
Do not allow remote executables with the suid bit
|
||||||
program to be executed. This is only meaningful for mounts
|
program to be executed. This is only meaningful for mounts
|
||||||
to servers such as Samba which support the CIFS Unix Extensions.
|
to servers such as Samba which support the CIFS Unix Extensions.
|
||||||
If you do not trust the servers in your network (your mount
|
If you do not trust the servers in your network (your mount
|
||||||
targets) it is recommended that you specify this option for
|
targets) it is recommended that you specify this option for
|
||||||
greater security.
|
greater security.
|
||||||
exec Permit execution of binaries on the mount.
|
exec
|
||||||
noexec Do not permit execution of binaries on the mount.
|
Permit execution of binaries on the mount.
|
||||||
dev Recognize block devices on the remote mount.
|
noexec
|
||||||
nodev Do not recognize devices on the remote mount.
|
Do not permit execution of binaries on the mount.
|
||||||
suid Allow remote files on this mountpoint with suid enabled to
|
dev
|
||||||
|
Recognize block devices on the remote mount.
|
||||||
|
nodev
|
||||||
|
Do not recognize devices on the remote mount.
|
||||||
|
suid
|
||||||
|
Allow remote files on this mountpoint with suid enabled to
|
||||||
be executed (default for mounts when executed as root,
|
be executed (default for mounts when executed as root,
|
||||||
nosuid is default for user mounts).
|
nosuid is default for user mounts).
|
||||||
credentials Although ignored by the cifs kernel component, it is used by
|
credentials
|
||||||
|
Although ignored by the cifs kernel component, it is used by
|
||||||
the mount helper, mount.cifs. When mount.cifs is installed it
|
the mount helper, mount.cifs. When mount.cifs is installed it
|
||||||
opens and reads the credential file specified in order
|
opens and reads the credential file specified in order
|
||||||
to obtain the userid and password arguments which are passed to
|
to obtain the userid and password arguments which are passed to
|
||||||
the cifs vfs.
|
the cifs vfs.
|
||||||
guest Although ignored by the kernel component, the mount.cifs
|
guest
|
||||||
|
Although ignored by the kernel component, the mount.cifs
|
||||||
mount helper will not prompt the user for a password
|
mount helper will not prompt the user for a password
|
||||||
if guest is specified on the mount options. If no
|
if guest is specified on the mount options. If no
|
||||||
password is specified a null password will be used.
|
password is specified a null password will be used.
|
||||||
perm Client does permission checks (vfs_permission check of uid
|
perm
|
||||||
|
Client does permission checks (vfs_permission check of uid
|
||||||
and gid of the file against the mode and desired operation),
|
and gid of the file against the mode and desired operation),
|
||||||
Note that this is in addition to the normal ACL check on the
|
Note that this is in addition to the normal ACL check on the
|
||||||
target machine done by the server software.
|
target machine done by the server software.
|
||||||
Client permission checking is enabled by default.
|
Client permission checking is enabled by default.
|
||||||
noperm Client does not do permission checks. This can expose
|
noperm
|
||||||
|
Client does not do permission checks. This can expose
|
||||||
files on this mount to access by other users on the local
|
files on this mount to access by other users on the local
|
||||||
client system. It is typically only needed when the server
|
client system. It is typically only needed when the server
|
||||||
supports the CIFS Unix Extensions but the UIDs/GIDs on the
|
supports the CIFS Unix Extensions but the UIDs/GIDs on the
|
||||||
@ -399,7 +461,8 @@ A partial list of the supported mount options follows:
|
|||||||
Note that this does not affect the normal ACL check on the
|
Note that this does not affect the normal ACL check on the
|
||||||
target machine done by the server software (of the server
|
target machine done by the server software (of the server
|
||||||
ACL against the user name provided at mount time).
|
ACL against the user name provided at mount time).
|
||||||
serverino Use server's inode numbers instead of generating automatically
|
serverino
|
||||||
|
Use server's inode numbers instead of generating automatically
|
||||||
incrementing inode numbers on the client. Although this will
|
incrementing inode numbers on the client. Although this will
|
||||||
make it easier to spot hardlinked files (as they will have
|
make it easier to spot hardlinked files (as they will have
|
||||||
the same inode numbers) and inode numbers may be persistent,
|
the same inode numbers) and inode numbers may be persistent,
|
||||||
@ -414,12 +477,14 @@ A partial list of the supported mount options follows:
|
|||||||
under nfsd requires this mount option on the cifs mount.
|
under nfsd requires this mount option on the cifs mount.
|
||||||
This is now the default if server supports the
|
This is now the default if server supports the
|
||||||
required network operation.
|
required network operation.
|
||||||
noserverino Client generates inode numbers (rather than using the actual one
|
noserverino
|
||||||
|
Client generates inode numbers (rather than using the actual one
|
||||||
from the server). These inode numbers will vary after
|
from the server). These inode numbers will vary after
|
||||||
unmount or reboot which can confuse some applications,
|
unmount or reboot which can confuse some applications,
|
||||||
but not all server filesystems support unique inode
|
but not all server filesystems support unique inode
|
||||||
numbers.
|
numbers.
|
||||||
setuids If the CIFS Unix extensions are negotiated with the server
|
setuids
|
||||||
|
If the CIFS Unix extensions are negotiated with the server
|
||||||
the client will attempt to set the effective uid and gid of
|
the client will attempt to set the effective uid and gid of
|
||||||
the local process on newly created files, directories, and
|
the local process on newly created files, directories, and
|
||||||
devices (create, mkdir, mknod). If the CIFS Unix Extensions
|
devices (create, mkdir, mknod). If the CIFS Unix Extensions
|
||||||
@ -428,7 +493,8 @@ A partial list of the supported mount options follows:
|
|||||||
the mount, cache the new file's uid and gid locally which means
|
the mount, cache the new file's uid and gid locally which means
|
||||||
that the uid for the file can change when the inode is
|
that the uid for the file can change when the inode is
|
||||||
reloaded (or the user remounts the share).
|
reloaded (or the user remounts the share).
|
||||||
nosetuids The client will not attempt to set the uid and gid on
|
nosetuids
|
||||||
|
The client will not attempt to set the uid and gid on
|
||||||
on newly created files, directories, and devices (create,
|
on newly created files, directories, and devices (create,
|
||||||
mkdir, mknod) which will result in the server setting the
|
mkdir, mknod) which will result in the server setting the
|
||||||
uid and gid to the default (usually the server uid of the
|
uid and gid to the default (usually the server uid of the
|
||||||
@ -437,10 +503,12 @@ A partial list of the supported mount options follows:
|
|||||||
Unix Extensions are not negotiated then the uid and gid for
|
Unix Extensions are not negotiated then the uid and gid for
|
||||||
new files will appear to be the uid (gid) of the mounter or the
|
new files will appear to be the uid (gid) of the mounter or the
|
||||||
uid (gid) parameter specified on the mount.
|
uid (gid) parameter specified on the mount.
|
||||||
netbiosname When mounting to servers via port 139, specifies the RFC1001
|
netbiosname
|
||||||
|
When mounting to servers via port 139, specifies the RFC1001
|
||||||
source name to use to represent the client netbios machine
|
source name to use to represent the client netbios machine
|
||||||
name when doing the RFC1001 netbios session initialize.
|
name when doing the RFC1001 netbios session initialize.
|
||||||
direct Do not do inode data caching on files opened on this mount.
|
direct
|
||||||
|
Do not do inode data caching on files opened on this mount.
|
||||||
This precludes mmapping files on this mount. In some cases
|
This precludes mmapping files on this mount. In some cases
|
||||||
with fast networks and little or no caching benefits on the
|
with fast networks and little or no caching benefits on the
|
||||||
client (e.g. when the application is doing large sequential
|
client (e.g. when the application is doing large sequential
|
||||||
@ -451,24 +519,33 @@ A partial list of the supported mount options follows:
|
|||||||
if oplock (caching token) is granted and held. Note that
|
if oplock (caching token) is granted and held. Note that
|
||||||
direct allows write operations larger than page size
|
direct allows write operations larger than page size
|
||||||
to be sent to the server.
|
to be sent to the server.
|
||||||
strictcache Use for switching on strict cache mode. In this mode the
|
strictcache
|
||||||
|
Use for switching on strict cache mode. In this mode the
|
||||||
client read from the cache all the time it has Oplock Level II,
|
client read from the cache all the time it has Oplock Level II,
|
||||||
otherwise - read from the server. All written data are stored
|
otherwise - read from the server. All written data are stored
|
||||||
in the cache, but if the client doesn't have Exclusive Oplock,
|
in the cache, but if the client doesn't have Exclusive Oplock,
|
||||||
it writes the data to the server.
|
it writes the data to the server.
|
||||||
rwpidforward Forward pid of a process who opened a file to any read or write
|
rwpidforward
|
||||||
|
Forward pid of a process who opened a file to any read or write
|
||||||
operation on that file. This prevent applications like WINE
|
operation on that file. This prevent applications like WINE
|
||||||
from failing on read and write if we use mandatory brlock style.
|
from failing on read and write if we use mandatory brlock style.
|
||||||
acl Allow setfacl and getfacl to manage posix ACLs if server
|
acl
|
||||||
|
Allow setfacl and getfacl to manage posix ACLs if server
|
||||||
supports them. (default)
|
supports them. (default)
|
||||||
noacl Do not allow setfacl and getfacl calls on this mount
|
noacl
|
||||||
user_xattr Allow getting and setting user xattrs (those attributes whose
|
Do not allow setfacl and getfacl calls on this mount
|
||||||
name begins with "user." or "os2.") as OS/2 EAs (extended
|
user_xattr
|
||||||
|
Allow getting and setting user xattrs (those attributes whose
|
||||||
|
name begins with ``user.`` or ``os2.``) as OS/2 EAs (extended
|
||||||
attributes) to the server. This allows support of the
|
attributes) to the server. This allows support of the
|
||||||
setfattr and getfattr utilities. (default)
|
setfattr and getfattr utilities. (default)
|
||||||
nouser_xattr Do not allow getfattr/setfattr to get/set/list xattrs
|
nouser_xattr
|
||||||
mapchars Translate six of the seven reserved characters (not backslash)
|
Do not allow getfattr/setfattr to get/set/list xattrs
|
||||||
|
mapchars
|
||||||
|
Translate six of the seven reserved characters (not backslash)::
|
||||||
|
|
||||||
*?<>|:
|
*?<>|:
|
||||||
|
|
||||||
to the remap range (above 0xF000), which also
|
to the remap range (above 0xF000), which also
|
||||||
allows the CIFS client to recognize files created with
|
allows the CIFS client to recognize files created with
|
||||||
such characters by Windows's POSIX emulation. This can
|
such characters by Windows's POSIX emulation. This can
|
||||||
@ -477,39 +554,47 @@ A partial list of the supported mount options follows:
|
|||||||
whose names contain any of these seven characters).
|
whose names contain any of these seven characters).
|
||||||
This has no effect if the server does not support
|
This has no effect if the server does not support
|
||||||
Unicode on the wire.
|
Unicode on the wire.
|
||||||
nomapchars Do not translate any of these seven characters (default).
|
nomapchars
|
||||||
nocase Request case insensitive path name matching (case
|
Do not translate any of these seven characters (default).
|
||||||
|
nocase
|
||||||
|
Request case insensitive path name matching (case
|
||||||
sensitive is the default if the server supports it).
|
sensitive is the default if the server supports it).
|
||||||
(mount option "ignorecase" is identical to "nocase")
|
(mount option ``ignorecase`` is identical to ``nocase``)
|
||||||
posixpaths If CIFS Unix extensions are supported, attempt to
|
posixpaths
|
||||||
|
If CIFS Unix extensions are supported, attempt to
|
||||||
negotiate posix path name support which allows certain
|
negotiate posix path name support which allows certain
|
||||||
characters forbidden in typical CIFS filenames, without
|
characters forbidden in typical CIFS filenames, without
|
||||||
requiring remapping. (default)
|
requiring remapping. (default)
|
||||||
noposixpaths If CIFS Unix extensions are supported, do not request
|
noposixpaths
|
||||||
|
If CIFS Unix extensions are supported, do not request
|
||||||
posix path name support (this may cause servers to
|
posix path name support (this may cause servers to
|
||||||
reject creatingfile with certain reserved characters).
|
reject creatingfile with certain reserved characters).
|
||||||
nounix Disable the CIFS Unix Extensions for this mount (tree
|
nounix
|
||||||
|
Disable the CIFS Unix Extensions for this mount (tree
|
||||||
connection). This is rarely needed, but it may be useful
|
connection). This is rarely needed, but it may be useful
|
||||||
in order to turn off multiple settings all at once (ie
|
in order to turn off multiple settings all at once (ie
|
||||||
posix acls, posix locks, posix paths, symlink support
|
posix acls, posix locks, posix paths, symlink support
|
||||||
and retrieving uids/gids/mode from the server) or to
|
and retrieving uids/gids/mode from the server) or to
|
||||||
work around a bug in server which implement the Unix
|
work around a bug in server which implement the Unix
|
||||||
Extensions.
|
Extensions.
|
||||||
nobrl Do not send byte range lock requests to the server.
|
nobrl
|
||||||
|
Do not send byte range lock requests to the server.
|
||||||
This is necessary for certain applications that break
|
This is necessary for certain applications that break
|
||||||
with cifs style mandatory byte range locks (and most
|
with cifs style mandatory byte range locks (and most
|
||||||
cifs servers do not yet support requesting advisory
|
cifs servers do not yet support requesting advisory
|
||||||
byte range locks).
|
byte range locks).
|
||||||
forcemandatorylock Even if the server supports posix (advisory) byte range
|
forcemandatorylock
|
||||||
|
Even if the server supports posix (advisory) byte range
|
||||||
locking, send only mandatory lock requests. For some
|
locking, send only mandatory lock requests. For some
|
||||||
(presumably rare) applications, originally coded for
|
(presumably rare) applications, originally coded for
|
||||||
DOS/Windows, which require Windows style mandatory byte range
|
DOS/Windows, which require Windows style mandatory byte range
|
||||||
locking, they may be able to take advantage of this option,
|
locking, they may be able to take advantage of this option,
|
||||||
forcing the cifs client to only send mandatory locks
|
forcing the cifs client to only send mandatory locks
|
||||||
even if the cifs server would support posix advisory locks.
|
even if the cifs server would support posix advisory locks.
|
||||||
"forcemand" is accepted as a shorter form of this mount
|
``forcemand`` is accepted as a shorter form of this mount
|
||||||
option.
|
option.
|
||||||
nostrictsync If this mount option is set, when an application does an
|
nostrictsync
|
||||||
|
If this mount option is set, when an application does an
|
||||||
fsync call then the cifs client does not send an SMB Flush
|
fsync call then the cifs client does not send an SMB Flush
|
||||||
to the server (to force the server to write all dirty data
|
to the server (to force the server to write all dirty data
|
||||||
for this file immediately to disk), although cifs still sends
|
for this file immediately to disk), although cifs still sends
|
||||||
@ -522,41 +607,50 @@ A partial list of the supported mount options follows:
|
|||||||
crash. If this mount option is not set, by default cifs will
|
crash. If this mount option is not set, by default cifs will
|
||||||
send an SMB flush request (and wait for a response) on every
|
send an SMB flush request (and wait for a response) on every
|
||||||
fsync call.
|
fsync call.
|
||||||
nodfs Disable DFS (global name space support) even if the
|
nodfs
|
||||||
|
Disable DFS (global name space support) even if the
|
||||||
server claims to support it. This can help work around
|
server claims to support it. This can help work around
|
||||||
a problem with parsing of DFS paths with Samba server
|
a problem with parsing of DFS paths with Samba server
|
||||||
versions 3.0.24 and 3.0.25.
|
versions 3.0.24 and 3.0.25.
|
||||||
remount remount the share (often used to change from ro to rw mounts
|
remount
|
||||||
|
remount the share (often used to change from ro to rw mounts
|
||||||
or vice versa)
|
or vice versa)
|
||||||
cifsacl Report mode bits (e.g. on stat) based on the Windows ACL for
|
cifsacl
|
||||||
|
Report mode bits (e.g. on stat) based on the Windows ACL for
|
||||||
the file. (EXPERIMENTAL)
|
the file. (EXPERIMENTAL)
|
||||||
servern Specify the server 's netbios name (RFC1001 name) to use
|
servern
|
||||||
|
Specify the server 's netbios name (RFC1001 name) to use
|
||||||
when attempting to setup a session to the server.
|
when attempting to setup a session to the server.
|
||||||
This is needed for mounting to some older servers (such
|
This is needed for mounting to some older servers (such
|
||||||
as OS/2 or Windows 98 and Windows ME) since they do not
|
as OS/2 or Windows 98 and Windows ME) since they do not
|
||||||
support a default server name. A server name can be up
|
support a default server name. A server name can be up
|
||||||
to 15 characters long and is usually uppercased.
|
to 15 characters long and is usually uppercased.
|
||||||
sfu When the CIFS Unix Extensions are not negotiated, attempt to
|
sfu
|
||||||
|
When the CIFS Unix Extensions are not negotiated, attempt to
|
||||||
create device files and fifos in a format compatible with
|
create device files and fifos in a format compatible with
|
||||||
Services for Unix (SFU). In addition retrieve bits 10-12
|
Services for Unix (SFU). In addition retrieve bits 10-12
|
||||||
of the mode via the SETFILEBITS extended attribute (as
|
of the mode via the SETFILEBITS extended attribute (as
|
||||||
SFU does). In the future the bottom 9 bits of the
|
SFU does). In the future the bottom 9 bits of the
|
||||||
mode also will be emulated using queries of the security
|
mode also will be emulated using queries of the security
|
||||||
descriptor (ACL).
|
descriptor (ACL).
|
||||||
mfsymlinks Enable support for Minshall+French symlinks
|
mfsymlinks
|
||||||
|
Enable support for Minshall+French symlinks
|
||||||
(see http://wiki.samba.org/index.php/UNIX_Extensions#Minshall.2BFrench_symlinks)
|
(see http://wiki.samba.org/index.php/UNIX_Extensions#Minshall.2BFrench_symlinks)
|
||||||
This option is ignored when specified together with the
|
This option is ignored when specified together with the
|
||||||
'sfu' option. Minshall+French symlinks are used even if
|
'sfu' option. Minshall+French symlinks are used even if
|
||||||
the server supports the CIFS Unix Extensions.
|
the server supports the CIFS Unix Extensions.
|
||||||
sign Must use packet signing (helps avoid unwanted data modification
|
sign
|
||||||
|
Must use packet signing (helps avoid unwanted data modification
|
||||||
by intermediate systems in the route). Note that signing
|
by intermediate systems in the route). Note that signing
|
||||||
does not work with lanman or plaintext authentication.
|
does not work with lanman or plaintext authentication.
|
||||||
seal Must seal (encrypt) all data on this mounted share before
|
seal
|
||||||
|
Must seal (encrypt) all data on this mounted share before
|
||||||
sending on the network. Requires support for Unix Extensions.
|
sending on the network. Requires support for Unix Extensions.
|
||||||
Note that this differs from the sign mount option in that it
|
Note that this differs from the sign mount option in that it
|
||||||
causes encryption of data sent over this mounted share but other
|
causes encryption of data sent over this mounted share but other
|
||||||
shares mounted to the same server are unaffected.
|
shares mounted to the same server are unaffected.
|
||||||
locallease This option is rarely needed. Fcntl F_SETLEASE is
|
locallease
|
||||||
|
This option is rarely needed. Fcntl F_SETLEASE is
|
||||||
used by some applications such as Samba and NFSv4 server to
|
used by some applications such as Samba and NFSv4 server to
|
||||||
check to see whether a file is cacheable. CIFS has no way
|
check to see whether a file is cacheable. CIFS has no way
|
||||||
to explicitly request a lease, but can check whether a file
|
to explicitly request a lease, but can check whether a file
|
||||||
@ -569,50 +663,72 @@ A partial list of the supported mount options follows:
|
|||||||
will allow the cifs client to check for leases (only) locally
|
will allow the cifs client to check for leases (only) locally
|
||||||
for files which are not oplocked instead of denying leases
|
for files which are not oplocked instead of denying leases
|
||||||
in that case. (EXPERIMENTAL)
|
in that case. (EXPERIMENTAL)
|
||||||
sec Security mode. Allowed values are:
|
sec
|
||||||
none attempt to connection as a null user (no name)
|
Security mode. Allowed values are:
|
||||||
krb5 Use Kerberos version 5 authentication
|
|
||||||
krb5i Use Kerberos authentication and packet signing
|
none
|
||||||
ntlm Use NTLM password hashing (default)
|
attempt to connection as a null user (no name)
|
||||||
ntlmi Use NTLM password hashing with signing (if
|
krb5
|
||||||
|
Use Kerberos version 5 authentication
|
||||||
|
krb5i
|
||||||
|
Use Kerberos authentication and packet signing
|
||||||
|
ntlm
|
||||||
|
Use NTLM password hashing (default)
|
||||||
|
ntlmi
|
||||||
|
Use NTLM password hashing with signing (if
|
||||||
/proc/fs/cifs/PacketSigningEnabled on or if
|
/proc/fs/cifs/PacketSigningEnabled on or if
|
||||||
server requires signing also can be the default)
|
server requires signing also can be the default)
|
||||||
ntlmv2 Use NTLMv2 password hashing
|
ntlmv2
|
||||||
ntlmv2i Use NTLMv2 password hashing with packet signing
|
Use NTLMv2 password hashing
|
||||||
lanman (if configured in kernel config) use older
|
ntlmv2i
|
||||||
|
Use NTLMv2 password hashing with packet signing
|
||||||
|
lanman
|
||||||
|
(if configured in kernel config) use older
|
||||||
lanman hash
|
lanman hash
|
||||||
hard Retry file operations if server is not responding
|
hard
|
||||||
soft Limit retries to unresponsive servers (usually only
|
Retry file operations if server is not responding
|
||||||
|
soft
|
||||||
|
Limit retries to unresponsive servers (usually only
|
||||||
one retry) before returning an error. (default)
|
one retry) before returning an error. (default)
|
||||||
|
|
||||||
The mount.cifs mount helper also accepts a few mount options before -o
|
The mount.cifs mount helper also accepts a few mount options before -o
|
||||||
including:
|
including:
|
||||||
|
|
||||||
|
=============== ===============================================================
|
||||||
-S take password from stdin (equivalent to setting the environment
|
-S take password from stdin (equivalent to setting the environment
|
||||||
variable "PASSWD_FD=0"
|
variable ``PASSWD_FD=0``
|
||||||
-V print mount.cifs version
|
-V print mount.cifs version
|
||||||
-? display simple usage information
|
-? display simple usage information
|
||||||
|
=============== ===============================================================
|
||||||
|
|
||||||
With most 2.6 kernel versions of modutils, the version of the cifs kernel
|
With most 2.6 kernel versions of modutils, the version of the cifs kernel
|
||||||
module can be displayed via modinfo.
|
module can be displayed via modinfo.
|
||||||
|
|
||||||
Misc /proc/fs/cifs Flags and Debug Info
|
Misc /proc/fs/cifs Flags and Debug Info
|
||||||
=======================================
|
=======================================
|
||||||
|
|
||||||
Informational pseudo-files:
|
Informational pseudo-files:
|
||||||
|
|
||||||
|
======================= =======================================================
|
||||||
DebugData Displays information about active CIFS sessions and
|
DebugData Displays information about active CIFS sessions and
|
||||||
shares, features enabled as well as the cifs.ko
|
shares, features enabled as well as the cifs.ko
|
||||||
version.
|
version.
|
||||||
Stats Lists summary resource usage information as well as per
|
Stats Lists summary resource usage information as well as per
|
||||||
share statistics.
|
share statistics.
|
||||||
|
======================= =======================================================
|
||||||
|
|
||||||
Configuration pseudo-files:
|
Configuration pseudo-files:
|
||||||
|
|
||||||
|
======================= =======================================================
|
||||||
SecurityFlags Flags which control security negotiation and
|
SecurityFlags Flags which control security negotiation and
|
||||||
also packet signing. Authentication (may/must)
|
also packet signing. Authentication (may/must)
|
||||||
flags (e.g. for NTLM and/or NTLMv2) may be combined with
|
flags (e.g. for NTLM and/or NTLMv2) may be combined with
|
||||||
the signing flags. Specifying two different password
|
the signing flags. Specifying two different password
|
||||||
hashing mechanisms (as "must use") on the other hand
|
hashing mechanisms (as "must use") on the other hand
|
||||||
does not make much sense. Default flags are
|
does not make much sense. Default flags are::
|
||||||
|
|
||||||
0x07007
|
0x07007
|
||||||
|
|
||||||
(NTLM, NTLMv2 and packet signing allowed). The maximum
|
(NTLM, NTLMv2 and packet signing allowed). The maximum
|
||||||
allowable flags if you want to allow mounts to servers
|
allowable flags if you want to allow mounts to servers
|
||||||
using weaker password hashes is 0x37037 (lanman,
|
using weaker password hashes is 0x37037 (lanman,
|
||||||
@ -626,7 +742,7 @@ SecurityFlags Flags which control security negotiation and
|
|||||||
laintext passwords using the older lanman dialect
|
laintext passwords using the older lanman dialect
|
||||||
form of the session setup SMB. (e.g. for authentication
|
form of the session setup SMB. (e.g. for authentication
|
||||||
using plain text passwords, set the SecurityFlags
|
using plain text passwords, set the SecurityFlags
|
||||||
to 0x30030):
|
to 0x30030)::
|
||||||
|
|
||||||
may use packet signing 0x00001
|
may use packet signing 0x00001
|
||||||
must use packet signing 0x01001
|
must use packet signing 0x01001
|
||||||
@ -650,13 +766,18 @@ cifsFYI If set to non-zero value, additional debug information
|
|||||||
Some debugging statements are not compiled into the
|
Some debugging statements are not compiled into the
|
||||||
cifs kernel unless CONFIG_CIFS_DEBUG2 is enabled in the
|
cifs kernel unless CONFIG_CIFS_DEBUG2 is enabled in the
|
||||||
kernel configuration. cifsFYI may be set to one or
|
kernel configuration. cifsFYI may be set to one or
|
||||||
nore of the following flags (7 sets them all):
|
nore of the following flags (7 sets them all)::
|
||||||
|
|
||||||
log cifs informational messages 0x01
|
|
||||||
log return codes from cifs entry points 0x02
|
|
||||||
log slow responses (ie which take longer than 1 second)
|
|
||||||
CONFIG_CIFS_STATS2 must be enabled in .config 0x04
|
|
||||||
|
|
||||||
|
+-----------------------------------------------+------+
|
||||||
|
| log cifs informational messages | 0x01 |
|
||||||
|
+-----------------------------------------------+------+
|
||||||
|
| log return codes from cifs entry points | 0x02 |
|
||||||
|
+-----------------------------------------------+------+
|
||||||
|
| log slow responses | 0x04 |
|
||||||
|
| (ie which take longer than 1 second) | |
|
||||||
|
| | |
|
||||||
|
| CONFIG_CIFS_STATS2 must be enabled in .config | |
|
||||||
|
+-----------------------------------------------+------+
|
||||||
|
|
||||||
traceSMB If set to one, debug information is logged to the
|
traceSMB If set to one, debug information is logged to the
|
||||||
system error log with the start of smb requests
|
system error log with the start of smb requests
|
||||||
@ -674,11 +795,12 @@ LinuxExtensionsEnabled If set to one then the client will attempt to
|
|||||||
support and want to map the uid and gid fields
|
support and want to map the uid and gid fields
|
||||||
to values supplied at mount (rather than the
|
to values supplied at mount (rather than the
|
||||||
actual values, then set this to zero. (default 1)
|
actual values, then set this to zero. (default 1)
|
||||||
|
======================= =======================================================
|
||||||
|
|
||||||
These experimental features and tracing can be enabled by changing flags in
|
These experimental features and tracing can be enabled by changing flags in
|
||||||
/proc/fs/cifs (after the cifs module has been installed or built into the
|
/proc/fs/cifs (after the cifs module has been installed or built into the
|
||||||
kernel, e.g. insmod cifs). To enable a feature set it to 1 e.g. to enable
|
kernel, e.g. insmod cifs). To enable a feature set it to 1 e.g. to enable
|
||||||
tracing to the kernel message log type:
|
tracing to the kernel message log type::
|
||||||
|
|
||||||
echo 7 > /proc/fs/cifs/cifsFYI
|
echo 7 > /proc/fs/cifs/cifsFYI
|
||||||
|
|
||||||
@ -688,7 +810,7 @@ SMB return codes while 4 enables logging of requests that take longer
|
|||||||
than one second to complete (except for byte range lock requests).
|
than one second to complete (except for byte range lock requests).
|
||||||
Setting it to 4 requires CONFIG_CIFS_STATS2 to be set in kernel configuration
|
Setting it to 4 requires CONFIG_CIFS_STATS2 to be set in kernel configuration
|
||||||
(.config). Setting it to seven enables all three. Finally, tracing
|
(.config). Setting it to seven enables all three. Finally, tracing
|
||||||
the start of smb requests and responses can be enabled via:
|
the start of smb requests and responses can be enabled via::
|
||||||
|
|
||||||
echo 1 > /proc/fs/cifs/traceSMB
|
echo 1 > /proc/fs/cifs/traceSMB
|
||||||
|
|
||||||
@ -700,10 +822,10 @@ server) SMB3 (or cifs) requests grouped by request type (read, write, close etc.
|
|||||||
Also recorded is the total bytes read and bytes written to the server for
|
Also recorded is the total bytes read and bytes written to the server for
|
||||||
that share. Note that due to client caching effects this can be less than the
|
that share. Note that due to client caching effects this can be less than the
|
||||||
number of bytes read and written by the application running on the client.
|
number of bytes read and written by the application running on the client.
|
||||||
Statistics can be reset to zero by "echo 0 > /proc/fs/cifs/Stats" which may be
|
Statistics can be reset to zero by ``echo 0 > /proc/fs/cifs/Stats`` which may be
|
||||||
useful if comparing performance of two different scenarios.
|
useful if comparing performance of two different scenarios.
|
||||||
|
|
||||||
Also note that "cat /proc/fs/cifs/DebugData" will display information about
|
Also note that ``cat /proc/fs/cifs/DebugData`` will display information about
|
||||||
the active sessions and the shares that are mounted.
|
the active sessions and the shares that are mounted.
|
||||||
|
|
||||||
Enabling Kerberos (extended security) works but requires version 1.2 or later
|
Enabling Kerberos (extended security) works but requires version 1.2 or later
|
||||||
@ -725,7 +847,7 @@ space to ease network configuration and improve reliability.
|
|||||||
|
|
||||||
To use cifs Kerberos and DFS support, the Linux keyutils package should be
|
To use cifs Kerberos and DFS support, the Linux keyutils package should be
|
||||||
installed and something like the following lines should be added to the
|
installed and something like the following lines should be added to the
|
||||||
/etc/request-key.conf file:
|
/etc/request-key.conf file::
|
||||||
|
|
||||||
create cifs.spnego * * /usr/local/sbin/cifs.upcall %k
|
create cifs.spnego * * /usr/local/sbin/cifs.upcall %k
|
||||||
create dns_resolver * * /usr/local/sbin/cifs.upcall %k
|
create dns_resolver * * /usr/local/sbin/cifs.upcall %k
|
||||||
@ -733,11 +855,15 @@ create dns_resolver * * /usr/local/sbin/cifs.upcall %k
|
|||||||
CIFS kernel module parameters
|
CIFS kernel module parameters
|
||||||
=============================
|
=============================
|
||||||
These module parameters can be specified or modified either during the time of
|
These module parameters can be specified or modified either during the time of
|
||||||
module loading or during the runtime by using the interface
|
module loading or during the runtime by using the interface::
|
||||||
|
|
||||||
/proc/module/cifs/parameters/<param>
|
/proc/module/cifs/parameters/<param>
|
||||||
|
|
||||||
i.e. echo "value" > /sys/module/cifs/parameters/<param>
|
i.e.::
|
||||||
|
|
||||||
1. enable_oplocks - Enable or disable oplocks. Oplocks are enabled by default.
|
echo "value" > /sys/module/cifs/parameters/<param>
|
||||||
|
|
||||||
|
================= ==========================================================
|
||||||
|
1. enable_oplocks Enable or disable oplocks. Oplocks are enabled by default.
|
||||||
[Y/y/1]. To disable use any of [N/n/0].
|
[Y/y/1]. To disable use any of [N/n/0].
|
||||||
|
================= ==========================================================
|
@ -1647,8 +1647,17 @@
|
|||||||
0 = /dev/comedi0 First comedi device
|
0 = /dev/comedi0 First comedi device
|
||||||
1 = /dev/comedi1 Second comedi device
|
1 = /dev/comedi1 Second comedi device
|
||||||
...
|
...
|
||||||
|
47 = /dev/comedi47 48th comedi device
|
||||||
|
|
||||||
See http://stm.lbl.gov/comedi.
|
Minors 48 to 255 are reserved for comedi subdevices with
|
||||||
|
pathnames of the form "/dev/comediX_subdY", where "X" is the
|
||||||
|
minor number of the associated comedi device and "Y" is the
|
||||||
|
subdevice number. These subdevice minors are assigned
|
||||||
|
dynamically, so there is no fixed mapping from subdevice
|
||||||
|
pathnames to minor numbers.
|
||||||
|
|
||||||
|
See http://www.comedi.org/ for information about the Comedi
|
||||||
|
project.
|
||||||
|
|
||||||
98 block User-mode virtual block device
|
98 block User-mode virtual block device
|
||||||
0 = /dev/ubda First user-mode block device
|
0 = /dev/ubda First user-mode block device
|
||||||
|
@ -77,7 +77,10 @@ configure specific aspects of kernel behavior to your liking.
|
|||||||
blockdev/index
|
blockdev/index
|
||||||
ext4
|
ext4
|
||||||
binderfs
|
binderfs
|
||||||
|
cifs/index
|
||||||
xfs
|
xfs
|
||||||
|
jfs
|
||||||
|
ufs
|
||||||
pm/index
|
pm/index
|
||||||
thunderbolt
|
thunderbolt
|
||||||
LSM/index
|
LSM/index
|
||||||
@ -98,6 +101,7 @@ configure specific aspects of kernel behavior to your liking.
|
|||||||
iostats
|
iostats
|
||||||
kernel-per-CPU-kthreads
|
kernel-per-CPU-kthreads
|
||||||
laptops/index
|
laptops/index
|
||||||
|
auxdisplay/index
|
||||||
lcd-panel-cgram
|
lcd-panel-cgram
|
||||||
ldm
|
ldm
|
||||||
lockup-watchdogs
|
lockup-watchdogs
|
||||||
@ -105,6 +109,7 @@ configure specific aspects of kernel behavior to your liking.
|
|||||||
pnp
|
pnp
|
||||||
rtc
|
rtc
|
||||||
svga
|
svga
|
||||||
|
wimax/index
|
||||||
video-output
|
video-output
|
||||||
|
|
||||||
.. only:: subproject and html
|
.. only:: subproject and html
|
||||||
|
@ -1,44 +1,58 @@
|
|||||||
|
===========================================
|
||||||
IBM's Journaled File System (JFS) for Linux
|
IBM's Journaled File System (JFS) for Linux
|
||||||
|
===========================================
|
||||||
|
|
||||||
JFS Homepage: http://jfs.sourceforge.net/
|
JFS Homepage: http://jfs.sourceforge.net/
|
||||||
|
|
||||||
The following mount options are supported:
|
The following mount options are supported:
|
||||||
|
|
||||||
(*) == default
|
(*) == default
|
||||||
|
|
||||||
iocharset=name Character set to use for converting from Unicode to
|
iocharset=name
|
||||||
|
Character set to use for converting from Unicode to
|
||||||
ASCII. The default is to do no conversion. Use
|
ASCII. The default is to do no conversion. Use
|
||||||
iocharset=utf8 for UTF-8 translations. This requires
|
iocharset=utf8 for UTF-8 translations. This requires
|
||||||
CONFIG_NLS_UTF8 to be set in the kernel .config file.
|
CONFIG_NLS_UTF8 to be set in the kernel .config file.
|
||||||
iocharset=none specifies the default behavior explicitly.
|
iocharset=none specifies the default behavior explicitly.
|
||||||
|
|
||||||
resize=value Resize the volume to <value> blocks. JFS only supports
|
resize=value
|
||||||
|
Resize the volume to <value> blocks. JFS only supports
|
||||||
growing a volume, not shrinking it. This option is only
|
growing a volume, not shrinking it. This option is only
|
||||||
valid during a remount, when the volume is mounted
|
valid during a remount, when the volume is mounted
|
||||||
read-write. The resize keyword with no value will grow
|
read-write. The resize keyword with no value will grow
|
||||||
the volume to the full size of the partition.
|
the volume to the full size of the partition.
|
||||||
|
|
||||||
nointegrity Do not write to the journal. The primary use of this option
|
nointegrity
|
||||||
|
Do not write to the journal. The primary use of this option
|
||||||
is to allow for higher performance when restoring a volume
|
is to allow for higher performance when restoring a volume
|
||||||
from backup media. The integrity of the volume is not
|
from backup media. The integrity of the volume is not
|
||||||
guaranteed if the system abnormally abends.
|
guaranteed if the system abnormally abends.
|
||||||
|
|
||||||
integrity(*) Commit metadata changes to the journal. Use this option to
|
integrity(*)
|
||||||
|
Commit metadata changes to the journal. Use this option to
|
||||||
remount a volume where the nointegrity option was
|
remount a volume where the nointegrity option was
|
||||||
previously specified in order to restore normal behavior.
|
previously specified in order to restore normal behavior.
|
||||||
|
|
||||||
errors=continue Keep going on a filesystem error.
|
errors=continue
|
||||||
errors=remount-ro(*) Remount the filesystem read-only on an error.
|
Keep going on a filesystem error.
|
||||||
errors=panic Panic and halt the machine if an error occurs.
|
errors=remount-ro(*)
|
||||||
|
Remount the filesystem read-only on an error.
|
||||||
|
errors=panic
|
||||||
|
Panic and halt the machine if an error occurs.
|
||||||
|
|
||||||
uid=value Override on-disk uid with specified value
|
uid=value
|
||||||
gid=value Override on-disk gid with specified value
|
Override on-disk uid with specified value
|
||||||
umask=value Override on-disk umask with specified octal value. For
|
gid=value
|
||||||
|
Override on-disk gid with specified value
|
||||||
|
umask=value
|
||||||
|
Override on-disk umask with specified octal value. For
|
||||||
directories, the execute bit will be set if the corresponding
|
directories, the execute bit will be set if the corresponding
|
||||||
read bit is set.
|
read bit is set.
|
||||||
|
|
||||||
discard=minlen This enables/disables the use of discard/TRIM commands.
|
discard=minlen, discard/nodiscard(*)
|
||||||
discard The discard/TRIM commands are sent to the underlying
|
This enables/disables the use of discard/TRIM commands.
|
||||||
nodiscard(*) block device when blocks are freed. This is useful for SSD
|
The discard/TRIM commands are sent to the underlying
|
||||||
|
block device when blocks are freed. This is useful for SSD
|
||||||
devices and sparse/thinly-provisioned LUNs. The FITRIM ioctl
|
devices and sparse/thinly-provisioned LUNs. The FITRIM ioctl
|
||||||
command is also available together with the nodiscard option.
|
command is also available together with the nodiscard option.
|
||||||
The value of minlen specifies the minimum blockcount, when
|
The value of minlen specifies the minimum blockcount, when
|
@ -1044,6 +1044,10 @@
|
|||||||
specified address. The serial port must already be
|
specified address. The serial port must already be
|
||||||
setup and configured. Options are not yet supported.
|
setup and configured. Options are not yet supported.
|
||||||
|
|
||||||
|
sbi
|
||||||
|
Use RISC-V SBI (Supervisor Binary Interface) for early
|
||||||
|
console.
|
||||||
|
|
||||||
smh Use ARM semihosting calls for early console.
|
smh Use ARM semihosting calls for early console.
|
||||||
|
|
||||||
s3c2410,<addr>
|
s3c2410,<addr>
|
||||||
|
@ -171,22 +171,20 @@ It seems others find it useful as (System Attention Key) which is
|
|||||||
useful when you want to exit a program that will not let you switch consoles.
|
useful when you want to exit a program that will not let you switch consoles.
|
||||||
(For example, X or a svgalib program.)
|
(For example, X or a svgalib program.)
|
||||||
|
|
||||||
``reboot(b)`` is good when you're unable to shut down. But you should also
|
``reboot(b)`` is good when you're unable to shut down, it is an equivalent
|
||||||
``sync(s)`` and ``umount(u)`` first.
|
of pressing the "reset" button.
|
||||||
|
|
||||||
``crash(c)`` can be used to manually trigger a crashdump when the system is hung.
|
``crash(c)`` can be used to manually trigger a crashdump when the system is hung.
|
||||||
Note that this just triggers a crash if there is no dump mechanism available.
|
Note that this just triggers a crash if there is no dump mechanism available.
|
||||||
|
|
||||||
``sync(s)`` is great when your system is locked up, it allows you to sync your
|
``sync(s)`` is handy before yanking removable medium or after using a rescue
|
||||||
disks and will certainly lessen the chance of data loss and fscking. Note
|
shell that provides no graceful shutdown -- it will ensure your data is
|
||||||
that the sync hasn't taken place until you see the "OK" and "Done" appear
|
safely written to the disk. Note that the sync hasn't taken place until you see
|
||||||
on the screen. (If the kernel is really in strife, you may not ever get the
|
the "OK" and "Done" appear on the screen.
|
||||||
OK or Done message...)
|
|
||||||
|
|
||||||
``umount(u)`` is basically useful in the same ways as ``sync(s)``. I generally
|
``umount(u)`` can be used to mark filesystems as properly unmounted. From the
|
||||||
``sync(s)``, ``umount(u)``, then ``reboot(b)`` when my system locks. It's saved
|
running system's point of view, they will be remounted read-only. The remount
|
||||||
me many a fsck. Again, the unmount (remount read-only) hasn't taken place until
|
isn't complete until you see the "OK" and "Done" message appear on the screen.
|
||||||
you see the "OK" and "Done" message appear on the screen.
|
|
||||||
|
|
||||||
The loglevels ``0``-``9`` are useful when your console is being flooded with
|
The loglevels ``0``-``9`` are useful when your console is being flooded with
|
||||||
kernel messages you do not want to see. Selecting ``0`` will prevent all but
|
kernel messages you do not want to see. Selecting ``0`` will prevent all but
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
USING UFS
|
=========
|
||||||
|
Using UFS
|
||||||
=========
|
=========
|
||||||
|
|
||||||
mount -t ufs -o ufstype=type_of_ufs device dir
|
mount -t ufs -o ufstype=type_of_ufs device dir
|
||||||
|
|
||||||
|
|
||||||
UFS OPTIONS
|
UFS Options
|
||||||
===========
|
===========
|
||||||
|
|
||||||
ufstype=type_of_ufs
|
ufstype=type_of_ufs
|
||||||
@ -14,24 +15,31 @@ ufstype=type_of_ufs
|
|||||||
type of ufs automatically. That's why user must specify type of
|
type of ufs automatically. That's why user must specify type of
|
||||||
ufs manually by mount option ufstype. Possible values are:
|
ufs manually by mount option ufstype. Possible values are:
|
||||||
|
|
||||||
old old format of ufs
|
old
|
||||||
|
old format of ufs
|
||||||
default value, supported as read-only
|
default value, supported as read-only
|
||||||
|
|
||||||
44bsd used in FreeBSD, NetBSD, OpenBSD
|
44bsd
|
||||||
|
used in FreeBSD, NetBSD, OpenBSD
|
||||||
supported as read-write
|
supported as read-write
|
||||||
|
|
||||||
ufs2 used in FreeBSD 5.x
|
ufs2
|
||||||
|
used in FreeBSD 5.x
|
||||||
supported as read-write
|
supported as read-write
|
||||||
|
|
||||||
5xbsd synonym for ufs2
|
5xbsd
|
||||||
|
synonym for ufs2
|
||||||
|
|
||||||
sun used in SunOS (Solaris)
|
sun
|
||||||
|
used in SunOS (Solaris)
|
||||||
supported as read-write
|
supported as read-write
|
||||||
|
|
||||||
sunx86 used in SunOS for Intel (Solarisx86)
|
sunx86
|
||||||
|
used in SunOS for Intel (Solarisx86)
|
||||||
supported as read-write
|
supported as read-write
|
||||||
|
|
||||||
hp used in HP-UX
|
hp
|
||||||
|
used in HP-UX
|
||||||
supported as read-only
|
supported as read-only
|
||||||
|
|
||||||
nextstep
|
nextstep
|
||||||
@ -47,14 +55,14 @@ ufstype=type_of_ufs
|
|||||||
supported as read-only
|
supported as read-only
|
||||||
|
|
||||||
|
|
||||||
POSSIBLE PROBLEMS
|
Possible Problems
|
||||||
=================
|
-----------------
|
||||||
|
|
||||||
See next section, if you have any.
|
See next section, if you have any.
|
||||||
|
|
||||||
|
|
||||||
BUG REPORTS
|
Bug Reports
|
||||||
===========
|
-----------
|
||||||
|
|
||||||
Any ufs bug report you can send to daniel.pirkl@email.cz or
|
Any ufs bug report you can send to daniel.pirkl@email.cz or
|
||||||
to dushistov@mail.ru (do not send partition tables bug reports).
|
to dushistov@mail.ru (do not send partition tables bug reports).
|
@ -1,18 +1,23 @@
|
|||||||
|
.. include:: <isonum.txt>
|
||||||
|
|
||||||
|
====================================================
|
||||||
Driver for the Intel Wireless Wimax Connection 2400m
|
Driver for the Intel Wireless Wimax Connection 2400m
|
||||||
|
====================================================
|
||||||
|
|
||||||
(C) 2008 Intel Corporation < linux-wimax@intel.com >
|
:Copyright: |copy| 2008 Intel Corporation < linux-wimax@intel.com >
|
||||||
|
|
||||||
This provides a driver for the Intel Wireless WiMAX Connection 2400m
|
This provides a driver for the Intel Wireless WiMAX Connection 2400m
|
||||||
and a basic Linux kernel WiMAX stack.
|
and a basic Linux kernel WiMAX stack.
|
||||||
|
|
||||||
1. Requirements
|
1. Requirements
|
||||||
|
===============
|
||||||
|
|
||||||
* Linux installation with Linux kernel 2.6.22 or newer (if building
|
* Linux installation with Linux kernel 2.6.22 or newer (if building
|
||||||
from a separate tree)
|
from a separate tree)
|
||||||
* Intel i2400m Echo Peak or Baxter Peak; this includes the Intel
|
* Intel i2400m Echo Peak or Baxter Peak; this includes the Intel
|
||||||
Wireless WiMAX/WiFi Link 5x50 series.
|
Wireless WiMAX/WiFi Link 5x50 series.
|
||||||
* build tools:
|
* build tools:
|
||||||
|
|
||||||
+ Linux kernel development package for the target kernel; to
|
+ Linux kernel development package for the target kernel; to
|
||||||
build against your currently running kernel, you need to have
|
build against your currently running kernel, you need to have
|
||||||
the kernel development package corresponding to the running
|
the kernel development package corresponding to the running
|
||||||
@ -22,8 +27,10 @@
|
|||||||
+ GNU C Compiler, make
|
+ GNU C Compiler, make
|
||||||
|
|
||||||
2. Compilation and installation
|
2. Compilation and installation
|
||||||
|
===============================
|
||||||
|
|
||||||
2.1. Compilation of the drivers included in the kernel
|
2.1. Compilation of the drivers included in the kernel
|
||||||
|
------------------------------------------------------
|
||||||
|
|
||||||
Configure the kernel; to enable the WiMAX drivers select Drivers >
|
Configure the kernel; to enable the WiMAX drivers select Drivers >
|
||||||
Networking Drivers > WiMAX device support. Enable all of them as
|
Networking Drivers > WiMAX device support. Enable all of them as
|
||||||
@ -36,8 +43,9 @@
|
|||||||
Compile and install your kernel as usual.
|
Compile and install your kernel as usual.
|
||||||
|
|
||||||
2.2. Compilation of the drivers distributed as an standalone module
|
2.2. Compilation of the drivers distributed as an standalone module
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
|
||||||
To compile
|
To compile::
|
||||||
|
|
||||||
$ cd source/directory
|
$ cd source/directory
|
||||||
$ make
|
$ make
|
||||||
@ -46,26 +54,27 @@ $ make
|
|||||||
load.sh will load the modules, load.sh u will unload them.
|
load.sh will load the modules, load.sh u will unload them.
|
||||||
|
|
||||||
To install in the default kernel directories (and enable auto loading
|
To install in the default kernel directories (and enable auto loading
|
||||||
when the device is plugged):
|
when the device is plugged)::
|
||||||
|
|
||||||
$ make install
|
$ make install
|
||||||
$ depmod -a
|
$ depmod -a
|
||||||
|
|
||||||
If your kernel development files are located in a non standard
|
If your kernel development files are located in a non standard
|
||||||
directory or if you want to build for a kernel that is not the
|
directory or if you want to build for a kernel that is not the
|
||||||
currently running one, set KDIR to the right location:
|
currently running one, set KDIR to the right location::
|
||||||
|
|
||||||
$ make KDIR=/path/to/kernel/dev/tree
|
$ make KDIR=/path/to/kernel/dev/tree
|
||||||
|
|
||||||
For more information, please contact linux-wimax@intel.com.
|
For more information, please contact linux-wimax@intel.com.
|
||||||
|
|
||||||
3. Installing the firmware
|
3. Installing the firmware
|
||||||
|
--------------------------
|
||||||
|
|
||||||
The firmware can be obtained from http://linuxwimax.org or might have
|
The firmware can be obtained from http://linuxwimax.org or might have
|
||||||
been supplied with your hardware.
|
been supplied with your hardware.
|
||||||
|
|
||||||
It has to be installed in the target system:
|
It has to be installed in the target system::
|
||||||
*
|
|
||||||
$ cp FIRMWAREFILE.sbcf /lib/firmware/i2400m-fw-BUSTYPE-1.3.sbcf
|
$ cp FIRMWAREFILE.sbcf /lib/firmware/i2400m-fw-BUSTYPE-1.3.sbcf
|
||||||
|
|
||||||
* NOTE: if your firmware came in an .rpm or .deb file, just install
|
* NOTE: if your firmware came in an .rpm or .deb file, just install
|
||||||
@ -76,6 +85,7 @@ $ cp FIRMWAREFILE.sbcf /lib/firmware/i2400m-fw-BUSTYPE-1.3.sbcf
|
|||||||
with other types.
|
with other types.
|
||||||
|
|
||||||
4. Design
|
4. Design
|
||||||
|
=========
|
||||||
|
|
||||||
This package contains two major parts: a WiMAX kernel stack and a
|
This package contains two major parts: a WiMAX kernel stack and a
|
||||||
driver for the Intel i2400m.
|
driver for the Intel i2400m.
|
||||||
@ -102,12 +112,13 @@ $ cp FIRMWAREFILE.sbcf /lib/firmware/i2400m-fw-BUSTYPE-1.3.sbcf
|
|||||||
API calls should be replaced with the target OS's.
|
API calls should be replaced with the target OS's.
|
||||||
|
|
||||||
5. Usage
|
5. Usage
|
||||||
|
========
|
||||||
|
|
||||||
To load the driver, follow the instructions in the install section;
|
To load the driver, follow the instructions in the install section;
|
||||||
once the driver is loaded, plug in the device (unless it is permanently
|
once the driver is loaded, plug in the device (unless it is permanently
|
||||||
plugged in). The driver will enumerate the device, upload the firmware
|
plugged in). The driver will enumerate the device, upload the firmware
|
||||||
and output messages in the kernel log (dmesg, /var/log/messages or
|
and output messages in the kernel log (dmesg, /var/log/messages or
|
||||||
/var/log/kern.log) such as:
|
/var/log/kern.log) such as::
|
||||||
|
|
||||||
...
|
...
|
||||||
i2400m_usb 5-4:1.0: firmware interface version 8.0.0
|
i2400m_usb 5-4:1.0: firmware interface version 8.0.0
|
||||||
@ -120,38 +131,42 @@ i2400m_usb 5-4:1.0: WiMAX interface wmx0 (00:1d:e1:01:94:2c) ready
|
|||||||
on how to scan, connect and disconnect.
|
on how to scan, connect and disconnect.
|
||||||
|
|
||||||
5.1. Module parameters
|
5.1. Module parameters
|
||||||
|
----------------------
|
||||||
|
|
||||||
Module parameters can be set at kernel or module load time or by
|
Module parameters can be set at kernel or module load time or by
|
||||||
echoing values:
|
echoing values::
|
||||||
|
|
||||||
$ echo VALUE > /sys/module/MODULENAME/parameters/PARAMETERNAME
|
$ echo VALUE > /sys/module/MODULENAME/parameters/PARAMETERNAME
|
||||||
|
|
||||||
To make changes permanent, for example, for the i2400m module, you can
|
To make changes permanent, for example, for the i2400m module, you can
|
||||||
also create a file named /etc/modprobe.d/i2400m containing:
|
also create a file named /etc/modprobe.d/i2400m containing::
|
||||||
|
|
||||||
options i2400m idle_mode_disabled=1
|
options i2400m idle_mode_disabled=1
|
||||||
|
|
||||||
To find which parameters are supported by a module, run:
|
To find which parameters are supported by a module, run::
|
||||||
|
|
||||||
$ modinfo path/to/module.ko
|
$ modinfo path/to/module.ko
|
||||||
|
|
||||||
During kernel bootup (if the driver is linked in the kernel), specify
|
During kernel bootup (if the driver is linked in the kernel), specify
|
||||||
the following to the kernel command line:
|
the following to the kernel command line::
|
||||||
|
|
||||||
i2400m.PARAMETER=VALUE
|
i2400m.PARAMETER=VALUE
|
||||||
|
|
||||||
5.1.1. i2400m: idle_mode_disabled
|
5.1.1. i2400m: idle_mode_disabled
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
The i2400m module supports a parameter to disable idle mode. This
|
The i2400m module supports a parameter to disable idle mode. This
|
||||||
parameter, once set, will take effect only when the device is
|
parameter, once set, will take effect only when the device is
|
||||||
reinitialized by the driver (eg: following a reset or a reconnect).
|
reinitialized by the driver (eg: following a reset or a reconnect).
|
||||||
|
|
||||||
5.2. Debug operations: debugfs entries
|
5.2. Debug operations: debugfs entries
|
||||||
|
--------------------------------------
|
||||||
|
|
||||||
The driver will register debugfs entries that allow the user to tweak
|
The driver will register debugfs entries that allow the user to tweak
|
||||||
debug settings. There are three main container directories where
|
debug settings. There are three main container directories where
|
||||||
entries are placed, which correspond to the three blocks a i2400m WiMAX
|
entries are placed, which correspond to the three blocks a i2400m WiMAX
|
||||||
driver has:
|
driver has:
|
||||||
|
|
||||||
* /sys/kernel/debug/wimax:DEVNAME/ for the generic WiMAX stack
|
* /sys/kernel/debug/wimax:DEVNAME/ for the generic WiMAX stack
|
||||||
controls
|
controls
|
||||||
* /sys/kernel/debug/wimax:DEVNAME/i2400m for the i2400m generic
|
* /sys/kernel/debug/wimax:DEVNAME/i2400m for the i2400m generic
|
||||||
@ -163,10 +178,11 @@ i2400m.PARAMETER=VALUE
|
|||||||
/sys/kernel/debug, those paths will change.
|
/sys/kernel/debug, those paths will change.
|
||||||
|
|
||||||
5.2.1. Increasing debug output
|
5.2.1. Increasing debug output
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
The files named *dl_* indicate knobs for controlling the debug output
|
The files named *dl_* indicate knobs for controlling the debug output
|
||||||
of different submodules:
|
of different submodules::
|
||||||
*
|
|
||||||
# find /sys/kernel/debug/wimax\:wmx0 -name \*dl_\*
|
# find /sys/kernel/debug/wimax\:wmx0 -name \*dl_\*
|
||||||
/sys/kernel/debug/wimax:wmx0/i2400m-usb/dl_tx
|
/sys/kernel/debug/wimax:wmx0/i2400m-usb/dl_tx
|
||||||
/sys/kernel/debug/wimax:wmx0/i2400m-usb/dl_rx
|
/sys/kernel/debug/wimax:wmx0/i2400m-usb/dl_rx
|
||||||
@ -192,7 +208,7 @@ i2400m.PARAMETER=VALUE
|
|||||||
level; by writing to it, you can set it.
|
level; by writing to it, you can set it.
|
||||||
|
|
||||||
To increase the debug level of, for example, the i2400m's generic TX
|
To increase the debug level of, for example, the i2400m's generic TX
|
||||||
engine, just write:
|
engine, just write::
|
||||||
|
|
||||||
$ echo 3 > /sys/kernel/debug/wimax:wmx0/i2400m/dl_tx
|
$ echo 3 > /sys/kernel/debug/wimax:wmx0/i2400m/dl_tx
|
||||||
|
|
||||||
@ -201,14 +217,16 @@ $ echo 3 > /sys/kernel/debug/wimax:wmx0/i2400m/dl_tx
|
|||||||
uses 0 for disabled and increasing values until 8.
|
uses 0 for disabled and increasing values until 8.
|
||||||
|
|
||||||
5.2.2. RX and TX statistics
|
5.2.2. RX and TX statistics
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
The i2400m/rx_stats and i2400m/tx_stats provide statistics about the
|
The i2400m/rx_stats and i2400m/tx_stats provide statistics about the
|
||||||
data reception/delivery from the device:
|
data reception/delivery from the device::
|
||||||
|
|
||||||
$ cat /sys/kernel/debug/wimax:wmx0/i2400m/rx_stats
|
$ cat /sys/kernel/debug/wimax:wmx0/i2400m/rx_stats
|
||||||
45 1 3 34 3104 48 480
|
45 1 3 34 3104 48 480
|
||||||
|
|
||||||
The numbers reported are
|
The numbers reported are:
|
||||||
|
|
||||||
* packets/RX-buffer: total, min, max
|
* packets/RX-buffer: total, min, max
|
||||||
* RX-buffers: total RX buffers received, accumulated RX buffer size
|
* RX-buffers: total RX buffers received, accumulated RX buffer size
|
||||||
in bytes, min size received, max size received
|
in bytes, min size received, max size received
|
||||||
@ -216,7 +234,7 @@ $ cat /sys/kernel/debug/wimax:wmx0/i2400m/rx_stats
|
|||||||
Thus, to find the average buffer size received, divide accumulated
|
Thus, to find the average buffer size received, divide accumulated
|
||||||
RX-buffer / total RX-buffers.
|
RX-buffer / total RX-buffers.
|
||||||
|
|
||||||
To clear the statistics back to 0, write anything to the rx_stats file:
|
To clear the statistics back to 0, write anything to the rx_stats file::
|
||||||
|
|
||||||
$ echo 1 > /sys/kernel/debug/wimax:wmx0/i2400m_rx_stats
|
$ echo 1 > /sys/kernel/debug/wimax:wmx0/i2400m_rx_stats
|
||||||
|
|
||||||
@ -227,14 +245,16 @@ $ echo 1 > /sys/kernel/debug/wimax:wmx0/i2400m_rx_stats
|
|||||||
to the host. See drivers/net/wimax/i2400m/tx.c.
|
to the host. See drivers/net/wimax/i2400m/tx.c.
|
||||||
|
|
||||||
5.2.3. Tracing messages received from user space
|
5.2.3. Tracing messages received from user space
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
To echo messages received from user space into the trace pipe that the
|
To echo messages received from user space into the trace pipe that the
|
||||||
i2400m driver creates, set the debug file i2400m/trace_msg_from_user to
|
i2400m driver creates, set the debug file i2400m/trace_msg_from_user to
|
||||||
1:
|
1::
|
||||||
*
|
|
||||||
$ echo 1 > /sys/kernel/debug/wimax:wmx0/i2400m/trace_msg_from_user
|
$ echo 1 > /sys/kernel/debug/wimax:wmx0/i2400m/trace_msg_from_user
|
||||||
|
|
||||||
5.2.4. Performing a device reset
|
5.2.4. Performing a device reset
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
By writing a 0, a 1 or a 2 to the file
|
By writing a 0, a 1 or a 2 to the file
|
||||||
/sys/kernel/debug/wimax:wmx0/reset, the driver performs a warm (without
|
/sys/kernel/debug/wimax:wmx0/reset, the driver performs a warm (without
|
||||||
@ -242,16 +262,19 @@ $ echo 1 > /sys/kernel/debug/wimax:wmx0/i2400m/trace_msg_from_user
|
|||||||
(bus specific) reset on the device.
|
(bus specific) reset on the device.
|
||||||
|
|
||||||
5.2.5. Asking the device to enter power saving mode
|
5.2.5. Asking the device to enter power saving mode
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
By writing any value to the /sys/kernel/debug/wimax:wmx0 file, the
|
By writing any value to the /sys/kernel/debug/wimax:wmx0 file, the
|
||||||
device will attempt to enter power saving mode.
|
device will attempt to enter power saving mode.
|
||||||
|
|
||||||
6. Troubleshooting
|
6. Troubleshooting
|
||||||
|
==================
|
||||||
|
|
||||||
6.1. Driver complains about 'i2400m-fw-usb-1.2.sbcf: request failed'
|
6.1. Driver complains about ``i2400m-fw-usb-1.2.sbcf: request failed``
|
||||||
|
----------------------------------------------------------------------
|
||||||
|
|
||||||
If upon connecting the device, the following is output in the kernel
|
If upon connecting the device, the following is output in the kernel
|
||||||
log:
|
log::
|
||||||
|
|
||||||
i2400m_usb 5-4:1.0: fw i2400m-fw-usb-1.3.sbcf: request failed: -2
|
i2400m_usb 5-4:1.0: fw i2400m-fw-usb-1.3.sbcf: request failed: -2
|
||||||
|
|
19
Documentation/admin-guide/wimax/index.rst
Normal file
19
Documentation/admin-guide/wimax/index.rst
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
===============
|
||||||
|
WiMAX subsystem
|
||||||
|
===============
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 2
|
||||||
|
|
||||||
|
wimax
|
||||||
|
|
||||||
|
i2400m
|
||||||
|
|
||||||
|
.. only:: subproject and html
|
||||||
|
|
||||||
|
Indices
|
||||||
|
=======
|
||||||
|
|
||||||
|
* :ref:`genindex`
|
@ -1,12 +1,16 @@
|
|||||||
|
.. include:: <isonum.txt>
|
||||||
|
|
||||||
|
========================
|
||||||
Linux kernel WiMAX stack
|
Linux kernel WiMAX stack
|
||||||
|
========================
|
||||||
|
|
||||||
(C) 2008 Intel Corporation < linux-wimax@intel.com >
|
:Copyright: |copy| 2008 Intel Corporation < linux-wimax@intel.com >
|
||||||
|
|
||||||
This provides a basic Linux kernel WiMAX stack to provide a common
|
This provides a basic Linux kernel WiMAX stack to provide a common
|
||||||
control API for WiMAX devices, usable from kernel and user space.
|
control API for WiMAX devices, usable from kernel and user space.
|
||||||
|
|
||||||
1. Design
|
1. Design
|
||||||
|
=========
|
||||||
|
|
||||||
The WiMAX stack is designed to provide for common WiMAX control
|
The WiMAX stack is designed to provide for common WiMAX control
|
||||||
services to current and future WiMAX devices from any vendor.
|
services to current and future WiMAX devices from any vendor.
|
||||||
@ -31,6 +35,7 @@
|
|||||||
include/linux/wimax.h.
|
include/linux/wimax.h.
|
||||||
|
|
||||||
2. Usage
|
2. Usage
|
||||||
|
========
|
||||||
|
|
||||||
For usage in a driver (registration, API, etc) please refer to the
|
For usage in a driver (registration, API, etc) please refer to the
|
||||||
instructions in the header file include/linux/wimax.h.
|
instructions in the header file include/linux/wimax.h.
|
||||||
@ -40,6 +45,7 @@
|
|||||||
control.
|
control.
|
||||||
|
|
||||||
2.1. Obtaining debug information: debugfs entries
|
2.1. Obtaining debug information: debugfs entries
|
||||||
|
-------------------------------------------------
|
||||||
|
|
||||||
The WiMAX stack is compiled, by default, with debug messages that can
|
The WiMAX stack is compiled, by default, with debug messages that can
|
||||||
be used to diagnose issues. By default, said messages are disabled.
|
be used to diagnose issues. By default, said messages are disabled.
|
||||||
@ -52,10 +58,11 @@
|
|||||||
create more subentries below it.
|
create more subentries below it.
|
||||||
|
|
||||||
2.1.1. Increasing debug output
|
2.1.1. Increasing debug output
|
||||||
|
------------------------------
|
||||||
|
|
||||||
The files named *dl_* indicate knobs for controlling the debug output
|
The files named *dl_* indicate knobs for controlling the debug output
|
||||||
of different submodules of the WiMAX stack:
|
of different submodules of the WiMAX stack::
|
||||||
*
|
|
||||||
# find /sys/kernel/debug/wimax\:wmx0 -name \*dl_\*
|
# find /sys/kernel/debug/wimax\:wmx0 -name \*dl_\*
|
||||||
/sys/kernel/debug/wimax:wmx0/wimax_dl_stack
|
/sys/kernel/debug/wimax:wmx0/wimax_dl_stack
|
||||||
/sys/kernel/debug/wimax:wmx0/wimax_dl_op_rfkill
|
/sys/kernel/debug/wimax:wmx0/wimax_dl_op_rfkill
|
||||||
@ -65,7 +72,8 @@
|
|||||||
/sys/kernel/debug/wimax:wmx0/wimax_dl_debugfs
|
/sys/kernel/debug/wimax:wmx0/wimax_dl_debugfs
|
||||||
/sys/kernel/debug/wimax:wmx0/.... # other driver specific files
|
/sys/kernel/debug/wimax:wmx0/.... # other driver specific files
|
||||||
|
|
||||||
NOTE: Of course, if debugfs is mounted in a directory other than
|
NOTE:
|
||||||
|
Of course, if debugfs is mounted in a directory other than
|
||||||
/sys/kernel/debug, those paths will change.
|
/sys/kernel/debug, those paths will change.
|
||||||
|
|
||||||
By reading the file you can obtain the current value of said debug
|
By reading the file you can obtain the current value of said debug
|
@ -337,11 +337,12 @@ None at present.
|
|||||||
Removed Sysctls
|
Removed Sysctls
|
||||||
===============
|
===============
|
||||||
|
|
||||||
|
============================= =======
|
||||||
Name Removed
|
Name Removed
|
||||||
---- -------
|
============================= =======
|
||||||
fs.xfs.xfsbufd_centisec v4.0
|
fs.xfs.xfsbufd_centisec v4.0
|
||||||
fs.xfs.age_buffer_centisecs v4.0
|
fs.xfs.age_buffer_centisecs v4.0
|
||||||
|
============================= =======
|
||||||
|
|
||||||
Error handling
|
Error handling
|
||||||
==============
|
==============
|
||||||
|
@ -1,51 +0,0 @@
|
|||||||
===============================
|
|
||||||
ADS Bitsy Single Board Computer
|
|
||||||
===============================
|
|
||||||
|
|
||||||
(It is different from Bitsy(iPAQ) of Compaq)
|
|
||||||
|
|
||||||
For more details, contact Applied Data Systems or see
|
|
||||||
http://www.applieddata.net/products.html
|
|
||||||
|
|
||||||
The Linux support for this product has been provided by
|
|
||||||
Woojung Huh <whuh@applieddata.net>
|
|
||||||
|
|
||||||
Use 'make adsbitsy_config' before any 'make config'.
|
|
||||||
This will set up defaults for ADS Bitsy support.
|
|
||||||
|
|
||||||
The kernel zImage is linked to be loaded and executed at 0xc0400000.
|
|
||||||
|
|
||||||
Linux can be used with the ADS BootLoader that ships with the
|
|
||||||
newer rev boards. See their documentation on how to load Linux.
|
|
||||||
|
|
||||||
Supported peripherals
|
|
||||||
=====================
|
|
||||||
|
|
||||||
- SA1100 LCD frame buffer (8/16bpp...sort of)
|
|
||||||
- SA1111 USB Master
|
|
||||||
- SA1100 serial port
|
|
||||||
- pcmcia, compact flash
|
|
||||||
- touchscreen(ucb1200)
|
|
||||||
- console on LCD screen
|
|
||||||
- serial ports (ttyS[0-2])
|
|
||||||
- ttyS0 is default for serial console
|
|
||||||
|
|
||||||
To do
|
|
||||||
=====
|
|
||||||
|
|
||||||
- everything else! :-)
|
|
||||||
|
|
||||||
Notes
|
|
||||||
=====
|
|
||||||
|
|
||||||
- The flash on board is divided into 3 partitions.
|
|
||||||
You should be careful to use flash on board.
|
|
||||||
Its partition is different from GraphicsClient Plus and GraphicsMaster
|
|
||||||
|
|
||||||
- 16bpp mode requires a different cable than what ships with the board.
|
|
||||||
Contact ADS or look through the manual to wire your own. Currently,
|
|
||||||
if you compile with 16bit mode support and switch into a lower bpp
|
|
||||||
mode, the timing is off so the image is corrupted. This will be
|
|
||||||
fixed soon.
|
|
||||||
|
|
||||||
Any contribution can be sent to nico@fluxnic.net and will be greatly welcome!
|
|
@ -14,7 +14,7 @@ Building the kernel
|
|||||||
|
|
||||||
To build the kernel with current defaults::
|
To build the kernel with current defaults::
|
||||||
|
|
||||||
make assabet_config
|
make assabet_defconfig
|
||||||
make oldconfig
|
make oldconfig
|
||||||
make zImage
|
make zImage
|
||||||
|
|
||||||
|
@ -1,69 +0,0 @@
|
|||||||
======
|
|
||||||
Brutus
|
|
||||||
======
|
|
||||||
|
|
||||||
Brutus is an evaluation platform for the SA1100 manufactured by Intel.
|
|
||||||
For more details, see:
|
|
||||||
|
|
||||||
http://developer.intel.com
|
|
||||||
|
|
||||||
To compile for Brutus, you must issue the following commands::
|
|
||||||
|
|
||||||
make brutus_config
|
|
||||||
make config
|
|
||||||
[accept all the defaults]
|
|
||||||
make zImage
|
|
||||||
|
|
||||||
The resulting kernel will end up in linux/arch/arm/boot/zImage. This file
|
|
||||||
must be loaded at 0xc0008000 in Brutus's memory and execution started at
|
|
||||||
0xc0008000 as well with the value of registers r0 = 0 and r1 = 16 upon
|
|
||||||
entry.
|
|
||||||
|
|
||||||
But prior to execute the kernel, a ramdisk image must also be loaded in
|
|
||||||
memory. Use memory address 0xd8000000 for this. Note that the file
|
|
||||||
containing the (compressed) ramdisk image must not exceed 4 MB.
|
|
||||||
|
|
||||||
Typically, you'll need angelboot to load the kernel.
|
|
||||||
The following angelboot.opt file should be used::
|
|
||||||
|
|
||||||
base 0xc0008000
|
|
||||||
entry 0xc0008000
|
|
||||||
r0 0x00000000
|
|
||||||
r1 0x00000010
|
|
||||||
device /dev/ttyS0
|
|
||||||
options "9600 8N1"
|
|
||||||
baud 115200
|
|
||||||
otherfile ramdisk_img.gz
|
|
||||||
otherbase 0xd8000000
|
|
||||||
|
|
||||||
Then load the kernel and ramdisk with::
|
|
||||||
|
|
||||||
angelboot -f angelboot.opt zImage
|
|
||||||
|
|
||||||
The first Brutus serial port (assumed to be linked to /dev/ttyS0 on your
|
|
||||||
host PC) is used by angel to load the kernel and ramdisk image. The serial
|
|
||||||
console is provided through the second Brutus serial port. To access it,
|
|
||||||
you may use minicom configured with /dev/ttyS1, 9600 baud, 8N1, no flow
|
|
||||||
control.
|
|
||||||
|
|
||||||
Currently supported
|
|
||||||
===================
|
|
||||||
|
|
||||||
- RS232 serial ports
|
|
||||||
- audio output
|
|
||||||
- LCD screen
|
|
||||||
- keyboard
|
|
||||||
|
|
||||||
The actual Brutus support may not be complete without extra patches.
|
|
||||||
If such patches exist, they should be found from
|
|
||||||
ftp.netwinder.org/users/n/nico.
|
|
||||||
|
|
||||||
A full PCMCIA support is still missing, although it's possible to hack
|
|
||||||
some drivers in order to drive already inserted cards at boot time with
|
|
||||||
little modifications.
|
|
||||||
|
|
||||||
Any contribution is welcome.
|
|
||||||
|
|
||||||
Please send patches to nico@fluxnic.net
|
|
||||||
|
|
||||||
Have Fun !
|
|
@ -1,25 +0,0 @@
|
|||||||
========
|
|
||||||
Freebird
|
|
||||||
========
|
|
||||||
|
|
||||||
Freebird-1.1 is produced by Legend(C), Inc.
|
|
||||||
`http://web.archive.org/web/*/http://www.legend.com.cn`
|
|
||||||
and software/linux maintained by Coventive(C), Inc.
|
|
||||||
(http://www.coventive.com)
|
|
||||||
|
|
||||||
Based on the Nicolas's strongarm kernel tree.
|
|
||||||
|
|
||||||
Maintainer:
|
|
||||||
|
|
||||||
Chester Kuo
|
|
||||||
- <chester@coventive.com>
|
|
||||||
- <chester@linux.org.tw>
|
|
||||||
|
|
||||||
Author:
|
|
||||||
|
|
||||||
- Tim wu <timwu@coventive.com>
|
|
||||||
- CIH <cih@coventive.com>
|
|
||||||
- Eric Peng <ericpeng@coventive.com>
|
|
||||||
- Jeff Lee <jeff_lee@coventive.com>
|
|
||||||
- Allen Cheng
|
|
||||||
- Tony Liu <tonyliu@coventive.com>
|
|
@ -1,102 +0,0 @@
|
|||||||
=============================================
|
|
||||||
ADS GraphicsClient Plus Single Board Computer
|
|
||||||
=============================================
|
|
||||||
|
|
||||||
For more details, contact Applied Data Systems or see
|
|
||||||
http://www.applieddata.net/products.html
|
|
||||||
|
|
||||||
The original Linux support for this product has been provided by
|
|
||||||
Nicolas Pitre <nico@fluxnic.net>. Continued development work by
|
|
||||||
Woojung Huh <whuh@applieddata.net>
|
|
||||||
|
|
||||||
It's currently possible to mount a root filesystem via NFS providing a
|
|
||||||
complete Linux environment. Otherwise a ramdisk image may be used. The
|
|
||||||
board supports MTD/JFFS, so you could also mount something on there.
|
|
||||||
|
|
||||||
Use 'make graphicsclient_config' before any 'make config'. This will set up
|
|
||||||
defaults for GraphicsClient Plus support.
|
|
||||||
|
|
||||||
The kernel zImage is linked to be loaded and executed at 0xc0200000.
|
|
||||||
Also the following registers should have the specified values upon entry::
|
|
||||||
|
|
||||||
r0 = 0
|
|
||||||
r1 = 29 (this is the GraphicsClient architecture number)
|
|
||||||
|
|
||||||
Linux can be used with the ADS BootLoader that ships with the
|
|
||||||
newer rev boards. See their documentation on how to load Linux.
|
|
||||||
Angel is not available for the GraphicsClient Plus AFAIK.
|
|
||||||
|
|
||||||
There is a board known as just the GraphicsClient that ADS used to
|
|
||||||
produce but has end of lifed. This code will not work on the older
|
|
||||||
board with the ADS bootloader, but should still work with Angel,
|
|
||||||
as outlined below. In any case, if you're planning on deploying
|
|
||||||
something en masse, you should probably get the newer board.
|
|
||||||
|
|
||||||
If using Angel on the older boards, here is a typical angel.opt option file
|
|
||||||
if the kernel is loaded through the Angel Debug Monitor::
|
|
||||||
|
|
||||||
base 0xc0200000
|
|
||||||
entry 0xc0200000
|
|
||||||
r0 0x00000000
|
|
||||||
r1 0x0000001d
|
|
||||||
device /dev/ttyS1
|
|
||||||
options "38400 8N1"
|
|
||||||
baud 115200
|
|
||||||
#otherfile ramdisk.gz
|
|
||||||
#otherbase 0xc0800000
|
|
||||||
exec minicom
|
|
||||||
|
|
||||||
Then the kernel (and ramdisk if otherfile/otherbase lines above are
|
|
||||||
uncommented) would be loaded with::
|
|
||||||
|
|
||||||
angelboot -f angelboot.opt zImage
|
|
||||||
|
|
||||||
Here it is assumed that the board is connected to ttyS1 on your PC
|
|
||||||
and that minicom is preconfigured with /dev/ttyS1, 38400 baud, 8N1, no flow
|
|
||||||
control by default.
|
|
||||||
|
|
||||||
If any other bootloader is used, ensure it accomplish the same, especially
|
|
||||||
for r0/r1 register values before jumping into the kernel.
|
|
||||||
|
|
||||||
|
|
||||||
Supported peripherals
|
|
||||||
=====================
|
|
||||||
|
|
||||||
- SA1100 LCD frame buffer (8/16bpp...sort of)
|
|
||||||
- on-board SMC 92C96 ethernet NIC
|
|
||||||
- SA1100 serial port
|
|
||||||
- flash memory access (MTD/JFFS)
|
|
||||||
- pcmcia
|
|
||||||
- touchscreen(ucb1200)
|
|
||||||
- ps/2 keyboard
|
|
||||||
- console on LCD screen
|
|
||||||
- serial ports (ttyS[0-2])
|
|
||||||
- ttyS0 is default for serial console
|
|
||||||
- Smart I/O (ADC, keypad, digital inputs, etc)
|
|
||||||
See http://www.eurotech-inc.com/linux-sbc.asp for IOCTL documentation
|
|
||||||
and example user space code. ps/2 keybd is multiplexed through this driver
|
|
||||||
|
|
||||||
To do
|
|
||||||
=====
|
|
||||||
|
|
||||||
- UCB1200 audio with new ucb_generic layer
|
|
||||||
- everything else! :-)
|
|
||||||
|
|
||||||
Notes
|
|
||||||
=====
|
|
||||||
|
|
||||||
- The flash on board is divided into 3 partitions. mtd0 is where
|
|
||||||
the ADS boot ROM and zImage is stored. It's been marked as
|
|
||||||
read-only to keep you from blasting over the bootloader. :) mtd1 is
|
|
||||||
for the ramdisk.gz image. mtd2 is user flash space and can be
|
|
||||||
utilized for either JFFS or if you're feeling crazy, running ext2
|
|
||||||
on top of it. If you're not using the ADS bootloader, you're
|
|
||||||
welcome to blast over the mtd1 partition also.
|
|
||||||
|
|
||||||
- 16bpp mode requires a different cable than what ships with the board.
|
|
||||||
Contact ADS or look through the manual to wire your own. Currently,
|
|
||||||
if you compile with 16bit mode support and switch into a lower bpp
|
|
||||||
mode, the timing is off so the image is corrupted. This will be
|
|
||||||
fixed soon.
|
|
||||||
|
|
||||||
Any contribution can be sent to nico@fluxnic.net and will be greatly welcome!
|
|
@ -1,60 +0,0 @@
|
|||||||
========================================
|
|
||||||
ADS GraphicsMaster Single Board Computer
|
|
||||||
========================================
|
|
||||||
|
|
||||||
For more details, contact Applied Data Systems or see
|
|
||||||
http://www.applieddata.net/products.html
|
|
||||||
|
|
||||||
The original Linux support for this product has been provided by
|
|
||||||
Nicolas Pitre <nico@fluxnic.net>. Continued development work by
|
|
||||||
Woojung Huh <whuh@applieddata.net>
|
|
||||||
|
|
||||||
Use 'make graphicsmaster_config' before any 'make config'.
|
|
||||||
This will set up defaults for GraphicsMaster support.
|
|
||||||
|
|
||||||
The kernel zImage is linked to be loaded and executed at 0xc0400000.
|
|
||||||
|
|
||||||
Linux can be used with the ADS BootLoader that ships with the
|
|
||||||
newer rev boards. See their documentation on how to load Linux.
|
|
||||||
|
|
||||||
Supported peripherals
|
|
||||||
=====================
|
|
||||||
|
|
||||||
- SA1100 LCD frame buffer (8/16bpp...sort of)
|
|
||||||
- SA1111 USB Master
|
|
||||||
- on-board SMC 92C96 ethernet NIC
|
|
||||||
- SA1100 serial port
|
|
||||||
- flash memory access (MTD/JFFS)
|
|
||||||
- pcmcia, compact flash
|
|
||||||
- touchscreen(ucb1200)
|
|
||||||
- ps/2 keyboard
|
|
||||||
- console on LCD screen
|
|
||||||
- serial ports (ttyS[0-2])
|
|
||||||
- ttyS0 is default for serial console
|
|
||||||
- Smart I/O (ADC, keypad, digital inputs, etc)
|
|
||||||
See http://www.eurotech-inc.com/linux-sbc.asp for IOCTL documentation
|
|
||||||
and example user space code. ps/2 keybd is multiplexed through this driver
|
|
||||||
|
|
||||||
To do
|
|
||||||
=====
|
|
||||||
|
|
||||||
- everything else! :-)
|
|
||||||
|
|
||||||
Notes
|
|
||||||
=====
|
|
||||||
|
|
||||||
- The flash on board is divided into 3 partitions. mtd0 is where
|
|
||||||
the zImage is stored. It's been marked as read-only to keep you
|
|
||||||
from blasting over the bootloader. :) mtd1 is
|
|
||||||
for the ramdisk.gz image. mtd2 is user flash space and can be
|
|
||||||
utilized for either JFFS or if you're feeling crazy, running ext2
|
|
||||||
on top of it. If you're not using the ADS bootloader, you're
|
|
||||||
welcome to blast over the mtd1 partition also.
|
|
||||||
|
|
||||||
- 16bpp mode requires a different cable than what ships with the board.
|
|
||||||
Contact ADS or look through the manual to wire your own. Currently,
|
|
||||||
if you compile with 16bit mode support and switch into a lower bpp
|
|
||||||
mode, the timing is off so the image is corrupted. This will be
|
|
||||||
fixed soon.
|
|
||||||
|
|
||||||
Any contribution can be sent to nico@fluxnic.net and will be greatly welcome!
|
|
@ -1,21 +0,0 @@
|
|||||||
=======================
|
|
||||||
Hoeft & Wessel Webpanel
|
|
||||||
=======================
|
|
||||||
|
|
||||||
The HUW_WEBPANEL is a product of the german company Hoeft & Wessel AG
|
|
||||||
|
|
||||||
If you want more information, please visit
|
|
||||||
http://www.hoeft-wessel.de
|
|
||||||
|
|
||||||
To build the kernel::
|
|
||||||
|
|
||||||
make huw_webpanel_config
|
|
||||||
make oldconfig
|
|
||||||
[accept all defaults]
|
|
||||||
make zImage
|
|
||||||
|
|
||||||
Mostly of the work is done by:
|
|
||||||
Roman Jordan jor@hoeft-wessel.de
|
|
||||||
Christoph Schulz schu@hoeft-wessel.de
|
|
||||||
|
|
||||||
2000/12/18/
|
|
@ -7,19 +7,7 @@ Intel StrongARM 1100
|
|||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
adsbitsy
|
|
||||||
assabet
|
assabet
|
||||||
brutus
|
|
||||||
cerf
|
cerf
|
||||||
freebird
|
|
||||||
graphicsclient
|
|
||||||
graphicsmaster
|
|
||||||
huw_webpanel
|
|
||||||
itsy
|
|
||||||
lart
|
lart
|
||||||
nanoengine
|
|
||||||
pangolin
|
|
||||||
pleb
|
|
||||||
serial_uart
|
serial_uart
|
||||||
tifon
|
|
||||||
yopy
|
|
||||||
|
@ -1,47 +0,0 @@
|
|||||||
====
|
|
||||||
Itsy
|
|
||||||
====
|
|
||||||
|
|
||||||
Itsy is a research project done by the Western Research Lab, and Systems
|
|
||||||
Research Center in Palo Alto, CA. The Itsy project is one of several
|
|
||||||
research projects at Compaq that are related to pocket computing.
|
|
||||||
|
|
||||||
For more information, see:
|
|
||||||
|
|
||||||
http://www.hpl.hp.com/downloads/crl/itsy/
|
|
||||||
|
|
||||||
Notes on initial 2.4 Itsy support (8/27/2000) :
|
|
||||||
|
|
||||||
The port was done on an Itsy version 1.5 machine with a daughtercard with
|
|
||||||
64 Meg of DRAM and 32 Meg of Flash. The initial work includes support for
|
|
||||||
serial console (to see what you're doing). No other devices have been
|
|
||||||
enabled.
|
|
||||||
|
|
||||||
To build, do a "make menuconfig" (or xmenuconfig) and select Itsy support.
|
|
||||||
Disable Flash and LCD support. and then do a make zImage.
|
|
||||||
Finally, you will need to cd to arch/arm/boot/tools and execute a make there
|
|
||||||
to build the params-itsy program used to boot the kernel.
|
|
||||||
|
|
||||||
In order to install the port of 2.4 to the itsy, You will need to set the
|
|
||||||
configuration parameters in the monitor as follows::
|
|
||||||
|
|
||||||
Arg 1:0x08340000, Arg2: 0xC0000000, Arg3:18 (0x12), Arg4:0
|
|
||||||
|
|
||||||
Make sure the start-routine address is set to 0x00060000.
|
|
||||||
|
|
||||||
Next, flash the params-itsy program to 0x00060000 ("p 1 0x00060000" in the
|
|
||||||
flash menu) Flash the kernel in arch/arm/boot/zImage into 0x08340000
|
|
||||||
("p 1 0x00340000"). Finally flash an initial ramdisk into 0xC8000000
|
|
||||||
("p 2 0x0") We used ramdisk-2-30.gz from the 0.11 version directory on
|
|
||||||
handhelds.org.
|
|
||||||
|
|
||||||
The serial connection we established was at:
|
|
||||||
|
|
||||||
8-bit data, no parity, 1 stop bit(s), 115200.00 b/s. in the monitor, in the
|
|
||||||
params-itsy program, and in the kernel itself. This can be changed, but
|
|
||||||
not easily. The monitor parameters are easily changed, the params program
|
|
||||||
setup is assembly outl's, and the kernel is a configuration item specific to
|
|
||||||
the itsy. (i.e. grep for CONFIG_SA1100_ITSY and you'll find where it is.)
|
|
||||||
|
|
||||||
|
|
||||||
This should get you a properly booting 2.4 kernel on the itsy.
|
|
@ -1,11 +0,0 @@
|
|||||||
==========
|
|
||||||
nanoEngine
|
|
||||||
==========
|
|
||||||
|
|
||||||
"nanoEngine" is a SA1110 based single board computer from
|
|
||||||
Bright Star Engineering Inc. See www.brightstareng.com/arm
|
|
||||||
for more info.
|
|
||||||
(Ref: Stuart Adams <sja@brightstareng.com>)
|
|
||||||
|
|
||||||
Also visit Larry Doolittle's "Linux for the nanoEngine" site:
|
|
||||||
http://www.brightstareng.com/arm/nanoeng.htm
|
|
@ -1,29 +0,0 @@
|
|||||||
========
|
|
||||||
Pangolin
|
|
||||||
========
|
|
||||||
|
|
||||||
Pangolin is a StrongARM 1110-based evaluation platform produced
|
|
||||||
by Dialogue Technology (http://www.dialogue.com.tw/).
|
|
||||||
It has EISA slots for ease of configuration with SDRAM/Flash
|
|
||||||
memory card, USB/Serial/Audio card, Compact Flash card,
|
|
||||||
PCMCIA/IDE card and TFT-LCD card.
|
|
||||||
|
|
||||||
To compile for Pangolin, you must issue the following commands::
|
|
||||||
|
|
||||||
make pangolin_config
|
|
||||||
make oldconfig
|
|
||||||
make zImage
|
|
||||||
|
|
||||||
Supported peripherals
|
|
||||||
=====================
|
|
||||||
|
|
||||||
- SA1110 serial port (UART1/UART2/UART3)
|
|
||||||
- flash memory access
|
|
||||||
- compact flash driver
|
|
||||||
- UDA1341 sound driver
|
|
||||||
- SA1100 LCD controller for 800x600 16bpp TFT-LCD
|
|
||||||
- MQ-200 driver for 800x600 16bpp TFT-LCD
|
|
||||||
- Penmount(touch panel) driver
|
|
||||||
- PCMCIA driver
|
|
||||||
- SMC91C94 LAN driver
|
|
||||||
- IDE driver (experimental)
|
|
@ -1,13 +0,0 @@
|
|||||||
====
|
|
||||||
PLEB
|
|
||||||
====
|
|
||||||
|
|
||||||
The PLEB project was started as a student initiative at the School of
|
|
||||||
Computer Science and Engineering, University of New South Wales to make a
|
|
||||||
pocket computer capable of running the Linux Kernel.
|
|
||||||
|
|
||||||
PLEB support has yet to be fully integrated.
|
|
||||||
|
|
||||||
For more information, see:
|
|
||||||
|
|
||||||
http://www.cse.unsw.edu.au
|
|
@ -1,7 +0,0 @@
|
|||||||
=====
|
|
||||||
Tifon
|
|
||||||
=====
|
|
||||||
|
|
||||||
More info has to come...
|
|
||||||
|
|
||||||
Contact: Peter Danielsson <peter.danielsson@era-t.ericsson.se>
|
|
@ -1,5 +0,0 @@
|
|||||||
====
|
|
||||||
Yopy
|
|
||||||
====
|
|
||||||
|
|
||||||
See http://www.yopydeveloper.org for more.
|
|
@ -1,6 +1,6 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
==========================
|
==========================
|
||||||
Samsung S3C24XX SoC Family
|
Samsung S3C24XX SoC Family
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
|
1
Documentation/arm/sh-mobile/.gitignore
vendored
1
Documentation/arm/sh-mobile/.gitignore
vendored
@ -1 +0,0 @@
|
|||||||
vrl4
|
|
@ -1,105 +0,0 @@
|
|||||||
===================================
|
|
||||||
cfag12864b LCD Driver Documentation
|
|
||||||
===================================
|
|
||||||
|
|
||||||
License: GPLv2
|
|
||||||
Author & Maintainer: Miguel Ojeda Sandonis
|
|
||||||
Date: 2006-10-27
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--------
|
|
||||||
0. INDEX
|
|
||||||
--------
|
|
||||||
|
|
||||||
1. DRIVER INFORMATION
|
|
||||||
2. DEVICE INFORMATION
|
|
||||||
3. WIRING
|
|
||||||
4. USERSPACE PROGRAMMING
|
|
||||||
|
|
||||||
|
|
||||||
---------------------
|
|
||||||
1. DRIVER INFORMATION
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
This driver supports a cfag12864b LCD.
|
|
||||||
|
|
||||||
|
|
||||||
---------------------
|
|
||||||
2. DEVICE INFORMATION
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
Manufacturer: Crystalfontz
|
|
||||||
Device Name: Crystalfontz 12864b LCD Series
|
|
||||||
Device Code: cfag12864b
|
|
||||||
Webpage: http://www.crystalfontz.com
|
|
||||||
Device Webpage: http://www.crystalfontz.com/products/12864b/
|
|
||||||
Type: LCD (Liquid Crystal Display)
|
|
||||||
Width: 128
|
|
||||||
Height: 64
|
|
||||||
Colors: 2 (B/N)
|
|
||||||
Controller: ks0108
|
|
||||||
Controllers: 2
|
|
||||||
Pages: 8 each controller
|
|
||||||
Addresses: 64 each page
|
|
||||||
Data size: 1 byte each address
|
|
||||||
Memory size: 2 * 8 * 64 * 1 = 1024 bytes = 1 Kbyte
|
|
||||||
|
|
||||||
|
|
||||||
---------
|
|
||||||
3. WIRING
|
|
||||||
---------
|
|
||||||
|
|
||||||
The cfag12864b LCD Series don't have official wiring.
|
|
||||||
|
|
||||||
The common wiring is done to the parallel port as shown:
|
|
||||||
|
|
||||||
Parallel Port cfag12864b
|
|
||||||
|
|
||||||
Name Pin# Pin# Name
|
|
||||||
|
|
||||||
Strobe ( 1)------------------------------(17) Enable
|
|
||||||
Data 0 ( 2)------------------------------( 4) Data 0
|
|
||||||
Data 1 ( 3)------------------------------( 5) Data 1
|
|
||||||
Data 2 ( 4)------------------------------( 6) Data 2
|
|
||||||
Data 3 ( 5)------------------------------( 7) Data 3
|
|
||||||
Data 4 ( 6)------------------------------( 8) Data 4
|
|
||||||
Data 5 ( 7)------------------------------( 9) Data 5
|
|
||||||
Data 6 ( 8)------------------------------(10) Data 6
|
|
||||||
Data 7 ( 9)------------------------------(11) Data 7
|
|
||||||
(10) [+5v]---( 1) Vdd
|
|
||||||
(11) [GND]---( 2) Ground
|
|
||||||
(12) [+5v]---(14) Reset
|
|
||||||
(13) [GND]---(15) Read / Write
|
|
||||||
Line (14)------------------------------(13) Controller Select 1
|
|
||||||
(15)
|
|
||||||
Init (16)------------------------------(12) Controller Select 2
|
|
||||||
Select (17)------------------------------(16) Data / Instruction
|
|
||||||
Ground (18)---[GND] [+5v]---(19) LED +
|
|
||||||
Ground (19)---[GND]
|
|
||||||
Ground (20)---[GND] E A Values:
|
|
||||||
Ground (21)---[GND] [GND]---[P1]---(18) Vee - R = Resistor = 22 ohm
|
|
||||||
Ground (22)---[GND] | - P1 = Preset = 10 Kohm
|
|
||||||
Ground (23)---[GND] ---- S ------( 3) V0 - P2 = Preset = 1 Kohm
|
|
||||||
Ground (24)---[GND] | |
|
|
||||||
Ground (25)---[GND] [GND]---[P2]---[R]---(20) LED -
|
|
||||||
|
|
||||||
|
|
||||||
------------------------
|
|
||||||
4. USERSPACE PROGRAMMING
|
|
||||||
------------------------
|
|
||||||
|
|
||||||
The cfag12864bfb describes a framebuffer device (/dev/fbX).
|
|
||||||
|
|
||||||
It has a size of 1024 bytes = 1 Kbyte.
|
|
||||||
Each bit represents one pixel. If the bit is high, the pixel will
|
|
||||||
turn on. If the pixel is low, the pixel will turn off.
|
|
||||||
|
|
||||||
You can use the framebuffer as a file: fopen, fwrite, fclose...
|
|
||||||
Although the LCD won't get updated until the next refresh time arrives.
|
|
||||||
|
|
||||||
Also, you can mmap the framebuffer: open & mmap, munmap & close...
|
|
||||||
which is the best option for most uses.
|
|
||||||
|
|
||||||
Check samples/auxdisplay/cfag12864b-example.c
|
|
||||||
for a real working userspace complete program with usage examples.
|
|
@ -1,55 +0,0 @@
|
|||||||
==========================================
|
|
||||||
ks0108 LCD Controller Driver Documentation
|
|
||||||
==========================================
|
|
||||||
|
|
||||||
License: GPLv2
|
|
||||||
Author & Maintainer: Miguel Ojeda Sandonis
|
|
||||||
Date: 2006-10-27
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--------
|
|
||||||
0. INDEX
|
|
||||||
--------
|
|
||||||
|
|
||||||
1. DRIVER INFORMATION
|
|
||||||
2. DEVICE INFORMATION
|
|
||||||
3. WIRING
|
|
||||||
|
|
||||||
|
|
||||||
---------------------
|
|
||||||
1. DRIVER INFORMATION
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
This driver supports the ks0108 LCD controller.
|
|
||||||
|
|
||||||
|
|
||||||
---------------------
|
|
||||||
2. DEVICE INFORMATION
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
Manufacturer: Samsung
|
|
||||||
Device Name: KS0108 LCD Controller
|
|
||||||
Device Code: ks0108
|
|
||||||
Webpage: -
|
|
||||||
Device Webpage: -
|
|
||||||
Type: LCD Controller (Liquid Crystal Display Controller)
|
|
||||||
Width: 64
|
|
||||||
Height: 64
|
|
||||||
Colors: 2 (B/N)
|
|
||||||
Pages: 8
|
|
||||||
Addresses: 64 each page
|
|
||||||
Data size: 1 byte each address
|
|
||||||
Memory size: 8 * 64 * 1 = 512 bytes
|
|
||||||
|
|
||||||
|
|
||||||
---------
|
|
||||||
3. WIRING
|
|
||||||
---------
|
|
||||||
|
|
||||||
The driver supports data parallel port wiring.
|
|
||||||
|
|
||||||
If you aren't building LCD related hardware, you should check
|
|
||||||
your LCD specific wiring information in the same folder.
|
|
||||||
|
|
||||||
For example, check Documentation/auxdisplay/cfag12864b.
|
|
@ -25,6 +25,7 @@ Core utilities
|
|||||||
librs
|
librs
|
||||||
genalloc
|
genalloc
|
||||||
errseq
|
errseq
|
||||||
|
packing
|
||||||
printk-formats
|
printk-formats
|
||||||
circular-buffers
|
circular-buffers
|
||||||
generic-radix-tree
|
generic-radix-tree
|
||||||
@ -48,7 +49,7 @@ Interfaces for kernel debugging
|
|||||||
debug-objects
|
debug-objects
|
||||||
tracepoint
|
tracepoint
|
||||||
|
|
||||||
.. only:: subproject
|
.. only:: subproject and html
|
||||||
|
|
||||||
Indices
|
Indices
|
||||||
=======
|
=======
|
||||||
|
@ -30,6 +30,7 @@ The solution
|
|||||||
------------
|
------------
|
||||||
|
|
||||||
This API deals with 2 basic operations:
|
This API deals with 2 basic operations:
|
||||||
|
|
||||||
- Packing a CPU-usable number into a memory buffer (with hardware
|
- Packing a CPU-usable number into a memory buffer (with hardware
|
||||||
constraints/quirks)
|
constraints/quirks)
|
||||||
- Unpacking a memory buffer (which has hardware constraints/quirks)
|
- Unpacking a memory buffer (which has hardware constraints/quirks)
|
||||||
@ -49,6 +50,8 @@ What the examples show is where the logical bytes and bits sit.
|
|||||||
|
|
||||||
1. Normally (no quirks), we would do it like this:
|
1. Normally (no quirks), we would do it like this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32
|
63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32
|
||||||
7 6 5 4
|
7 6 5 4
|
||||||
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
|
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
|
||||||
@ -63,6 +66,8 @@ comments as "logical" notation.
|
|||||||
|
|
||||||
2. If QUIRK_MSB_ON_THE_RIGHT is set, we do it like this:
|
2. If QUIRK_MSB_ON_THE_RIGHT is set, we do it like this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
56 57 58 59 60 61 62 63 48 49 50 51 52 53 54 55 40 41 42 43 44 45 46 47 32 33 34 35 36 37 38 39
|
56 57 58 59 60 61 62 63 48 49 50 51 52 53 54 55 40 41 42 43 44 45 46 47 32 33 34 35 36 37 38 39
|
||||||
7 6 5 4
|
7 6 5 4
|
||||||
24 25 26 27 28 29 30 31 16 17 18 19 20 21 22 23 8 9 10 11 12 13 14 15 0 1 2 3 4 5 6 7
|
24 25 26 27 28 29 30 31 16 17 18 19 20 21 22 23 8 9 10 11 12 13 14 15 0 1 2 3 4 5 6 7
|
||||||
@ -74,6 +79,8 @@ inverts bit offsets inside a byte.
|
|||||||
|
|
||||||
3. If QUIRK_LITTLE_ENDIAN is set, we do it like this:
|
3. If QUIRK_LITTLE_ENDIAN is set, we do it like this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
39 38 37 36 35 34 33 32 47 46 45 44 43 42 41 40 55 54 53 52 51 50 49 48 63 62 61 60 59 58 57 56
|
39 38 37 36 35 34 33 32 47 46 45 44 43 42 41 40 55 54 53 52 51 50 49 48 63 62 61 60 59 58 57 56
|
||||||
4 5 6 7
|
4 5 6 7
|
||||||
7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16 31 30 29 28 27 26 25 24
|
7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16 31 30 29 28 27 26 25 24
|
||||||
@ -86,6 +93,8 @@ the boundary of that word.
|
|||||||
4. If QUIRK_MSB_ON_THE_RIGHT and QUIRK_LITTLE_ENDIAN are both set, we do it
|
4. If QUIRK_MSB_ON_THE_RIGHT and QUIRK_LITTLE_ENDIAN are both set, we do it
|
||||||
like this:
|
like this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
||||||
4 5 6 7
|
4 5 6 7
|
||||||
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
||||||
@ -94,6 +103,8 @@ the boundary of that word.
|
|||||||
|
|
||||||
5. If just QUIRK_LSW32_IS_FIRST is set, we do it like this:
|
5. If just QUIRK_LSW32_IS_FIRST is set, we do it like this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
|
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
|
||||||
3 2 1 0
|
3 2 1 0
|
||||||
63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32
|
63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32
|
||||||
@ -107,6 +118,8 @@ the more significant 4-byte word.
|
|||||||
6. If QUIRK_LSW32_IS_FIRST and QUIRK_MSB_ON_THE_RIGHT are set, we do it like
|
6. If QUIRK_LSW32_IS_FIRST and QUIRK_MSB_ON_THE_RIGHT are set, we do it like
|
||||||
this:
|
this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
24 25 26 27 28 29 30 31 16 17 18 19 20 21 22 23 8 9 10 11 12 13 14 15 0 1 2 3 4 5 6 7
|
24 25 26 27 28 29 30 31 16 17 18 19 20 21 22 23 8 9 10 11 12 13 14 15 0 1 2 3 4 5 6 7
|
||||||
3 2 1 0
|
3 2 1 0
|
||||||
56 57 58 59 60 61 62 63 48 49 50 51 52 53 54 55 40 41 42 43 44 45 46 47 32 33 34 35 36 37 38 39
|
56 57 58 59 60 61 62 63 48 49 50 51 52 53 54 55 40 41 42 43 44 45 46 47 32 33 34 35 36 37 38 39
|
||||||
@ -116,6 +129,8 @@ the more significant 4-byte word.
|
|||||||
7. If QUIRK_LSW32_IS_FIRST and QUIRK_LITTLE_ENDIAN are set, it looks like
|
7. If QUIRK_LSW32_IS_FIRST and QUIRK_LITTLE_ENDIAN are set, it looks like
|
||||||
this:
|
this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16 31 30 29 28 27 26 25 24
|
7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16 31 30 29 28 27 26 25 24
|
||||||
0 1 2 3
|
0 1 2 3
|
||||||
39 38 37 36 35 34 33 32 47 46 45 44 43 42 41 40 55 54 53 52 51 50 49 48 63 62 61 60 59 58 57 56
|
39 38 37 36 35 34 33 32 47 46 45 44 43 42 41 40 55 54 53 52 51 50 49 48 63 62 61 60 59 58 57 56
|
||||||
@ -125,6 +140,8 @@ the more significant 4-byte word.
|
|||||||
8. If QUIRK_LSW32_IS_FIRST, QUIRK_LITTLE_ENDIAN and QUIRK_MSB_ON_THE_RIGHT
|
8. If QUIRK_LSW32_IS_FIRST, QUIRK_LITTLE_ENDIAN and QUIRK_MSB_ON_THE_RIGHT
|
||||||
are set, it looks like this:
|
are set, it looks like this:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
||||||
0 1 2 3
|
0 1 2 3
|
||||||
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
@ -13,10 +13,10 @@ Integer types
|
|||||||
|
|
||||||
If variable is of Type, use printk format specifier:
|
If variable is of Type, use printk format specifier:
|
||||||
------------------------------------------------------------
|
------------------------------------------------------------
|
||||||
char %hhd or %hhx
|
char %d or %x
|
||||||
unsigned char %hhu or %hhx
|
unsigned char %u or %x
|
||||||
short int %hd or %hx
|
short int %d or %x
|
||||||
unsigned short int %hu or %hx
|
unsigned short int %u or %x
|
||||||
int %d or %x
|
int %d or %x
|
||||||
unsigned int %u or %x
|
unsigned int %u or %x
|
||||||
long %ld or %lx
|
long %ld or %lx
|
||||||
@ -25,10 +25,10 @@ Integer types
|
|||||||
unsigned long long %llu or %llx
|
unsigned long long %llu or %llx
|
||||||
size_t %zu or %zx
|
size_t %zu or %zx
|
||||||
ssize_t %zd or %zx
|
ssize_t %zd or %zx
|
||||||
s8 %hhd or %hhx
|
s8 %d or %x
|
||||||
u8 %hhu or %hhx
|
u8 %u or %x
|
||||||
s16 %hd or %hx
|
s16 %d or %x
|
||||||
u16 %hu or %hx
|
u16 %u or %x
|
||||||
s32 %d or %x
|
s32 %d or %x
|
||||||
u32 %u or %x
|
u32 %u or %x
|
||||||
s64 %lld or %llx
|
s64 %lld or %llx
|
||||||
|
@ -42,7 +42,7 @@ Optional properties:
|
|||||||
This means that no unrelated I2C transactions are allowed on the parent I2C
|
This means that no unrelated I2C transactions are allowed on the parent I2C
|
||||||
adapter for the complete multiplexed I2C transaction.
|
adapter for the complete multiplexed I2C transaction.
|
||||||
The properties of mux-locked and parent-locked multiplexers are discussed
|
The properties of mux-locked and parent-locked multiplexers are discussed
|
||||||
in more detail in Documentation/i2c/i2c-topology.
|
in more detail in Documentation/i2c/i2c-topology.rst.
|
||||||
|
|
||||||
For each i2c child node, an I2C child bus will be created. They will
|
For each i2c child node, an I2C child bus will be created. They will
|
||||||
be numbered based on their order in the device tree.
|
be numbered based on their order in the device tree.
|
||||||
|
@ -4,7 +4,7 @@ Allwinner SUN8I audio codec
|
|||||||
On Sun8i-A33 SoCs, the audio is separated in different parts:
|
On Sun8i-A33 SoCs, the audio is separated in different parts:
|
||||||
- A DAI driver. It uses the "sun4i-i2s" driver which is
|
- A DAI driver. It uses the "sun4i-i2s" driver which is
|
||||||
documented here:
|
documented here:
|
||||||
Documentation/devicetree/bindings/sound/sun4i-i2s.txt
|
Documentation/devicetree/bindings/sound/allwinner,sun4i-a10-i2s.yaml
|
||||||
- An analog part of the codec which is handled as PRCM registers.
|
- An analog part of the codec which is handled as PRCM registers.
|
||||||
See Documentation/devicetree/bindings/sound/sun8i-codec-analog.txt
|
See Documentation/devicetree/bindings/sound/sun8i-codec-analog.txt
|
||||||
- An digital part of the codec which is documented in this current
|
- An digital part of the codec which is documented in this current
|
||||||
|
@ -1,130 +0,0 @@
|
|||||||
# Writing DeviceTree Bindings in json-schema
|
|
||||||
|
|
||||||
Devicetree bindings are written using json-schema vocabulary. Schema files are
|
|
||||||
written in a JSON compatible subset of YAML. YAML is used instead of JSON as it
|
|
||||||
considered more human readable and has some advantages such as allowing
|
|
||||||
comments (Prefixed with '#').
|
|
||||||
|
|
||||||
## Schema Contents
|
|
||||||
|
|
||||||
Each schema doc is a structured json-schema which is defined by a set of
|
|
||||||
top-level properties. Generally, there is one binding defined per file. The
|
|
||||||
top-level json-schema properties used are:
|
|
||||||
|
|
||||||
- __$id__ - A json-schema unique identifier string. The string must be a valid
|
|
||||||
URI typically containing the binding's filename and path. For DT schema, it must
|
|
||||||
begin with "http://devicetree.org/schemas/". The URL is used in constructing
|
|
||||||
references to other files specified in schema "$ref" properties. A $ref values
|
|
||||||
with a leading '/' will have the hostname prepended. A $ref value a relative
|
|
||||||
path or filename only will be prepended with the hostname and path components
|
|
||||||
of the current schema file's '$id' value. A URL is used even for local files,
|
|
||||||
but there may not actually be files present at those locations.
|
|
||||||
|
|
||||||
- __$schema__ - Indicates the meta-schema the schema file adheres to.
|
|
||||||
|
|
||||||
- __title__ - A one line description on the contents of the binding schema.
|
|
||||||
|
|
||||||
- __maintainers__ - A DT specific property. Contains a list of email address(es)
|
|
||||||
for maintainers of this binding.
|
|
||||||
|
|
||||||
- __description__ - Optional. A multi-line text block containing any detailed
|
|
||||||
information about this binding. It should contain things such as what the block
|
|
||||||
or device does, standards the device conforms to, and links to datasheets for
|
|
||||||
more information.
|
|
||||||
|
|
||||||
- __select__ - Optional. A json-schema used to match nodes for applying the
|
|
||||||
schema. By default without 'select', nodes are matched against their possible
|
|
||||||
compatible string values or node name. Most bindings should not need select.
|
|
||||||
|
|
||||||
- __allOf__ - Optional. A list of other schemas to include. This is used to
|
|
||||||
include other schemas the binding conforms to. This may be schemas for a
|
|
||||||
particular class of devices such as I2C or SPI controllers.
|
|
||||||
|
|
||||||
- __properties__ - A set of sub-schema defining all the DT properties for the
|
|
||||||
binding. The exact schema syntax depends on whether properties are known,
|
|
||||||
common properties (e.g. 'interrupts') or are binding/vendor specific properties.
|
|
||||||
|
|
||||||
A property can also define a child DT node with child properties defined
|
|
||||||
under it.
|
|
||||||
|
|
||||||
For more details on properties sections, see 'Property Schema' section.
|
|
||||||
|
|
||||||
- __patternProperties__ - Optional. Similar to 'properties', but names are regex.
|
|
||||||
|
|
||||||
- __required__ - A list of DT properties from the 'properties' section that
|
|
||||||
must always be present.
|
|
||||||
|
|
||||||
- __examples__ - Optional. A list of one or more DTS hunks implementing the
|
|
||||||
binding. Note: YAML doesn't allow leading tabs, so spaces must be used instead.
|
|
||||||
|
|
||||||
Unless noted otherwise, all properties are required.
|
|
||||||
|
|
||||||
## Property Schema
|
|
||||||
|
|
||||||
The 'properties' section of the schema contains all the DT properties for a
|
|
||||||
binding. Each property contains a set of constraints using json-schema
|
|
||||||
vocabulary for that property. The properties schemas are what is used for
|
|
||||||
validation of DT files.
|
|
||||||
|
|
||||||
For common properties, only additional constraints not covered by the common
|
|
||||||
binding schema need to be defined such as how many values are valid or what
|
|
||||||
possible values are valid.
|
|
||||||
|
|
||||||
Vendor specific properties will typically need more detailed schema. With the
|
|
||||||
exception of boolean properties, they should have a reference to a type in
|
|
||||||
schemas/types.yaml. A "description" property is always required.
|
|
||||||
|
|
||||||
The Devicetree schemas don't exactly match the YAML encoded DT data produced by
|
|
||||||
dtc. They are simplified to make them more compact and avoid a bunch of
|
|
||||||
boilerplate. The tools process the schema files to produce the final schema for
|
|
||||||
validation. There are currently 2 transformations the tools perform.
|
|
||||||
|
|
||||||
The default for arrays in json-schema is they are variable sized and allow more
|
|
||||||
entries than explicitly defined. This can be restricted by defining 'minItems',
|
|
||||||
'maxItems', and 'additionalItems'. However, for DeviceTree Schemas, a fixed
|
|
||||||
size is desired in most cases, so these properties are added based on the
|
|
||||||
number of entries in an 'items' list.
|
|
||||||
|
|
||||||
The YAML Devicetree format also makes all string values an array and scalar
|
|
||||||
values a matrix (in order to define groupings) even when only a single value
|
|
||||||
is present. Single entries in schemas are fixed up to match this encoding.
|
|
||||||
|
|
||||||
## Testing
|
|
||||||
|
|
||||||
### Dependencies
|
|
||||||
|
|
||||||
The DT schema project must be installed in order to validate the DT schema
|
|
||||||
binding documents and validate DTS files using the DT schema. The DT schema
|
|
||||||
project can be installed with pip:
|
|
||||||
|
|
||||||
`pip3 install git+https://github.com/devicetree-org/dt-schema.git@master`
|
|
||||||
|
|
||||||
dtc must also be built with YAML output support enabled. This requires that
|
|
||||||
libyaml and its headers be installed on the host system.
|
|
||||||
|
|
||||||
### Running checks
|
|
||||||
|
|
||||||
The DT schema binding documents must be validated using the meta-schema (the
|
|
||||||
schema for the schema) to ensure they are both valid json-schema and valid
|
|
||||||
binding schema. All of the DT binding documents can be validated using the
|
|
||||||
`dt_binding_check` target:
|
|
||||||
|
|
||||||
`make dt_binding_check`
|
|
||||||
|
|
||||||
In order to perform validation of DT source files, use the `dtbs_check` target:
|
|
||||||
|
|
||||||
`make dtbs_check`
|
|
||||||
|
|
||||||
This will first run the `dt_binding_check` which generates the processed schema.
|
|
||||||
|
|
||||||
It is also possible to run checks with a single schema file by setting the
|
|
||||||
'DT_SCHEMA_FILES' variable to a specific schema file.
|
|
||||||
|
|
||||||
`make dtbs_check DT_SCHEMA_FILES=Documentation/devicetree/bindings/trivial-devices.yaml`
|
|
||||||
|
|
||||||
|
|
||||||
## json-schema Resources
|
|
||||||
|
|
||||||
[JSON-Schema Specifications](http://json-schema.org/)
|
|
||||||
|
|
||||||
[Using JSON Schema Book](http://usingjsonschema.com/)
|
|
153
Documentation/devicetree/writing-schema.rst
Normal file
153
Documentation/devicetree/writing-schema.rst
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
:orphan:
|
||||||
|
|
||||||
|
Writing DeviceTree Bindings in json-schema
|
||||||
|
==========================================
|
||||||
|
|
||||||
|
Devicetree bindings are written using json-schema vocabulary. Schema files are
|
||||||
|
written in a JSON compatible subset of YAML. YAML is used instead of JSON as it
|
||||||
|
considered more human readable and has some advantages such as allowing
|
||||||
|
comments (Prefixed with '#').
|
||||||
|
|
||||||
|
Schema Contents
|
||||||
|
---------------
|
||||||
|
|
||||||
|
Each schema doc is a structured json-schema which is defined by a set of
|
||||||
|
top-level properties. Generally, there is one binding defined per file. The
|
||||||
|
top-level json-schema properties used are:
|
||||||
|
|
||||||
|
$id
|
||||||
|
A json-schema unique identifier string. The string must be a valid
|
||||||
|
URI typically containing the binding's filename and path. For DT schema, it must
|
||||||
|
begin with "http://devicetree.org/schemas/". The URL is used in constructing
|
||||||
|
references to other files specified in schema "$ref" properties. A $ref values
|
||||||
|
with a leading '/' will have the hostname prepended. A $ref value a relative
|
||||||
|
path or filename only will be prepended with the hostname and path components
|
||||||
|
of the current schema file's '$id' value. A URL is used even for local files,
|
||||||
|
but there may not actually be files present at those locations.
|
||||||
|
|
||||||
|
$schema
|
||||||
|
Indicates the meta-schema the schema file adheres to.
|
||||||
|
|
||||||
|
title
|
||||||
|
A one line description on the contents of the binding schema.
|
||||||
|
|
||||||
|
maintainers
|
||||||
|
A DT specific property. Contains a list of email address(es)
|
||||||
|
for maintainers of this binding.
|
||||||
|
|
||||||
|
description
|
||||||
|
Optional. A multi-line text block containing any detailed
|
||||||
|
information about this binding. It should contain things such as what the block
|
||||||
|
or device does, standards the device conforms to, and links to datasheets for
|
||||||
|
more information.
|
||||||
|
|
||||||
|
select
|
||||||
|
Optional. A json-schema used to match nodes for applying the
|
||||||
|
schema. By default without 'select', nodes are matched against their possible
|
||||||
|
compatible string values or node name. Most bindings should not need select.
|
||||||
|
|
||||||
|
allOf
|
||||||
|
Optional. A list of other schemas to include. This is used to
|
||||||
|
include other schemas the binding conforms to. This may be schemas for a
|
||||||
|
particular class of devices such as I2C or SPI controllers.
|
||||||
|
|
||||||
|
properties
|
||||||
|
A set of sub-schema defining all the DT properties for the
|
||||||
|
binding. The exact schema syntax depends on whether properties are known,
|
||||||
|
common properties (e.g. 'interrupts') or are binding/vendor specific properties.
|
||||||
|
|
||||||
|
A property can also define a child DT node with child properties defined
|
||||||
|
under it.
|
||||||
|
|
||||||
|
For more details on properties sections, see 'Property Schema' section.
|
||||||
|
|
||||||
|
patternProperties
|
||||||
|
Optional. Similar to 'properties', but names are regex.
|
||||||
|
|
||||||
|
required
|
||||||
|
A list of DT properties from the 'properties' section that
|
||||||
|
must always be present.
|
||||||
|
|
||||||
|
examples
|
||||||
|
Optional. A list of one or more DTS hunks implementing the
|
||||||
|
binding. Note: YAML doesn't allow leading tabs, so spaces must be used instead.
|
||||||
|
|
||||||
|
Unless noted otherwise, all properties are required.
|
||||||
|
|
||||||
|
Property Schema
|
||||||
|
---------------
|
||||||
|
|
||||||
|
The 'properties' section of the schema contains all the DT properties for a
|
||||||
|
binding. Each property contains a set of constraints using json-schema
|
||||||
|
vocabulary for that property. The properties schemas are what is used for
|
||||||
|
validation of DT files.
|
||||||
|
|
||||||
|
For common properties, only additional constraints not covered by the common
|
||||||
|
binding schema need to be defined such as how many values are valid or what
|
||||||
|
possible values are valid.
|
||||||
|
|
||||||
|
Vendor specific properties will typically need more detailed schema. With the
|
||||||
|
exception of boolean properties, they should have a reference to a type in
|
||||||
|
schemas/types.yaml. A "description" property is always required.
|
||||||
|
|
||||||
|
The Devicetree schemas don't exactly match the YAML encoded DT data produced by
|
||||||
|
dtc. They are simplified to make them more compact and avoid a bunch of
|
||||||
|
boilerplate. The tools process the schema files to produce the final schema for
|
||||||
|
validation. There are currently 2 transformations the tools perform.
|
||||||
|
|
||||||
|
The default for arrays in json-schema is they are variable sized and allow more
|
||||||
|
entries than explicitly defined. This can be restricted by defining 'minItems',
|
||||||
|
'maxItems', and 'additionalItems'. However, for DeviceTree Schemas, a fixed
|
||||||
|
size is desired in most cases, so these properties are added based on the
|
||||||
|
number of entries in an 'items' list.
|
||||||
|
|
||||||
|
The YAML Devicetree format also makes all string values an array and scalar
|
||||||
|
values a matrix (in order to define groupings) even when only a single value
|
||||||
|
is present. Single entries in schemas are fixed up to match this encoding.
|
||||||
|
|
||||||
|
Testing
|
||||||
|
-------
|
||||||
|
|
||||||
|
Dependencies
|
||||||
|
~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The DT schema project must be installed in order to validate the DT schema
|
||||||
|
binding documents and validate DTS files using the DT schema. The DT schema
|
||||||
|
project can be installed with pip::
|
||||||
|
|
||||||
|
pip3 install git+https://github.com/devicetree-org/dt-schema.git@master
|
||||||
|
|
||||||
|
dtc must also be built with YAML output support enabled. This requires that
|
||||||
|
libyaml and its headers be installed on the host system.
|
||||||
|
|
||||||
|
Running checks
|
||||||
|
~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The DT schema binding documents must be validated using the meta-schema (the
|
||||||
|
schema for the schema) to ensure they are both valid json-schema and valid
|
||||||
|
binding schema. All of the DT binding documents can be validated using the
|
||||||
|
``dt_binding_check`` target::
|
||||||
|
|
||||||
|
make dt_binding_check
|
||||||
|
|
||||||
|
In order to perform validation of DT source files, use the `dtbs_check` target::
|
||||||
|
|
||||||
|
make dtbs_check
|
||||||
|
|
||||||
|
This will first run the `dt_binding_check` which generates the processed schema.
|
||||||
|
|
||||||
|
It is also possible to run checks with a single schema file by setting the
|
||||||
|
``DT_SCHEMA_FILES`` variable to a specific schema file.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
make dtbs_check DT_SCHEMA_FILES=Documentation/devicetree/bindings/trivial-devices.yaml
|
||||||
|
|
||||||
|
|
||||||
|
json-schema Resources
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
|
||||||
|
`JSON-Schema Specifications <http://json-schema.org/>`_
|
||||||
|
|
||||||
|
`Using JSON Schema Book <http://usingjsonschema.com/>`_
|
@ -47,7 +47,7 @@ This book adds some notes about PXA DMA
|
|||||||
|
|
||||||
pxa_dma
|
pxa_dma
|
||||||
|
|
||||||
.. only:: subproject
|
.. only:: subproject and html
|
||||||
|
|
||||||
Indices
|
Indices
|
||||||
=======
|
=======
|
||||||
|
@ -65,6 +65,7 @@ available subsections can be seen below.
|
|||||||
dmaengine/index
|
dmaengine/index
|
||||||
slimbus
|
slimbus
|
||||||
soundwire/index
|
soundwire/index
|
||||||
|
thermal/index
|
||||||
fpga/index
|
fpga/index
|
||||||
acpi/index
|
acpi/index
|
||||||
backlight/lp855x-driver.rst
|
backlight/lp855x-driver.rst
|
||||||
@ -75,6 +76,7 @@ available subsections can be seen below.
|
|||||||
dell_rbu
|
dell_rbu
|
||||||
edid
|
edid
|
||||||
eisa
|
eisa
|
||||||
|
ipmb
|
||||||
isa
|
isa
|
||||||
isapnp
|
isapnp
|
||||||
generic-counter
|
generic-counter
|
||||||
|
@ -83,7 +83,7 @@ Instantiate the device
|
|||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
After loading the driver, you can instantiate the device as
|
After loading the driver, you can instantiate the device as
|
||||||
described in 'Documentation/i2c/instantiating-devices'.
|
described in 'Documentation/i2c/instantiating-devices.rst'.
|
||||||
If you have multiple BMCs, each connected to your Satellite MC via
|
If you have multiple BMCs, each connected to your Satellite MC via
|
||||||
a different I2C bus, you can instantiate a device for each of
|
a different I2C bus, you can instantiate a device for each of
|
||||||
those BMCs.
|
those BMCs.
|
||||||
|
@ -59,7 +59,7 @@ Part III - How can drivers use the framework?
|
|||||||
|
|
||||||
The main API is spi_nor_scan(). Before you call the hook, a driver should
|
The main API is spi_nor_scan(). Before you call the hook, a driver should
|
||||||
initialize the necessary fields for spi_nor{}. Please see
|
initialize the necessary fields for spi_nor{}. Please see
|
||||||
drivers/mtd/spi-nor/spi-nor.c for detail. Please also refer to fsl-quadspi.c
|
drivers/mtd/spi-nor/spi-nor.c for detail. Please also refer to spi-fsl-qspi.c
|
||||||
when you want to write a new driver for a SPI NOR controller.
|
when you want to write a new driver for a SPI NOR controller.
|
||||||
Another API is spi_nor_restore(), this is used to restore the status of SPI
|
Another API is spi_nor_restore(), this is used to restore the status of SPI
|
||||||
flash chip such as addressing mode. Call it whenever detach the driver from
|
flash chip such as addressing mode. Call it whenever detach the driver from
|
||||||
|
@ -10,7 +10,7 @@ SoundWire Documentation
|
|||||||
error_handling
|
error_handling
|
||||||
locking
|
locking
|
||||||
|
|
||||||
.. only:: subproject
|
.. only:: subproject and html
|
||||||
|
|
||||||
Indices
|
Indices
|
||||||
=======
|
=======
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
:orphan:
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
=======
|
=======
|
||||||
Thermal
|
Thermal
|
@ -552,7 +552,7 @@ emul_temp
|
|||||||
sustainable_power
|
sustainable_power
|
||||||
An estimate of the sustained power that can be dissipated by
|
An estimate of the sustained power that can be dissipated by
|
||||||
the thermal zone. Used by the power allocator governor. For
|
the thermal zone. Used by the power allocator governor. For
|
||||||
more information see Documentation/thermal/power_allocator.rst
|
more information see Documentation/driver-api/thermal/power_allocator.rst
|
||||||
|
|
||||||
Unit: milliwatts
|
Unit: milliwatts
|
||||||
|
|
||||||
@ -563,7 +563,7 @@ k_po
|
|||||||
controller during temperature overshoot. Temperature overshoot
|
controller during temperature overshoot. Temperature overshoot
|
||||||
is when the current temperature is above the "desired
|
is when the current temperature is above the "desired
|
||||||
temperature" trip point. For more information see
|
temperature" trip point. For more information see
|
||||||
Documentation/thermal/power_allocator.rst
|
Documentation/driver-api/thermal/power_allocator.rst
|
||||||
|
|
||||||
RW, Optional
|
RW, Optional
|
||||||
|
|
||||||
@ -572,7 +572,7 @@ k_pu
|
|||||||
controller during temperature undershoot. Temperature undershoot
|
controller during temperature undershoot. Temperature undershoot
|
||||||
is when the current temperature is below the "desired
|
is when the current temperature is below the "desired
|
||||||
temperature" trip point. For more information see
|
temperature" trip point. For more information see
|
||||||
Documentation/thermal/power_allocator.rst
|
Documentation/driver-api/thermal/power_allocator.rst
|
||||||
|
|
||||||
RW, Optional
|
RW, Optional
|
||||||
|
|
||||||
@ -580,14 +580,14 @@ k_i
|
|||||||
The integral term of the power allocator governor's PID
|
The integral term of the power allocator governor's PID
|
||||||
controller. This term allows the PID controller to compensate
|
controller. This term allows the PID controller to compensate
|
||||||
for long term drift. For more information see
|
for long term drift. For more information see
|
||||||
Documentation/thermal/power_allocator.rst
|
Documentation/driver-api/thermal/power_allocator.rst
|
||||||
|
|
||||||
RW, Optional
|
RW, Optional
|
||||||
|
|
||||||
k_d
|
k_d
|
||||||
The derivative term of the power allocator governor's PID
|
The derivative term of the power allocator governor's PID
|
||||||
controller. For more information see
|
controller. For more information see
|
||||||
Documentation/thermal/power_allocator.rst
|
Documentation/driver-api/thermal/power_allocator.rst
|
||||||
|
|
||||||
RW, Optional
|
RW, Optional
|
||||||
|
|
||||||
@ -598,7 +598,7 @@ integral_cutoff
|
|||||||
example, if integral_cutoff is 0, then the integral term only
|
example, if integral_cutoff is 0, then the integral term only
|
||||||
accumulates error when temperature is above the desired
|
accumulates error when temperature is above the desired
|
||||||
temperature trip point. For more information see
|
temperature trip point. For more information see
|
||||||
Documentation/thermal/power_allocator.rst
|
Documentation/driver-api/thermal/power_allocator.rst
|
||||||
|
|
||||||
Unit: millidegree Celsius
|
Unit: millidegree Celsius
|
||||||
|
|
@ -40,7 +40,7 @@ This contains two trip points:
|
|||||||
- trip_point_1_temp
|
- trip_point_1_temp
|
||||||
|
|
||||||
User can set any temperature between 0 to TJ-Max temperature. Temperature units
|
User can set any temperature between 0 to TJ-Max temperature. Temperature units
|
||||||
are in milli-degree Celsius. Refer to "Documentation/thermal/sysfs-api.rst" for
|
are in milli-degree Celsius. Refer to "Documentation/driver-api/thermal/sysfs-api.rst" for
|
||||||
thermal sys-fs details.
|
thermal sys-fs details.
|
||||||
|
|
||||||
Any value other than 0 in these trip points, can trigger thermal notifications.
|
Any value other than 0 in these trip points, can trigger thermal notifications.
|
@ -30,5 +30,5 @@
|
|||||||
| um: | TODO |
|
| um: | TODO |
|
||||||
| unicore32: | TODO |
|
| unicore32: | TODO |
|
||||||
| x86: | ok |
|
| x86: | ok |
|
||||||
| xtensa: | TODO |
|
| xtensa: | ok |
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
| alpha: | TODO |
|
| alpha: | TODO |
|
||||||
| arc: | TODO |
|
| arc: | TODO |
|
||||||
| arm: | TODO |
|
| arm: | TODO |
|
||||||
| arm64: | TODO |
|
| arm64: | ok |
|
||||||
| c6x: | TODO |
|
| c6x: | TODO |
|
||||||
| csky: | TODO |
|
| csky: | TODO |
|
||||||
| h8300: | TODO |
|
| h8300: | TODO |
|
||||||
@ -30,5 +30,5 @@
|
|||||||
| um: | TODO |
|
| um: | TODO |
|
||||||
| unicore32: | TODO |
|
| unicore32: | TODO |
|
||||||
| x86: | ok |
|
| x86: | ok |
|
||||||
| xtensa: | TODO |
|
| xtensa: | ok |
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -1,34 +0,0 @@
|
|||||||
#
|
|
||||||
# Feature name: rwsem-optimized
|
|
||||||
# Kconfig: !RWSEM_GENERIC_SPINLOCK
|
|
||||||
# description: arch provides optimized rwsem APIs
|
|
||||||
#
|
|
||||||
-----------------------
|
|
||||||
| arch |status|
|
|
||||||
-----------------------
|
|
||||||
| alpha: | ok |
|
|
||||||
| arc: | TODO |
|
|
||||||
| arm: | ok |
|
|
||||||
| arm64: | ok |
|
|
||||||
| c6x: | TODO |
|
|
||||||
| csky: | TODO |
|
|
||||||
| h8300: | TODO |
|
|
||||||
| hexagon: | TODO |
|
|
||||||
| ia64: | ok |
|
|
||||||
| m68k: | TODO |
|
|
||||||
| microblaze: | TODO |
|
|
||||||
| mips: | TODO |
|
|
||||||
| nds32: | TODO |
|
|
||||||
| nios2: | TODO |
|
|
||||||
| openrisc: | TODO |
|
|
||||||
| parisc: | TODO |
|
|
||||||
| powerpc: | TODO |
|
|
||||||
| riscv: | TODO |
|
|
||||||
| s390: | ok |
|
|
||||||
| sh: | ok |
|
|
||||||
| sparc: | ok |
|
|
||||||
| um: | ok |
|
|
||||||
| unicore32: | TODO |
|
|
||||||
| x86: | ok |
|
|
||||||
| xtensa: | ok |
|
|
||||||
-----------------------
|
|
@ -421,7 +421,7 @@ kernel support.
|
|||||||
|
|
||||||
|
|
||||||
The CodaCred structure defines a variety of user and group ids as
|
The CodaCred structure defines a variety of user and group ids as
|
||||||
they are set for the calling process. The vuid_t and guid_t are 32 bit
|
they are set for the calling process. The vuid_t and vgid_t are 32 bit
|
||||||
unsigned integers. It also defines group membership in an array. On
|
unsigned integers. It also defines group membership in an array. On
|
||||||
Unix the CodaCred has proven sufficient to implement good security
|
Unix the CodaCred has proven sufficient to implement good security
|
||||||
semantics for Coda but the structure may have to undergo modification
|
semantics for Coda but the structure may have to undergo modification
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
=================
|
||||||
|
Directory Locking
|
||||||
|
=================
|
||||||
|
|
||||||
|
|
||||||
Locking scheme used for directory operations is based on two
|
Locking scheme used for directory operations is based on two
|
||||||
kinds of locks - per-inode (->i_rwsem) and per-filesystem
|
kinds of locks - per-inode (->i_rwsem) and per-filesystem
|
||||||
(->s_vfs_rename_mutex).
|
(->s_vfs_rename_mutex).
|
||||||
@ -27,14 +32,17 @@ NB: we might get away with locking the the source (and target in exchange
|
|||||||
case) shared.
|
case) shared.
|
||||||
|
|
||||||
5) link creation. Locking rules:
|
5) link creation. Locking rules:
|
||||||
|
|
||||||
* lock parent
|
* lock parent
|
||||||
* check that source is not a directory
|
* check that source is not a directory
|
||||||
* lock source
|
* lock source
|
||||||
* call the method.
|
* call the method.
|
||||||
|
|
||||||
All locks are exclusive.
|
All locks are exclusive.
|
||||||
|
|
||||||
6) cross-directory rename. The trickiest in the whole bunch. Locking
|
6) cross-directory rename. The trickiest in the whole bunch. Locking
|
||||||
rules:
|
rules:
|
||||||
|
|
||||||
* lock the filesystem
|
* lock the filesystem
|
||||||
* lock parents in "ancestors first" order.
|
* lock parents in "ancestors first" order.
|
||||||
* find source and target.
|
* find source and target.
|
||||||
@ -46,6 +54,7 @@ rules:
|
|||||||
* If the target exists, lock it. If the source is a non-directory,
|
* If the target exists, lock it. If the source is a non-directory,
|
||||||
lock it. If we need to lock both, do so in inode pointer order.
|
lock it. If we need to lock both, do so in inode pointer order.
|
||||||
* call the method.
|
* call the method.
|
||||||
|
|
||||||
All ->i_rwsem are taken exclusive. Again, we might get away with locking
|
All ->i_rwsem are taken exclusive. Again, we might get away with locking
|
||||||
the the source (and target in exchange case) shared.
|
the the source (and target in exchange case) shared.
|
||||||
|
|
||||||
@ -54,6 +63,7 @@ read, modified or removed by method will be locked by caller.
|
|||||||
|
|
||||||
|
|
||||||
If no directory is its own ancestor, the scheme above is deadlock-free.
|
If no directory is its own ancestor, the scheme above is deadlock-free.
|
||||||
|
|
||||||
Proof:
|
Proof:
|
||||||
|
|
||||||
First of all, at any moment we have a partial ordering of the
|
First of all, at any moment we have a partial ordering of the
|
@ -20,6 +20,10 @@ algorithms work.
|
|||||||
path-lookup
|
path-lookup
|
||||||
api-summary
|
api-summary
|
||||||
splice
|
splice
|
||||||
|
locking
|
||||||
|
directory-locking
|
||||||
|
|
||||||
|
porting
|
||||||
|
|
||||||
Filesystem support layers
|
Filesystem support layers
|
||||||
=========================
|
=========================
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
=======
|
||||||
|
Locking
|
||||||
|
=======
|
||||||
|
|
||||||
The text below describes the locking rules for VFS-related methods.
|
The text below describes the locking rules for VFS-related methods.
|
||||||
It is (believed to be) up-to-date. *Please*, if you change anything in
|
It is (believed to be) up-to-date. *Please*, if you change anything in
|
||||||
prototypes or locking protocols - update this file. And update the relevant
|
prototypes or locking protocols - update this file. And update the relevant
|
||||||
@ -5,10 +9,14 @@ instances in the tree, don't leave that to maintainers of filesystems/devices/
|
|||||||
etc. At the very least, put the list of dubious cases in the end of this file.
|
etc. At the very least, put the list of dubious cases in the end of this file.
|
||||||
Don't turn it into log - maintainers of out-of-the-tree code are supposed to
|
Don't turn it into log - maintainers of out-of-the-tree code are supposed to
|
||||||
be able to use diff(1).
|
be able to use diff(1).
|
||||||
|
|
||||||
Thing currently missing here: socket operations. Alexey?
|
Thing currently missing here: socket operations. Alexey?
|
||||||
|
|
||||||
--------------------------- dentry_operations --------------------------
|
dentry_operations
|
||||||
prototypes:
|
=================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
int (*d_revalidate)(struct dentry *, unsigned int);
|
int (*d_revalidate)(struct dentry *, unsigned int);
|
||||||
int (*d_weak_revalidate)(struct dentry *, unsigned int);
|
int (*d_weak_revalidate)(struct dentry *, unsigned int);
|
||||||
int (*d_hash)(const struct dentry *, struct qstr *);
|
int (*d_hash)(const struct dentry *, struct qstr *);
|
||||||
@ -24,7 +32,10 @@ prototypes:
|
|||||||
struct dentry *(*d_real)(struct dentry *, const struct inode *);
|
struct dentry *(*d_real)(struct dentry *, const struct inode *);
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
rename_lock ->d_lock may block rcu-walk
|
|
||||||
|
================== =========== ======== ============== ========
|
||||||
|
ops rename_lock ->d_lock may block rcu-walk
|
||||||
|
================== =========== ======== ============== ========
|
||||||
d_revalidate: no no yes (ref-walk) maybe
|
d_revalidate: no no yes (ref-walk) maybe
|
||||||
d_weak_revalidate: no no yes no
|
d_weak_revalidate: no no yes no
|
||||||
d_hash no no no maybe
|
d_hash no no no maybe
|
||||||
@ -38,9 +49,13 @@ d_dname: no no no no
|
|||||||
d_automount: no no yes no
|
d_automount: no no yes no
|
||||||
d_manage: no no yes (ref-walk) maybe
|
d_manage: no no yes (ref-walk) maybe
|
||||||
d_real no no yes no
|
d_real no no yes no
|
||||||
|
================== =========== ======== ============== ========
|
||||||
|
|
||||||
|
inode_operations
|
||||||
|
================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
--------------------------- inode_operations ---------------------------
|
|
||||||
prototypes:
|
|
||||||
int (*create) (struct inode *,struct dentry *,umode_t, bool);
|
int (*create) (struct inode *,struct dentry *,umode_t, bool);
|
||||||
struct dentry * (*lookup) (struct inode *,struct dentry *, unsigned int);
|
struct dentry * (*lookup) (struct inode *,struct dentry *, unsigned int);
|
||||||
int (*link) (struct dentry *,struct inode *,struct dentry *);
|
int (*link) (struct dentry *,struct inode *,struct dentry *);
|
||||||
@ -68,7 +83,10 @@ prototypes:
|
|||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
all may block
|
all may block
|
||||||
i_rwsem(inode)
|
|
||||||
|
============ =============================================
|
||||||
|
ops i_rwsem(inode)
|
||||||
|
============ =============================================
|
||||||
lookup: shared
|
lookup: shared
|
||||||
create: exclusive
|
create: exclusive
|
||||||
link: exclusive (both)
|
link: exclusive (both)
|
||||||
@ -89,17 +107,21 @@ fiemap: no
|
|||||||
update_time: no
|
update_time: no
|
||||||
atomic_open: exclusive
|
atomic_open: exclusive
|
||||||
tmpfile: no
|
tmpfile: no
|
||||||
|
============ =============================================
|
||||||
|
|
||||||
|
|
||||||
Additionally, ->rmdir(), ->unlink() and ->rename() have ->i_rwsem
|
Additionally, ->rmdir(), ->unlink() and ->rename() have ->i_rwsem
|
||||||
exclusive on victim.
|
exclusive on victim.
|
||||||
cross-directory ->rename() has (per-superblock) ->s_vfs_rename_sem.
|
cross-directory ->rename() has (per-superblock) ->s_vfs_rename_sem.
|
||||||
|
|
||||||
See Documentation/filesystems/directory-locking for more detailed discussion
|
See Documentation/filesystems/directory-locking.rst for more detailed discussion
|
||||||
of the locking scheme for directory operations.
|
of the locking scheme for directory operations.
|
||||||
|
|
||||||
----------------------- xattr_handler operations -----------------------
|
xattr_handler operations
|
||||||
prototypes:
|
========================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
bool (*list)(struct dentry *dentry);
|
bool (*list)(struct dentry *dentry);
|
||||||
int (*get)(const struct xattr_handler *handler, struct dentry *dentry,
|
int (*get)(const struct xattr_handler *handler, struct dentry *dentry,
|
||||||
struct inode *inode, const char *name, void *buffer,
|
struct inode *inode, const char *name, void *buffer,
|
||||||
@ -110,13 +132,20 @@ prototypes:
|
|||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
all may block
|
all may block
|
||||||
i_rwsem(inode)
|
|
||||||
|
===== ==============
|
||||||
|
ops i_rwsem(inode)
|
||||||
|
===== ==============
|
||||||
list: no
|
list: no
|
||||||
get: no
|
get: no
|
||||||
set: exclusive
|
set: exclusive
|
||||||
|
===== ==============
|
||||||
|
|
||||||
|
super_operations
|
||||||
|
================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
--------------------------- super_operations ---------------------------
|
|
||||||
prototypes:
|
|
||||||
struct inode *(*alloc_inode)(struct super_block *sb);
|
struct inode *(*alloc_inode)(struct super_block *sb);
|
||||||
void (*free_inode)(struct inode *);
|
void (*free_inode)(struct inode *);
|
||||||
void (*destroy_inode)(struct inode *);
|
void (*destroy_inode)(struct inode *);
|
||||||
@ -138,7 +167,10 @@ prototypes:
|
|||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
All may block [not true, see below]
|
All may block [not true, see below]
|
||||||
s_umount
|
|
||||||
|
====================== ============ ========================
|
||||||
|
ops s_umount note
|
||||||
|
====================== ============ ========================
|
||||||
alloc_inode:
|
alloc_inode:
|
||||||
free_inode: called from RCU callback
|
free_inode: called from RCU callback
|
||||||
destroy_inode:
|
destroy_inode:
|
||||||
@ -157,6 +189,7 @@ show_options: no (namespace_sem)
|
|||||||
quota_read: no (see below)
|
quota_read: no (see below)
|
||||||
quota_write: no (see below)
|
quota_write: no (see below)
|
||||||
bdev_try_to_free_page: no (see below)
|
bdev_try_to_free_page: no (see below)
|
||||||
|
====================== ============ ========================
|
||||||
|
|
||||||
->statfs() has s_umount (shared) when called by ustat(2) (native or
|
->statfs() has s_umount (shared) when called by ustat(2) (native or
|
||||||
compat), but that's an accident of bad API; s_umount is used to pin
|
compat), but that's an accident of bad API; s_umount is used to pin
|
||||||
@ -164,31 +197,44 @@ the superblock down when we only have dev_t given us by userland to
|
|||||||
identify the superblock. Everything else (statfs(), fstatfs(), etc.)
|
identify the superblock. Everything else (statfs(), fstatfs(), etc.)
|
||||||
doesn't hold it when calling ->statfs() - superblock is pinned down
|
doesn't hold it when calling ->statfs() - superblock is pinned down
|
||||||
by resolving the pathname passed to syscall.
|
by resolving the pathname passed to syscall.
|
||||||
|
|
||||||
->quota_read() and ->quota_write() functions are both guaranteed to
|
->quota_read() and ->quota_write() functions are both guaranteed to
|
||||||
be the only ones operating on the quota file by the quota code (via
|
be the only ones operating on the quota file by the quota code (via
|
||||||
dqio_sem) (unless an admin really wants to screw up something and
|
dqio_sem) (unless an admin really wants to screw up something and
|
||||||
writes to quota files with quotas on). For other details about locking
|
writes to quota files with quotas on). For other details about locking
|
||||||
see also dquot_operations section.
|
see also dquot_operations section.
|
||||||
|
|
||||||
->bdev_try_to_free_page is called from the ->releasepage handler of
|
->bdev_try_to_free_page is called from the ->releasepage handler of
|
||||||
the block device inode. See there for more details.
|
the block device inode. See there for more details.
|
||||||
|
|
||||||
--------------------------- file_system_type ---------------------------
|
file_system_type
|
||||||
prototypes:
|
================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
struct dentry *(*mount) (struct file_system_type *, int,
|
struct dentry *(*mount) (struct file_system_type *, int,
|
||||||
const char *, void *);
|
const char *, void *);
|
||||||
void (*kill_sb) (struct super_block *);
|
void (*kill_sb) (struct super_block *);
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
may block
|
|
||||||
|
======= =========
|
||||||
|
ops may block
|
||||||
|
======= =========
|
||||||
mount yes
|
mount yes
|
||||||
kill_sb yes
|
kill_sb yes
|
||||||
|
======= =========
|
||||||
|
|
||||||
->mount() returns ERR_PTR or the root dentry; its superblock should be locked
|
->mount() returns ERR_PTR or the root dentry; its superblock should be locked
|
||||||
on return.
|
on return.
|
||||||
|
|
||||||
->kill_sb() takes a write-locked superblock, does all shutdown work on it,
|
->kill_sb() takes a write-locked superblock, does all shutdown work on it,
|
||||||
unlocks and drops the reference.
|
unlocks and drops the reference.
|
||||||
|
|
||||||
--------------------------- address_space_operations --------------------------
|
address_space_operations
|
||||||
prototypes:
|
========================
|
||||||
|
prototypes::
|
||||||
|
|
||||||
int (*writepage)(struct page *page, struct writeback_control *wbc);
|
int (*writepage)(struct page *page, struct writeback_control *wbc);
|
||||||
int (*readpage)(struct file *, struct page *);
|
int (*readpage)(struct file *, struct page *);
|
||||||
int (*writepages)(struct address_space *, struct writeback_control *);
|
int (*writepages)(struct address_space *, struct writeback_control *);
|
||||||
@ -218,7 +264,9 @@ prototypes:
|
|||||||
locking rules:
|
locking rules:
|
||||||
All except set_page_dirty and freepage may block
|
All except set_page_dirty and freepage may block
|
||||||
|
|
||||||
PageLocked(page) i_rwsem
|
====================== ======================== =========
|
||||||
|
ops PageLocked(page) i_rwsem
|
||||||
|
====================== ======================== =========
|
||||||
writepage: yes, unlocks (see below)
|
writepage: yes, unlocks (see below)
|
||||||
readpage: yes, unlocks
|
readpage: yes, unlocks
|
||||||
writepages:
|
writepages:
|
||||||
@ -239,6 +287,7 @@ is_partially_uptodate: yes
|
|||||||
error_remove_page: yes
|
error_remove_page: yes
|
||||||
swap_activate: no
|
swap_activate: no
|
||||||
swap_deactivate: no
|
swap_deactivate: no
|
||||||
|
====================== ======================== =========
|
||||||
|
|
||||||
->write_begin(), ->write_end() and ->readpage() may be called from
|
->write_begin(), ->write_end() and ->readpage() may be called from
|
||||||
the request handler (/dev/loop).
|
the request handler (/dev/loop).
|
||||||
@ -299,10 +348,10 @@ in the filesystem like having dirty inodes at umount and losing written data.
|
|||||||
|
|
||||||
->writepages() is used for periodic writeback and for syscall-initiated
|
->writepages() is used for periodic writeback and for syscall-initiated
|
||||||
sync operations. The address_space should start I/O against at least
|
sync operations. The address_space should start I/O against at least
|
||||||
*nr_to_write pages. *nr_to_write must be decremented for each page which is
|
``*nr_to_write`` pages. ``*nr_to_write`` must be decremented for each page
|
||||||
written. The address_space implementation may write more (or less) pages
|
which is written. The address_space implementation may write more (or less)
|
||||||
than *nr_to_write asks for, but it should try to be reasonably close. If
|
pages than ``*nr_to_write`` asks for, but it should try to be reasonably close.
|
||||||
nr_to_write is NULL, all dirty pages must be written.
|
If nr_to_write is NULL, all dirty pages must be written.
|
||||||
|
|
||||||
writepages should _only_ write pages which are present on
|
writepages should _only_ write pages which are present on
|
||||||
mapping->io_pages.
|
mapping->io_pages.
|
||||||
@ -344,23 +393,34 @@ address space operations.
|
|||||||
->swap_deactivate() will be called in the sys_swapoff()
|
->swap_deactivate() will be called in the sys_swapoff()
|
||||||
path after ->swap_activate() returned success.
|
path after ->swap_activate() returned success.
|
||||||
|
|
||||||
----------------------- file_lock_operations ------------------------------
|
file_lock_operations
|
||||||
prototypes:
|
====================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
void (*fl_copy_lock)(struct file_lock *, struct file_lock *);
|
void (*fl_copy_lock)(struct file_lock *, struct file_lock *);
|
||||||
void (*fl_release_private)(struct file_lock *);
|
void (*fl_release_private)(struct file_lock *);
|
||||||
|
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
inode->i_lock may block
|
|
||||||
fl_copy_lock: yes no
|
|
||||||
fl_release_private: maybe maybe[1]
|
|
||||||
|
|
||||||
[1]: ->fl_release_private for flock or POSIX locks is currently allowed
|
=================== ============= =========
|
||||||
|
ops inode->i_lock may block
|
||||||
|
=================== ============= =========
|
||||||
|
fl_copy_lock: yes no
|
||||||
|
fl_release_private: maybe maybe[1]_
|
||||||
|
=================== ============= =========
|
||||||
|
|
||||||
|
.. [1]:
|
||||||
|
->fl_release_private for flock or POSIX locks is currently allowed
|
||||||
to block. Leases however can still be freed while the i_lock is held and
|
to block. Leases however can still be freed while the i_lock is held and
|
||||||
so fl_release_private called on a lease should not block.
|
so fl_release_private called on a lease should not block.
|
||||||
|
|
||||||
----------------------- lock_manager_operations ---------------------------
|
lock_manager_operations
|
||||||
prototypes:
|
=======================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
void (*lm_notify)(struct file_lock *); /* unblock callback */
|
void (*lm_notify)(struct file_lock *); /* unblock callback */
|
||||||
int (*lm_grant)(struct file_lock *, struct file_lock *, int);
|
int (*lm_grant)(struct file_lock *, struct file_lock *, int);
|
||||||
void (*lm_break)(struct file_lock *); /* break_lease callback */
|
void (*lm_break)(struct file_lock *); /* break_lease callback */
|
||||||
@ -368,24 +428,33 @@ prototypes:
|
|||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
|
|
||||||
inode->i_lock blocked_lock_lock may block
|
========== ============= ================= =========
|
||||||
|
ops inode->i_lock blocked_lock_lock may block
|
||||||
|
========== ============= ================= =========
|
||||||
lm_notify: yes yes no
|
lm_notify: yes yes no
|
||||||
lm_grant: no no no
|
lm_grant: no no no
|
||||||
lm_break: yes no no
|
lm_break: yes no no
|
||||||
lm_change yes no no
|
lm_change yes no no
|
||||||
|
========== ============= ================= =========
|
||||||
|
|
||||||
|
buffer_head
|
||||||
|
===========
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
--------------------------- buffer_head -----------------------------------
|
|
||||||
prototypes:
|
|
||||||
void (*b_end_io)(struct buffer_head *bh, int uptodate);
|
void (*b_end_io)(struct buffer_head *bh, int uptodate);
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
|
|
||||||
called from interrupts. In other words, extreme care is needed here.
|
called from interrupts. In other words, extreme care is needed here.
|
||||||
bh is locked, but that's all warranties we have here. Currently only RAID1,
|
bh is locked, but that's all warranties we have here. Currently only RAID1,
|
||||||
highmem, fs/buffer.c, and fs/ntfs/aops.c are providing these. Block devices
|
highmem, fs/buffer.c, and fs/ntfs/aops.c are providing these. Block devices
|
||||||
call this method upon the IO completion.
|
call this method upon the IO completion.
|
||||||
|
|
||||||
--------------------------- block_device_operations -----------------------
|
block_device_operations
|
||||||
prototypes:
|
=======================
|
||||||
|
prototypes::
|
||||||
|
|
||||||
int (*open) (struct block_device *, fmode_t);
|
int (*open) (struct block_device *, fmode_t);
|
||||||
int (*release) (struct gendisk *, fmode_t);
|
int (*release) (struct gendisk *, fmode_t);
|
||||||
int (*ioctl) (struct block_device *, fmode_t, unsigned, unsigned long);
|
int (*ioctl) (struct block_device *, fmode_t, unsigned, unsigned long);
|
||||||
@ -399,7 +468,10 @@ prototypes:
|
|||||||
void (*swap_slot_free_notify) (struct block_device *, unsigned long);
|
void (*swap_slot_free_notify) (struct block_device *, unsigned long);
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
bd_mutex
|
|
||||||
|
======================= ===================
|
||||||
|
ops bd_mutex
|
||||||
|
======================= ===================
|
||||||
open: yes
|
open: yes
|
||||||
release: yes
|
release: yes
|
||||||
ioctl: no
|
ioctl: no
|
||||||
@ -410,6 +482,7 @@ unlock_native_capacity: no
|
|||||||
revalidate_disk: no
|
revalidate_disk: no
|
||||||
getgeo: no
|
getgeo: no
|
||||||
swap_slot_free_notify: no (see below)
|
swap_slot_free_notify: no (see below)
|
||||||
|
======================= ===================
|
||||||
|
|
||||||
media_changed, unlock_native_capacity and revalidate_disk are called only from
|
media_changed, unlock_native_capacity and revalidate_disk are called only from
|
||||||
check_disk_change().
|
check_disk_change().
|
||||||
@ -418,8 +491,11 @@ swap_slot_free_notify is called with swap_lock and sometimes the page lock
|
|||||||
held.
|
held.
|
||||||
|
|
||||||
|
|
||||||
--------------------------- file_operations -------------------------------
|
file_operations
|
||||||
prototypes:
|
===============
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
loff_t (*llseek) (struct file *, loff_t, int);
|
loff_t (*llseek) (struct file *, loff_t, int);
|
||||||
ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
|
ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
|
||||||
ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *);
|
ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *);
|
||||||
@ -455,7 +531,6 @@ prototypes:
|
|||||||
size_t, unsigned int);
|
size_t, unsigned int);
|
||||||
int (*setlease)(struct file *, long, struct file_lock **, void **);
|
int (*setlease)(struct file *, long, struct file_lock **, void **);
|
||||||
long (*fallocate)(struct file *, int, loff_t, loff_t);
|
long (*fallocate)(struct file *, int, loff_t, loff_t);
|
||||||
};
|
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
All may block.
|
All may block.
|
||||||
@ -490,8 +565,11 @@ in sys_read() and friends.
|
|||||||
the lease within the individual filesystem to record the result of the
|
the lease within the individual filesystem to record the result of the
|
||||||
operation
|
operation
|
||||||
|
|
||||||
--------------------------- dquot_operations -------------------------------
|
dquot_operations
|
||||||
prototypes:
|
================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
int (*write_dquot) (struct dquot *);
|
int (*write_dquot) (struct dquot *);
|
||||||
int (*acquire_dquot) (struct dquot *);
|
int (*acquire_dquot) (struct dquot *);
|
||||||
int (*release_dquot) (struct dquot *);
|
int (*release_dquot) (struct dquot *);
|
||||||
@ -503,20 +581,26 @@ a proper locking wrt the filesystem and call the generic quota operations.
|
|||||||
|
|
||||||
What filesystem should expect from the generic quota functions:
|
What filesystem should expect from the generic quota functions:
|
||||||
|
|
||||||
FS recursion Held locks when called
|
============== ============ =========================
|
||||||
|
ops FS recursion Held locks when called
|
||||||
|
============== ============ =========================
|
||||||
write_dquot: yes dqonoff_sem or dqptr_sem
|
write_dquot: yes dqonoff_sem or dqptr_sem
|
||||||
acquire_dquot: yes dqonoff_sem or dqptr_sem
|
acquire_dquot: yes dqonoff_sem or dqptr_sem
|
||||||
release_dquot: yes dqonoff_sem or dqptr_sem
|
release_dquot: yes dqonoff_sem or dqptr_sem
|
||||||
mark_dirty: no -
|
mark_dirty: no -
|
||||||
write_info: yes dqonoff_sem
|
write_info: yes dqonoff_sem
|
||||||
|
============== ============ =========================
|
||||||
|
|
||||||
FS recursion means calling ->quota_read() and ->quota_write() from superblock
|
FS recursion means calling ->quota_read() and ->quota_write() from superblock
|
||||||
operations.
|
operations.
|
||||||
|
|
||||||
More details about quota locking can be found in fs/dquot.c.
|
More details about quota locking can be found in fs/dquot.c.
|
||||||
|
|
||||||
--------------------------- vm_operations_struct -----------------------------
|
vm_operations_struct
|
||||||
prototypes:
|
====================
|
||||||
|
|
||||||
|
prototypes::
|
||||||
|
|
||||||
void (*open)(struct vm_area_struct*);
|
void (*open)(struct vm_area_struct*);
|
||||||
void (*close)(struct vm_area_struct*);
|
void (*close)(struct vm_area_struct*);
|
||||||
vm_fault_t (*fault)(struct vm_area_struct*, struct vm_fault *);
|
vm_fault_t (*fault)(struct vm_area_struct*, struct vm_fault *);
|
||||||
@ -525,7 +609,10 @@ prototypes:
|
|||||||
int (*access)(struct vm_area_struct *, unsigned long, void*, int, int);
|
int (*access)(struct vm_area_struct *, unsigned long, void*, int, int);
|
||||||
|
|
||||||
locking rules:
|
locking rules:
|
||||||
mmap_sem PageLocked(page)
|
|
||||||
|
============= ======== ===========================
|
||||||
|
ops mmap_sem PageLocked(page)
|
||||||
|
============= ======== ===========================
|
||||||
open: yes
|
open: yes
|
||||||
close: yes
|
close: yes
|
||||||
fault: yes can return with page locked
|
fault: yes can return with page locked
|
||||||
@ -533,6 +620,7 @@ map_pages: yes
|
|||||||
page_mkwrite: yes can return with page locked
|
page_mkwrite: yes can return with page locked
|
||||||
pfn_mkwrite: yes
|
pfn_mkwrite: yes
|
||||||
access: yes
|
access: yes
|
||||||
|
============= ======== ===========================
|
||||||
|
|
||||||
->fault() is called when a previously not present pte is about
|
->fault() is called when a previously not present pte is about
|
||||||
to be faulted in. The filesystem must find and return the page associated
|
to be faulted in. The filesystem must find and return the page associated
|
||||||
@ -569,7 +657,8 @@ access_process_vm(), typically used to debug a process through
|
|||||||
/proc/pid/mem or ptrace. This function is needed only for
|
/proc/pid/mem or ptrace. This function is needed only for
|
||||||
VM_IO | VM_PFNMAP VMAs.
|
VM_IO | VM_PFNMAP VMAs.
|
||||||
|
|
||||||
================================================================================
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
Dubious stuff
|
Dubious stuff
|
||||||
|
|
||||||
(if you break something or notice that it is broken and do not fix it yourself
|
(if you break something or notice that it is broken and do not fix it yourself
|
@ -1,3 +1,4 @@
|
|||||||
|
:orphan:
|
||||||
|
|
||||||
Making Filesystems Exportable
|
Making Filesystems Exportable
|
||||||
=============================
|
=============================
|
||||||
@ -42,9 +43,9 @@ filehandle fragment, there is no automatic creation of a path prefix
|
|||||||
for the object. This leads to two related but distinct features of
|
for the object. This leads to two related but distinct features of
|
||||||
the dcache that are not needed for normal filesystem access.
|
the dcache that are not needed for normal filesystem access.
|
||||||
|
|
||||||
1/ The dcache must sometimes contain objects that are not part of the
|
1. The dcache must sometimes contain objects that are not part of the
|
||||||
proper prefix. i.e that are not connected to the root.
|
proper prefix. i.e that are not connected to the root.
|
||||||
2/ The dcache must be prepared for a newly found (via ->lookup) directory
|
2. The dcache must be prepared for a newly found (via ->lookup) directory
|
||||||
to already have a (non-connected) dentry, and must be able to move
|
to already have a (non-connected) dentry, and must be able to move
|
||||||
that dentry into place (based on the parent and name in the
|
that dentry into place (based on the parent and name in the
|
||||||
->lookup). This is particularly needed for directories as
|
->lookup). This is particularly needed for directories as
|
||||||
@ -52,7 +53,7 @@ the dcache that are not needed for normal filesystem access.
|
|||||||
|
|
||||||
To implement these features, the dcache has:
|
To implement these features, the dcache has:
|
||||||
|
|
||||||
a/ A dentry flag DCACHE_DISCONNECTED which is set on
|
a. A dentry flag DCACHE_DISCONNECTED which is set on
|
||||||
any dentry that might not be part of the proper prefix.
|
any dentry that might not be part of the proper prefix.
|
||||||
This is set when anonymous dentries are created, and cleared when a
|
This is set when anonymous dentries are created, and cleared when a
|
||||||
dentry is noticed to be a child of a dentry which is in the proper
|
dentry is noticed to be a child of a dentry which is in the proper
|
||||||
@ -71,19 +72,23 @@ a/ A dentry flag DCACHE_DISCONNECTED which is set on
|
|||||||
dentries. That guarantees that we won't need to hunt them down upon
|
dentries. That guarantees that we won't need to hunt them down upon
|
||||||
umount.
|
umount.
|
||||||
|
|
||||||
b/ A primitive for creation of secondary roots - d_obtain_root(inode).
|
b. A primitive for creation of secondary roots - d_obtain_root(inode).
|
||||||
Those do _not_ bear DCACHE_DISCONNECTED. They are placed on the
|
Those do _not_ bear DCACHE_DISCONNECTED. They are placed on the
|
||||||
per-superblock list (->s_roots), so they can be located at umount
|
per-superblock list (->s_roots), so they can be located at umount
|
||||||
time for eviction purposes.
|
time for eviction purposes.
|
||||||
|
|
||||||
c/ Helper routines to allocate anonymous dentries, and to help attach
|
c. Helper routines to allocate anonymous dentries, and to help attach
|
||||||
loose directory dentries at lookup time. They are:
|
loose directory dentries at lookup time. They are:
|
||||||
|
|
||||||
d_obtain_alias(inode) will return a dentry for the given inode.
|
d_obtain_alias(inode) will return a dentry for the given inode.
|
||||||
If the inode already has a dentry, one of those is returned.
|
If the inode already has a dentry, one of those is returned.
|
||||||
|
|
||||||
If it doesn't, a new anonymous (IS_ROOT and
|
If it doesn't, a new anonymous (IS_ROOT and
|
||||||
DCACHE_DISCONNECTED) dentry is allocated and attached.
|
DCACHE_DISCONNECTED) dentry is allocated and attached.
|
||||||
|
|
||||||
In the case of a directory, care is taken that only one dentry
|
In the case of a directory, care is taken that only one dentry
|
||||||
can ever be attached.
|
can ever be attached.
|
||||||
|
|
||||||
d_splice_alias(inode, dentry) will introduce a new dentry into the tree;
|
d_splice_alias(inode, dentry) will introduce a new dentry into the tree;
|
||||||
either the passed-in dentry or a preexisting alias for the given inode
|
either the passed-in dentry or a preexisting alias for the given inode
|
||||||
(such as an anonymous one created by d_obtain_alias), if appropriate.
|
(such as an anonymous one created by d_obtain_alias), if appropriate.
|
||||||
@ -95,17 +100,17 @@ Filesystem Issues
|
|||||||
|
|
||||||
For a filesystem to be exportable it must:
|
For a filesystem to be exportable it must:
|
||||||
|
|
||||||
1/ provide the filehandle fragment routines described below.
|
1. provide the filehandle fragment routines described below.
|
||||||
2/ make sure that d_splice_alias is used rather than d_add
|
2. make sure that d_splice_alias is used rather than d_add
|
||||||
when ->lookup finds an inode for a given parent and name.
|
when ->lookup finds an inode for a given parent and name.
|
||||||
|
|
||||||
If inode is NULL, d_splice_alias(inode, dentry) is equivalent to
|
If inode is NULL, d_splice_alias(inode, dentry) is equivalent to::
|
||||||
|
|
||||||
d_add(dentry, inode), NULL
|
d_add(dentry, inode), NULL
|
||||||
|
|
||||||
Similarly, d_splice_alias(ERR_PTR(err), dentry) = ERR_PTR(err)
|
Similarly, d_splice_alias(ERR_PTR(err), dentry) = ERR_PTR(err)
|
||||||
|
|
||||||
Typically the ->lookup routine will simply end with a:
|
Typically the ->lookup routine will simply end with a::
|
||||||
|
|
||||||
return d_splice_alias(inode, dentry);
|
return d_splice_alias(inode, dentry);
|
||||||
}
|
}
|
@ -1,686 +0,0 @@
|
|||||||
Changes since 2.5.0:
|
|
||||||
|
|
||||||
---
|
|
||||||
[recommended]
|
|
||||||
|
|
||||||
New helpers: sb_bread(), sb_getblk(), sb_find_get_block(), set_bh(),
|
|
||||||
sb_set_blocksize() and sb_min_blocksize().
|
|
||||||
|
|
||||||
Use them.
|
|
||||||
|
|
||||||
(sb_find_get_block() replaces 2.4's get_hash_table())
|
|
||||||
|
|
||||||
---
|
|
||||||
[recommended]
|
|
||||||
|
|
||||||
New methods: ->alloc_inode() and ->destroy_inode().
|
|
||||||
|
|
||||||
Remove inode->u.foo_inode_i
|
|
||||||
Declare
|
|
||||||
struct foo_inode_info {
|
|
||||||
/* fs-private stuff */
|
|
||||||
struct inode vfs_inode;
|
|
||||||
};
|
|
||||||
static inline struct foo_inode_info *FOO_I(struct inode *inode)
|
|
||||||
{
|
|
||||||
return list_entry(inode, struct foo_inode_info, vfs_inode);
|
|
||||||
}
|
|
||||||
|
|
||||||
Use FOO_I(inode) instead of &inode->u.foo_inode_i;
|
|
||||||
|
|
||||||
Add foo_alloc_inode() and foo_destroy_inode() - the former should allocate
|
|
||||||
foo_inode_info and return the address of ->vfs_inode, the latter should free
|
|
||||||
FOO_I(inode) (see in-tree filesystems for examples).
|
|
||||||
|
|
||||||
Make them ->alloc_inode and ->destroy_inode in your super_operations.
|
|
||||||
|
|
||||||
Keep in mind that now you need explicit initialization of private data
|
|
||||||
typically between calling iget_locked() and unlocking the inode.
|
|
||||||
|
|
||||||
At some point that will become mandatory.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
Change of file_system_type method (->read_super to ->get_sb)
|
|
||||||
|
|
||||||
->read_super() is no more. Ditto for DECLARE_FSTYPE and DECLARE_FSTYPE_DEV.
|
|
||||||
|
|
||||||
Turn your foo_read_super() into a function that would return 0 in case of
|
|
||||||
success and negative number in case of error (-EINVAL unless you have more
|
|
||||||
informative error value to report). Call it foo_fill_super(). Now declare
|
|
||||||
|
|
||||||
int foo_get_sb(struct file_system_type *fs_type,
|
|
||||||
int flags, const char *dev_name, void *data, struct vfsmount *mnt)
|
|
||||||
{
|
|
||||||
return get_sb_bdev(fs_type, flags, dev_name, data, foo_fill_super,
|
|
||||||
mnt);
|
|
||||||
}
|
|
||||||
|
|
||||||
(or similar with s/bdev/nodev/ or s/bdev/single/, depending on the kind of
|
|
||||||
filesystem).
|
|
||||||
|
|
||||||
Replace DECLARE_FSTYPE... with explicit initializer and have ->get_sb set as
|
|
||||||
foo_get_sb.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
Locking change: ->s_vfs_rename_sem is taken only by cross-directory renames.
|
|
||||||
Most likely there is no need to change anything, but if you relied on
|
|
||||||
global exclusion between renames for some internal purpose - you need to
|
|
||||||
change your internal locking. Otherwise exclusion warranties remain the
|
|
||||||
same (i.e. parents and victim are locked, etc.).
|
|
||||||
|
|
||||||
---
|
|
||||||
[informational]
|
|
||||||
|
|
||||||
Now we have the exclusion between ->lookup() and directory removal (by
|
|
||||||
->rmdir() and ->rename()). If you used to need that exclusion and do
|
|
||||||
it by internal locking (most of filesystems couldn't care less) - you
|
|
||||||
can relax your locking.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->lookup(), ->truncate(), ->create(), ->unlink(), ->mknod(), ->mkdir(),
|
|
||||||
->rmdir(), ->link(), ->lseek(), ->symlink(), ->rename()
|
|
||||||
and ->readdir() are called without BKL now. Grab it on entry, drop upon return
|
|
||||||
- that will guarantee the same locking you used to have. If your method or its
|
|
||||||
parts do not need BKL - better yet, now you can shift lock_kernel() and
|
|
||||||
unlock_kernel() so that they would protect exactly what needs to be
|
|
||||||
protected.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
BKL is also moved from around sb operations. BKL should have been shifted into
|
|
||||||
individual fs sb_op functions. If you don't need it, remove it.
|
|
||||||
|
|
||||||
---
|
|
||||||
[informational]
|
|
||||||
|
|
||||||
check for ->link() target not being a directory is done by callers. Feel
|
|
||||||
free to drop it...
|
|
||||||
|
|
||||||
---
|
|
||||||
[informational]
|
|
||||||
|
|
||||||
->link() callers hold ->i_mutex on the object we are linking to. Some of your
|
|
||||||
problems might be over...
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
new file_system_type method - kill_sb(superblock). If you are converting
|
|
||||||
an existing filesystem, set it according to ->fs_flags:
|
|
||||||
FS_REQUIRES_DEV - kill_block_super
|
|
||||||
FS_LITTER - kill_litter_super
|
|
||||||
neither - kill_anon_super
|
|
||||||
FS_LITTER is gone - just remove it from fs_flags.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
FS_SINGLE is gone (actually, that had happened back when ->get_sb()
|
|
||||||
went in - and hadn't been documented ;-/). Just remove it from fs_flags
|
|
||||||
(and see ->get_sb() entry for other actions).
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->setattr() is called without BKL now. Caller _always_ holds ->i_mutex, so
|
|
||||||
watch for ->i_mutex-grabbing code that might be used by your ->setattr().
|
|
||||||
Callers of notify_change() need ->i_mutex now.
|
|
||||||
|
|
||||||
---
|
|
||||||
[recommended]
|
|
||||||
|
|
||||||
New super_block field "struct export_operations *s_export_op" for
|
|
||||||
explicit support for exporting, e.g. via NFS. The structure is fully
|
|
||||||
documented at its declaration in include/linux/fs.h, and in
|
|
||||||
Documentation/filesystems/nfs/Exporting.
|
|
||||||
|
|
||||||
Briefly it allows for the definition of decode_fh and encode_fh operations
|
|
||||||
to encode and decode filehandles, and allows the filesystem to use
|
|
||||||
a standard helper function for decode_fh, and provide file-system specific
|
|
||||||
support for this helper, particularly get_parent.
|
|
||||||
|
|
||||||
It is planned that this will be required for exporting once the code
|
|
||||||
settles down a bit.
|
|
||||||
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
s_export_op is now required for exporting a filesystem.
|
|
||||||
isofs, ext2, ext3, resierfs, fat
|
|
||||||
can be used as examples of very different filesystems.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
iget4() and the read_inode2 callback have been superseded by iget5_locked()
|
|
||||||
which has the following prototype,
|
|
||||||
|
|
||||||
struct inode *iget5_locked(struct super_block *sb, unsigned long ino,
|
|
||||||
int (*test)(struct inode *, void *),
|
|
||||||
int (*set)(struct inode *, void *),
|
|
||||||
void *data);
|
|
||||||
|
|
||||||
'test' is an additional function that can be used when the inode
|
|
||||||
number is not sufficient to identify the actual file object. 'set'
|
|
||||||
should be a non-blocking function that initializes those parts of a
|
|
||||||
newly created inode to allow the test function to succeed. 'data' is
|
|
||||||
passed as an opaque value to both test and set functions.
|
|
||||||
|
|
||||||
When the inode has been created by iget5_locked(), it will be returned with the
|
|
||||||
I_NEW flag set and will still be locked. The filesystem then needs to finalize
|
|
||||||
the initialization. Once the inode is initialized it must be unlocked by
|
|
||||||
calling unlock_new_inode().
|
|
||||||
|
|
||||||
The filesystem is responsible for setting (and possibly testing) i_ino
|
|
||||||
when appropriate. There is also a simpler iget_locked function that
|
|
||||||
just takes the superblock and inode number as arguments and does the
|
|
||||||
test and set for you.
|
|
||||||
|
|
||||||
e.g.
|
|
||||||
inode = iget_locked(sb, ino);
|
|
||||||
if (inode->i_state & I_NEW) {
|
|
||||||
err = read_inode_from_disk(inode);
|
|
||||||
if (err < 0) {
|
|
||||||
iget_failed(inode);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
unlock_new_inode(inode);
|
|
||||||
}
|
|
||||||
|
|
||||||
Note that if the process of setting up a new inode fails, then iget_failed()
|
|
||||||
should be called on the inode to render it dead, and an appropriate error
|
|
||||||
should be passed back to the caller.
|
|
||||||
|
|
||||||
---
|
|
||||||
[recommended]
|
|
||||||
|
|
||||||
->getattr() finally getting used. See instances in nfs, minix, etc.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->revalidate() is gone. If your filesystem had it - provide ->getattr()
|
|
||||||
and let it call whatever you had as ->revlidate() + (for symlinks that
|
|
||||||
had ->revalidate()) add calls in ->follow_link()/->readlink().
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->d_parent changes are not protected by BKL anymore. Read access is safe
|
|
||||||
if at least one of the following is true:
|
|
||||||
* filesystem has no cross-directory rename()
|
|
||||||
* we know that parent had been locked (e.g. we are looking at
|
|
||||||
->d_parent of ->lookup() argument).
|
|
||||||
* we are called from ->rename().
|
|
||||||
* the child's ->d_lock is held
|
|
||||||
Audit your code and add locking if needed. Notice that any place that is
|
|
||||||
not protected by the conditions above is risky even in the old tree - you
|
|
||||||
had been relying on BKL and that's prone to screwups. Old tree had quite
|
|
||||||
a few holes of that kind - unprotected access to ->d_parent leading to
|
|
||||||
anything from oops to silent memory corruption.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
FS_NOMOUNT is gone. If you use it - just set SB_NOUSER in flags
|
|
||||||
(see rootfs for one kind of solution and bdev/socket/pipe for another).
|
|
||||||
|
|
||||||
---
|
|
||||||
[recommended]
|
|
||||||
|
|
||||||
Use bdev_read_only(bdev) instead of is_read_only(kdev). The latter
|
|
||||||
is still alive, but only because of the mess in drivers/s390/block/dasd.c.
|
|
||||||
As soon as it gets fixed is_read_only() will die.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->permission() is called without BKL now. Grab it on entry, drop upon
|
|
||||||
return - that will guarantee the same locking you used to have. If
|
|
||||||
your method or its parts do not need BKL - better yet, now you can
|
|
||||||
shift lock_kernel() and unlock_kernel() so that they would protect
|
|
||||||
exactly what needs to be protected.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->statfs() is now called without BKL held. BKL should have been
|
|
||||||
shifted into individual fs sb_op functions where it's not clear that
|
|
||||||
it's safe to remove it. If you don't need it, remove it.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
is_read_only() is gone; use bdev_read_only() instead.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
destroy_buffers() is gone; use invalidate_bdev().
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
fsync_dev() is gone; use fsync_bdev(). NOTE: lvm breakage is
|
|
||||||
deliberate; as soon as struct block_device * is propagated in a reasonable
|
|
||||||
way by that code fixing will become trivial; until then nothing can be
|
|
||||||
done.
|
|
||||||
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
block truncatation on error exit from ->write_begin, and ->direct_IO
|
|
||||||
moved from generic methods (block_write_begin, cont_write_begin,
|
|
||||||
nobh_write_begin, blockdev_direct_IO*) to callers. Take a look at
|
|
||||||
ext2_write_failed and callers for an example.
|
|
||||||
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->truncate is gone. The whole truncate sequence needs to be
|
|
||||||
implemented in ->setattr, which is now mandatory for filesystems
|
|
||||||
implementing on-disk size changes. Start with a copy of the old inode_setattr
|
|
||||||
and vmtruncate, and the reorder the vmtruncate + foofs_vmtruncate sequence to
|
|
||||||
be in order of zeroing blocks using block_truncate_page or similar helpers,
|
|
||||||
size update and on finally on-disk truncation which should not fail.
|
|
||||||
setattr_prepare (which used to be inode_change_ok) now includes the size checks
|
|
||||||
for ATTR_SIZE and must be called in the beginning of ->setattr unconditionally.
|
|
||||||
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
->clear_inode() and ->delete_inode() are gone; ->evict_inode() should
|
|
||||||
be used instead. It gets called whenever the inode is evicted, whether it has
|
|
||||||
remaining links or not. Caller does *not* evict the pagecache or inode-associated
|
|
||||||
metadata buffers; the method has to use truncate_inode_pages_final() to get rid
|
|
||||||
of those. Caller makes sure async writeback cannot be running for the inode while
|
|
||||||
(or after) ->evict_inode() is called.
|
|
||||||
|
|
||||||
->drop_inode() returns int now; it's called on final iput() with
|
|
||||||
inode->i_lock held and it returns true if filesystems wants the inode to be
|
|
||||||
dropped. As before, generic_drop_inode() is still the default and it's been
|
|
||||||
updated appropriately. generic_delete_inode() is also alive and it consists
|
|
||||||
simply of return 1. Note that all actual eviction work is done by caller after
|
|
||||||
->drop_inode() returns.
|
|
||||||
|
|
||||||
As before, clear_inode() must be called exactly once on each call of
|
|
||||||
->evict_inode() (as it used to be for each call of ->delete_inode()). Unlike
|
|
||||||
before, if you are using inode-associated metadata buffers (i.e.
|
|
||||||
mark_buffer_dirty_inode()), it's your responsibility to call
|
|
||||||
invalidate_inode_buffers() before clear_inode().
|
|
||||||
|
|
||||||
NOTE: checking i_nlink in the beginning of ->write_inode() and bailing out
|
|
||||||
if it's zero is not *and* *never* *had* *been* enough. Final unlink() and iput()
|
|
||||||
may happen while the inode is in the middle of ->write_inode(); e.g. if you blindly
|
|
||||||
free the on-disk inode, you may end up doing that while ->write_inode() is writing
|
|
||||||
to it.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
.d_delete() now only advises the dcache as to whether or not to cache
|
|
||||||
unreferenced dentries, and is now only called when the dentry refcount goes to
|
|
||||||
0. Even on 0 refcount transition, it must be able to tolerate being called 0,
|
|
||||||
1, or more times (eg. constant, idempotent).
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
.d_compare() calling convention and locking rules are significantly
|
|
||||||
changed. Read updated documentation in Documentation/filesystems/vfs.rst (and
|
|
||||||
look at examples of other filesystems) for guidance.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
.d_hash() calling convention and locking rules are significantly
|
|
||||||
changed. Read updated documentation in Documentation/filesystems/vfs.rst (and
|
|
||||||
look at examples of other filesystems) for guidance.
|
|
||||||
|
|
||||||
---
|
|
||||||
[mandatory]
|
|
||||||
dcache_lock is gone, replaced by fine grained locks. See fs/dcache.c
|
|
||||||
for details of what locks to replace dcache_lock with in order to protect
|
|
||||||
particular things. Most of the time, a filesystem only needs ->d_lock, which
|
|
||||||
protects *all* the dcache state of a given dentry.
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
|
|
||||||
Filesystems must RCU-free their inodes, if they can have been accessed
|
|
||||||
via rcu-walk path walk (basically, if the file can have had a path name in the
|
|
||||||
vfs namespace).
|
|
||||||
|
|
||||||
Even though i_dentry and i_rcu share storage in a union, we will
|
|
||||||
initialize the former in inode_init_always(), so just leave it alone in
|
|
||||||
the callback. It used to be necessary to clean it there, but not anymore
|
|
||||||
(starting at 3.2).
|
|
||||||
|
|
||||||
--
|
|
||||||
[recommended]
|
|
||||||
vfs now tries to do path walking in "rcu-walk mode", which avoids
|
|
||||||
atomic operations and scalability hazards on dentries and inodes (see
|
|
||||||
Documentation/filesystems/path-lookup.txt). d_hash and d_compare changes
|
|
||||||
(above) are examples of the changes required to support this. For more complex
|
|
||||||
filesystem callbacks, the vfs drops out of rcu-walk mode before the fs call, so
|
|
||||||
no changes are required to the filesystem. However, this is costly and loses
|
|
||||||
the benefits of rcu-walk mode. We will begin to add filesystem callbacks that
|
|
||||||
are rcu-walk aware, shown below. Filesystems should take advantage of this
|
|
||||||
where possible.
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
d_revalidate is a callback that is made on every path element (if
|
|
||||||
the filesystem provides it), which requires dropping out of rcu-walk mode. This
|
|
||||||
may now be called in rcu-walk mode (nd->flags & LOOKUP_RCU). -ECHILD should be
|
|
||||||
returned if the filesystem cannot handle rcu-walk. See
|
|
||||||
Documentation/filesystems/vfs.rst for more details.
|
|
||||||
|
|
||||||
permission is an inode permission check that is called on many or all
|
|
||||||
directory inodes on the way down a path walk (to check for exec permission). It
|
|
||||||
must now be rcu-walk aware (mask & MAY_NOT_BLOCK). See
|
|
||||||
Documentation/filesystems/vfs.rst for more details.
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
In ->fallocate() you must check the mode option passed in. If your
|
|
||||||
filesystem does not support hole punching (deallocating space in the middle of a
|
|
||||||
file) you must return -EOPNOTSUPP if FALLOC_FL_PUNCH_HOLE is set in mode.
|
|
||||||
Currently you can only have FALLOC_FL_PUNCH_HOLE with FALLOC_FL_KEEP_SIZE set,
|
|
||||||
so the i_size should not change when hole punching, even when puching the end of
|
|
||||||
a file off.
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->get_sb() is gone. Switch to use of ->mount(). Typically it's just
|
|
||||||
a matter of switching from calling get_sb_... to mount_... and changing the
|
|
||||||
function type. If you were doing it manually, just switch from setting ->mnt_root
|
|
||||||
to some pointer to returning that pointer. On errors return ERR_PTR(...).
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->permission() and generic_permission()have lost flags
|
|
||||||
argument; instead of passing IPERM_FLAG_RCU we add MAY_NOT_BLOCK into mask.
|
|
||||||
generic_permission() has also lost the check_acl argument; ACL checking
|
|
||||||
has been taken to VFS and filesystems need to provide a non-NULL ->i_op->get_acl
|
|
||||||
to read an ACL from disk.
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
If you implement your own ->llseek() you must handle SEEK_HOLE and
|
|
||||||
SEEK_DATA. You can hanle this by returning -EINVAL, but it would be nicer to
|
|
||||||
support it in some way. The generic handler assumes that the entire file is
|
|
||||||
data and there is a virtual hole at the end of the file. So if the provided
|
|
||||||
offset is less than i_size and SEEK_DATA is specified, return the same offset.
|
|
||||||
If the above is true for the offset and you are given SEEK_HOLE, return the end
|
|
||||||
of the file. If the offset is i_size or greater return -ENXIO in either case.
|
|
||||||
|
|
||||||
[mandatory]
|
|
||||||
If you have your own ->fsync() you must make sure to call
|
|
||||||
filemap_write_and_wait_range() so that all dirty pages are synced out properly.
|
|
||||||
You must also keep in mind that ->fsync() is not called with i_mutex held
|
|
||||||
anymore, so if you require i_mutex locking you must make sure to take it and
|
|
||||||
release it yourself.
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
d_alloc_root() is gone, along with a lot of bugs caused by code
|
|
||||||
misusing it. Replacement: d_make_root(inode). On success d_make_root(inode)
|
|
||||||
allocates and returns a new dentry instantiated with the passed in inode.
|
|
||||||
On failure NULL is returned and the passed in inode is dropped so the reference
|
|
||||||
to inode is consumed in all cases and failure handling need not do any cleanup
|
|
||||||
for the inode. If d_make_root(inode) is passed a NULL inode it returns NULL
|
|
||||||
and also requires no further error handling. Typical usage is:
|
|
||||||
|
|
||||||
inode = foofs_new_inode(....);
|
|
||||||
s->s_root = d_make_root(inode);
|
|
||||||
if (!s->s_root)
|
|
||||||
/* Nothing needed for the inode cleanup */
|
|
||||||
return -ENOMEM;
|
|
||||||
...
|
|
||||||
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
The witch is dead! Well, 2/3 of it, anyway. ->d_revalidate() and
|
|
||||||
->lookup() do *not* take struct nameidata anymore; just the flags.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->create() doesn't take struct nameidata *; unlike the previous
|
|
||||||
two, it gets "is it an O_EXCL or equivalent?" boolean argument. Note that
|
|
||||||
local filesystems can ignore tha argument - they are guaranteed that the
|
|
||||||
object doesn't exist. It's remote/distributed ones that might care...
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
FS_REVAL_DOT is gone; if you used to have it, add ->d_weak_revalidate()
|
|
||||||
in your dentry operations instead.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
vfs_readdir() is gone; switch to iterate_dir() instead
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->readdir() is gone now; switch to ->iterate()
|
|
||||||
[mandatory]
|
|
||||||
vfs_follow_link has been removed. Filesystems must use nd_set_link
|
|
||||||
from ->follow_link for normal symlinks, or nd_jump_link for magic
|
|
||||||
/proc/<pid> style links.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
iget5_locked()/ilookup5()/ilookup5_nowait() test() callback used to be
|
|
||||||
called with both ->i_lock and inode_hash_lock held; the former is *not*
|
|
||||||
taken anymore, so verify that your callbacks do not rely on it (none
|
|
||||||
of the in-tree instances did). inode_hash_lock is still held,
|
|
||||||
of course, so they are still serialized wrt removal from inode hash,
|
|
||||||
as well as wrt set() callback of iget5_locked().
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
d_materialise_unique() is gone; d_splice_alias() does everything you
|
|
||||||
need now. Remember that they have opposite orders of arguments ;-/
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
f_dentry is gone; use f_path.dentry, or, better yet, see if you can avoid
|
|
||||||
it entirely.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
never call ->read() and ->write() directly; use __vfs_{read,write} or
|
|
||||||
wrappers; instead of checking for ->write or ->read being NULL, look for
|
|
||||||
FMODE_CAN_{WRITE,READ} in file->f_mode.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
do _not_ use new_sync_{read,write} for ->read/->write; leave it NULL
|
|
||||||
instead.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->aio_read/->aio_write are gone. Use ->read_iter/->write_iter.
|
|
||||||
---
|
|
||||||
[recommended]
|
|
||||||
for embedded ("fast") symlinks just set inode->i_link to wherever the
|
|
||||||
symlink body is and use simple_follow_link() as ->follow_link().
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
calling conventions for ->follow_link() have changed. Instead of returning
|
|
||||||
cookie and using nd_set_link() to store the body to traverse, we return
|
|
||||||
the body to traverse and store the cookie using explicit void ** argument.
|
|
||||||
nameidata isn't passed at all - nd_jump_link() doesn't need it and
|
|
||||||
nd_[gs]et_link() is gone.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
calling conventions for ->put_link() have changed. It gets inode instead of
|
|
||||||
dentry, it does not get nameidata at all and it gets called only when cookie
|
|
||||||
is non-NULL. Note that link body isn't available anymore, so if you need it,
|
|
||||||
store it as cookie.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
any symlink that might use page_follow_link_light/page_put_link() must
|
|
||||||
have inode_nohighmem(inode) called before anything might start playing with
|
|
||||||
its pagecache. No highmem pages should end up in the pagecache of such
|
|
||||||
symlinks. That includes any preseeding that might be done during symlink
|
|
||||||
creation. __page_symlink() will honour the mapping gfp flags, so once
|
|
||||||
you've done inode_nohighmem() it's safe to use, but if you allocate and
|
|
||||||
insert the page manually, make sure to use the right gfp flags.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->follow_link() is replaced with ->get_link(); same API, except that
|
|
||||||
* ->get_link() gets inode as a separate argument
|
|
||||||
* ->get_link() may be called in RCU mode - in that case NULL
|
|
||||||
dentry is passed
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->get_link() gets struct delayed_call *done now, and should do
|
|
||||||
set_delayed_call() where it used to set *cookie.
|
|
||||||
->put_link() is gone - just give the destructor to set_delayed_call()
|
|
||||||
in ->get_link().
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->getxattr() and xattr_handler.get() get dentry and inode passed separately.
|
|
||||||
dentry might be yet to be attached to inode, so do _not_ use its ->d_inode
|
|
||||||
in the instances. Rationale: !@#!@# security_d_instantiate() needs to be
|
|
||||||
called before we attach dentry to inode.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
symlinks are no longer the only inodes that do *not* have i_bdev/i_cdev/
|
|
||||||
i_pipe/i_link union zeroed out at inode eviction. As the result, you can't
|
|
||||||
assume that non-NULL value in ->i_nlink at ->destroy_inode() implies that
|
|
||||||
it's a symlink. Checking ->i_mode is really needed now. In-tree we had
|
|
||||||
to fix shmem_destroy_callback() that used to take that kind of shortcut;
|
|
||||||
watch out, since that shortcut is no longer valid.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->i_mutex is replaced with ->i_rwsem now. inode_lock() et.al. work as
|
|
||||||
they used to - they just take it exclusive. However, ->lookup() may be
|
|
||||||
called with parent locked shared. Its instances must not
|
|
||||||
* use d_instantiate) and d_rehash() separately - use d_add() or
|
|
||||||
d_splice_alias() instead.
|
|
||||||
* use d_rehash() alone - call d_add(new_dentry, NULL) instead.
|
|
||||||
* in the unlikely case when (read-only) access to filesystem
|
|
||||||
data structures needs exclusion for some reason, arrange it
|
|
||||||
yourself. None of the in-tree filesystems needed that.
|
|
||||||
* rely on ->d_parent and ->d_name not changing after dentry has
|
|
||||||
been fed to d_add() or d_splice_alias(). Again, none of the
|
|
||||||
in-tree instances relied upon that.
|
|
||||||
We are guaranteed that lookups of the same name in the same directory
|
|
||||||
will not happen in parallel ("same" in the sense of your ->d_compare()).
|
|
||||||
Lookups on different names in the same directory can and do happen in
|
|
||||||
parallel now.
|
|
||||||
--
|
|
||||||
[recommended]
|
|
||||||
->iterate_shared() is added; it's a parallel variant of ->iterate().
|
|
||||||
Exclusion on struct file level is still provided (as well as that
|
|
||||||
between it and lseek on the same struct file), but if your directory
|
|
||||||
has been opened several times, you can get these called in parallel.
|
|
||||||
Exclusion between that method and all directory-modifying ones is
|
|
||||||
still provided, of course.
|
|
||||||
|
|
||||||
Often enough ->iterate() can serve as ->iterate_shared() without any
|
|
||||||
changes - it is a read-only operation, after all. If you have any
|
|
||||||
per-inode or per-dentry in-core data structures modified by ->iterate(),
|
|
||||||
you might need something to serialize the access to them. If you
|
|
||||||
do dcache pre-seeding, you'll need to switch to d_alloc_parallel() for
|
|
||||||
that; look for in-tree examples.
|
|
||||||
|
|
||||||
Old method is only used if the new one is absent; eventually it will
|
|
||||||
be removed. Switch while you still can; the old one won't stay.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->atomic_open() calls without O_CREAT may happen in parallel.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->setxattr() and xattr_handler.set() get dentry and inode passed separately.
|
|
||||||
dentry might be yet to be attached to inode, so do _not_ use its ->d_inode
|
|
||||||
in the instances. Rationale: !@#!@# security_d_instantiate() needs to be
|
|
||||||
called before we attach dentry to inode and !@#!@##!@$!$#!@#$!@$!@$ smack
|
|
||||||
->d_instantiate() uses not just ->getxattr() but ->setxattr() as well.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->d_compare() doesn't get parent as a separate argument anymore. If you
|
|
||||||
used it for finding the struct super_block involved, dentry->d_sb will
|
|
||||||
work just as well; if it's something more complicated, use dentry->d_parent.
|
|
||||||
Just be careful not to assume that fetching it more than once will yield
|
|
||||||
the same value - in RCU mode it could change under you.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->rename() has an added flags argument. Any flags not handled by the
|
|
||||||
filesystem should result in EINVAL being returned.
|
|
||||||
--
|
|
||||||
[recommended]
|
|
||||||
->readlink is optional for symlinks. Don't set, unless filesystem needs
|
|
||||||
to fake something for readlink(2).
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->getattr() is now passed a struct path rather than a vfsmount and
|
|
||||||
dentry separately, and it now has request_mask and query_flags arguments
|
|
||||||
to specify the fields and sync type requested by statx. Filesystems not
|
|
||||||
supporting any statx-specific features may ignore the new arguments.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->atomic_open() calling conventions have changed. Gone is int *opened,
|
|
||||||
along with FILE_OPENED/FILE_CREATED. In place of those we have
|
|
||||||
FMODE_OPENED/FMODE_CREATED, set in file->f_mode. Additionally, return
|
|
||||||
value for 'called finish_no_open(), open it yourself' case has become
|
|
||||||
0, not 1. Since finish_no_open() itself is returning 0 now, that part
|
|
||||||
does not need any changes in ->atomic_open() instances.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
alloc_file() has become static now; two wrappers are to be used instead.
|
|
||||||
alloc_file_pseudo(inode, vfsmount, name, flags, ops) is for the cases
|
|
||||||
when dentry needs to be created; that's the majority of old alloc_file()
|
|
||||||
users. Calling conventions: on success a reference to new struct file
|
|
||||||
is returned and callers reference to inode is subsumed by that. On
|
|
||||||
failure, ERR_PTR() is returned and no caller's references are affected,
|
|
||||||
so the caller needs to drop the inode reference it held.
|
|
||||||
alloc_file_clone(file, flags, ops) does not affect any caller's references.
|
|
||||||
On success you get a new struct file sharing the mount/dentry with the
|
|
||||||
original, on failure - ERR_PTR().
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
->clone_file_range() and ->dedupe_file_range have been replaced with
|
|
||||||
->remap_file_range(). See Documentation/filesystems/vfs.rst for more
|
|
||||||
information.
|
|
||||||
--
|
|
||||||
[recommended]
|
|
||||||
->lookup() instances doing an equivalent of
|
|
||||||
if (IS_ERR(inode))
|
|
||||||
return ERR_CAST(inode);
|
|
||||||
return d_splice_alias(inode, dentry);
|
|
||||||
don't need to bother with the check - d_splice_alias() will do the
|
|
||||||
right thing when given ERR_PTR(...) as inode. Moreover, passing NULL
|
|
||||||
inode to d_splice_alias() will also do the right thing (equivalent of
|
|
||||||
d_add(dentry, NULL); return NULL;), so that kind of special cases
|
|
||||||
also doesn't need a separate treatment.
|
|
||||||
--
|
|
||||||
[strongly recommended]
|
|
||||||
take the RCU-delayed parts of ->destroy_inode() into a new method -
|
|
||||||
->free_inode(). If ->destroy_inode() becomes empty - all the better,
|
|
||||||
just get rid of it. Synchronous work (e.g. the stuff that can't
|
|
||||||
be done from an RCU callback, or any WARN_ON() where we want the
|
|
||||||
stack trace) *might* be movable to ->evict_inode(); however,
|
|
||||||
that goes only for the things that are not needed to balance something
|
|
||||||
done by ->alloc_inode(). IOW, if it's cleaning up the stuff that
|
|
||||||
might have accumulated over the life of in-core inode, ->evict_inode()
|
|
||||||
might be a fit.
|
|
||||||
|
|
||||||
Rules for inode destruction:
|
|
||||||
* if ->destroy_inode() is non-NULL, it gets called
|
|
||||||
* if ->free_inode() is non-NULL, it gets scheduled by call_rcu()
|
|
||||||
* combination of NULL ->destroy_inode and NULL ->free_inode is
|
|
||||||
treated as NULL/free_inode_nonrcu, to preserve the compatibility.
|
|
||||||
|
|
||||||
Note that the callback (be it via ->free_inode() or explicit call_rcu()
|
|
||||||
in ->destroy_inode()) is *NOT* ordered wrt superblock destruction;
|
|
||||||
as the matter of fact, the superblock and all associated structures
|
|
||||||
might be already gone. The filesystem driver is guaranteed to be still
|
|
||||||
there, but that's it. Freeing memory in the callback is fine; doing
|
|
||||||
more than that is possible, but requires a lot of care and is best
|
|
||||||
avoided.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
DCACHE_RCUACCESS is gone; having an RCU delay on dentry freeing is the
|
|
||||||
default. DCACHE_NORCU opts out, and only d_alloc_pseudo() has any
|
|
||||||
business doing so.
|
|
||||||
--
|
|
||||||
[mandatory]
|
|
||||||
d_alloc_pseudo() is internal-only; uses outside of alloc_file_pseudo() are
|
|
||||||
very suspect (and won't work in modules). Such uses are very likely to
|
|
||||||
be misspelled d_alloc_anon().
|
|
852
Documentation/filesystems/porting.rst
Normal file
852
Documentation/filesystems/porting.rst
Normal file
@ -0,0 +1,852 @@
|
|||||||
|
====================
|
||||||
|
Changes since 2.5.0:
|
||||||
|
====================
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
New helpers: sb_bread(), sb_getblk(), sb_find_get_block(), set_bh(),
|
||||||
|
sb_set_blocksize() and sb_min_blocksize().
|
||||||
|
|
||||||
|
Use them.
|
||||||
|
|
||||||
|
(sb_find_get_block() replaces 2.4's get_hash_table())
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
New methods: ->alloc_inode() and ->destroy_inode().
|
||||||
|
|
||||||
|
Remove inode->u.foo_inode_i
|
||||||
|
|
||||||
|
Declare::
|
||||||
|
|
||||||
|
struct foo_inode_info {
|
||||||
|
/* fs-private stuff */
|
||||||
|
struct inode vfs_inode;
|
||||||
|
};
|
||||||
|
static inline struct foo_inode_info *FOO_I(struct inode *inode)
|
||||||
|
{
|
||||||
|
return list_entry(inode, struct foo_inode_info, vfs_inode);
|
||||||
|
}
|
||||||
|
|
||||||
|
Use FOO_I(inode) instead of &inode->u.foo_inode_i;
|
||||||
|
|
||||||
|
Add foo_alloc_inode() and foo_destroy_inode() - the former should allocate
|
||||||
|
foo_inode_info and return the address of ->vfs_inode, the latter should free
|
||||||
|
FOO_I(inode) (see in-tree filesystems for examples).
|
||||||
|
|
||||||
|
Make them ->alloc_inode and ->destroy_inode in your super_operations.
|
||||||
|
|
||||||
|
Keep in mind that now you need explicit initialization of private data
|
||||||
|
typically between calling iget_locked() and unlocking the inode.
|
||||||
|
|
||||||
|
At some point that will become mandatory.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
Change of file_system_type method (->read_super to ->get_sb)
|
||||||
|
|
||||||
|
->read_super() is no more. Ditto for DECLARE_FSTYPE and DECLARE_FSTYPE_DEV.
|
||||||
|
|
||||||
|
Turn your foo_read_super() into a function that would return 0 in case of
|
||||||
|
success and negative number in case of error (-EINVAL unless you have more
|
||||||
|
informative error value to report). Call it foo_fill_super(). Now declare::
|
||||||
|
|
||||||
|
int foo_get_sb(struct file_system_type *fs_type,
|
||||||
|
int flags, const char *dev_name, void *data, struct vfsmount *mnt)
|
||||||
|
{
|
||||||
|
return get_sb_bdev(fs_type, flags, dev_name, data, foo_fill_super,
|
||||||
|
mnt);
|
||||||
|
}
|
||||||
|
|
||||||
|
(or similar with s/bdev/nodev/ or s/bdev/single/, depending on the kind of
|
||||||
|
filesystem).
|
||||||
|
|
||||||
|
Replace DECLARE_FSTYPE... with explicit initializer and have ->get_sb set as
|
||||||
|
foo_get_sb.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
Locking change: ->s_vfs_rename_sem is taken only by cross-directory renames.
|
||||||
|
Most likely there is no need to change anything, but if you relied on
|
||||||
|
global exclusion between renames for some internal purpose - you need to
|
||||||
|
change your internal locking. Otherwise exclusion warranties remain the
|
||||||
|
same (i.e. parents and victim are locked, etc.).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**informational**
|
||||||
|
|
||||||
|
Now we have the exclusion between ->lookup() and directory removal (by
|
||||||
|
->rmdir() and ->rename()). If you used to need that exclusion and do
|
||||||
|
it by internal locking (most of filesystems couldn't care less) - you
|
||||||
|
can relax your locking.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->lookup(), ->truncate(), ->create(), ->unlink(), ->mknod(), ->mkdir(),
|
||||||
|
->rmdir(), ->link(), ->lseek(), ->symlink(), ->rename()
|
||||||
|
and ->readdir() are called without BKL now. Grab it on entry, drop upon return
|
||||||
|
- that will guarantee the same locking you used to have. If your method or its
|
||||||
|
parts do not need BKL - better yet, now you can shift lock_kernel() and
|
||||||
|
unlock_kernel() so that they would protect exactly what needs to be
|
||||||
|
protected.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
BKL is also moved from around sb operations. BKL should have been shifted into
|
||||||
|
individual fs sb_op functions. If you don't need it, remove it.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**informational**
|
||||||
|
|
||||||
|
check for ->link() target not being a directory is done by callers. Feel
|
||||||
|
free to drop it...
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**informational**
|
||||||
|
|
||||||
|
->link() callers hold ->i_mutex on the object we are linking to. Some of your
|
||||||
|
problems might be over...
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
new file_system_type method - kill_sb(superblock). If you are converting
|
||||||
|
an existing filesystem, set it according to ->fs_flags::
|
||||||
|
|
||||||
|
FS_REQUIRES_DEV - kill_block_super
|
||||||
|
FS_LITTER - kill_litter_super
|
||||||
|
neither - kill_anon_super
|
||||||
|
|
||||||
|
FS_LITTER is gone - just remove it from fs_flags.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
FS_SINGLE is gone (actually, that had happened back when ->get_sb()
|
||||||
|
went in - and hadn't been documented ;-/). Just remove it from fs_flags
|
||||||
|
(and see ->get_sb() entry for other actions).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->setattr() is called without BKL now. Caller _always_ holds ->i_mutex, so
|
||||||
|
watch for ->i_mutex-grabbing code that might be used by your ->setattr().
|
||||||
|
Callers of notify_change() need ->i_mutex now.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
New super_block field ``struct export_operations *s_export_op`` for
|
||||||
|
explicit support for exporting, e.g. via NFS. The structure is fully
|
||||||
|
documented at its declaration in include/linux/fs.h, and in
|
||||||
|
Documentation/filesystems/nfs/exporting.rst.
|
||||||
|
|
||||||
|
Briefly it allows for the definition of decode_fh and encode_fh operations
|
||||||
|
to encode and decode filehandles, and allows the filesystem to use
|
||||||
|
a standard helper function for decode_fh, and provide file-system specific
|
||||||
|
support for this helper, particularly get_parent.
|
||||||
|
|
||||||
|
It is planned that this will be required for exporting once the code
|
||||||
|
settles down a bit.
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
s_export_op is now required for exporting a filesystem.
|
||||||
|
isofs, ext2, ext3, resierfs, fat
|
||||||
|
can be used as examples of very different filesystems.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
iget4() and the read_inode2 callback have been superseded by iget5_locked()
|
||||||
|
which has the following prototype::
|
||||||
|
|
||||||
|
struct inode *iget5_locked(struct super_block *sb, unsigned long ino,
|
||||||
|
int (*test)(struct inode *, void *),
|
||||||
|
int (*set)(struct inode *, void *),
|
||||||
|
void *data);
|
||||||
|
|
||||||
|
'test' is an additional function that can be used when the inode
|
||||||
|
number is not sufficient to identify the actual file object. 'set'
|
||||||
|
should be a non-blocking function that initializes those parts of a
|
||||||
|
newly created inode to allow the test function to succeed. 'data' is
|
||||||
|
passed as an opaque value to both test and set functions.
|
||||||
|
|
||||||
|
When the inode has been created by iget5_locked(), it will be returned with the
|
||||||
|
I_NEW flag set and will still be locked. The filesystem then needs to finalize
|
||||||
|
the initialization. Once the inode is initialized it must be unlocked by
|
||||||
|
calling unlock_new_inode().
|
||||||
|
|
||||||
|
The filesystem is responsible for setting (and possibly testing) i_ino
|
||||||
|
when appropriate. There is also a simpler iget_locked function that
|
||||||
|
just takes the superblock and inode number as arguments and does the
|
||||||
|
test and set for you.
|
||||||
|
|
||||||
|
e.g.::
|
||||||
|
|
||||||
|
inode = iget_locked(sb, ino);
|
||||||
|
if (inode->i_state & I_NEW) {
|
||||||
|
err = read_inode_from_disk(inode);
|
||||||
|
if (err < 0) {
|
||||||
|
iget_failed(inode);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
unlock_new_inode(inode);
|
||||||
|
}
|
||||||
|
|
||||||
|
Note that if the process of setting up a new inode fails, then iget_failed()
|
||||||
|
should be called on the inode to render it dead, and an appropriate error
|
||||||
|
should be passed back to the caller.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
->getattr() finally getting used. See instances in nfs, minix, etc.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->revalidate() is gone. If your filesystem had it - provide ->getattr()
|
||||||
|
and let it call whatever you had as ->revlidate() + (for symlinks that
|
||||||
|
had ->revalidate()) add calls in ->follow_link()/->readlink().
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->d_parent changes are not protected by BKL anymore. Read access is safe
|
||||||
|
if at least one of the following is true:
|
||||||
|
|
||||||
|
* filesystem has no cross-directory rename()
|
||||||
|
* we know that parent had been locked (e.g. we are looking at
|
||||||
|
->d_parent of ->lookup() argument).
|
||||||
|
* we are called from ->rename().
|
||||||
|
* the child's ->d_lock is held
|
||||||
|
|
||||||
|
Audit your code and add locking if needed. Notice that any place that is
|
||||||
|
not protected by the conditions above is risky even in the old tree - you
|
||||||
|
had been relying on BKL and that's prone to screwups. Old tree had quite
|
||||||
|
a few holes of that kind - unprotected access to ->d_parent leading to
|
||||||
|
anything from oops to silent memory corruption.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
FS_NOMOUNT is gone. If you use it - just set SB_NOUSER in flags
|
||||||
|
(see rootfs for one kind of solution and bdev/socket/pipe for another).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
Use bdev_read_only(bdev) instead of is_read_only(kdev). The latter
|
||||||
|
is still alive, but only because of the mess in drivers/s390/block/dasd.c.
|
||||||
|
As soon as it gets fixed is_read_only() will die.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->permission() is called without BKL now. Grab it on entry, drop upon
|
||||||
|
return - that will guarantee the same locking you used to have. If
|
||||||
|
your method or its parts do not need BKL - better yet, now you can
|
||||||
|
shift lock_kernel() and unlock_kernel() so that they would protect
|
||||||
|
exactly what needs to be protected.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->statfs() is now called without BKL held. BKL should have been
|
||||||
|
shifted into individual fs sb_op functions where it's not clear that
|
||||||
|
it's safe to remove it. If you don't need it, remove it.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
is_read_only() is gone; use bdev_read_only() instead.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
destroy_buffers() is gone; use invalidate_bdev().
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
fsync_dev() is gone; use fsync_bdev(). NOTE: lvm breakage is
|
||||||
|
deliberate; as soon as struct block_device * is propagated in a reasonable
|
||||||
|
way by that code fixing will become trivial; until then nothing can be
|
||||||
|
done.
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
block truncatation on error exit from ->write_begin, and ->direct_IO
|
||||||
|
moved from generic methods (block_write_begin, cont_write_begin,
|
||||||
|
nobh_write_begin, blockdev_direct_IO*) to callers. Take a look at
|
||||||
|
ext2_write_failed and callers for an example.
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->truncate is gone. The whole truncate sequence needs to be
|
||||||
|
implemented in ->setattr, which is now mandatory for filesystems
|
||||||
|
implementing on-disk size changes. Start with a copy of the old inode_setattr
|
||||||
|
and vmtruncate, and the reorder the vmtruncate + foofs_vmtruncate sequence to
|
||||||
|
be in order of zeroing blocks using block_truncate_page or similar helpers,
|
||||||
|
size update and on finally on-disk truncation which should not fail.
|
||||||
|
setattr_prepare (which used to be inode_change_ok) now includes the size checks
|
||||||
|
for ATTR_SIZE and must be called in the beginning of ->setattr unconditionally.
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->clear_inode() and ->delete_inode() are gone; ->evict_inode() should
|
||||||
|
be used instead. It gets called whenever the inode is evicted, whether it has
|
||||||
|
remaining links or not. Caller does *not* evict the pagecache or inode-associated
|
||||||
|
metadata buffers; the method has to use truncate_inode_pages_final() to get rid
|
||||||
|
of those. Caller makes sure async writeback cannot be running for the inode while
|
||||||
|
(or after) ->evict_inode() is called.
|
||||||
|
|
||||||
|
->drop_inode() returns int now; it's called on final iput() with
|
||||||
|
inode->i_lock held and it returns true if filesystems wants the inode to be
|
||||||
|
dropped. As before, generic_drop_inode() is still the default and it's been
|
||||||
|
updated appropriately. generic_delete_inode() is also alive and it consists
|
||||||
|
simply of return 1. Note that all actual eviction work is done by caller after
|
||||||
|
->drop_inode() returns.
|
||||||
|
|
||||||
|
As before, clear_inode() must be called exactly once on each call of
|
||||||
|
->evict_inode() (as it used to be for each call of ->delete_inode()). Unlike
|
||||||
|
before, if you are using inode-associated metadata buffers (i.e.
|
||||||
|
mark_buffer_dirty_inode()), it's your responsibility to call
|
||||||
|
invalidate_inode_buffers() before clear_inode().
|
||||||
|
|
||||||
|
NOTE: checking i_nlink in the beginning of ->write_inode() and bailing out
|
||||||
|
if it's zero is not *and* *never* *had* *been* enough. Final unlink() and iput()
|
||||||
|
may happen while the inode is in the middle of ->write_inode(); e.g. if you blindly
|
||||||
|
free the on-disk inode, you may end up doing that while ->write_inode() is writing
|
||||||
|
to it.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
.d_delete() now only advises the dcache as to whether or not to cache
|
||||||
|
unreferenced dentries, and is now only called when the dentry refcount goes to
|
||||||
|
0. Even on 0 refcount transition, it must be able to tolerate being called 0,
|
||||||
|
1, or more times (eg. constant, idempotent).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
.d_compare() calling convention and locking rules are significantly
|
||||||
|
changed. Read updated documentation in Documentation/filesystems/vfs.rst (and
|
||||||
|
look at examples of other filesystems) for guidance.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
.d_hash() calling convention and locking rules are significantly
|
||||||
|
changed. Read updated documentation in Documentation/filesystems/vfs.rst (and
|
||||||
|
look at examples of other filesystems) for guidance.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
dcache_lock is gone, replaced by fine grained locks. See fs/dcache.c
|
||||||
|
for details of what locks to replace dcache_lock with in order to protect
|
||||||
|
particular things. Most of the time, a filesystem only needs ->d_lock, which
|
||||||
|
protects *all* the dcache state of a given dentry.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
Filesystems must RCU-free their inodes, if they can have been accessed
|
||||||
|
via rcu-walk path walk (basically, if the file can have had a path name in the
|
||||||
|
vfs namespace).
|
||||||
|
|
||||||
|
Even though i_dentry and i_rcu share storage in a union, we will
|
||||||
|
initialize the former in inode_init_always(), so just leave it alone in
|
||||||
|
the callback. It used to be necessary to clean it there, but not anymore
|
||||||
|
(starting at 3.2).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
vfs now tries to do path walking in "rcu-walk mode", which avoids
|
||||||
|
atomic operations and scalability hazards on dentries and inodes (see
|
||||||
|
Documentation/filesystems/path-lookup.txt). d_hash and d_compare changes
|
||||||
|
(above) are examples of the changes required to support this. For more complex
|
||||||
|
filesystem callbacks, the vfs drops out of rcu-walk mode before the fs call, so
|
||||||
|
no changes are required to the filesystem. However, this is costly and loses
|
||||||
|
the benefits of rcu-walk mode. We will begin to add filesystem callbacks that
|
||||||
|
are rcu-walk aware, shown below. Filesystems should take advantage of this
|
||||||
|
where possible.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
d_revalidate is a callback that is made on every path element (if
|
||||||
|
the filesystem provides it), which requires dropping out of rcu-walk mode. This
|
||||||
|
may now be called in rcu-walk mode (nd->flags & LOOKUP_RCU). -ECHILD should be
|
||||||
|
returned if the filesystem cannot handle rcu-walk. See
|
||||||
|
Documentation/filesystems/vfs.rst for more details.
|
||||||
|
|
||||||
|
permission is an inode permission check that is called on many or all
|
||||||
|
directory inodes on the way down a path walk (to check for exec permission). It
|
||||||
|
must now be rcu-walk aware (mask & MAY_NOT_BLOCK). See
|
||||||
|
Documentation/filesystems/vfs.rst for more details.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
In ->fallocate() you must check the mode option passed in. If your
|
||||||
|
filesystem does not support hole punching (deallocating space in the middle of a
|
||||||
|
file) you must return -EOPNOTSUPP if FALLOC_FL_PUNCH_HOLE is set in mode.
|
||||||
|
Currently you can only have FALLOC_FL_PUNCH_HOLE with FALLOC_FL_KEEP_SIZE set,
|
||||||
|
so the i_size should not change when hole punching, even when puching the end of
|
||||||
|
a file off.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->get_sb() is gone. Switch to use of ->mount(). Typically it's just
|
||||||
|
a matter of switching from calling ``get_sb_``... to ``mount_``... and changing
|
||||||
|
the function type. If you were doing it manually, just switch from setting
|
||||||
|
->mnt_root to some pointer to returning that pointer. On errors return
|
||||||
|
ERR_PTR(...).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->permission() and generic_permission()have lost flags
|
||||||
|
argument; instead of passing IPERM_FLAG_RCU we add MAY_NOT_BLOCK into mask.
|
||||||
|
|
||||||
|
generic_permission() has also lost the check_acl argument; ACL checking
|
||||||
|
has been taken to VFS and filesystems need to provide a non-NULL ->i_op->get_acl
|
||||||
|
to read an ACL from disk.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
If you implement your own ->llseek() you must handle SEEK_HOLE and
|
||||||
|
SEEK_DATA. You can hanle this by returning -EINVAL, but it would be nicer to
|
||||||
|
support it in some way. The generic handler assumes that the entire file is
|
||||||
|
data and there is a virtual hole at the end of the file. So if the provided
|
||||||
|
offset is less than i_size and SEEK_DATA is specified, return the same offset.
|
||||||
|
If the above is true for the offset and you are given SEEK_HOLE, return the end
|
||||||
|
of the file. If the offset is i_size or greater return -ENXIO in either case.
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
If you have your own ->fsync() you must make sure to call
|
||||||
|
filemap_write_and_wait_range() so that all dirty pages are synced out properly.
|
||||||
|
You must also keep in mind that ->fsync() is not called with i_mutex held
|
||||||
|
anymore, so if you require i_mutex locking you must make sure to take it and
|
||||||
|
release it yourself.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
d_alloc_root() is gone, along with a lot of bugs caused by code
|
||||||
|
misusing it. Replacement: d_make_root(inode). On success d_make_root(inode)
|
||||||
|
allocates and returns a new dentry instantiated with the passed in inode.
|
||||||
|
On failure NULL is returned and the passed in inode is dropped so the reference
|
||||||
|
to inode is consumed in all cases and failure handling need not do any cleanup
|
||||||
|
for the inode. If d_make_root(inode) is passed a NULL inode it returns NULL
|
||||||
|
and also requires no further error handling. Typical usage is::
|
||||||
|
|
||||||
|
inode = foofs_new_inode(....);
|
||||||
|
s->s_root = d_make_root(inode);
|
||||||
|
if (!s->s_root)
|
||||||
|
/* Nothing needed for the inode cleanup */
|
||||||
|
return -ENOMEM;
|
||||||
|
...
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
The witch is dead! Well, 2/3 of it, anyway. ->d_revalidate() and
|
||||||
|
->lookup() do *not* take struct nameidata anymore; just the flags.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->create() doesn't take ``struct nameidata *``; unlike the previous
|
||||||
|
two, it gets "is it an O_EXCL or equivalent?" boolean argument. Note that
|
||||||
|
local filesystems can ignore tha argument - they are guaranteed that the
|
||||||
|
object doesn't exist. It's remote/distributed ones that might care...
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
FS_REVAL_DOT is gone; if you used to have it, add ->d_weak_revalidate()
|
||||||
|
in your dentry operations instead.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
vfs_readdir() is gone; switch to iterate_dir() instead
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->readdir() is gone now; switch to ->iterate()
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
vfs_follow_link has been removed. Filesystems must use nd_set_link
|
||||||
|
from ->follow_link for normal symlinks, or nd_jump_link for magic
|
||||||
|
/proc/<pid> style links.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
iget5_locked()/ilookup5()/ilookup5_nowait() test() callback used to be
|
||||||
|
called with both ->i_lock and inode_hash_lock held; the former is *not*
|
||||||
|
taken anymore, so verify that your callbacks do not rely on it (none
|
||||||
|
of the in-tree instances did). inode_hash_lock is still held,
|
||||||
|
of course, so they are still serialized wrt removal from inode hash,
|
||||||
|
as well as wrt set() callback of iget5_locked().
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
d_materialise_unique() is gone; d_splice_alias() does everything you
|
||||||
|
need now. Remember that they have opposite orders of arguments ;-/
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
f_dentry is gone; use f_path.dentry, or, better yet, see if you can avoid
|
||||||
|
it entirely.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
never call ->read() and ->write() directly; use __vfs_{read,write} or
|
||||||
|
wrappers; instead of checking for ->write or ->read being NULL, look for
|
||||||
|
FMODE_CAN_{WRITE,READ} in file->f_mode.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
do _not_ use new_sync_{read,write} for ->read/->write; leave it NULL
|
||||||
|
instead.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
->aio_read/->aio_write are gone. Use ->read_iter/->write_iter.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
for embedded ("fast") symlinks just set inode->i_link to wherever the
|
||||||
|
symlink body is and use simple_follow_link() as ->follow_link().
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
calling conventions for ->follow_link() have changed. Instead of returning
|
||||||
|
cookie and using nd_set_link() to store the body to traverse, we return
|
||||||
|
the body to traverse and store the cookie using explicit void ** argument.
|
||||||
|
nameidata isn't passed at all - nd_jump_link() doesn't need it and
|
||||||
|
nd_[gs]et_link() is gone.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
calling conventions for ->put_link() have changed. It gets inode instead of
|
||||||
|
dentry, it does not get nameidata at all and it gets called only when cookie
|
||||||
|
is non-NULL. Note that link body isn't available anymore, so if you need it,
|
||||||
|
store it as cookie.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
any symlink that might use page_follow_link_light/page_put_link() must
|
||||||
|
have inode_nohighmem(inode) called before anything might start playing with
|
||||||
|
its pagecache. No highmem pages should end up in the pagecache of such
|
||||||
|
symlinks. That includes any preseeding that might be done during symlink
|
||||||
|
creation. __page_symlink() will honour the mapping gfp flags, so once
|
||||||
|
you've done inode_nohighmem() it's safe to use, but if you allocate and
|
||||||
|
insert the page manually, make sure to use the right gfp flags.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->follow_link() is replaced with ->get_link(); same API, except that
|
||||||
|
|
||||||
|
* ->get_link() gets inode as a separate argument
|
||||||
|
* ->get_link() may be called in RCU mode - in that case NULL
|
||||||
|
dentry is passed
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->get_link() gets struct delayed_call ``*done`` now, and should do
|
||||||
|
set_delayed_call() where it used to set ``*cookie``.
|
||||||
|
|
||||||
|
->put_link() is gone - just give the destructor to set_delayed_call()
|
||||||
|
in ->get_link().
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->getxattr() and xattr_handler.get() get dentry and inode passed separately.
|
||||||
|
dentry might be yet to be attached to inode, so do _not_ use its ->d_inode
|
||||||
|
in the instances. Rationale: !@#!@# security_d_instantiate() needs to be
|
||||||
|
called before we attach dentry to inode.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
symlinks are no longer the only inodes that do *not* have i_bdev/i_cdev/
|
||||||
|
i_pipe/i_link union zeroed out at inode eviction. As the result, you can't
|
||||||
|
assume that non-NULL value in ->i_nlink at ->destroy_inode() implies that
|
||||||
|
it's a symlink. Checking ->i_mode is really needed now. In-tree we had
|
||||||
|
to fix shmem_destroy_callback() that used to take that kind of shortcut;
|
||||||
|
watch out, since that shortcut is no longer valid.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->i_mutex is replaced with ->i_rwsem now. inode_lock() et.al. work as
|
||||||
|
they used to - they just take it exclusive. However, ->lookup() may be
|
||||||
|
called with parent locked shared. Its instances must not
|
||||||
|
|
||||||
|
* use d_instantiate) and d_rehash() separately - use d_add() or
|
||||||
|
d_splice_alias() instead.
|
||||||
|
* use d_rehash() alone - call d_add(new_dentry, NULL) instead.
|
||||||
|
* in the unlikely case when (read-only) access to filesystem
|
||||||
|
data structures needs exclusion for some reason, arrange it
|
||||||
|
yourself. None of the in-tree filesystems needed that.
|
||||||
|
* rely on ->d_parent and ->d_name not changing after dentry has
|
||||||
|
been fed to d_add() or d_splice_alias(). Again, none of the
|
||||||
|
in-tree instances relied upon that.
|
||||||
|
|
||||||
|
We are guaranteed that lookups of the same name in the same directory
|
||||||
|
will not happen in parallel ("same" in the sense of your ->d_compare()).
|
||||||
|
Lookups on different names in the same directory can and do happen in
|
||||||
|
parallel now.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
->iterate_shared() is added; it's a parallel variant of ->iterate().
|
||||||
|
Exclusion on struct file level is still provided (as well as that
|
||||||
|
between it and lseek on the same struct file), but if your directory
|
||||||
|
has been opened several times, you can get these called in parallel.
|
||||||
|
Exclusion between that method and all directory-modifying ones is
|
||||||
|
still provided, of course.
|
||||||
|
|
||||||
|
Often enough ->iterate() can serve as ->iterate_shared() without any
|
||||||
|
changes - it is a read-only operation, after all. If you have any
|
||||||
|
per-inode or per-dentry in-core data structures modified by ->iterate(),
|
||||||
|
you might need something to serialize the access to them. If you
|
||||||
|
do dcache pre-seeding, you'll need to switch to d_alloc_parallel() for
|
||||||
|
that; look for in-tree examples.
|
||||||
|
|
||||||
|
Old method is only used if the new one is absent; eventually it will
|
||||||
|
be removed. Switch while you still can; the old one won't stay.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->atomic_open() calls without O_CREAT may happen in parallel.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->setxattr() and xattr_handler.set() get dentry and inode passed separately.
|
||||||
|
dentry might be yet to be attached to inode, so do _not_ use its ->d_inode
|
||||||
|
in the instances. Rationale: !@#!@# security_d_instantiate() needs to be
|
||||||
|
called before we attach dentry to inode and !@#!@##!@$!$#!@#$!@$!@$ smack
|
||||||
|
->d_instantiate() uses not just ->getxattr() but ->setxattr() as well.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->d_compare() doesn't get parent as a separate argument anymore. If you
|
||||||
|
used it for finding the struct super_block involved, dentry->d_sb will
|
||||||
|
work just as well; if it's something more complicated, use dentry->d_parent.
|
||||||
|
Just be careful not to assume that fetching it more than once will yield
|
||||||
|
the same value - in RCU mode it could change under you.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->rename() has an added flags argument. Any flags not handled by the
|
||||||
|
filesystem should result in EINVAL being returned.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
->readlink is optional for symlinks. Don't set, unless filesystem needs
|
||||||
|
to fake something for readlink(2).
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->getattr() is now passed a struct path rather than a vfsmount and
|
||||||
|
dentry separately, and it now has request_mask and query_flags arguments
|
||||||
|
to specify the fields and sync type requested by statx. Filesystems not
|
||||||
|
supporting any statx-specific features may ignore the new arguments.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->atomic_open() calling conventions have changed. Gone is ``int *opened``,
|
||||||
|
along with FILE_OPENED/FILE_CREATED. In place of those we have
|
||||||
|
FMODE_OPENED/FMODE_CREATED, set in file->f_mode. Additionally, return
|
||||||
|
value for 'called finish_no_open(), open it yourself' case has become
|
||||||
|
0, not 1. Since finish_no_open() itself is returning 0 now, that part
|
||||||
|
does not need any changes in ->atomic_open() instances.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
alloc_file() has become static now; two wrappers are to be used instead.
|
||||||
|
alloc_file_pseudo(inode, vfsmount, name, flags, ops) is for the cases
|
||||||
|
when dentry needs to be created; that's the majority of old alloc_file()
|
||||||
|
users. Calling conventions: on success a reference to new struct file
|
||||||
|
is returned and callers reference to inode is subsumed by that. On
|
||||||
|
failure, ERR_PTR() is returned and no caller's references are affected,
|
||||||
|
so the caller needs to drop the inode reference it held.
|
||||||
|
alloc_file_clone(file, flags, ops) does not affect any caller's references.
|
||||||
|
On success you get a new struct file sharing the mount/dentry with the
|
||||||
|
original, on failure - ERR_PTR().
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
->clone_file_range() and ->dedupe_file_range have been replaced with
|
||||||
|
->remap_file_range(). See Documentation/filesystems/vfs.rst for more
|
||||||
|
information.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**recommended**
|
||||||
|
|
||||||
|
->lookup() instances doing an equivalent of::
|
||||||
|
|
||||||
|
if (IS_ERR(inode))
|
||||||
|
return ERR_CAST(inode);
|
||||||
|
return d_splice_alias(inode, dentry);
|
||||||
|
|
||||||
|
don't need to bother with the check - d_splice_alias() will do the
|
||||||
|
right thing when given ERR_PTR(...) as inode. Moreover, passing NULL
|
||||||
|
inode to d_splice_alias() will also do the right thing (equivalent of
|
||||||
|
d_add(dentry, NULL); return NULL;), so that kind of special cases
|
||||||
|
also doesn't need a separate treatment.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**strongly recommended**
|
||||||
|
|
||||||
|
take the RCU-delayed parts of ->destroy_inode() into a new method -
|
||||||
|
->free_inode(). If ->destroy_inode() becomes empty - all the better,
|
||||||
|
just get rid of it. Synchronous work (e.g. the stuff that can't
|
||||||
|
be done from an RCU callback, or any WARN_ON() where we want the
|
||||||
|
stack trace) *might* be movable to ->evict_inode(); however,
|
||||||
|
that goes only for the things that are not needed to balance something
|
||||||
|
done by ->alloc_inode(). IOW, if it's cleaning up the stuff that
|
||||||
|
might have accumulated over the life of in-core inode, ->evict_inode()
|
||||||
|
might be a fit.
|
||||||
|
|
||||||
|
Rules for inode destruction:
|
||||||
|
|
||||||
|
* if ->destroy_inode() is non-NULL, it gets called
|
||||||
|
* if ->free_inode() is non-NULL, it gets scheduled by call_rcu()
|
||||||
|
* combination of NULL ->destroy_inode and NULL ->free_inode is
|
||||||
|
treated as NULL/free_inode_nonrcu, to preserve the compatibility.
|
||||||
|
|
||||||
|
Note that the callback (be it via ->free_inode() or explicit call_rcu()
|
||||||
|
in ->destroy_inode()) is *NOT* ordered wrt superblock destruction;
|
||||||
|
as the matter of fact, the superblock and all associated structures
|
||||||
|
might be already gone. The filesystem driver is guaranteed to be still
|
||||||
|
there, but that's it. Freeing memory in the callback is fine; doing
|
||||||
|
more than that is possible, but requires a lot of care and is best
|
||||||
|
avoided.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
DCACHE_RCUACCESS is gone; having an RCU delay on dentry freeing is the
|
||||||
|
default. DCACHE_NORCU opts out, and only d_alloc_pseudo() has any
|
||||||
|
business doing so.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**mandatory**
|
||||||
|
|
||||||
|
d_alloc_pseudo() is internal-only; uses outside of alloc_file_pseudo() are
|
||||||
|
very suspect (and won't work in modules). Such uses are very likely to
|
||||||
|
be misspelled d_alloc_anon().
|
@ -1,8 +1,11 @@
|
|||||||
% UBIFS Authentication
|
:orphan:
|
||||||
% sigma star gmbh
|
|
||||||
% 2018
|
|
||||||
|
|
||||||
# Introduction
|
.. UBIFS Authentication
|
||||||
|
.. sigma star gmbh
|
||||||
|
.. 2018
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
UBIFS utilizes the fscrypt framework to provide confidentiality for file
|
UBIFS utilizes the fscrypt framework to provide confidentiality for file
|
||||||
contents and file names. This prevents attacks where an attacker is able to
|
contents and file names. This prevents attacks where an attacker is able to
|
||||||
@ -33,7 +36,8 @@ existing features like key derivation can be utilized. It should however also
|
|||||||
be possible to use UBIFS authentication without using encryption.
|
be possible to use UBIFS authentication without using encryption.
|
||||||
|
|
||||||
|
|
||||||
## MTD, UBI & UBIFS
|
MTD, UBI & UBIFS
|
||||||
|
----------------
|
||||||
|
|
||||||
On Linux, the MTD (Memory Technology Devices) subsystem provides a uniform
|
On Linux, the MTD (Memory Technology Devices) subsystem provides a uniform
|
||||||
interface to access raw flash devices. One of the more prominent subsystems that
|
interface to access raw flash devices. One of the more prominent subsystems that
|
||||||
@ -47,7 +51,7 @@ UBIFS is a filesystem for raw flash which operates on top of UBI. Thus, wear
|
|||||||
leveling and some flash specifics are left to UBI, while UBIFS focuses on
|
leveling and some flash specifics are left to UBI, while UBIFS focuses on
|
||||||
scalability, performance and recoverability.
|
scalability, performance and recoverability.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
+------------+ +*******+ +-----------+ +-----+
|
+------------+ +*******+ +-----------+ +-----+
|
||||||
| | * UBIFS * | UBI-BLOCK | | ... |
|
| | * UBIFS * | UBI-BLOCK | | ... |
|
||||||
@ -84,7 +88,8 @@ persisted onto the flash directly. More details on UBIFS can also be found in
|
|||||||
[UBIFS-WP].
|
[UBIFS-WP].
|
||||||
|
|
||||||
|
|
||||||
### UBIFS Index & Tree Node Cache
|
UBIFS Index & Tree Node Cache
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Basic on-flash UBIFS entities are called *nodes*. UBIFS knows different types
|
Basic on-flash UBIFS entities are called *nodes*. UBIFS knows different types
|
||||||
of nodes. Eg. data nodes (`struct ubifs_data_node`) which store chunks of file
|
of nodes. Eg. data nodes (`struct ubifs_data_node`) which store chunks of file
|
||||||
@ -118,17 +123,18 @@ on-flash filesystem structures like the index. On every commit, the TNC nodes
|
|||||||
marked as dirty are written to the flash to update the persisted index.
|
marked as dirty are written to the flash to update the persisted index.
|
||||||
|
|
||||||
|
|
||||||
### Journal
|
Journal
|
||||||
|
~~~~~~~
|
||||||
|
|
||||||
To avoid wearing out the flash, the index is only persisted (*commited*) when
|
To avoid wearing out the flash, the index is only persisted (*commited*) when
|
||||||
certain conditions are met (eg. `fsync(2)`). The journal is used to record
|
certain conditions are met (eg. ``fsync(2)``). The journal is used to record
|
||||||
any changes (in form of inode nodes, data nodes etc.) between commits
|
any changes (in form of inode nodes, data nodes etc.) between commits
|
||||||
of the index. During mount, the journal is read from the flash and replayed
|
of the index. During mount, the journal is read from the flash and replayed
|
||||||
onto the TNC (which will be created on-demand from the on-flash index).
|
onto the TNC (which will be created on-demand from the on-flash index).
|
||||||
|
|
||||||
UBIFS reserves a bunch of LEBs just for the journal called *log area*. The
|
UBIFS reserves a bunch of LEBs just for the journal called *log area*. The
|
||||||
amount of log area LEBs is configured on filesystem creation (using
|
amount of log area LEBs is configured on filesystem creation (using
|
||||||
`mkfs.ubifs`) and stored in the superblock node. The log area contains only
|
``mkfs.ubifs``) and stored in the superblock node. The log area contains only
|
||||||
two types of nodes: *reference nodes* and *commit start nodes*. A commit start
|
two types of nodes: *reference nodes* and *commit start nodes*. A commit start
|
||||||
node is written whenever an index commit is performed. Reference nodes are
|
node is written whenever an index commit is performed. Reference nodes are
|
||||||
written on every journal update. Each reference node points to the position of
|
written on every journal update. Each reference node points to the position of
|
||||||
@ -152,6 +158,7 @@ done for the last referenced LEB of the journal. Only this can become corrupt
|
|||||||
because of a power cut. If the recovery fails, UBIFS will not mount. An error
|
because of a power cut. If the recovery fails, UBIFS will not mount. An error
|
||||||
for every other LEB will directly cause UBIFS to fail the mount operation.
|
for every other LEB will directly cause UBIFS to fail the mount operation.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
| ---- LOG AREA ---- | ---------- MAIN AREA ------------ |
|
| ---- LOG AREA ---- | ---------- MAIN AREA ------------ |
|
||||||
|
|
||||||
@ -172,10 +179,11 @@ for every other LEB will directly cause UBIFS to fail the mount operation.
|
|||||||
containing their buds
|
containing their buds
|
||||||
|
|
||||||
|
|
||||||
### LEB Property Tree/Table
|
LEB Property Tree/Table
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
The LEB property tree is used to store per-LEB information. This includes the
|
The LEB property tree is used to store per-LEB information. This includes the
|
||||||
LEB type and amount of free and *dirty* (old, obsolete content) space [1] on
|
LEB type and amount of free and *dirty* (old, obsolete content) space [1]_ on
|
||||||
the LEB. The type is important, because UBIFS never mixes index nodes with data
|
the LEB. The type is important, because UBIFS never mixes index nodes with data
|
||||||
nodes on a single LEB and thus each LEB has a specific purpose. This again is
|
nodes on a single LEB and thus each LEB has a specific purpose. This again is
|
||||||
useful for free space calculations. See [UBIFS-WP] for more details.
|
useful for free space calculations. See [UBIFS-WP] for more details.
|
||||||
@ -185,19 +193,21 @@ index. Due to its smaller size it is always written as one chunk on every
|
|||||||
commit. Thus, saving the LPT is an atomic operation.
|
commit. Thus, saving the LPT is an atomic operation.
|
||||||
|
|
||||||
|
|
||||||
[1] Since LEBs can only be appended and never overwritten, there is a
|
.. [1] Since LEBs can only be appended and never overwritten, there is a
|
||||||
difference between free space ie. the remaining space left on the LEB to be
|
difference between free space ie. the remaining space left on the LEB to be
|
||||||
written to without erasing it and previously written content that is obsolete
|
written to without erasing it and previously written content that is obsolete
|
||||||
but can't be overwritten without erasing the full LEB.
|
but can't be overwritten without erasing the full LEB.
|
||||||
|
|
||||||
|
|
||||||
# UBIFS Authentication
|
UBIFS Authentication
|
||||||
|
====================
|
||||||
|
|
||||||
This chapter introduces UBIFS authentication which enables UBIFS to verify
|
This chapter introduces UBIFS authentication which enables UBIFS to verify
|
||||||
the authenticity and integrity of metadata and file contents stored on flash.
|
the authenticity and integrity of metadata and file contents stored on flash.
|
||||||
|
|
||||||
|
|
||||||
## Threat Model
|
Threat Model
|
||||||
|
------------
|
||||||
|
|
||||||
UBIFS authentication enables detection of offline data modification. While it
|
UBIFS authentication enables detection of offline data modification. While it
|
||||||
does not prevent it, it enables (trusted) code to check the integrity and
|
does not prevent it, it enables (trusted) code to check the integrity and
|
||||||
@ -224,7 +234,8 @@ Additional measures like secure boot and trusted boot have to be taken to
|
|||||||
ensure that only trusted code is executed on a device.
|
ensure that only trusted code is executed on a device.
|
||||||
|
|
||||||
|
|
||||||
## Authentication
|
Authentication
|
||||||
|
--------------
|
||||||
|
|
||||||
To be able to fully trust data read from flash, all UBIFS data structures
|
To be able to fully trust data read from flash, all UBIFS data structures
|
||||||
stored on flash are authenticated. That is:
|
stored on flash are authenticated. That is:
|
||||||
@ -236,7 +247,8 @@ stored on flash are authenticated. That is:
|
|||||||
- The LPT which stores UBI LEB metadata which UBIFS uses for free space accounting
|
- The LPT which stores UBI LEB metadata which UBIFS uses for free space accounting
|
||||||
|
|
||||||
|
|
||||||
### Index Authentication
|
Index Authentication
|
||||||
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Through UBIFS' concept of a wandering tree, it already takes care of only
|
Through UBIFS' concept of a wandering tree, it already takes care of only
|
||||||
updating and persisting changed parts from leaf node up to the root node
|
updating and persisting changed parts from leaf node up to the root node
|
||||||
@ -260,6 +272,7 @@ include a hash. All other types of nodes will remain unchanged. This reduces
|
|||||||
the storage overhead which is precious for users of UBIFS (ie. embedded
|
the storage overhead which is precious for users of UBIFS (ie. embedded
|
||||||
devices).
|
devices).
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
+---------------+
|
+---------------+
|
||||||
| Master Node |
|
| Master Node |
|
||||||
@ -303,7 +316,8 @@ hashes to index nodes does not change this since each hash will be persisted
|
|||||||
atomically together with its respective node.
|
atomically together with its respective node.
|
||||||
|
|
||||||
|
|
||||||
### Journal Authentication
|
Journal Authentication
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
The journal is authenticated too. Since the journal is continuously written
|
The journal is authenticated too. Since the journal is continuously written
|
||||||
it is necessary to also add authentication information frequently to the
|
it is necessary to also add authentication information frequently to the
|
||||||
@ -316,7 +330,7 @@ of the hash chain. That way a journal can be authenticated up to the last
|
|||||||
authentication node. The tail of the journal which may not have a authentication
|
authentication node. The tail of the journal which may not have a authentication
|
||||||
node cannot be authenticated and is skipped during journal replay.
|
node cannot be authenticated and is skipped during journal replay.
|
||||||
|
|
||||||
We get this picture for journal authentication:
|
We get this picture for journal authentication::
|
||||||
|
|
||||||
,,,,,,,,
|
,,,,,,,,
|
||||||
,......,...........................................
|
,......,...........................................
|
||||||
@ -352,7 +366,8 @@ the superblock struct. The superblock node is stored in LEB 0 and is only
|
|||||||
modified on feature flag or similar changes, but never on file changes.
|
modified on feature flag or similar changes, but never on file changes.
|
||||||
|
|
||||||
|
|
||||||
### LPT Authentication
|
LPT Authentication
|
||||||
|
~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
The location of the LPT root node on the flash is stored in the UBIFS master
|
The location of the LPT root node on the flash is stored in the UBIFS master
|
||||||
node. Since the LPT is written and read atomically on every commit, there is
|
node. Since the LPT is written and read atomically on every commit, there is
|
||||||
@ -363,7 +378,8 @@ be verified by verifying the authenticity of the master node and comparing the
|
|||||||
LTP hash stored there with the hash computed from the read on-flash LPT.
|
LTP hash stored there with the hash computed from the read on-flash LPT.
|
||||||
|
|
||||||
|
|
||||||
## Key Management
|
Key Management
|
||||||
|
--------------
|
||||||
|
|
||||||
For simplicity, UBIFS authentication uses a single key to compute the HMACs
|
For simplicity, UBIFS authentication uses a single key to compute the HMACs
|
||||||
of superblock, master, commit start and reference nodes. This key has to be
|
of superblock, master, commit start and reference nodes. This key has to be
|
||||||
@ -399,7 +415,8 @@ approach is similar to the approach proposed for fscrypt encryption policy v2
|
|||||||
[FSCRYPT-POLICY2].
|
[FSCRYPT-POLICY2].
|
||||||
|
|
||||||
|
|
||||||
# Future Extensions
|
Future Extensions
|
||||||
|
=================
|
||||||
|
|
||||||
In certain cases where a vendor wants to provide an authenticated filesystem
|
In certain cases where a vendor wants to provide an authenticated filesystem
|
||||||
image to customers, it should be possible to do so without sharing the secret
|
image to customers, it should be possible to do so without sharing the secret
|
||||||
@ -411,7 +428,8 @@ to the way the IMA/EVM subsystem deals with such situations. The HMAC key
|
|||||||
will then have to be provided beforehand in the normal way.
|
will then have to be provided beforehand in the normal way.
|
||||||
|
|
||||||
|
|
||||||
# References
|
References
|
||||||
|
==========
|
||||||
|
|
||||||
[CRYPTSETUP2] http://www.saout.de/pipermail/dm-crypt/2017-November/005745.html
|
[CRYPTSETUP2] http://www.saout.de/pipermail/dm-crypt/2017-November/005745.html
|
||||||
|
|
@ -20,7 +20,7 @@ kernel which allows different filesystem implementations to coexist.
|
|||||||
|
|
||||||
VFS system calls open(2), stat(2), read(2), write(2), chmod(2) and so on
|
VFS system calls open(2), stat(2), read(2), write(2), chmod(2) and so on
|
||||||
are called from a process context. Filesystem locking is described in
|
are called from a process context. Filesystem locking is described in
|
||||||
the document Documentation/filesystems/Locking.
|
the document Documentation/filesystems/locking.rst.
|
||||||
|
|
||||||
|
|
||||||
Directory Entry Cache (dcache)
|
Directory Entry Cache (dcache)
|
||||||
|
@ -142,7 +142,7 @@ loading the adm1021 module, then things are good.
|
|||||||
If nothing happens when loading the adm1021 module, and you are certain
|
If nothing happens when loading the adm1021 module, and you are certain
|
||||||
that your specific Xeon processor model includes compatible sensors, you
|
that your specific Xeon processor model includes compatible sensors, you
|
||||||
will have to explicitly instantiate the sensor chips from user-space. See
|
will have to explicitly instantiate the sensor chips from user-space. See
|
||||||
method 4 in Documentation/i2c/instantiating-devices. Possible slave
|
method 4 in Documentation/i2c/instantiating-devices.rst. Possible slave
|
||||||
addresses are 0x18, 0x1a, 0x29, 0x2b, 0x4c, or 0x4e. It is likely that
|
addresses are 0x18, 0x1a, 0x29, 0x2b, 0x4c, or 0x4e. It is likely that
|
||||||
only temp2 will be correct and temp1 will have to be ignored.
|
only temp2 will be correct and temp1 will have to be ignored.
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
The ADM1075, unlike many other PMBus devices, does not support internal voltage
|
The ADM1075, unlike many other PMBus devices, does not support internal voltage
|
||||||
|
@ -27,7 +27,7 @@ The devices communicate with the I2C protocol. All sensors are set to the same
|
|||||||
I2C address 0x27 by default, so an entry with I2C_BOARD_INFO("hih6130", 0x27)
|
I2C address 0x27 by default, so an entry with I2C_BOARD_INFO("hih6130", 0x27)
|
||||||
can be used in the board setup code.
|
can be used in the board setup code.
|
||||||
|
|
||||||
Please see Documentation/i2c/instantiating-devices for details on how to
|
Please see Documentation/i2c/instantiating-devices.rst for details on how to
|
||||||
instantiate I2C devices.
|
instantiate I2C devices.
|
||||||
|
|
||||||
sysfs-Interface
|
sysfs-Interface
|
||||||
|
@ -17,7 +17,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
Sysfs entries
|
Sysfs entries
|
||||||
|
@ -76,7 +76,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -79,7 +79,7 @@ Usage Notes
|
|||||||
|
|
||||||
This driver does not probe for devices, since there is no register which
|
This driver does not probe for devices, since there is no register which
|
||||||
can be safely used to identify the chip. You will have to instantiate
|
can be safely used to identify the chip. You will have to instantiate
|
||||||
the devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
the devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
WARNING: Do not access chip registers using the i2cdump command, and do not use
|
WARNING: Do not access chip registers using the i2cdump command, and do not use
|
||||||
|
@ -30,7 +30,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
For MAX34446, the value of the currX_crit attribute determines if current or
|
For MAX34446, the value of the currX_crit attribute determines if current or
|
||||||
|
@ -55,7 +55,7 @@ Usage notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
Module parameters
|
Module parameters
|
||||||
|
@ -28,7 +28,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ Usage Notes
|
|||||||
This driver is part of the MFD driver named "menf21bmc" and does
|
This driver is part of the MFD driver named "menf21bmc" and does
|
||||||
not auto-detect devices.
|
not auto-detect devices.
|
||||||
You will have to instantiate the MFD driver explicitly.
|
You will have to instantiate the MFD driver explicitly.
|
||||||
Please see Documentation/i2c/instantiating-devices for
|
Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
Sysfs entries
|
Sysfs entries
|
||||||
|
@ -68,7 +68,7 @@ Accessing PCF8591 via /sys interface
|
|||||||
The PCF8591 is plainly impossible to detect! Thus the driver won't even
|
The PCF8591 is plainly impossible to detect! Thus the driver won't even
|
||||||
try. You have to explicitly instantiate the device at the relevant
|
try. You have to explicitly instantiate the device at the relevant
|
||||||
address (in the interval [0x48..0x4f]) either through platform data, or
|
address (in the interval [0x48..0x4f]) either through platform data, or
|
||||||
using the sysfs interface. See Documentation/i2c/instantiating-devices
|
using the sysfs interface. See Documentation/i2c/instantiating-devices.rst
|
||||||
for details.
|
for details.
|
||||||
|
|
||||||
Directories are being created for each instantiated PCF8591:
|
Directories are being created for each instantiated PCF8591:
|
||||||
|
@ -26,7 +26,7 @@ scaled by 1000, i.e. the value for 31.5 degrees celsius is 31500.
|
|||||||
|
|
||||||
The device communicates with the I2C protocol. Sensors can have the I2C
|
The device communicates with the I2C protocol. Sensors can have the I2C
|
||||||
addresses 0x44 or 0x45, depending on the wiring. See
|
addresses 0x44 or 0x45, depending on the wiring. See
|
||||||
Documentation/i2c/instantiating-devices for methods to instantiate the device.
|
Documentation/i2c/instantiating-devices.rst for methods to instantiate the device.
|
||||||
|
|
||||||
There are two options configurable by means of sht3x_platform_data:
|
There are two options configurable by means of sht3x_platform_data:
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ chips, a humidity and temperature sensor. Temperature is measured in degrees
|
|||||||
celsius, relative humidity is expressed as a percentage.
|
celsius, relative humidity is expressed as a percentage.
|
||||||
|
|
||||||
The device communicates with the I2C protocol. All sensors are set to I2C
|
The device communicates with the I2C protocol. All sensors are set to I2C
|
||||||
address 0x70. See Documentation/i2c/instantiating-devices for methods to
|
address 0x70. See Documentation/i2c/instantiating-devices.rst for methods to
|
||||||
instantiate the device.
|
instantiate the device.
|
||||||
|
|
||||||
There are two options configurable by means of shtc1_platform_data:
|
There are two options configurable by means of shtc1_platform_data:
|
||||||
|
@ -30,4 +30,4 @@ The driver provides the common sysfs-interface for temperatures (see
|
|||||||
Documentation/hwmon/sysfs-interface.rst under Temperatures).
|
Documentation/hwmon/sysfs-interface.rst under Temperatures).
|
||||||
|
|
||||||
Please refer how to instantiate this driver:
|
Please refer how to instantiate this driver:
|
||||||
Documentation/i2c/instantiating-devices
|
Documentation/i2c/instantiating-devices.rst
|
||||||
|
@ -28,7 +28,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ all as a 686A.
|
|||||||
|
|
||||||
The Via 686a southbridge has integrated hardware monitor functionality.
|
The Via 686a southbridge has integrated hardware monitor functionality.
|
||||||
It also has an I2C bus, but this driver only supports the hardware monitor.
|
It also has an I2C bus, but this driver only supports the hardware monitor.
|
||||||
For the I2C bus driver, see <file:Documentation/i2c/busses/i2c-viapro>
|
For the I2C bus driver, see <file:Documentation/i2c/busses/i2c-viapro.rst>
|
||||||
|
|
||||||
The Via 686a implements three temperature sensors, two fan rotation speed
|
The Via 686a implements three temperature sensors, two fan rotation speed
|
||||||
sensors, five voltage sensors and alarms.
|
sensors, five voltage sensors and alarms.
|
||||||
|
@ -121,7 +121,7 @@ Usage Notes
|
|||||||
-----------
|
-----------
|
||||||
|
|
||||||
This driver does not auto-detect devices. You will have to instantiate the
|
This driver does not auto-detect devices. You will have to instantiate the
|
||||||
devices explicitly. Please see Documentation/i2c/instantiating-devices for
|
devices explicitly. Please see Documentation/i2c/instantiating-devices.rst for
|
||||||
details.
|
details.
|
||||||
|
|
||||||
.. warning::
|
.. warning::
|
||||||
|
@ -1,16 +1,19 @@
|
|||||||
|
=========================
|
||||||
Kernel driver i2c-ali1535
|
Kernel driver i2c-ali1535
|
||||||
|
=========================
|
||||||
|
|
||||||
Supported adapters:
|
Supported adapters:
|
||||||
* Acer Labs, Inc. ALI 1535 (south bridge)
|
* Acer Labs, Inc. ALI 1535 (south bridge)
|
||||||
|
|
||||||
Datasheet: Now under NDA
|
Datasheet: Now under NDA
|
||||||
http://www.ali.com.tw/
|
http://www.ali.com.tw/
|
||||||
|
|
||||||
Authors:
|
Authors:
|
||||||
Frodo Looijaard <frodol@dds.nl>,
|
- Frodo Looijaard <frodol@dds.nl>,
|
||||||
Philip Edelbrock <phil@netroedge.com>,
|
- Philip Edelbrock <phil@netroedge.com>,
|
||||||
Mark D. Studebaker <mdsxyz123@yahoo.com>,
|
- Mark D. Studebaker <mdsxyz123@yahoo.com>,
|
||||||
Dan Eaton <dan.eaton@rocketlogix.com>,
|
- Dan Eaton <dan.eaton@rocketlogix.com>,
|
||||||
Stephen Rousset<stephen.rousset@rocketlogix.com>
|
- Stephen Rousset<stephen.rousset@rocketlogix.com>
|
||||||
|
|
||||||
Description
|
Description
|
||||||
-----------
|
-----------
|
@ -1,7 +1,10 @@
|
|||||||
|
=========================
|
||||||
Kernel driver i2c-ali1563
|
Kernel driver i2c-ali1563
|
||||||
|
=========================
|
||||||
|
|
||||||
Supported adapters:
|
Supported adapters:
|
||||||
* Acer Labs, Inc. ALI 1563 (south bridge)
|
* Acer Labs, Inc. ALI 1563 (south bridge)
|
||||||
|
|
||||||
Datasheet: Now under NDA
|
Datasheet: Now under NDA
|
||||||
http://www.ali.com.tw/
|
http://www.ali.com.tw/
|
||||||
|
|
@ -1,14 +1,17 @@
|
|||||||
|
=========================
|
||||||
Kernel driver i2c-ali15x3
|
Kernel driver i2c-ali15x3
|
||||||
|
=========================
|
||||||
|
|
||||||
Supported adapters:
|
Supported adapters:
|
||||||
* Acer Labs, Inc. ALI 1533 and 1543C (south bridge)
|
* Acer Labs, Inc. ALI 1533 and 1543C (south bridge)
|
||||||
|
|
||||||
Datasheet: Now under NDA
|
Datasheet: Now under NDA
|
||||||
http://www.ali.com.tw/
|
http://www.ali.com.tw/
|
||||||
|
|
||||||
Authors:
|
Authors:
|
||||||
Frodo Looijaard <frodol@dds.nl>,
|
- Frodo Looijaard <frodol@dds.nl>,
|
||||||
Philip Edelbrock <phil@netroedge.com>,
|
- Philip Edelbrock <phil@netroedge.com>,
|
||||||
Mark D. Studebaker <mdsxyz123@yahoo.com>
|
- Mark D. Studebaker <mdsxyz123@yahoo.com>
|
||||||
|
|
||||||
Module Parameters
|
Module Parameters
|
||||||
-----------------
|
-----------------
|
||||||
@ -25,7 +28,9 @@ the BIOS. Does not do a PCI force; the device must still be present in
|
|||||||
lspci. Don't use this unless the driver complains that the base address is
|
lspci. Don't use this unless the driver complains that the base address is
|
||||||
not set.
|
not set.
|
||||||
|
|
||||||
Example: 'modprobe i2c-ali15x3 force_addr=0xe800'
|
Example::
|
||||||
|
|
||||||
|
modprobe i2c-ali15x3 force_addr=0xe800
|
||||||
|
|
||||||
SMBus periodically hangs on ASUS P5A motherboards and can only be cleared
|
SMBus periodically hangs on ASUS P5A motherboards and can only be cleared
|
||||||
by a power cycle. Cause unknown (see Issues below).
|
by a power cycle. Cause unknown (see Issues below).
|
||||||
@ -38,23 +43,26 @@ This is the driver for the SMB Host controller on Acer Labs Inc. (ALI)
|
|||||||
M1541 and M1543C South Bridges.
|
M1541 and M1543C South Bridges.
|
||||||
|
|
||||||
The M1543C is a South bridge for desktop systems.
|
The M1543C is a South bridge for desktop systems.
|
||||||
|
|
||||||
The M1541 is a South bridge for portable systems.
|
The M1541 is a South bridge for portable systems.
|
||||||
|
|
||||||
They are part of the following ALI chipsets:
|
They are part of the following ALI chipsets:
|
||||||
|
|
||||||
* "Aladdin Pro 2" includes the M1621 Slot 1 North bridge with AGP and
|
* "Aladdin Pro 2" includes the M1621 Slot 1 North bridge with AGP and
|
||||||
100MHz CPU Front Side bus
|
100MHz CPU Front Side bus
|
||||||
* "Aladdin V" includes the M1541 Socket 7 North bridge with AGP and 100MHz
|
* "Aladdin V" includes the M1541 Socket 7 North bridge with AGP and 100MHz
|
||||||
CPU Front Side bus
|
CPU Front Side bus
|
||||||
|
|
||||||
Some Aladdin V motherboards:
|
Some Aladdin V motherboards:
|
||||||
Asus P5A
|
- Asus P5A
|
||||||
Atrend ATC-5220
|
- Atrend ATC-5220
|
||||||
BCM/GVC VP1541
|
- BCM/GVC VP1541
|
||||||
Biostar M5ALA
|
- Biostar M5ALA
|
||||||
Gigabyte GA-5AX (** Generally doesn't work because the BIOS doesn't
|
- Gigabyte GA-5AX (Generally doesn't work because the BIOS doesn't
|
||||||
enable the 7101 device! **)
|
enable the 7101 device!)
|
||||||
Iwill XA100 Plus
|
- Iwill XA100 Plus
|
||||||
Micronics C200
|
- Micronics C200
|
||||||
Microstar (MSI) MS-5169
|
- Microstar (MSI) MS-5169
|
||||||
|
|
||||||
* "Aladdin IV" includes the M1541 Socket 7 North bridge
|
* "Aladdin IV" includes the M1541 Socket 7 North bridge
|
||||||
with host bus up to 83.3 MHz.
|
with host bus up to 83.3 MHz.
|
||||||
@ -64,21 +72,24 @@ full data sheets on the web site are password protected, however if you
|
|||||||
contact the ALI office in San Jose they may give you the password.
|
contact the ALI office in San Jose they may give you the password.
|
||||||
|
|
||||||
The M1533/M1543C devices appear as FOUR separate devices on the PCI bus. An
|
The M1533/M1543C devices appear as FOUR separate devices on the PCI bus. An
|
||||||
output of lspci will show something similar to the following:
|
output of lspci will show something similar to the following::
|
||||||
|
|
||||||
00:02.0 USB Controller: Acer Laboratories Inc. M5237 (rev 03)
|
00:02.0 USB Controller: Acer Laboratories Inc. M5237 (rev 03)
|
||||||
00:03.0 Bridge: Acer Laboratories Inc. M7101 <= THIS IS THE ONE WE NEED
|
00:03.0 Bridge: Acer Laboratories Inc. M7101 <= THIS IS THE ONE WE NEED
|
||||||
00:07.0 ISA bridge: Acer Laboratories Inc. M1533 (rev c3)
|
00:07.0 ISA bridge: Acer Laboratories Inc. M1533 (rev c3)
|
||||||
00:0f.0 IDE interface: Acer Laboratories Inc. M5229 (rev c1)
|
00:0f.0 IDE interface: Acer Laboratories Inc. M5229 (rev c1)
|
||||||
|
|
||||||
** IMPORTANT **
|
.. important::
|
||||||
** If you have a M1533 or M1543C on the board and you get
|
|
||||||
** "ali15x3: Error: Can't detect ali15x3!"
|
If you have a M1533 or M1543C on the board and you get
|
||||||
** then run lspci.
|
"ali15x3: Error: Can't detect ali15x3!"
|
||||||
** If you see the 1533 and 5229 devices but NOT the 7101 device,
|
then run lspci.
|
||||||
** then you must enable ACPI, the PMU, SMB, or something similar
|
|
||||||
** in the BIOS.
|
If you see the 1533 and 5229 devices but NOT the 7101 device,
|
||||||
** The driver won't work if it can't find the M7101 device.
|
then you must enable ACPI, the PMU, SMB, or something similar
|
||||||
|
in the BIOS.
|
||||||
|
|
||||||
|
The driver won't work if it can't find the M7101 device.
|
||||||
|
|
||||||
The SMB controller is part of the M7101 device, which is an ACPI-compliant
|
The SMB controller is part of the M7101 device, which is an ACPI-compliant
|
||||||
Power Management Unit (PMU).
|
Power Management Unit (PMU).
|
||||||
@ -109,4 +120,3 @@ There may be electrical problems on this board.
|
|||||||
On the P5A, the W83781D sensor chip is on both the ISA and
|
On the P5A, the W83781D sensor chip is on both the ISA and
|
||||||
SMBus. Therefore the SMBus hangs can generally be avoided
|
SMBus. Therefore the SMBus hangs can generally be avoided
|
||||||
by accessing the W83781D on the ISA bus only.
|
by accessing the W83781D on the ISA bus only.
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user