mirror of
https://gitee.com/bianbu-linux/linux-6.6
synced 2025-04-24 14:07:52 -04:00
ASoC: Updates for v5.3
This is a very big update, mainly thanks to Morimoto-san's refactoring work and some fairly large new drivers. - Lots more work on moving towards a component based framework from Morimoto-san. - Support for force disconnecting muxes from Jerome Brunet. - New drivers for Cirrus Logic CS47L35, CS47L85 and CS47L90, Conexant CX2072X, Realtek RT1011 and RT1308. -----BEGIN PGP SIGNATURE----- iQFHBAABCgAxFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAl0jGwUTHGJyb29uaWVA a2VybmVsLm9yZwAKCRAk1otyXVSH0LD4B/9AkutfS+vznOrk0V0wFb2SUfjwE4Pr +z/kAehohAOl/7pg9Dun/lmZYBWMyOM2aYmK81ahEo2DfO+uzwkwjCaXFjGVGwEK j7XpWkrIjKnou/z1FeALgVvt+crzdy5iNWC04AbKaP2WHCcI7zvPQIsBta/V0OJt lg+j0J7pagnTMcgV1+qJdaASmofy/hpoZ79Gv0PIfGC8hpJ/3mBgcNPCLQrJtD4R v+tzvCZNrZVqCanwLf3vouEm1bpWYOpI+Wdmu4u6rY7MhmCj72EJ2zyfdm/qtaxF e7whgCyOQFkWe7NgDn0G08aAT6LsaxOtPNr7H8tL8S8sw8425fqeOouV =n/HQ -----END PGP SIGNATURE----- Merge tag 'asoc-v5.3' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus ASoC: Updates for v5.3 This is a very big update, mainly thanks to Morimoto-san's refactoring work and some fairly large new drivers. - Lots more work on moving towards a component based framework from Morimoto-san. - Support for force disconnecting muxes from Jerome Brunet. - New drivers for Cirrus Logic CS47L35, CS47L85 and CS47L90, Conexant CX2072X, Realtek RT1011 and RT1308. Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
commit
3c53c6255d
22820 changed files with 65749 additions and 159218 deletions
2
.mailmap
2
.mailmap
|
@ -81,6 +81,7 @@ 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>
|
||||||
Gregory CLEMENT <gregory.clement@bootlin.com> <gregory.clement@free-electrons.com>
|
Gregory CLEMENT <gregory.clement@bootlin.com> <gregory.clement@free-electrons.com>
|
||||||
|
Hanjun Guo <guohanjun@huawei.com> <hanjun.guo@linaro.org>
|
||||||
Henk Vergonet <Henk.Vergonet@gmail.com>
|
Henk Vergonet <Henk.Vergonet@gmail.com>
|
||||||
Henrik Kretzschmar <henne@nachtwindheim.de>
|
Henrik Kretzschmar <henne@nachtwindheim.de>
|
||||||
Henrik Rydberg <rydberg@bitmath.org>
|
Henrik Rydberg <rydberg@bitmath.org>
|
||||||
|
@ -238,6 +239,7 @@ Vlad Dogaru <ddvlad@gmail.com> <vlad.dogaru@intel.com>
|
||||||
Vladimir Davydov <vdavydov.dev@gmail.com> <vdavydov@virtuozzo.com>
|
Vladimir Davydov <vdavydov.dev@gmail.com> <vdavydov@virtuozzo.com>
|
||||||
Vladimir Davydov <vdavydov.dev@gmail.com> <vdavydov@parallels.com>
|
Vladimir Davydov <vdavydov.dev@gmail.com> <vdavydov@parallels.com>
|
||||||
Takashi YOSHII <takashi.yoshii.zj@renesas.com>
|
Takashi YOSHII <takashi.yoshii.zj@renesas.com>
|
||||||
|
Will Deacon <will@kernel.org> <will.deacon@arm.com>
|
||||||
Yakir Yang <kuankuan.y@gmail.com> <ykk@rock-chips.com>
|
Yakir Yang <kuankuan.y@gmail.com> <ykk@rock-chips.com>
|
||||||
Yusuke Goda <goda.yusuke@renesas.com>
|
Yusuke Goda <goda.yusuke@renesas.com>
|
||||||
Gustavo Padovan <gustavo@las.ic.unicamp.br>
|
Gustavo Padovan <gustavo@las.ic.unicamp.br>
|
||||||
|
|
8
CREDITS
8
CREDITS
|
@ -3364,6 +3364,14 @@ S: Braunschweiger Strasse 79
|
||||||
S: 31134 Hildesheim
|
S: 31134 Hildesheim
|
||||||
S: Germany
|
S: Germany
|
||||||
|
|
||||||
|
N: Martin Schwidefsky
|
||||||
|
D: Martin was the most significant contributor to the initial s390
|
||||||
|
D: port of the Linux Kernel and later the maintainer of the s390
|
||||||
|
D: architecture backend for almost two decades.
|
||||||
|
D: He passed away in 2019, and will be greatly missed.
|
||||||
|
S: Germany
|
||||||
|
W: https://lwn.net/Articles/789028/
|
||||||
|
|
||||||
N: Marcel Selhorst
|
N: Marcel Selhorst
|
||||||
E: tpmdd@selhorst.net
|
E: tpmdd@selhorst.net
|
||||||
D: TPM driver
|
D: TPM driver
|
||||||
|
|
|
@ -1,29 +0,0 @@
|
||||||
What: /sys/bus/mdio_bus/devices/.../phy_id
|
|
||||||
Date: November 2012
|
|
||||||
KernelVersion: 3.8
|
|
||||||
Contact: netdev@vger.kernel.org
|
|
||||||
Description:
|
|
||||||
This attribute contains the 32-bit PHY Identifier as reported
|
|
||||||
by the device during bus enumeration, encoded in hexadecimal.
|
|
||||||
This ID is used to match the device with the appropriate
|
|
||||||
driver.
|
|
||||||
|
|
||||||
What: /sys/bus/mdio_bus/devices/.../phy_interface
|
|
||||||
Date: February 2014
|
|
||||||
KernelVersion: 3.15
|
|
||||||
Contact: netdev@vger.kernel.org
|
|
||||||
Description:
|
|
||||||
This attribute contains the PHY interface as configured by the
|
|
||||||
Ethernet driver during bus enumeration, encoded in string.
|
|
||||||
This interface mode is used to configure the Ethernet MAC with the
|
|
||||||
appropriate mode for its data lines to the PHY hardware.
|
|
||||||
|
|
||||||
What: /sys/bus/mdio_bus/devices/.../phy_has_fixups
|
|
||||||
Date: February 2014
|
|
||||||
KernelVersion: 3.15
|
|
||||||
Contact: netdev@vger.kernel.org
|
|
||||||
Description:
|
|
||||||
This attribute contains the boolean value whether a given PHY
|
|
||||||
device has had any "fixup" workaround running on it, encoded as
|
|
||||||
a boolean. This information is provided to help troubleshooting
|
|
||||||
PHY configurations.
|
|
|
@ -1,6 +1,6 @@
|
||||||
What: /sys/bus/siox/devices/siox-X/active
|
What: /sys/bus/siox/devices/siox-X/active
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
On reading represents the current state of the bus. If it
|
On reading represents the current state of the bus. If it
|
||||||
contains a "0" the bus is stopped and connected devices are
|
contains a "0" the bus is stopped and connected devices are
|
||||||
|
@ -12,7 +12,7 @@ Description:
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X/device_add
|
What: /sys/bus/siox/devices/siox-X/device_add
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Write-only file. Write
|
Write-only file. Write
|
||||||
|
|
||||||
|
@ -27,13 +27,13 @@ Description:
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X/device_remove
|
What: /sys/bus/siox/devices/siox-X/device_remove
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Write-only file. A single write removes the last device in the siox chain.
|
Write-only file. A single write removes the last device in the siox chain.
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X/poll_interval_ns
|
What: /sys/bus/siox/devices/siox-X/poll_interval_ns
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Defines the interval between two poll cycles in nano seconds.
|
Defines the interval between two poll cycles in nano seconds.
|
||||||
Note this is rounded to jiffies on writing. On reading the current value
|
Note this is rounded to jiffies on writing. On reading the current value
|
||||||
|
@ -41,33 +41,33 @@ Description:
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/connected
|
What: /sys/bus/siox/devices/siox-X-Y/connected
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Read-only value. "0" means the Yth device on siox bus X isn't "connected" i.e.
|
Read-only value. "0" means the Yth device on siox bus X isn't "connected" i.e.
|
||||||
communication with it is not ensured. "1" signals a working connection.
|
communication with it is not ensured. "1" signals a working connection.
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/inbytes
|
What: /sys/bus/siox/devices/siox-X-Y/inbytes
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Read-only value reporting the inbytes value provided to siox-X/device_add
|
Read-only value reporting the inbytes value provided to siox-X/device_add
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/status_errors
|
What: /sys/bus/siox/devices/siox-X-Y/status_errors
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Counts the number of time intervals when the read status byte doesn't yield the
|
Counts the number of time intervals when the read status byte doesn't yield the
|
||||||
expected value.
|
expected value.
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/type
|
What: /sys/bus/siox/devices/siox-X-Y/type
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Read-only value reporting the type value provided to siox-X/device_add.
|
Read-only value reporting the type value provided to siox-X/device_add.
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/watchdog
|
What: /sys/bus/siox/devices/siox-X-Y/watchdog
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Read-only value reporting if the watchdog of the siox device is
|
Read-only value reporting if the watchdog of the siox device is
|
||||||
active. "0" means the watchdog is not active and the device is expected to
|
active. "0" means the watchdog is not active and the device is expected to
|
||||||
|
@ -75,13 +75,13 @@ Description:
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/watchdog_errors
|
What: /sys/bus/siox/devices/siox-X-Y/watchdog_errors
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Read-only value reporting the number to time intervals when the
|
Read-only value reporting the number to time intervals when the
|
||||||
watchdog was active.
|
watchdog was active.
|
||||||
|
|
||||||
What: /sys/bus/siox/devices/siox-X-Y/outbytes
|
What: /sys/bus/siox/devices/siox-X-Y/outbytes
|
||||||
KernelVersion: 4.16
|
KernelVersion: 4.16
|
||||||
Contact: Gavin Schenk <g.schenk@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
Contact: Thorsten Scherer <t.scherer@eckelmann.de>, Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
Description:
|
Description:
|
||||||
Read-only value reporting the outbytes value provided to siox-X/device_add.
|
Read-only value reporting the outbytes value provided to siox-X/device_add.
|
||||||
|
|
|
@ -11,24 +11,31 @@ Date: February 2014
|
||||||
KernelVersion: 3.15
|
KernelVersion: 3.15
|
||||||
Contact: netdev@vger.kernel.org
|
Contact: netdev@vger.kernel.org
|
||||||
Description:
|
Description:
|
||||||
Boolean value indicating whether the PHY device has
|
This attribute contains the boolean value whether a given PHY
|
||||||
any fixups registered against it (phy_register_fixup)
|
device has had any "fixup" workaround running on it, encoded as
|
||||||
|
a boolean. This information is provided to help troubleshooting
|
||||||
|
PHY configurations.
|
||||||
|
|
||||||
What: /sys/class/mdio_bus/<bus>/<device>/phy_id
|
What: /sys/class/mdio_bus/<bus>/<device>/phy_id
|
||||||
Date: November 2012
|
Date: November 2012
|
||||||
KernelVersion: 3.8
|
KernelVersion: 3.8
|
||||||
Contact: netdev@vger.kernel.org
|
Contact: netdev@vger.kernel.org
|
||||||
Description:
|
Description:
|
||||||
32-bit hexadecimal value corresponding to the PHY device's OUI,
|
This attribute contains the 32-bit PHY Identifier as reported
|
||||||
model and revision number.
|
by the device during bus enumeration, encoded in hexadecimal.
|
||||||
|
This ID is used to match the device with the appropriate
|
||||||
|
driver.
|
||||||
|
|
||||||
What: /sys/class/mdio_bus/<bus>/<device>/phy_interface
|
What: /sys/class/mdio_bus/<bus>/<device>/phy_interface
|
||||||
Date: February 2014
|
Date: February 2014
|
||||||
KernelVersion: 3.15
|
KernelVersion: 3.15
|
||||||
Contact: netdev@vger.kernel.org
|
Contact: netdev@vger.kernel.org
|
||||||
Description:
|
Description:
|
||||||
String value indicating the PHY interface, possible
|
This attribute contains the PHY interface as configured by the
|
||||||
values are:.
|
Ethernet driver during bus enumeration, encoded in string.
|
||||||
|
This interface mode is used to configure the Ethernet MAC with the
|
||||||
|
appropriate mode for its data lines to the PHY hardware.
|
||||||
|
Possible values are:
|
||||||
<empty> (not available), mii, gmii, sgmii, tbi, rev-mii,
|
<empty> (not available), mii, gmii, sgmii, tbi, rev-mii,
|
||||||
rmii, rgmii, rgmii-id, rgmii-rxid, rgmii-txid, rtbi, smii
|
rmii, rgmii, rgmii-id, rgmii-rxid, rgmii-txid, rtbi, smii
|
||||||
xgmii, moca, qsgmii, trgmii, 1000base-x, 2500base-x, rxaui,
|
xgmii, moca, qsgmii, trgmii, 1000base-x, 2500base-x, rxaui,
|
||||||
|
|
|
@ -29,7 +29,7 @@ Contact: Bjørn Mork <bjorn@mork.no>
|
||||||
Description:
|
Description:
|
||||||
Unsigned integer.
|
Unsigned integer.
|
||||||
|
|
||||||
Write a number ranging from 1 to 127 to add a qmap mux
|
Write a number ranging from 1 to 254 to add a qmap mux
|
||||||
based network device, supported by recent Qualcomm based
|
based network device, supported by recent Qualcomm based
|
||||||
modems.
|
modems.
|
||||||
|
|
||||||
|
@ -46,5 +46,5 @@ Contact: Bjørn Mork <bjorn@mork.no>
|
||||||
Description:
|
Description:
|
||||||
Unsigned integer.
|
Unsigned integer.
|
||||||
|
|
||||||
Write a number ranging from 1 to 127 to delete a previously
|
Write a number ranging from 1 to 254 to delete a previously
|
||||||
created qmap mux based network device.
|
created qmap mux based network device.
|
||||||
|
|
|
@ -177,6 +177,15 @@ cgroup v2 currently supports the following mount options.
|
||||||
ignored on non-init namespace mounts. Please refer to the
|
ignored on non-init namespace mounts. Please refer to the
|
||||||
Delegation section for details.
|
Delegation section for details.
|
||||||
|
|
||||||
|
memory_localevents
|
||||||
|
|
||||||
|
Only populate memory.events with data for the current cgroup,
|
||||||
|
and not any subtrees. This is legacy behaviour, the default
|
||||||
|
behaviour without this option is to include subtree counts.
|
||||||
|
This option is system wide and can only be set on mount or
|
||||||
|
modified through remount from the init namespace. The mount
|
||||||
|
option is ignored on non-init namespace mounts.
|
||||||
|
|
||||||
|
|
||||||
Organizing Processes and Threads
|
Organizing Processes and Threads
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
|
@ -31,6 +31,7 @@ the Linux memory management.
|
||||||
ksm
|
ksm
|
||||||
memory-hotplug
|
memory-hotplug
|
||||||
numa_memory_policy
|
numa_memory_policy
|
||||||
|
numaperf
|
||||||
pagemap
|
pagemap
|
||||||
soft-dirty
|
soft-dirty
|
||||||
transhuge
|
transhuge
|
||||||
|
|
|
@ -15,7 +15,7 @@ characteristics. Some memory may share the same node as a CPU, and others
|
||||||
are provided as memory only nodes. While memory only nodes do not provide
|
are provided as memory only nodes. While memory only nodes do not provide
|
||||||
CPUs, they may still be local to one or more compute nodes relative to
|
CPUs, they may still be local to one or more compute nodes relative to
|
||||||
other nodes. The following diagram shows one such example of two compute
|
other nodes. The following diagram shows one such example of two compute
|
||||||
nodes with local memory and a memory only node for each of compute node:
|
nodes with local memory and a memory only node for each of compute node::
|
||||||
|
|
||||||
+------------------+ +------------------+
|
+------------------+ +------------------+
|
||||||
| Compute Node 0 +-----+ Compute Node 1 |
|
| Compute Node 0 +-----+ Compute Node 1 |
|
||||||
|
|
|
@ -58,13 +58,14 @@ stable kernels.
|
||||||
| ARM | Cortex-A72 | #853709 | N/A |
|
| ARM | Cortex-A72 | #853709 | N/A |
|
||||||
| ARM | Cortex-A73 | #858921 | ARM64_ERRATUM_858921 |
|
| ARM | Cortex-A73 | #858921 | ARM64_ERRATUM_858921 |
|
||||||
| ARM | Cortex-A55 | #1024718 | ARM64_ERRATUM_1024718 |
|
| ARM | Cortex-A55 | #1024718 | ARM64_ERRATUM_1024718 |
|
||||||
| ARM | Cortex-A76 | #1188873 | ARM64_ERRATUM_1188873 |
|
| ARM | Cortex-A76 | #1188873,1418040| ARM64_ERRATUM_1418040 |
|
||||||
| ARM | Cortex-A76 | #1165522 | ARM64_ERRATUM_1165522 |
|
| ARM | Cortex-A76 | #1165522 | ARM64_ERRATUM_1165522 |
|
||||||
| ARM | Cortex-A76 | #1286807 | ARM64_ERRATUM_1286807 |
|
| ARM | Cortex-A76 | #1286807 | ARM64_ERRATUM_1286807 |
|
||||||
| ARM | Neoverse-N1 | #1188873 | ARM64_ERRATUM_1188873 |
|
| ARM | Cortex-A76 | #1463225 | ARM64_ERRATUM_1463225 |
|
||||||
| ARM | MMU-500 | #841119,#826419 | N/A |
|
| ARM | Neoverse-N1 | #1188873,1418040| ARM64_ERRATUM_1418040 |
|
||||||
|
| ARM | MMU-500 | #841119,826419 | N/A |
|
||||||
| | | | |
|
| | | | |
|
||||||
| Cavium | ThunderX ITS | #22375, #24313 | CAVIUM_ERRATUM_22375 |
|
| Cavium | ThunderX ITS | #22375,24313 | CAVIUM_ERRATUM_22375 |
|
||||||
| Cavium | ThunderX ITS | #23144 | CAVIUM_ERRATUM_23144 |
|
| Cavium | ThunderX ITS | #23144 | CAVIUM_ERRATUM_23144 |
|
||||||
| Cavium | ThunderX GICv3 | #23154 | CAVIUM_ERRATUM_23154 |
|
| Cavium | ThunderX GICv3 | #23154 | CAVIUM_ERRATUM_23154 |
|
||||||
| Cavium | ThunderX Core | #27456 | CAVIUM_ERRATUM_27456 |
|
| Cavium | ThunderX Core | #27456 | CAVIUM_ERRATUM_27456 |
|
||||||
|
|
|
@ -56,6 +56,18 @@ model features for SVE is included in Appendix A.
|
||||||
is to connect to a target process first and then attempt a
|
is to connect to a target process first and then attempt a
|
||||||
ptrace(PTRACE_GETREGSET, pid, NT_ARM_SVE, &iov).
|
ptrace(PTRACE_GETREGSET, pid, NT_ARM_SVE, &iov).
|
||||||
|
|
||||||
|
* Whenever SVE scalable register values (Zn, Pn, FFR) are exchanged in memory
|
||||||
|
between userspace and the kernel, the register value is encoded in memory in
|
||||||
|
an endianness-invariant layout, with bits [(8 * i + 7) : (8 * i)] encoded at
|
||||||
|
byte offset i from the start of the memory representation. This affects for
|
||||||
|
example the signal frame (struct sve_context) and ptrace interface
|
||||||
|
(struct user_sve_header) and associated data.
|
||||||
|
|
||||||
|
Beware that on big-endian systems this results in a different byte order than
|
||||||
|
for the FPSIMD V-registers, which are stored as single host-endian 128-bit
|
||||||
|
values, with bits [(127 - 8 * i) : (120 - 8 * i)] of the register encoded at
|
||||||
|
byte offset i. (struct fpsimd_context, struct user_fpsimd_state).
|
||||||
|
|
||||||
|
|
||||||
2. Vector length terminology
|
2. Vector length terminology
|
||||||
-----------------------------
|
-----------------------------
|
||||||
|
@ -124,6 +136,10 @@ the SVE instruction set architecture.
|
||||||
size and layout. Macros SVE_SIG_* are defined [1] to facilitate access to
|
size and layout. Macros SVE_SIG_* are defined [1] to facilitate access to
|
||||||
the members.
|
the members.
|
||||||
|
|
||||||
|
* Each scalable register (Zn, Pn, FFR) is stored in an endianness-invariant
|
||||||
|
layout, with bits [(8 * i + 7) : (8 * i)] stored at byte offset i from the
|
||||||
|
start of the register's representation in memory.
|
||||||
|
|
||||||
* If the SVE context is too big to fit in sigcontext.__reserved[], then extra
|
* If the SVE context is too big to fit in sigcontext.__reserved[], then extra
|
||||||
space is allocated on the stack, an extra_context record is written in
|
space is allocated on the stack, an extra_context record is written in
|
||||||
__reserved[] referencing this space. sve_context is then written in the
|
__reserved[] referencing this space. sve_context is then written in the
|
||||||
|
|
|
@ -13,11 +13,9 @@ you can do so by typing:
|
||||||
|
|
||||||
# mount none /sys -t sysfs
|
# mount none /sys -t sysfs
|
||||||
|
|
||||||
As of the Linux 2.6.10 kernel, it is now possible to change the
|
It is possible to change the IO scheduler for a given block device on
|
||||||
IO scheduler for a given block device on the fly (thus making it possible,
|
the fly to select one of mq-deadline, none, bfq, or kyber schedulers -
|
||||||
for instance, to set the CFQ scheduler for the system default, but
|
which can improve that device's throughput.
|
||||||
set a specific device to use the deadline or noop schedulers - which
|
|
||||||
can improve that device's throughput).
|
|
||||||
|
|
||||||
To set a specific scheduler, simply do this:
|
To set a specific scheduler, simply do this:
|
||||||
|
|
||||||
|
@ -30,8 +28,8 @@ The list of defined schedulers can be found by simply doing
|
||||||
a "cat /sys/block/DEV/queue/scheduler" - the list of valid names
|
a "cat /sys/block/DEV/queue/scheduler" - the list of valid names
|
||||||
will be displayed, with the currently selected scheduler in brackets:
|
will be displayed, with the currently selected scheduler in brackets:
|
||||||
|
|
||||||
# cat /sys/block/hda/queue/scheduler
|
# cat /sys/block/sda/queue/scheduler
|
||||||
noop deadline [cfq]
|
[mq-deadline] kyber bfq none
|
||||||
# echo deadline > /sys/block/hda/queue/scheduler
|
# echo none >/sys/block/sda/queue/scheduler
|
||||||
# cat /sys/block/hda/queue/scheduler
|
# cat /sys/block/sda/queue/scheduler
|
||||||
noop [deadline] cfq
|
[none] mq-deadline kyber bfq
|
||||||
|
|
|
@ -131,7 +131,7 @@ The following sections detail encoding of each kind.
|
||||||
``btf_type`` is followed by a ``u32`` with the following bits arrangement::
|
``btf_type`` is followed by a ``u32`` with the following bits arrangement::
|
||||||
|
|
||||||
#define BTF_INT_ENCODING(VAL) (((VAL) & 0x0f000000) >> 24)
|
#define BTF_INT_ENCODING(VAL) (((VAL) & 0x0f000000) >> 24)
|
||||||
#define BTF_INT_OFFSET(VAL) (((VAL & 0x00ff0000)) >> 16)
|
#define BTF_INT_OFFSET(VAL) (((VAL) & 0x00ff0000) >> 16)
|
||||||
#define BTF_INT_BITS(VAL) ((VAL) & 0x000000ff)
|
#define BTF_INT_BITS(VAL) ((VAL) & 0x000000ff)
|
||||||
|
|
||||||
The ``BTF_INT_ENCODING`` has the following attributes::
|
The ``BTF_INT_ENCODING`` has the following attributes::
|
||||||
|
|
|
@ -8,61 +8,13 @@ both at leaf nodes as well as at intermediate nodes in a storage hierarchy.
|
||||||
Plan is to use the same cgroup based management interface for blkio controller
|
Plan is to use the same cgroup based management interface for blkio controller
|
||||||
and based on user options switch IO policies in the background.
|
and based on user options switch IO policies in the background.
|
||||||
|
|
||||||
Currently two IO control policies are implemented. First one is proportional
|
One IO control policy is throttling policy which can be used to
|
||||||
weight time based division of disk policy. It is implemented in CFQ. Hence
|
specify upper IO rate limits on devices. This policy is implemented in
|
||||||
this policy takes effect only on leaf nodes when CFQ is being used. The second
|
generic block layer and can be used on leaf nodes as well as higher
|
||||||
one is throttling policy which can be used to specify upper IO rate limits
|
level logical devices like device mapper.
|
||||||
on devices. This policy is implemented in generic block layer and can be
|
|
||||||
used on leaf nodes as well as higher level logical devices like device mapper.
|
|
||||||
|
|
||||||
HOWTO
|
HOWTO
|
||||||
=====
|
=====
|
||||||
Proportional Weight division of bandwidth
|
|
||||||
-----------------------------------------
|
|
||||||
You can do a very simple testing of running two dd threads in two different
|
|
||||||
cgroups. Here is what you can do.
|
|
||||||
|
|
||||||
- Enable Block IO controller
|
|
||||||
CONFIG_BLK_CGROUP=y
|
|
||||||
|
|
||||||
- Enable group scheduling in CFQ
|
|
||||||
CONFIG_CFQ_GROUP_IOSCHED=y
|
|
||||||
|
|
||||||
- Compile and boot into kernel and mount IO controller (blkio); see
|
|
||||||
cgroups.txt, Why are cgroups needed?.
|
|
||||||
|
|
||||||
mount -t tmpfs cgroup_root /sys/fs/cgroup
|
|
||||||
mkdir /sys/fs/cgroup/blkio
|
|
||||||
mount -t cgroup -o blkio none /sys/fs/cgroup/blkio
|
|
||||||
|
|
||||||
- Create two cgroups
|
|
||||||
mkdir -p /sys/fs/cgroup/blkio/test1/ /sys/fs/cgroup/blkio/test2
|
|
||||||
|
|
||||||
- Set weights of group test1 and test2
|
|
||||||
echo 1000 > /sys/fs/cgroup/blkio/test1/blkio.weight
|
|
||||||
echo 500 > /sys/fs/cgroup/blkio/test2/blkio.weight
|
|
||||||
|
|
||||||
- Create two same size files (say 512MB each) on same disk (file1, file2) and
|
|
||||||
launch two dd threads in different cgroup to read those files.
|
|
||||||
|
|
||||||
sync
|
|
||||||
echo 3 > /proc/sys/vm/drop_caches
|
|
||||||
|
|
||||||
dd if=/mnt/sdb/zerofile1 of=/dev/null &
|
|
||||||
echo $! > /sys/fs/cgroup/blkio/test1/tasks
|
|
||||||
cat /sys/fs/cgroup/blkio/test1/tasks
|
|
||||||
|
|
||||||
dd if=/mnt/sdb/zerofile2 of=/dev/null &
|
|
||||||
echo $! > /sys/fs/cgroup/blkio/test2/tasks
|
|
||||||
cat /sys/fs/cgroup/blkio/test2/tasks
|
|
||||||
|
|
||||||
- At macro level, first dd should finish first. To get more precise data, keep
|
|
||||||
on looking at (with the help of script), at blkio.disk_time and
|
|
||||||
blkio.disk_sectors files of both test1 and test2 groups. This will tell how
|
|
||||||
much disk time (in milliseconds), each group got and how many sectors each
|
|
||||||
group dispatched to the disk. We provide fairness in terms of disk time, so
|
|
||||||
ideally io.disk_time of cgroups should be in proportion to the weight.
|
|
||||||
|
|
||||||
Throttling/Upper Limit policy
|
Throttling/Upper Limit policy
|
||||||
-----------------------------
|
-----------------------------
|
||||||
- Enable Block IO controller
|
- Enable Block IO controller
|
||||||
|
@ -94,7 +46,7 @@ Throttling/Upper Limit policy
|
||||||
Hierarchical Cgroups
|
Hierarchical Cgroups
|
||||||
====================
|
====================
|
||||||
|
|
||||||
Both CFQ and throttling implement hierarchy support; however,
|
Throttling implements hierarchy support; however,
|
||||||
throttling's hierarchy support is enabled iff "sane_behavior" is
|
throttling's hierarchy support is enabled iff "sane_behavior" is
|
||||||
enabled from cgroup side, which currently is a development option and
|
enabled from cgroup side, which currently is a development option and
|
||||||
not publicly available.
|
not publicly available.
|
||||||
|
@ -107,9 +59,8 @@ If somebody created a hierarchy like as follows.
|
||||||
|
|
|
|
||||||
test3
|
test3
|
||||||
|
|
||||||
CFQ by default and throttling with "sane_behavior" will handle the
|
Throttling with "sane_behavior" will handle the
|
||||||
hierarchy correctly. For details on CFQ hierarchy support, refer to
|
hierarchy correctly. For throttling, all limits apply
|
||||||
Documentation/block/cfq-iosched.txt. For throttling, all limits apply
|
|
||||||
to the whole subtree while all statistics are local to the IOs
|
to the whole subtree while all statistics are local to the IOs
|
||||||
directly generated by tasks in that cgroup.
|
directly generated by tasks in that cgroup.
|
||||||
|
|
||||||
|
@ -130,10 +81,6 @@ CONFIG_DEBUG_BLK_CGROUP
|
||||||
- Debug help. Right now some additional stats file show up in cgroup
|
- Debug help. Right now some additional stats file show up in cgroup
|
||||||
if this option is enabled.
|
if this option is enabled.
|
||||||
|
|
||||||
CONFIG_CFQ_GROUP_IOSCHED
|
|
||||||
- Enables group scheduling in CFQ. Currently only 1 level of group
|
|
||||||
creation is allowed.
|
|
||||||
|
|
||||||
CONFIG_BLK_DEV_THROTTLING
|
CONFIG_BLK_DEV_THROTTLING
|
||||||
- Enable block device throttling support in block layer.
|
- Enable block device throttling support in block layer.
|
||||||
|
|
||||||
|
@ -344,32 +291,3 @@ Common files among various policies
|
||||||
- blkio.reset_stats
|
- blkio.reset_stats
|
||||||
- Writing an int to this file will result in resetting all the stats
|
- Writing an int to this file will result in resetting all the stats
|
||||||
for that cgroup.
|
for that cgroup.
|
||||||
|
|
||||||
CFQ sysfs tunable
|
|
||||||
=================
|
|
||||||
/sys/block/<disk>/queue/iosched/slice_idle
|
|
||||||
------------------------------------------
|
|
||||||
On a faster hardware CFQ can be slow, especially with sequential workload.
|
|
||||||
This happens because CFQ idles on a single queue and single queue might not
|
|
||||||
drive deeper request queue depths to keep the storage busy. In such scenarios
|
|
||||||
one can try setting slice_idle=0 and that would switch CFQ to IOPS
|
|
||||||
(IO operations per second) mode on NCQ supporting hardware.
|
|
||||||
|
|
||||||
That means CFQ will not idle between cfq queues of a cfq group and hence be
|
|
||||||
able to driver higher queue depth and achieve better throughput. That also
|
|
||||||
means that cfq provides fairness among groups in terms of IOPS and not in
|
|
||||||
terms of disk time.
|
|
||||||
|
|
||||||
/sys/block/<disk>/queue/iosched/group_idle
|
|
||||||
------------------------------------------
|
|
||||||
If one disables idling on individual cfq queues and cfq service trees by
|
|
||||||
setting slice_idle=0, group_idle kicks in. That means CFQ will still idle
|
|
||||||
on the group in an attempt to provide fairness among groups.
|
|
||||||
|
|
||||||
By default group_idle is same as slice_idle and does not do anything if
|
|
||||||
slice_idle is enabled.
|
|
||||||
|
|
||||||
One can experience an overall throughput drop if you have created multiple
|
|
||||||
groups and put applications in that group which are not driving enough
|
|
||||||
IO to keep disk busy. In that case set group_idle=0, and CFQ will not idle
|
|
||||||
on individual groups and throughput should improve.
|
|
||||||
|
|
|
@ -32,14 +32,18 @@ Brief summary of control files
|
||||||
hugetlb.<hugepagesize>.usage_in_bytes # show current usage for "hugepagesize" hugetlb
|
hugetlb.<hugepagesize>.usage_in_bytes # show current usage for "hugepagesize" hugetlb
|
||||||
hugetlb.<hugepagesize>.failcnt # show the number of allocation failure due to HugeTLB limit
|
hugetlb.<hugepagesize>.failcnt # show the number of allocation failure due to HugeTLB limit
|
||||||
|
|
||||||
For a system supporting two hugepage size (16M and 16G) the control
|
For a system supporting three hugepage sizes (64k, 32M and 1G), the control
|
||||||
files include:
|
files include:
|
||||||
|
|
||||||
hugetlb.16GB.limit_in_bytes
|
hugetlb.1GB.limit_in_bytes
|
||||||
hugetlb.16GB.max_usage_in_bytes
|
hugetlb.1GB.max_usage_in_bytes
|
||||||
hugetlb.16GB.usage_in_bytes
|
hugetlb.1GB.usage_in_bytes
|
||||||
hugetlb.16GB.failcnt
|
hugetlb.1GB.failcnt
|
||||||
hugetlb.16MB.limit_in_bytes
|
hugetlb.64KB.limit_in_bytes
|
||||||
hugetlb.16MB.max_usage_in_bytes
|
hugetlb.64KB.max_usage_in_bytes
|
||||||
hugetlb.16MB.usage_in_bytes
|
hugetlb.64KB.usage_in_bytes
|
||||||
hugetlb.16MB.failcnt
|
hugetlb.64KB.failcnt
|
||||||
|
hugetlb.32MB.limit_in_bytes
|
||||||
|
hugetlb.32MB.max_usage_in_bytes
|
||||||
|
hugetlb.32MB.usage_in_bytes
|
||||||
|
hugetlb.32MB.failcnt
|
||||||
|
|
|
@ -37,7 +37,7 @@ needs_sphinx = '1.3'
|
||||||
extensions = ['kerneldoc', 'rstFlatTable', 'kernel_include', 'cdomain', 'kfigure', 'sphinx.ext.ifconfig']
|
extensions = ['kerneldoc', 'rstFlatTable', 'kernel_include', 'cdomain', 'kfigure', 'sphinx.ext.ifconfig']
|
||||||
|
|
||||||
# The name of the math extension changed on Sphinx 1.4
|
# The name of the math extension changed on Sphinx 1.4
|
||||||
if major == 1 and minor > 3:
|
if (major == 1 and minor > 3) or (major > 1):
|
||||||
extensions.append("sphinx.ext.imgmath")
|
extensions.append("sphinx.ext.imgmath")
|
||||||
else:
|
else:
|
||||||
extensions.append("sphinx.ext.pngmath")
|
extensions.append("sphinx.ext.pngmath")
|
||||||
|
|
|
@ -5,7 +5,7 @@ DT_MK_SCHEMA ?= dt-mk-schema
|
||||||
DT_MK_SCHEMA_FLAGS := $(if $(DT_SCHEMA_FILES), -u)
|
DT_MK_SCHEMA_FLAGS := $(if $(DT_SCHEMA_FILES), -u)
|
||||||
|
|
||||||
quiet_cmd_chk_binding = CHKDT $(patsubst $(srctree)/%,%,$<)
|
quiet_cmd_chk_binding = CHKDT $(patsubst $(srctree)/%,%,$<)
|
||||||
cmd_chk_binding = $(DT_DOC_CHECKER) $< ; \
|
cmd_chk_binding = $(DT_DOC_CHECKER) -u $(srctree)/$(src) $< ; \
|
||||||
$(DT_EXTRACT_EX) $< > $@
|
$(DT_EXTRACT_EX) $< > $@
|
||||||
|
|
||||||
$(obj)/%.example.dts: $(src)/%.yaml FORCE
|
$(obj)/%.example.dts: $(src)/%.yaml FORCE
|
||||||
|
|
|
@ -216,7 +216,7 @@ Example:
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
|
|
||||||
A57_0: cpu@0 {
|
A57_0: cpu@0 {
|
||||||
compatible = "arm,cortex-a57","arm,armv8";
|
compatible = "arm,cortex-a57";
|
||||||
reg = <0x0 0x0>;
|
reg = <0x0 0x0>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
@ -225,7 +225,7 @@ Example:
|
||||||
.....
|
.....
|
||||||
|
|
||||||
A53_0: cpu@100 {
|
A53_0: cpu@100 {
|
||||||
compatible = "arm,cortex-a53","arm,armv8";
|
compatible = "arm,cortex-a53";
|
||||||
reg = <0x0 0x100>;
|
reg = <0x0 0x100>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
|
|
@ -118,7 +118,7 @@ cpus {
|
||||||
};
|
};
|
||||||
|
|
||||||
A57_0: cpu@0 {
|
A57_0: cpu@0 {
|
||||||
compatible = "arm,cortex-a57","arm,armv8";
|
compatible = "arm,cortex-a57";
|
||||||
reg = <0x0 0x0>;
|
reg = <0x0 0x0>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
@ -129,7 +129,7 @@ cpus {
|
||||||
};
|
};
|
||||||
|
|
||||||
A57_1: cpu@1 {
|
A57_1: cpu@1 {
|
||||||
compatible = "arm,cortex-a57","arm,armv8";
|
compatible = "arm,cortex-a57";
|
||||||
reg = <0x0 0x1>;
|
reg = <0x0 0x1>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
@ -140,7 +140,7 @@ cpus {
|
||||||
};
|
};
|
||||||
|
|
||||||
A53_0: cpu@100 {
|
A53_0: cpu@100 {
|
||||||
compatible = "arm,cortex-a53","arm,armv8";
|
compatible = "arm,cortex-a53";
|
||||||
reg = <0x0 0x100>;
|
reg = <0x0 0x100>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
@ -151,7 +151,7 @@ cpus {
|
||||||
};
|
};
|
||||||
|
|
||||||
A53_1: cpu@101 {
|
A53_1: cpu@101 {
|
||||||
compatible = "arm,cortex-a53","arm,armv8";
|
compatible = "arm,cortex-a53";
|
||||||
reg = <0x0 0x101>;
|
reg = <0x0 0x101>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
@ -162,7 +162,7 @@ cpus {
|
||||||
};
|
};
|
||||||
|
|
||||||
A53_2: cpu@102 {
|
A53_2: cpu@102 {
|
||||||
compatible = "arm,cortex-a53","arm,armv8";
|
compatible = "arm,cortex-a53";
|
||||||
reg = <0x0 0x102>;
|
reg = <0x0 0x102>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
@ -173,7 +173,7 @@ cpus {
|
||||||
};
|
};
|
||||||
|
|
||||||
A53_3: cpu@103 {
|
A53_3: cpu@103 {
|
||||||
compatible = "arm,cortex-a53","arm,armv8";
|
compatible = "arm,cortex-a53";
|
||||||
reg = <0x0 0x103>;
|
reg = <0x0 0x103>;
|
||||||
device_type = "cpu";
|
device_type = "cpu";
|
||||||
enable-method = "psci";
|
enable-method = "psci";
|
||||||
|
|
|
@ -41,7 +41,7 @@ Examples:
|
||||||
Consumer:
|
Consumer:
|
||||||
========
|
========
|
||||||
See Documentation/devicetree/bindings/interrupt-controller/interrupts.txt and
|
See Documentation/devicetree/bindings/interrupt-controller/interrupts.txt and
|
||||||
Documentation/devicetree/bindings/interrupt-controller/arm,gic.txt for
|
Documentation/devicetree/bindings/interrupt-controller/arm,gic.yaml for
|
||||||
further details.
|
further details.
|
||||||
|
|
||||||
An interrupt consumer on an SoC using crossbar will use:
|
An interrupt consumer on an SoC using crossbar will use:
|
||||||
|
|
|
@ -35,7 +35,7 @@ board device tree, including the system base clock, as selected by XOM[0]
|
||||||
pin of the SoC. Refer to generic fixed rate clock bindings
|
pin of the SoC. Refer to generic fixed rate clock bindings
|
||||||
documentation[1] for more information how to specify these clocks.
|
documentation[1] for more information how to specify these clocks.
|
||||||
|
|
||||||
[1] Documentation/devicetree/bindings/clock/fixed-clock.txt
|
[1] Documentation/devicetree/bindings/clock/fixed-clock.yaml
|
||||||
|
|
||||||
Example: Clock controller node:
|
Example: Clock controller node:
|
||||||
|
|
||||||
|
|
|
@ -92,6 +92,8 @@ properties:
|
||||||
minItems: 2
|
minItems: 2
|
||||||
maxItems: 4
|
maxItems: 4
|
||||||
|
|
||||||
|
ranges: true
|
||||||
|
|
||||||
interrupts:
|
interrupts:
|
||||||
description: Interrupt source of the parent interrupt controller on
|
description: Interrupt source of the parent interrupt controller on
|
||||||
secondary GICs, or VGIC maintenance interrupt on primary GIC (see
|
secondary GICs, or VGIC maintenance interrupt on primary GIC (see
|
||||||
|
@ -197,28 +199,28 @@ examples:
|
||||||
interrupt-controller@e1101000 {
|
interrupt-controller@e1101000 {
|
||||||
compatible = "arm,gic-400";
|
compatible = "arm,gic-400";
|
||||||
#interrupt-cells = <3>;
|
#interrupt-cells = <3>;
|
||||||
#address-cells = <2>;
|
#address-cells = <1>;
|
||||||
#size-cells = <2>;
|
#size-cells = <1>;
|
||||||
interrupt-controller;
|
interrupt-controller;
|
||||||
interrupts = <1 8 0xf04>;
|
interrupts = <1 8 0xf04>;
|
||||||
ranges = <0 0 0 0xe1100000 0 0x100000>;
|
ranges = <0 0xe1100000 0x100000>;
|
||||||
reg = <0x0 0xe1110000 0 0x01000>,
|
reg = <0xe1110000 0x01000>,
|
||||||
<0x0 0xe112f000 0 0x02000>,
|
<0xe112f000 0x02000>,
|
||||||
<0x0 0xe1140000 0 0x10000>,
|
<0xe1140000 0x10000>,
|
||||||
<0x0 0xe1160000 0 0x10000>;
|
<0xe1160000 0x10000>;
|
||||||
|
|
||||||
v2m0: v2m@8000 {
|
v2m0: v2m@80000 {
|
||||||
compatible = "arm,gic-v2m-frame";
|
compatible = "arm,gic-v2m-frame";
|
||||||
msi-controller;
|
msi-controller;
|
||||||
reg = <0x0 0x80000 0 0x1000>;
|
reg = <0x80000 0x1000>;
|
||||||
};
|
};
|
||||||
|
|
||||||
//...
|
//...
|
||||||
|
|
||||||
v2mN: v2m@9000 {
|
v2mN: v2m@90000 {
|
||||||
compatible = "arm,gic-v2m-frame";
|
compatible = "arm,gic-v2m-frame";
|
||||||
msi-controller;
|
msi-controller;
|
||||||
reg = <0x0 0x90000 0 0x1000>;
|
reg = <0x90000 0x1000>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
...
|
...
|
||||||
|
|
|
@ -23,7 +23,7 @@ Required properties:
|
||||||
- marvell,spi-base : List of GIC base SPI interrupts, one for each
|
- marvell,spi-base : List of GIC base SPI interrupts, one for each
|
||||||
ODMI frame. Those SPI interrupts are 0-based,
|
ODMI frame. Those SPI interrupts are 0-based,
|
||||||
i.e marvell,spi-base = <128> will use SPI #96.
|
i.e marvell,spi-base = <128> will use SPI #96.
|
||||||
See Documentation/devicetree/bindings/interrupt-controller/arm,gic.txt
|
See Documentation/devicetree/bindings/interrupt-controller/arm,gic.yaml
|
||||||
for details about the GIC Device Tree binding.
|
for details about the GIC Device Tree binding.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
|
@ -15,7 +15,7 @@ Optional properties:
|
||||||
- power-supply: specifies the power source. It can either be a regulator
|
- power-supply: specifies the power source. It can either be a regulator
|
||||||
or a gpio which enables a regulator, i.e. a regulator-fixed as
|
or a gpio which enables a regulator, i.e. a regulator-fixed as
|
||||||
described in
|
described in
|
||||||
Documentation/devicetree/bindings/regulator/fixed-regulator.txt
|
Documentation/devicetree/bindings/regulator/fixed-regulator.yaml
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ Required properties:
|
||||||
- clock-names: must contain "mclk", which is the DCMI peripherial clock
|
- clock-names: must contain "mclk", which is the DCMI peripherial clock
|
||||||
- pinctrl: the pincontrol settings to configure muxing properly
|
- pinctrl: the pincontrol settings to configure muxing properly
|
||||||
for pins that connect to DCMI device.
|
for pins that connect to DCMI device.
|
||||||
See Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.txt.
|
See Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.yaml.
|
||||||
- dmas: phandle to DMA controller node,
|
- dmas: phandle to DMA controller node,
|
||||||
see Documentation/devicetree/bindings/dma/stm32-dma.txt
|
see Documentation/devicetree/bindings/dma/stm32-dma.txt
|
||||||
- dma-names: must contain "tx", which is the transmit channel from DCMI to DMA
|
- dma-names: must contain "tx", which is the transmit channel from DCMI to DMA
|
||||||
|
|
|
@ -24,7 +24,7 @@ Optional children nodes:
|
||||||
Children nodes represent the available nand chips.
|
Children nodes represent the available nand chips.
|
||||||
|
|
||||||
Other properties:
|
Other properties:
|
||||||
see Documentation/devicetree/bindings/mtd/nand.txt for generic bindings.
|
see Documentation/devicetree/bindings/mtd/nand-controller.yaml for generic bindings.
|
||||||
|
|
||||||
Example demonstrate on AXG SoC:
|
Example demonstrate on AXG SoC:
|
||||||
|
|
||||||
|
|
|
@ -101,12 +101,12 @@ Required properties:
|
||||||
number (e.g., 0, 1, 2, etc.)
|
number (e.g., 0, 1, 2, etc.)
|
||||||
- #address-cells : see partition.txt
|
- #address-cells : see partition.txt
|
||||||
- #size-cells : see partition.txt
|
- #size-cells : see partition.txt
|
||||||
- nand-ecc-strength : see nand.txt
|
- nand-ecc-strength : see nand-controller.yaml
|
||||||
- nand-ecc-step-size : must be 512 or 1024. See nand.txt
|
- nand-ecc-step-size : must be 512 or 1024. See nand-controller.yaml
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- nand-on-flash-bbt : boolean, to enable the on-flash BBT for this
|
- nand-on-flash-bbt : boolean, to enable the on-flash BBT for this
|
||||||
chip-select. See nand.txt
|
chip-select. See nand-controller.yaml
|
||||||
- brcm,nand-oob-sector-size : integer, to denote the spare area sector size
|
- brcm,nand-oob-sector-size : integer, to denote the spare area sector size
|
||||||
expected for the ECC layout in use. This size, in
|
expected for the ECC layout in use. This size, in
|
||||||
addition to the strength and step-size,
|
addition to the strength and step-size,
|
||||||
|
|
|
@ -22,16 +22,16 @@ Sub-nodes:
|
||||||
select is connected.
|
select is connected.
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- nand-ecc-step-size: see nand.txt for details.
|
- nand-ecc-step-size: see nand-controller.yaml for details.
|
||||||
If present, the value must be
|
If present, the value must be
|
||||||
512 for "altr,socfpga-denali-nand"
|
512 for "altr,socfpga-denali-nand"
|
||||||
1024 for "socionext,uniphier-denali-nand-v5a"
|
1024 for "socionext,uniphier-denali-nand-v5a"
|
||||||
1024 for "socionext,uniphier-denali-nand-v5b"
|
1024 for "socionext,uniphier-denali-nand-v5b"
|
||||||
- nand-ecc-strength: see nand.txt for details. Valid values are:
|
- nand-ecc-strength: see nand-controller.yaml for details. Valid values are:
|
||||||
8, 15 for "altr,socfpga-denali-nand"
|
8, 15 for "altr,socfpga-denali-nand"
|
||||||
8, 16, 24 for "socionext,uniphier-denali-nand-v5a"
|
8, 16, 24 for "socionext,uniphier-denali-nand-v5a"
|
||||||
8, 16 for "socionext,uniphier-denali-nand-v5b"
|
8, 16 for "socionext,uniphier-denali-nand-v5b"
|
||||||
- nand-ecc-maximize: see nand.txt for details
|
- nand-ecc-maximize: see nand-controller.yaml for details
|
||||||
|
|
||||||
The chip nodes may optionally contain sub-nodes describing partitions of the
|
The chip nodes may optionally contain sub-nodes describing partitions of the
|
||||||
address space. See partition.txt for more detail.
|
address space. See partition.txt for more detail.
|
||||||
|
|
|
@ -30,9 +30,9 @@ Optional properties:
|
||||||
command is asserted. Zero means one cycle, 255 means 256
|
command is asserted. Zero means one cycle, 255 means 256
|
||||||
cycles.
|
cycles.
|
||||||
- bank: default NAND bank to use (0-3 are valid, 0 is the default).
|
- bank: default NAND bank to use (0-3 are valid, 0 is the default).
|
||||||
- nand-ecc-mode : see nand.txt
|
- nand-ecc-mode : see nand-controller.yaml
|
||||||
- nand-ecc-strength : see nand.txt
|
- nand-ecc-strength : see nand-controller.yaml
|
||||||
- nand-ecc-step-size : see nand.txt
|
- nand-ecc-step-size : see nand-controller.yaml
|
||||||
|
|
||||||
Can support 1-bit HW ECC (default) or if stronger correction is required,
|
Can support 1-bit HW ECC (default) or if stronger correction is required,
|
||||||
software-based BCH.
|
software-based BCH.
|
||||||
|
|
|
@ -8,7 +8,7 @@ explained in a separate documents - please refer to
|
||||||
Documentation/devicetree/bindings/memory-controllers/omap-gpmc.txt
|
Documentation/devicetree/bindings/memory-controllers/omap-gpmc.txt
|
||||||
|
|
||||||
For NAND specific properties such as ECC modes or bus width, please refer to
|
For NAND specific properties such as ECC modes or bus width, please refer to
|
||||||
Documentation/devicetree/bindings/mtd/nand.txt
|
Documentation/devicetree/bindings/mtd/nand-controller.yaml
|
||||||
|
|
||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
|
|
|
@ -7,7 +7,7 @@ Required properties:
|
||||||
NAND controller's registers. The second contains base
|
NAND controller's registers. The second contains base
|
||||||
physical address and size of NAND controller's buffer.
|
physical address and size of NAND controller's buffer.
|
||||||
- interrupts: Interrupt number for nfc.
|
- interrupts: Interrupt number for nfc.
|
||||||
- nand-bus-width: See nand.txt.
|
- nand-bus-width: See nand-controller.yaml.
|
||||||
- nand-ecc-mode: Support none and hw ecc mode.
|
- nand-ecc-mode: Support none and hw ecc mode.
|
||||||
- #address-cells: Partition address, should be set 1.
|
- #address-cells: Partition address, should be set 1.
|
||||||
- #size-cells: Partition size, should be set 1.
|
- #size-cells: Partition size, should be set 1.
|
||||||
|
|
|
@ -36,29 +36,29 @@ Children nodes represent the available NAND chips.
|
||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
- reg: shall contain the native Chip Select ids (0-3).
|
- reg: shall contain the native Chip Select ids (0-3).
|
||||||
- nand-rb: see nand.txt (0-1).
|
- nand-rb: see nand-controller.yaml (0-1).
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- marvell,nand-keep-config: orders the driver not to take the timings
|
- marvell,nand-keep-config: orders the driver not to take the timings
|
||||||
from the core and leaving them completely untouched. Bootloader
|
from the core and leaving them completely untouched. Bootloader
|
||||||
timings will then be used.
|
timings will then be used.
|
||||||
- label: MTD name.
|
- label: MTD name.
|
||||||
- nand-on-flash-bbt: see nand.txt.
|
- nand-on-flash-bbt: see nand-controller.yaml.
|
||||||
- nand-ecc-mode: see nand.txt. Will use hardware ECC if not specified.
|
- nand-ecc-mode: see nand-controller.yaml. Will use hardware ECC if not specified.
|
||||||
- nand-ecc-algo: see nand.txt. This property is essentially useful when
|
- nand-ecc-algo: see nand-controller.yaml. This property is essentially useful when
|
||||||
not using hardware ECC. Howerver, it may be added when using hardware
|
not using hardware ECC. Howerver, it may be added when using hardware
|
||||||
ECC for clarification but will be ignored by the driver because ECC
|
ECC for clarification but will be ignored by the driver because ECC
|
||||||
mode is chosen depending on the page size and the strength required by
|
mode is chosen depending on the page size and the strength required by
|
||||||
the NAND chip. This value may be overwritten with nand-ecc-strength
|
the NAND chip. This value may be overwritten with nand-ecc-strength
|
||||||
property.
|
property.
|
||||||
- nand-ecc-strength: see nand.txt.
|
- nand-ecc-strength: see nand-controller.yaml.
|
||||||
- nand-ecc-step-size: see nand.txt. Marvell's NAND flash controller does
|
- nand-ecc-step-size: see nand-controller.yaml. Marvell's NAND flash controller does
|
||||||
use fixed strength (1-bit for Hamming, 16-bit for BCH), so the actual
|
use fixed strength (1-bit for Hamming, 16-bit for BCH), so the actual
|
||||||
step size will shrink or grow in order to fit the required strength.
|
step size will shrink or grow in order to fit the required strength.
|
||||||
Step sizes are not completely random for all and follow certain
|
Step sizes are not completely random for all and follow certain
|
||||||
patterns described in AN-379, "Marvell SoC NFC ECC".
|
patterns described in AN-379, "Marvell SoC NFC ECC".
|
||||||
|
|
||||||
See Documentation/devicetree/bindings/mtd/nand.txt for more details on
|
See Documentation/devicetree/bindings/mtd/nand-controller.yaml for more details on
|
||||||
generic bindings.
|
generic bindings.
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -4,9 +4,9 @@ Required properties:
|
||||||
- compatible: "fsl,imxXX-nand"
|
- compatible: "fsl,imxXX-nand"
|
||||||
- reg: address range of the nfc block
|
- reg: address range of the nfc block
|
||||||
- interrupts: irq to be used
|
- interrupts: irq to be used
|
||||||
- nand-bus-width: see nand.txt
|
- nand-bus-width: see nand-controller.yaml
|
||||||
- nand-ecc-mode: see nand.txt
|
- nand-ecc-mode: see nand-controller.yaml
|
||||||
- nand-on-flash-bbt: see nand.txt
|
- nand-on-flash-bbt: see nand-controller.yaml
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
|
|
@ -26,14 +26,14 @@ Optional children node properties:
|
||||||
"hw" is supported.
|
"hw" is supported.
|
||||||
- nand-ecc-algo: string, algorithm of NAND ECC.
|
- nand-ecc-algo: string, algorithm of NAND ECC.
|
||||||
Supported values with "hw" ECC mode are: "rs", "bch".
|
Supported values with "hw" ECC mode are: "rs", "bch".
|
||||||
- nand-bus-width : See nand.txt
|
- nand-bus-width : See nand-controller.yaml
|
||||||
- nand-on-flash-bbt: See nand.txt
|
- nand-on-flash-bbt: See nand-controller.yaml
|
||||||
- nand-ecc-strength: integer representing the number of bits to correct
|
- nand-ecc-strength: integer representing the number of bits to correct
|
||||||
per ECC step (always 512). Supported strength using HW ECC
|
per ECC step (always 512). Supported strength using HW ECC
|
||||||
modes are:
|
modes are:
|
||||||
- RS: 4, 6, 8
|
- RS: 4, 6, 8
|
||||||
- BCH: 4, 8, 14, 16
|
- BCH: 4, 8, 14, 16
|
||||||
- nand-ecc-maximize: See nand.txt
|
- nand-ecc-maximize: See nand-controller.yaml
|
||||||
- nand-is-boot-medium: Makes sure only ECC strengths supported by the boot ROM
|
- nand-is-boot-medium: Makes sure only ECC strengths supported by the boot ROM
|
||||||
are chosen.
|
are chosen.
|
||||||
- wp-gpios: GPIO specifier for the write protect pin.
|
- wp-gpios: GPIO specifier for the write protect pin.
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
* Oxford Semiconductor OXNAS NAND Controller
|
* Oxford Semiconductor OXNAS NAND Controller
|
||||||
|
|
||||||
Please refer to nand.txt for generic information regarding MTD NAND bindings.
|
Please refer to nand-controller.yaml for generic information regarding MTD NAND bindings.
|
||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
- compatible: "oxsemi,ox820-nand"
|
- compatible: "oxsemi,ox820-nand"
|
||||||
|
|
|
@ -47,8 +47,8 @@ Required properties:
|
||||||
- #size-cells: see partition.txt
|
- #size-cells: see partition.txt
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- nand-bus-width: see nand.txt
|
- nand-bus-width: see nand-controller.yaml
|
||||||
- nand-ecc-strength: see nand.txt. If not specified, then ECC strength will
|
- nand-ecc-strength: see nand-controller.yaml. If not specified, then ECC strength will
|
||||||
be used according to chip requirement and available
|
be used according to chip requirement and available
|
||||||
OOB size.
|
OOB size.
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@ Required properties:
|
||||||
"samsung,s3c2412-nand"
|
"samsung,s3c2412-nand"
|
||||||
"samsung,s3c2440-nand"
|
"samsung,s3c2440-nand"
|
||||||
- reg : register's location and length.
|
- reg : register's location and length.
|
||||||
- #address-cells, #size-cells : see nand.txt
|
- #address-cells, #size-cells : see nand-controller.yaml
|
||||||
- clocks : phandle to the nand controller clock
|
- clocks : phandle to the nand controller clock
|
||||||
- clock-names : must contain "nand"
|
- clock-names : must contain "nand"
|
||||||
|
|
||||||
|
@ -14,8 +14,8 @@ Optional child nodes:
|
||||||
Child nodes representing the available nand chips.
|
Child nodes representing the available nand chips.
|
||||||
|
|
||||||
Optional child properties:
|
Optional child properties:
|
||||||
- nand-ecc-mode : see nand.txt
|
- nand-ecc-mode : see nand-controller.yaml
|
||||||
- nand-on-flash-bbt : see nand.txt
|
- nand-on-flash-bbt : see nand-controller.yaml
|
||||||
|
|
||||||
Each child device node may optionally contain a 'partitions' sub-node,
|
Each child device node may optionally contain a 'partitions' sub-node,
|
||||||
which further contains sub-nodes describing the flash partition mapping.
|
which further contains sub-nodes describing the flash partition mapping.
|
||||||
|
|
|
@ -24,9 +24,9 @@ Required properties:
|
||||||
- reg: describes the CS lines assigned to the NAND device.
|
- reg: describes the CS lines assigned to the NAND device.
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- nand-on-flash-bbt: see nand.txt
|
- nand-on-flash-bbt: see nand-controller.yaml
|
||||||
- nand-ecc-strength: see nand.txt
|
- nand-ecc-strength: see nand-controller.yaml
|
||||||
- nand-ecc-step-size: see nand.txt
|
- nand-ecc-step-size: see nand-controller.yaml
|
||||||
|
|
||||||
The following ECC strength and step size are currently supported:
|
The following ECC strength and step size are currently supported:
|
||||||
- nand-ecc-strength = <1>, nand-ecc-step-size = <512> (Hamming)
|
- nand-ecc-strength = <1>, nand-ecc-step-size = <512> (Hamming)
|
||||||
|
|
|
@ -11,7 +11,7 @@ Required properties:
|
||||||
- #size-cells: <0>
|
- #size-cells: <0>
|
||||||
|
|
||||||
Children nodes represent the available NAND chips.
|
Children nodes represent the available NAND chips.
|
||||||
See Documentation/devicetree/bindings/mtd/nand.txt for generic bindings.
|
See Documentation/devicetree/bindings/mtd/nand-controller.yaml for generic bindings.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
|
|
@ -25,14 +25,14 @@ only handle one NAND chip.
|
||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
- compatible: Should be set to "fsl,vf610-nfc-cs".
|
- compatible: Should be set to "fsl,vf610-nfc-cs".
|
||||||
- nand-bus-width: see nand.txt
|
- nand-bus-width: see nand-controller.yaml
|
||||||
- nand-ecc-mode: see nand.txt
|
- nand-ecc-mode: see nand-controller.yaml
|
||||||
|
|
||||||
Required properties for hardware ECC:
|
Required properties for hardware ECC:
|
||||||
- nand-ecc-strength: supported strengths are 24 and 32 bit (see nand.txt)
|
- nand-ecc-strength: supported strengths are 24 and 32 bit (see nand-controller.yaml)
|
||||||
- nand-ecc-step-size: step size equals page size, currently only 2k pages are
|
- nand-ecc-step-size: step size equals page size, currently only 2k pages are
|
||||||
supported
|
supported
|
||||||
- nand-on-flash-bbt: see nand.txt
|
- nand-on-flash-bbt: see nand-controller.yaml
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@ Required properties:
|
||||||
- compatible: Should be one of the following:
|
- compatible: Should be one of the following:
|
||||||
- "microchip,mcp2510" for MCP2510.
|
- "microchip,mcp2510" for MCP2510.
|
||||||
- "microchip,mcp2515" for MCP2515.
|
- "microchip,mcp2515" for MCP2515.
|
||||||
|
- "microchip,mcp25625" for MCP25625.
|
||||||
- reg: SPI chip select.
|
- reg: SPI chip select.
|
||||||
- clocks: The clock feeding the CAN controller.
|
- clocks: The clock feeding the CAN controller.
|
||||||
- interrupts: Should contain IRQ line for the CAN controller.
|
- interrupts: Should contain IRQ line for the CAN controller.
|
||||||
|
|
170
Documentation/devicetree/bindings/riscv/cpus.yaml
Normal file
170
Documentation/devicetree/bindings/riscv/cpus.yaml
Normal file
|
@ -0,0 +1,170 @@
|
||||||
|
# SPDX-License-Identifier: (GPL-2.0 OR MIT)
|
||||||
|
%YAML 1.2
|
||||||
|
---
|
||||||
|
$id: http://devicetree.org/schemas/riscv/cpus.yaml#
|
||||||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||||
|
|
||||||
|
title: RISC-V bindings for 'cpus' DT nodes
|
||||||
|
|
||||||
|
maintainers:
|
||||||
|
- Paul Walmsley <paul.walmsley@sifive.com>
|
||||||
|
- Palmer Dabbelt <palmer@sifive.com>
|
||||||
|
|
||||||
|
allOf:
|
||||||
|
- $ref: /schemas/cpus.yaml#
|
||||||
|
|
||||||
|
properties:
|
||||||
|
$nodename:
|
||||||
|
const: cpus
|
||||||
|
description: Container of cpu nodes
|
||||||
|
|
||||||
|
'#address-cells':
|
||||||
|
const: 1
|
||||||
|
description: |
|
||||||
|
A single unsigned 32-bit integer uniquely identifies each RISC-V
|
||||||
|
hart in a system. (See the "reg" node under the "cpu" node,
|
||||||
|
below).
|
||||||
|
|
||||||
|
'#size-cells':
|
||||||
|
const: 0
|
||||||
|
|
||||||
|
patternProperties:
|
||||||
|
'^cpu@[0-9a-f]+$':
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
- enum:
|
||||||
|
- sifive,rocket0
|
||||||
|
- sifive,e5
|
||||||
|
- sifive,e51
|
||||||
|
- sifive,u54-mc
|
||||||
|
- sifive,u54
|
||||||
|
- sifive,u5
|
||||||
|
- const: riscv
|
||||||
|
description:
|
||||||
|
Identifies that the hart uses the RISC-V instruction set
|
||||||
|
and identifies the type of the hart.
|
||||||
|
|
||||||
|
mmu-type:
|
||||||
|
allOf:
|
||||||
|
- $ref: "/schemas/types.yaml#/definitions/string"
|
||||||
|
- enum:
|
||||||
|
- riscv,sv32
|
||||||
|
- riscv,sv39
|
||||||
|
- riscv,sv48
|
||||||
|
description:
|
||||||
|
Identifies the MMU address translation mode used on this
|
||||||
|
hart. These values originate from the RISC-V Privileged
|
||||||
|
Specification document, available from
|
||||||
|
https://riscv.org/specifications/
|
||||||
|
|
||||||
|
riscv,isa:
|
||||||
|
allOf:
|
||||||
|
- $ref: "/schemas/types.yaml#/definitions/string"
|
||||||
|
- enum:
|
||||||
|
- rv64imac
|
||||||
|
- rv64imafdc
|
||||||
|
description:
|
||||||
|
Identifies the specific RISC-V instruction set architecture
|
||||||
|
supported by the hart. These are documented in the RISC-V
|
||||||
|
User-Level ISA document, available from
|
||||||
|
https://riscv.org/specifications/
|
||||||
|
|
||||||
|
timebase-frequency:
|
||||||
|
type: integer
|
||||||
|
minimum: 1
|
||||||
|
description:
|
||||||
|
Specifies the clock frequency of the system timer in Hz.
|
||||||
|
This value is common to all harts on a single system image.
|
||||||
|
|
||||||
|
interrupt-controller:
|
||||||
|
type: object
|
||||||
|
description: Describes the CPU's local interrupt controller
|
||||||
|
|
||||||
|
properties:
|
||||||
|
'#interrupt-cells':
|
||||||
|
const: 1
|
||||||
|
|
||||||
|
compatible:
|
||||||
|
const: riscv,cpu-intc
|
||||||
|
|
||||||
|
interrupt-controller: true
|
||||||
|
|
||||||
|
required:
|
||||||
|
- '#interrupt-cells'
|
||||||
|
- compatible
|
||||||
|
- interrupt-controller
|
||||||
|
|
||||||
|
required:
|
||||||
|
- riscv,isa
|
||||||
|
- timebase-frequency
|
||||||
|
- interrupt-controller
|
||||||
|
|
||||||
|
examples:
|
||||||
|
- |
|
||||||
|
// Example 1: SiFive Freedom U540G Development Kit
|
||||||
|
cpus {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
timebase-frequency = <1000000>;
|
||||||
|
cpu@0 {
|
||||||
|
clock-frequency = <0>;
|
||||||
|
compatible = "sifive,rocket0", "riscv";
|
||||||
|
device_type = "cpu";
|
||||||
|
i-cache-block-size = <64>;
|
||||||
|
i-cache-sets = <128>;
|
||||||
|
i-cache-size = <16384>;
|
||||||
|
reg = <0>;
|
||||||
|
riscv,isa = "rv64imac";
|
||||||
|
cpu_intc0: interrupt-controller {
|
||||||
|
#interrupt-cells = <1>;
|
||||||
|
compatible = "riscv,cpu-intc";
|
||||||
|
interrupt-controller;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
cpu@1 {
|
||||||
|
clock-frequency = <0>;
|
||||||
|
compatible = "sifive,rocket0", "riscv";
|
||||||
|
d-cache-block-size = <64>;
|
||||||
|
d-cache-sets = <64>;
|
||||||
|
d-cache-size = <32768>;
|
||||||
|
d-tlb-sets = <1>;
|
||||||
|
d-tlb-size = <32>;
|
||||||
|
device_type = "cpu";
|
||||||
|
i-cache-block-size = <64>;
|
||||||
|
i-cache-sets = <64>;
|
||||||
|
i-cache-size = <32768>;
|
||||||
|
i-tlb-sets = <1>;
|
||||||
|
i-tlb-size = <32>;
|
||||||
|
mmu-type = "riscv,sv39";
|
||||||
|
reg = <1>;
|
||||||
|
riscv,isa = "rv64imafdc";
|
||||||
|
tlb-split;
|
||||||
|
cpu_intc1: interrupt-controller {
|
||||||
|
#interrupt-cells = <1>;
|
||||||
|
compatible = "riscv,cpu-intc";
|
||||||
|
interrupt-controller;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
- |
|
||||||
|
// Example 2: Spike ISA Simulator with 1 Hart
|
||||||
|
cpus {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
cpu@0 {
|
||||||
|
device_type = "cpu";
|
||||||
|
reg = <0>;
|
||||||
|
compatible = "riscv";
|
||||||
|
riscv,isa = "rv64imafdc";
|
||||||
|
mmu-type = "riscv,sv48";
|
||||||
|
interrupt-controller {
|
||||||
|
#interrupt-cells = <1>;
|
||||||
|
interrupt-controller;
|
||||||
|
compatible = "riscv,cpu-intc";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
...
|
25
Documentation/devicetree/bindings/riscv/sifive.yaml
Normal file
25
Documentation/devicetree/bindings/riscv/sifive.yaml
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
# SPDX-License-Identifier: (GPL-2.0 OR MIT)
|
||||||
|
%YAML 1.2
|
||||||
|
---
|
||||||
|
$id: http://devicetree.org/schemas/riscv/sifive.yaml#
|
||||||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||||
|
|
||||||
|
title: SiFive SoC-based boards
|
||||||
|
|
||||||
|
maintainers:
|
||||||
|
- Paul Walmsley <paul.walmsley@sifive.com>
|
||||||
|
- Palmer Dabbelt <palmer@sifive.com>
|
||||||
|
|
||||||
|
description:
|
||||||
|
SiFive SoC-based boards
|
||||||
|
|
||||||
|
properties:
|
||||||
|
$nodename:
|
||||||
|
const: '/'
|
||||||
|
compatible:
|
||||||
|
items:
|
||||||
|
- enum:
|
||||||
|
- sifive,freedom-unleashed-a00
|
||||||
|
- const: sifive,fu540-c000
|
||||||
|
- const: sifive,fu540
|
||||||
|
...
|
|
@ -0,0 +1,38 @@
|
||||||
|
DT compatible string versioning for SiFive open-source IP blocks
|
||||||
|
|
||||||
|
This document describes the version specification for DT "compatible"
|
||||||
|
strings for open-source SiFive IP blocks. HDL for these IP blocks
|
||||||
|
can be found in this public repository:
|
||||||
|
|
||||||
|
https://github.com/sifive/sifive-blocks
|
||||||
|
|
||||||
|
IP block-specific DT compatible strings are contained within the HDL,
|
||||||
|
in the form "sifive,<ip-block-name><integer version number>".
|
||||||
|
|
||||||
|
An example is "sifive,uart0" from:
|
||||||
|
|
||||||
|
https://github.com/sifive/sifive-blocks/blob/v1.0/src/main/scala/devices/uart/UART.scala#L43
|
||||||
|
|
||||||
|
Until these IP blocks (or IP integration) support version
|
||||||
|
auto-discovery, the maintainers of these IP blocks intend to increment
|
||||||
|
the suffixed number in the compatible string whenever the software
|
||||||
|
interface to these IP blocks changes, or when the functionality of the
|
||||||
|
underlying IP blocks changes in a way that software should be aware of.
|
||||||
|
|
||||||
|
Driver developers can use compatible string "match" values such as
|
||||||
|
"sifive,uart0" to indicate that their driver is compatible with the
|
||||||
|
register interface and functionality associated with the relevant
|
||||||
|
upstream sifive-blocks commits. It is expected that most drivers will
|
||||||
|
match on these IP block-specific compatible strings.
|
||||||
|
|
||||||
|
DT data authors, when writing data for a particular SoC, should
|
||||||
|
continue to specify an SoC-specific compatible string value, such as
|
||||||
|
"sifive,fu540-c000-uart". This way, if SoC-specific
|
||||||
|
integration-specific bug fixes or workarounds are needed, the kernel
|
||||||
|
or other system software can match on this string to apply them. The
|
||||||
|
IP block-specific compatible string (such as "sifive,uart0") should
|
||||||
|
then be specified as a subsequent value.
|
||||||
|
|
||||||
|
An example of this style:
|
||||||
|
|
||||||
|
compatible = "sifive,fu540-c000-uart", "sifive,uart0";
|
|
@ -0,0 +1,132 @@
|
||||||
|
# SPDX-License-Identifier: (GPL-2.0+ OR BSD-2-Clause)
|
||||||
|
%YAML 1.2
|
||||||
|
---
|
||||||
|
$id: http://devicetree.org/schemas/sound/allwinner,sun4i-a10-i2s.yaml#
|
||||||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||||
|
|
||||||
|
title: Allwinner A10 I2S Controller Device Tree Bindings
|
||||||
|
|
||||||
|
maintainers:
|
||||||
|
- Chen-Yu Tsai <wens@csie.org>
|
||||||
|
- Maxime Ripard <maxime.ripard@bootlin.com>
|
||||||
|
|
||||||
|
properties:
|
||||||
|
"#sound-dai-cells":
|
||||||
|
const: 0
|
||||||
|
|
||||||
|
compatible:
|
||||||
|
oneOf:
|
||||||
|
- const: allwinner,sun4i-a10-i2s
|
||||||
|
- const: allwinner,sun6i-a31-i2s
|
||||||
|
- const: allwinner,sun8i-a83t-i2s
|
||||||
|
- const: allwinner,sun8i-h3-i2s
|
||||||
|
- const: allwinner,sun50i-a64-codec-i2s
|
||||||
|
- items:
|
||||||
|
- const: allwinner,sun50i-a64-i2s
|
||||||
|
- const: allwinner,sun8i-h3-i2s
|
||||||
|
|
||||||
|
reg:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
interrupts:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
clocks:
|
||||||
|
items:
|
||||||
|
- description: Bus Clock
|
||||||
|
- description: Module Clock
|
||||||
|
|
||||||
|
clock-names:
|
||||||
|
items:
|
||||||
|
- const: apb
|
||||||
|
- const: mod
|
||||||
|
|
||||||
|
# Even though it only applies to subschemas under the conditionals,
|
||||||
|
# not listing them here will trigger a warning because of the
|
||||||
|
# additionalsProperties set to false.
|
||||||
|
dmas: true
|
||||||
|
dma-names: true
|
||||||
|
resets:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
allOf:
|
||||||
|
- if:
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
contains:
|
||||||
|
enum:
|
||||||
|
- allwinner,sun6i-a31-i2s
|
||||||
|
- allwinner,sun8i-a83t-i2s
|
||||||
|
- allwinner,sun8i-h3-i2s
|
||||||
|
- allwinner,sun50i-a64-codec-i2s
|
||||||
|
|
||||||
|
then:
|
||||||
|
required:
|
||||||
|
- resets
|
||||||
|
|
||||||
|
- if:
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
contains:
|
||||||
|
const: allwinner,sun8i-a83t-i2s
|
||||||
|
|
||||||
|
then:
|
||||||
|
properties:
|
||||||
|
dmas:
|
||||||
|
minItems: 1
|
||||||
|
maxItems: 2
|
||||||
|
items:
|
||||||
|
- description: RX DMA Channel
|
||||||
|
- description: TX DMA Channel
|
||||||
|
description:
|
||||||
|
Some controllers cannot receive but can only transmit
|
||||||
|
data. In such a case, the RX DMA channel is to be omitted.
|
||||||
|
|
||||||
|
dma-names:
|
||||||
|
oneOf:
|
||||||
|
- items:
|
||||||
|
- const: rx
|
||||||
|
- const: tx
|
||||||
|
- const: tx
|
||||||
|
description:
|
||||||
|
Some controllers cannot receive but can only transmit
|
||||||
|
data. In such a case, the RX name is to be omitted.
|
||||||
|
|
||||||
|
else:
|
||||||
|
properties:
|
||||||
|
dmas:
|
||||||
|
items:
|
||||||
|
- description: RX DMA Channel
|
||||||
|
- description: TX DMA Channel
|
||||||
|
|
||||||
|
dma-names:
|
||||||
|
items:
|
||||||
|
- const: rx
|
||||||
|
- const: tx
|
||||||
|
|
||||||
|
required:
|
||||||
|
- "#sound-dai-cells"
|
||||||
|
- compatible
|
||||||
|
- reg
|
||||||
|
- interrupts
|
||||||
|
- clocks
|
||||||
|
- clock-names
|
||||||
|
- dmas
|
||||||
|
- dma-names
|
||||||
|
|
||||||
|
additionalProperties: false
|
||||||
|
|
||||||
|
examples:
|
||||||
|
- |
|
||||||
|
i2s0: i2s@1c22400 {
|
||||||
|
#sound-dai-cells = <0>;
|
||||||
|
compatible = "allwinner,sun4i-a10-i2s";
|
||||||
|
reg = <0x01c22400 0x400>;
|
||||||
|
interrupts = <0 16 4>;
|
||||||
|
clocks = <&apb0_gates 3>, <&i2s0_clk>;
|
||||||
|
clock-names = "apb", "mod";
|
||||||
|
dmas = <&dma 0 3>, <&dma 0 3>;
|
||||||
|
dma-names = "rx", "tx";
|
||||||
|
};
|
||||||
|
|
||||||
|
...
|
|
@ -0,0 +1,120 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
%YAML 1.2
|
||||||
|
---
|
||||||
|
$id: http://devicetree.org/schemas/sound/allwinner,sun4i-a10-spdif.yaml#
|
||||||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||||
|
|
||||||
|
title: Allwinner A10 S/PDIF Controller Device Tree Bindings
|
||||||
|
|
||||||
|
maintainers:
|
||||||
|
- Chen-Yu Tsai <wens@csie.org>
|
||||||
|
- Liam Girdwood <lgirdwood@gmail.com>
|
||||||
|
- Mark Brown <broonie@kernel.org>
|
||||||
|
- Maxime Ripard <maxime.ripard@bootlin.com>
|
||||||
|
|
||||||
|
properties:
|
||||||
|
"#sound-dai-cells":
|
||||||
|
const: 0
|
||||||
|
|
||||||
|
compatible:
|
||||||
|
oneOf:
|
||||||
|
- const: allwinner,sun4i-a10-spdif
|
||||||
|
- const: allwinner,sun6i-a31-spdif
|
||||||
|
- const: allwinner,sun8i-h3-spdif
|
||||||
|
- const: allwinner,sun50i-h6-spdif
|
||||||
|
- items:
|
||||||
|
- const: allwinner,sun8i-a83t-spdif
|
||||||
|
- const: allwinner,sun8i-h3-spdif
|
||||||
|
- items:
|
||||||
|
- const: allwinner,sun50i-a64-spdif
|
||||||
|
- const: allwinner,sun8i-h3-spdif
|
||||||
|
|
||||||
|
reg:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
interrupts:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
clocks:
|
||||||
|
items:
|
||||||
|
- description: Bus Clock
|
||||||
|
- description: Module Clock
|
||||||
|
|
||||||
|
clock-names:
|
||||||
|
items:
|
||||||
|
- const: apb
|
||||||
|
- const: spdif
|
||||||
|
|
||||||
|
# Even though it only applies to subschemas under the conditionals,
|
||||||
|
# not listing them here will trigger a warning because of the
|
||||||
|
# additionalsProperties set to false.
|
||||||
|
dmas: true
|
||||||
|
dma-names: true
|
||||||
|
resets:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
allOf:
|
||||||
|
- if:
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
contains:
|
||||||
|
enum:
|
||||||
|
- allwinner,sun6i-a31-spdif
|
||||||
|
- allwinner,sun8i-h3-spdif
|
||||||
|
|
||||||
|
then:
|
||||||
|
required:
|
||||||
|
- resets
|
||||||
|
|
||||||
|
- if:
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
contains:
|
||||||
|
const: allwinner,sun8i-h3-spdif
|
||||||
|
|
||||||
|
then:
|
||||||
|
properties:
|
||||||
|
dmas:
|
||||||
|
description: TX DMA Channel
|
||||||
|
|
||||||
|
dma-names:
|
||||||
|
const: tx
|
||||||
|
|
||||||
|
else:
|
||||||
|
properties:
|
||||||
|
dmas:
|
||||||
|
items:
|
||||||
|
- description: RX DMA Channel
|
||||||
|
- description: TX DMA Channel
|
||||||
|
|
||||||
|
dma-names:
|
||||||
|
items:
|
||||||
|
- const: rx
|
||||||
|
- const: tx
|
||||||
|
|
||||||
|
required:
|
||||||
|
- "#sound-dai-cells"
|
||||||
|
- compatible
|
||||||
|
- reg
|
||||||
|
- interrupts
|
||||||
|
- clocks
|
||||||
|
- clock-names
|
||||||
|
- dmas
|
||||||
|
- dma-names
|
||||||
|
|
||||||
|
additionalProperties: false
|
||||||
|
|
||||||
|
examples:
|
||||||
|
- |
|
||||||
|
spdif: spdif@1c21000 {
|
||||||
|
#sound-dai-cells = <0>;
|
||||||
|
compatible = "allwinner,sun4i-a10-spdif";
|
||||||
|
reg = <0x01c21000 0x40>;
|
||||||
|
interrupts = <13>;
|
||||||
|
clocks = <&apb0_gates 1>, <&spdif_clk>;
|
||||||
|
clock-names = "apb", "spdif";
|
||||||
|
dmas = <&dma 0 2>, <&dma 0 2>;
|
||||||
|
dma-names = "rx", "tx";
|
||||||
|
};
|
||||||
|
|
||||||
|
...
|
|
@ -15,11 +15,15 @@ Required properties:
|
||||||
* "lrclk" : sample clock
|
* "lrclk" : sample clock
|
||||||
* "lrclk_sel": sample clock input multiplexer
|
* "lrclk_sel": sample clock input multiplexer
|
||||||
|
|
||||||
Example of TDMOUT_A on the A113 SoC:
|
Optional property:
|
||||||
|
- resets: phandle to the dedicated reset line of the tdm formatter.
|
||||||
|
|
||||||
|
Example of TDMOUT_A on the S905X2 SoC:
|
||||||
|
|
||||||
tdmout_a: audio-controller@500 {
|
tdmout_a: audio-controller@500 {
|
||||||
compatible = "amlogic,axg-tdmout";
|
compatible = "amlogic,axg-tdmout";
|
||||||
reg = <0x0 0x500 0x0 0x40>;
|
reg = <0x0 0x500 0x0 0x40>;
|
||||||
|
resets = <&clkc_audio AUD_RESET_TDMOUT_A>;
|
||||||
clocks = <&clkc_audio AUD_CLKID_TDMOUT_A>,
|
clocks = <&clkc_audio AUD_CLKID_TDMOUT_A>,
|
||||||
<&clkc_audio AUD_CLKID_TDMOUT_A_SCLK>,
|
<&clkc_audio AUD_CLKID_TDMOUT_A_SCLK>,
|
||||||
<&clkc_audio AUD_CLKID_TDMOUT_A_SCLK_SEL>,
|
<&clkc_audio AUD_CLKID_TDMOUT_A_SCLK_SEL>,
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
* Amlogic HDMI Tx control glue
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: "amlogic,g12a-tohdmitx"
|
||||||
|
- reg: physical base address of the controller and length of memory
|
||||||
|
mapped region.
|
||||||
|
- #sound-dai-cells: should be 1.
|
||||||
|
|
||||||
|
Example on the S905X2 SoC:
|
||||||
|
|
||||||
|
tohdmitx: audio-controller@744 {
|
||||||
|
compatible = "amlogic,g12a-tohdmitx";
|
||||||
|
reg = <0x0 0x744 0x0 0x4>;
|
||||||
|
#sound-dai-cells = <1>;
|
||||||
|
};
|
||||||
|
|
||||||
|
Example of an 'amlogic,axg-sound-card':
|
||||||
|
|
||||||
|
sound {
|
||||||
|
compatible = "amlogic,axg-sound-card";
|
||||||
|
|
||||||
|
[...]
|
||||||
|
|
||||||
|
dai-link-x {
|
||||||
|
sound-dai = <&tdmif_a>;
|
||||||
|
dai-format = "i2s";
|
||||||
|
dai-tdm-slot-tx-mask-0 = <1 1>;
|
||||||
|
|
||||||
|
codec-0 {
|
||||||
|
sound-dai = <&tohdmitx TOHDMITX_I2S_IN_A>;
|
||||||
|
};
|
||||||
|
|
||||||
|
codec-1 {
|
||||||
|
sound-dai = <&external_dac>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
dai-link-y {
|
||||||
|
sound-dai = <&tdmif_c>;
|
||||||
|
dai-format = "i2s";
|
||||||
|
dai-tdm-slot-tx-mask-0 = <1 1>;
|
||||||
|
|
||||||
|
codec {
|
||||||
|
sound-dai = <&tohdmitx TOHDMITX_I2S_IN_C>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
dai-link-z {
|
||||||
|
sound-dai = <&tohdmitx TOHDMITX_I2S_OUT>;
|
||||||
|
|
||||||
|
codec {
|
||||||
|
sound-dai = <&hdmi_tx>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
|
@ -14,6 +14,11 @@ Required properties:
|
||||||
- VA-supply, VD-supply, VLS-supply, VLC-supply: power supplies for the device,
|
- VA-supply, VD-supply, VLS-supply, VLC-supply: power supplies for the device,
|
||||||
as covered in Documentation/devicetree/bindings/regulator/regulator.txt
|
as covered in Documentation/devicetree/bindings/regulator/regulator.txt
|
||||||
|
|
||||||
|
Optional properties:
|
||||||
|
|
||||||
|
- reset-gpios : a GPIO spec to define which pin is connected to the chip's
|
||||||
|
!RESET pin
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
cs42888: codec@48 {
|
cs42888: codec@48 {
|
||||||
|
@ -25,4 +30,5 @@ cs42888: codec@48 {
|
||||||
VD-supply = <®_audio>;
|
VD-supply = <®_audio>;
|
||||||
VLS-supply = <®_audio>;
|
VLS-supply = <®_audio>;
|
||||||
VLC-supply = <®_audio>;
|
VLC-supply = <®_audio>;
|
||||||
|
reset-gpios = <&pca9557_b 1 GPIO_ACTIVE_LOW>;
|
||||||
};
|
};
|
||||||
|
|
|
@ -44,6 +44,9 @@ Optional properties:
|
||||||
please refer to pinctrl-bindings.txt
|
please refer to pinctrl-bindings.txt
|
||||||
- fck_parent : Should contain a valid clock name which will be used as parent
|
- fck_parent : Should contain a valid clock name which will be used as parent
|
||||||
for the McASP fck
|
for the McASP fck
|
||||||
|
- auxclk-fs-ratio: When McASP is bus master indicates the ratio between AUCLK
|
||||||
|
and FS rate if applicable:
|
||||||
|
AUCLK rate = auxclk-fs-ratio * FS rate
|
||||||
|
|
||||||
Optional GPIO support:
|
Optional GPIO support:
|
||||||
If any McASP pin need to be used as GPIO then the McASP node must have:
|
If any McASP pin need to be used as GPIO then the McASP node must have:
|
||||||
|
|
67
Documentation/devicetree/bindings/sound/madera.txt
Normal file
67
Documentation/devicetree/bindings/sound/madera.txt
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
Cirrus Logic Madera class audio codecs
|
||||||
|
|
||||||
|
This describes audio configuration bindings for these codecs.
|
||||||
|
|
||||||
|
See also the core bindings for the parent MFD driver:
|
||||||
|
See Documentation/devicetree/bindings/mfd/madera.txt
|
||||||
|
|
||||||
|
and defines for values used in these bindings:
|
||||||
|
include/dt-bindings/sound/madera.h
|
||||||
|
|
||||||
|
These properties are all contained in the parent MFD node.
|
||||||
|
|
||||||
|
Optional properties:
|
||||||
|
- cirrus,dmic-ref : Indicates how the MICBIAS pins have been externally
|
||||||
|
connected to DMICs on each input, one cell per input.
|
||||||
|
<IN1 IN2 IN3 ...>
|
||||||
|
A value of 0 indicates MICVDD and is the default, other values depend on the
|
||||||
|
codec:
|
||||||
|
For CS47L35 one of the CS47L35_DMIC_REF_xxx values
|
||||||
|
For all other codecs one of the MADERA_DMIC_REF_xxx values
|
||||||
|
Also see the datasheet for a description of the INn_DMIC_SUP field.
|
||||||
|
|
||||||
|
- cirrus,inmode : A list of input mode settings for each input. A maximum of
|
||||||
|
16 cells, with four cells per input in the order INnAL, INnAR INnBL INnBR.
|
||||||
|
For non-muxed inputs the first two cells for that input set the mode for
|
||||||
|
the left and right channel and the second two cells must be 0.
|
||||||
|
For muxed inputs the first two cells for that input set the mode of the
|
||||||
|
left and right A inputs and the second two cells set the mode of the left
|
||||||
|
and right B inputs.
|
||||||
|
Valid mode values are one of the MADERA_INMODE_xxx. If the array is shorter
|
||||||
|
than the number of inputs the unspecified inputs default to
|
||||||
|
MADERA_INMODE_DIFF.
|
||||||
|
|
||||||
|
- cirrus,out-mono : Mono bit for each output, maximum of six cells if the
|
||||||
|
array is shorter outputs will be set to stereo.
|
||||||
|
|
||||||
|
- cirrus,max-channels-clocked : Maximum number of channels that I2S clocks
|
||||||
|
will be generated for. Useful when clock master for systems where the I2S
|
||||||
|
bus has multiple data lines.
|
||||||
|
One cell for each AIF, use a value of zero for AIFs that should be handled
|
||||||
|
normally.
|
||||||
|
|
||||||
|
- cirrus,pdm-fmt : PDM speaker data format, must contain 2 cells
|
||||||
|
(OUT5 and OUT6). See the PDM_SPKn_FMT field in the datasheet for a
|
||||||
|
description of this value.
|
||||||
|
The second cell is ignored for codecs that do not have OUT6.
|
||||||
|
|
||||||
|
- cirrus,pdm-mute : PDM mute format, must contain 2 cells
|
||||||
|
(OUT5 and OUT6). See the PDM_SPKn_CTRL_1 register in the datasheet for a
|
||||||
|
description of this value.
|
||||||
|
The second cell is ignored for codecs that do not have OUT6.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
cs47l35@0 {
|
||||||
|
compatible = "cirrus,cs47l35";
|
||||||
|
|
||||||
|
cirrus,dmic-ref = <0 0 CS47L35_DMIC_REF_MICBIAS1B 0>;
|
||||||
|
cirrus,inmode = <
|
||||||
|
MADERA_INMODE_DMIC MADERA_INMODE_DMIC /* IN1A digital */
|
||||||
|
MADERA_INMODE_SE MADERA_INMODE_SE /* IN1B single-ended */
|
||||||
|
MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN2 differential */
|
||||||
|
0 0 /* not used on this codec */
|
||||||
|
>;
|
||||||
|
cirrus,out-mono = <0 0 0 0 0 0>;
|
||||||
|
cirrus,max-channels-clocked = <2 0 0>;
|
||||||
|
};
|
|
@ -9,6 +9,10 @@ Optional properties:
|
||||||
- sdmode-gpios : GPIO specifier for the chip's SD_MODE pin.
|
- sdmode-gpios : GPIO specifier for the chip's SD_MODE pin.
|
||||||
If this option is not specified then driver does not manage
|
If this option is not specified then driver does not manage
|
||||||
the pin state (e.g. chip is always on).
|
the pin state (e.g. chip is always on).
|
||||||
|
- sdmode-delay : specify delay time for SD_MODE pin.
|
||||||
|
If this option is specified, which means it's required i2s clocks
|
||||||
|
ready before SD_MODE is unmuted in order to avoid the speaker pop noise.
|
||||||
|
It's observed that 5ms is sufficient.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
|
32
Documentation/devicetree/bindings/sound/rt1011.txt
Normal file
32
Documentation/devicetree/bindings/sound/rt1011.txt
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
RT1011 Mono Class D Audio Amplifier
|
||||||
|
|
||||||
|
This device supports I2C only.
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
|
||||||
|
- compatible : "realtek,rt1011".
|
||||||
|
|
||||||
|
- reg : The I2C address of the device. This I2C address decide by
|
||||||
|
two input pins (ASEL1 and ASEL2).
|
||||||
|
-------------------------------------
|
||||||
|
| ASEL2 | ASEL1 | Address |
|
||||||
|
-------------------------------------
|
||||||
|
| 0 | 0 | 0x38 |
|
||||||
|
-------------------------------------
|
||||||
|
| 0 | 1 | 0x39 |
|
||||||
|
-------------------------------------
|
||||||
|
| 1 | 0 | 0x3a |
|
||||||
|
-------------------------------------
|
||||||
|
| 1 | 1 | 0x3b |
|
||||||
|
-------------------------------------
|
||||||
|
|
||||||
|
Pins on the device (for linking into audio routes) for RT1011:
|
||||||
|
|
||||||
|
* SPO
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
rt1011: codec@38 {
|
||||||
|
compatible = "realtek,rt1011";
|
||||||
|
reg = <0x38>;
|
||||||
|
};
|
17
Documentation/devicetree/bindings/sound/rt1308.txt
Executable file
17
Documentation/devicetree/bindings/sound/rt1308.txt
Executable file
|
@ -0,0 +1,17 @@
|
||||||
|
RT1308 audio Amplifier
|
||||||
|
|
||||||
|
This device supports I2C only.
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
|
||||||
|
- compatible : "realtek,rt1308".
|
||||||
|
|
||||||
|
- reg : The I2C address of the device.
|
||||||
|
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
rt1308: rt1308@10 {
|
||||||
|
compatible = "realtek,rt1308";
|
||||||
|
reg = <0x10>;
|
||||||
|
};
|
|
@ -18,7 +18,7 @@ Required properties:
|
||||||
See Documentation/devicetree/bindings/dma/stm32-dma.txt.
|
See Documentation/devicetree/bindings/dma/stm32-dma.txt.
|
||||||
- dma-names: Identifier for each DMA request line. Must be "tx" and "rx".
|
- dma-names: Identifier for each DMA request line. Must be "tx" and "rx".
|
||||||
- pinctrl-names: should contain only value "default"
|
- pinctrl-names: should contain only value "default"
|
||||||
- pinctrl-0: see Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.txt
|
- pinctrl-0: see Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.yaml
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- resets: Reference to a reset controller asserting the reset controller
|
- resets: Reference to a reset controller asserting the reset controller
|
||||||
|
|
|
@ -41,7 +41,7 @@ SAI subnodes required properties:
|
||||||
"tx": if sai sub-block is configured as playback DAI
|
"tx": if sai sub-block is configured as playback DAI
|
||||||
"rx": if sai sub-block is configured as capture DAI
|
"rx": if sai sub-block is configured as capture DAI
|
||||||
- pinctrl-names: should contain only value "default"
|
- pinctrl-names: should contain only value "default"
|
||||||
- pinctrl-0: see Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.txt
|
- pinctrl-0: see Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.yaml
|
||||||
|
|
||||||
SAI subnodes Optional properties:
|
SAI subnodes Optional properties:
|
||||||
- st,sync: specify synchronization mode.
|
- st,sync: specify synchronization mode.
|
||||||
|
|
|
@ -1,45 +0,0 @@
|
||||||
* Allwinner A10 I2S controller
|
|
||||||
|
|
||||||
The I2S bus (Inter-IC sound bus) is a serial link for digital
|
|
||||||
audio data transfer between devices in the system.
|
|
||||||
|
|
||||||
Required properties:
|
|
||||||
|
|
||||||
- compatible: should be one of the following:
|
|
||||||
- "allwinner,sun4i-a10-i2s"
|
|
||||||
- "allwinner,sun6i-a31-i2s"
|
|
||||||
- "allwinner,sun8i-a83t-i2s"
|
|
||||||
- "allwinner,sun8i-h3-i2s"
|
|
||||||
- "allwinner,sun50i-a64-codec-i2s"
|
|
||||||
- reg: physical base address of the controller and length of memory mapped
|
|
||||||
region.
|
|
||||||
- interrupts: should contain the I2S interrupt.
|
|
||||||
- dmas: DMA specifiers for tx and rx dma. See the DMA client binding,
|
|
||||||
Documentation/devicetree/bindings/dma/dma.txt
|
|
||||||
- dma-names: should include "tx" and "rx".
|
|
||||||
- clocks: a list of phandle + clock-specifer pairs, one for each entry in clock-names.
|
|
||||||
- clock-names: should contain the following:
|
|
||||||
- "apb" : clock for the I2S bus interface
|
|
||||||
- "mod" : module clock for the I2S controller
|
|
||||||
- #sound-dai-cells : Must be equal to 0
|
|
||||||
|
|
||||||
Required properties for the following compatibles:
|
|
||||||
- "allwinner,sun6i-a31-i2s"
|
|
||||||
- "allwinner,sun8i-a83t-i2s"
|
|
||||||
- "allwinner,sun8i-h3-i2s"
|
|
||||||
- "allwinner,sun50i-a64-codec-i2s"
|
|
||||||
- resets: phandle to the reset line for this codec
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
i2s0: i2s@1c22400 {
|
|
||||||
#sound-dai-cells = <0>;
|
|
||||||
compatible = "allwinner,sun4i-a10-i2s";
|
|
||||||
reg = <0x01c22400 0x400>;
|
|
||||||
interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
|
|
||||||
clocks = <&apb0_gates 3>, <&i2s0_clk>;
|
|
||||||
clock-names = "apb", "mod";
|
|
||||||
dmas = <&dma SUN4I_DMA_NORMAL 3>,
|
|
||||||
<&dma SUN4I_DMA_NORMAL 3>;
|
|
||||||
dma-names = "rx", "tx";
|
|
||||||
};
|
|
|
@ -1,42 +0,0 @@
|
||||||
Allwinner Sony/Philips Digital Interface Format (S/PDIF) Controller
|
|
||||||
|
|
||||||
The Allwinner S/PDIF audio block is a transceiver that allows the
|
|
||||||
processor to receive and transmit digital audio via an coaxial cable or
|
|
||||||
a fibre cable.
|
|
||||||
For now only playback is supported.
|
|
||||||
|
|
||||||
Required properties:
|
|
||||||
|
|
||||||
- compatible : should be one of the following:
|
|
||||||
- "allwinner,sun4i-a10-spdif": for the Allwinner A10 SoC
|
|
||||||
- "allwinner,sun6i-a31-spdif": for the Allwinner A31 SoC
|
|
||||||
- "allwinner,sun8i-h3-spdif": for the Allwinner H3 SoC
|
|
||||||
|
|
||||||
- reg : Offset and length of the register set for the device.
|
|
||||||
|
|
||||||
- interrupts : Contains the spdif interrupt.
|
|
||||||
|
|
||||||
- dmas : Generic dma devicetree binding as described in
|
|
||||||
Documentation/devicetree/bindings/dma/dma.txt.
|
|
||||||
|
|
||||||
- dma-names : Two dmas have to be defined, "tx" and "rx".
|
|
||||||
|
|
||||||
- clocks : Contains an entry for each entry in clock-names.
|
|
||||||
|
|
||||||
- clock-names : Includes the following entries:
|
|
||||||
"apb" clock for the spdif bus.
|
|
||||||
"spdif" clock for spdif controller.
|
|
||||||
|
|
||||||
- resets : reset specifier for the ahb reset (A31 and newer only)
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
spdif: spdif@1c21000 {
|
|
||||||
compatible = "allwinner,sun4i-a10-spdif";
|
|
||||||
reg = <0x01c21000 0x40>;
|
|
||||||
interrupts = <13>;
|
|
||||||
clocks = <&apb0_gates 1>, <&spdif_clk>;
|
|
||||||
clock-names = "apb", "spdif";
|
|
||||||
dmas = <&dma 0 2>, <&dma 0 2>;
|
|
||||||
dma-names = "rx", "tx";
|
|
||||||
};
|
|
|
@ -251,7 +251,7 @@ for defining a counter device.
|
||||||
.. kernel-doc:: include/linux/counter.h
|
.. kernel-doc:: include/linux/counter.h
|
||||||
:internal:
|
:internal:
|
||||||
|
|
||||||
.. kernel-doc:: drivers/counter/generic-counter.c
|
.. kernel-doc:: drivers/counter/counter.c
|
||||||
:export:
|
:export:
|
||||||
|
|
||||||
Implementation
|
Implementation
|
||||||
|
|
|
@ -276,8 +276,8 @@ fields of ``struct uio_mem``:
|
||||||
- ``int memtype``: Required if the mapping is used. Set this to
|
- ``int memtype``: Required if the mapping is used. Set this to
|
||||||
``UIO_MEM_PHYS`` if you you have physical memory on your card to be
|
``UIO_MEM_PHYS`` if you you have physical memory on your card to be
|
||||||
mapped. Use ``UIO_MEM_LOGICAL`` for logical memory (e.g. allocated
|
mapped. Use ``UIO_MEM_LOGICAL`` for logical memory (e.g. allocated
|
||||||
with :c:func:`kmalloc()`). There's also ``UIO_MEM_VIRTUAL`` for
|
with :c:func:`__get_free_pages()` but not kmalloc()). There's also
|
||||||
virtual memory.
|
``UIO_MEM_VIRTUAL`` for virtual memory.
|
||||||
|
|
||||||
- ``phys_addr_t addr``: Required if the mapping is used. Fill in the
|
- ``phys_addr_t addr``: Required if the mapping is used. Fill in the
|
||||||
address of your memory block. This address is the one that appears in
|
address of your memory block. This address is the one that appears in
|
||||||
|
|
|
@ -79,7 +79,7 @@ C. Boot options
|
||||||
|
|
||||||
Select the initial font to use. The value 'name' can be any of the
|
Select the initial font to use. The value 'name' can be any of the
|
||||||
compiled-in fonts: 10x18, 6x10, 7x14, Acorn8x8, MINI4x6,
|
compiled-in fonts: 10x18, 6x10, 7x14, Acorn8x8, MINI4x6,
|
||||||
PEARL8x8, ProFont6x11, SUN12x22, SUN8x16, VGA8x16, VGA8x8.
|
PEARL8x8, ProFont6x11, SUN12x22, SUN8x16, TER16x32, VGA8x16, VGA8x8.
|
||||||
|
|
||||||
Note, not all drivers can handle font with widths not divisible by 8,
|
Note, not all drivers can handle font with widths not divisible by 8,
|
||||||
such as vga16fb.
|
such as vga16fb.
|
||||||
|
|
|
@ -336,8 +336,20 @@ the copied layers will fail the verification of the lower root file handle.
|
||||||
Non-standard behavior
|
Non-standard behavior
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
Overlayfs can now act as a POSIX compliant filesystem with the following
|
Current version of overlayfs can act as a mostly POSIX compliant
|
||||||
features turned on:
|
filesystem.
|
||||||
|
|
||||||
|
This is the list of cases that overlayfs doesn't currently handle:
|
||||||
|
|
||||||
|
a) POSIX mandates updating st_atime for reads. This is currently not
|
||||||
|
done in the case when the file resides on a lower layer.
|
||||||
|
|
||||||
|
b) If a file residing on a lower layer is opened for read-only and then
|
||||||
|
memory mapped with MAP_SHARED, then subsequent changes to the file are not
|
||||||
|
reflected in the memory mapping.
|
||||||
|
|
||||||
|
The following options allow overlayfs to act more like a standards
|
||||||
|
compliant filesystem:
|
||||||
|
|
||||||
1) "redirect_dir"
|
1) "redirect_dir"
|
||||||
|
|
||||||
|
|
|
@ -423,7 +423,7 @@ will be enumerated to depends on the device ID returned by _HID.
|
||||||
|
|
||||||
For example, the following ACPI sample might be used to enumerate an lm75-type
|
For example, the following ACPI sample might be used to enumerate an lm75-type
|
||||||
I2C temperature sensor and match it to the driver using the Device Tree
|
I2C temperature sensor and match it to the driver using the Device Tree
|
||||||
namespace link:
|
namespace link::
|
||||||
|
|
||||||
Device (TMP0)
|
Device (TMP0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -437,20 +437,6 @@ more details, with real examples.
|
||||||
The second argument is optional, and if supplied will be used
|
The second argument is optional, and if supplied will be used
|
||||||
if first argument is not supported.
|
if first argument is not supported.
|
||||||
|
|
||||||
cc-ldoption
|
|
||||||
cc-ldoption is used to check if $(CC) when used to link object files
|
|
||||||
supports the given option. An optional second option may be
|
|
||||||
specified if first option are not supported.
|
|
||||||
|
|
||||||
Example:
|
|
||||||
#arch/x86/kernel/Makefile
|
|
||||||
vsyscall-flags += $(call cc-ldoption, -Wl$(comma)--hash-style=sysv)
|
|
||||||
|
|
||||||
In the above example, vsyscall-flags will be assigned the option
|
|
||||||
-Wl$(comma)--hash-style=sysv if it is supported by $(CC).
|
|
||||||
The second argument is optional, and if supplied will be used
|
|
||||||
if first argument is not supported.
|
|
||||||
|
|
||||||
as-instr
|
as-instr
|
||||||
as-instr checks if the assembler reports a specific instruction
|
as-instr checks if the assembler reports a specific instruction
|
||||||
and then outputs either option1 or option2
|
and then outputs either option1 or option2
|
||||||
|
|
|
@ -410,7 +410,7 @@ Notes on loading the dump-capture kernel:
|
||||||
* Boot parameter "1" boots the dump-capture kernel into single-user
|
* Boot parameter "1" boots the dump-capture kernel into single-user
|
||||||
mode without networking. If you want networking, use "3".
|
mode without networking. If you want networking, use "3".
|
||||||
|
|
||||||
* We generally don' have to bring up a SMP kernel just to capture the
|
* We generally don't have to bring up a SMP kernel just to capture the
|
||||||
dump. Hence generally it is useful either to build a UP dump-capture
|
dump. Hence generally it is useful either to build a UP dump-capture
|
||||||
kernel or specify maxcpus=1 option while loading dump-capture kernel.
|
kernel or specify maxcpus=1 option while loading dump-capture kernel.
|
||||||
Note, though maxcpus always works, you had better replace it with
|
Note, though maxcpus always works, you had better replace it with
|
||||||
|
|
|
@ -316,16 +316,16 @@ A: When a netdev of a physical NIC is initialized, Linux usually
|
||||||
all the traffic, you can force the netdev to only have 1 queue, queue
|
all the traffic, you can force the netdev to only have 1 queue, queue
|
||||||
id 0, and then bind to queue 0. You can use ethtool to do this::
|
id 0, and then bind to queue 0. You can use ethtool to do this::
|
||||||
|
|
||||||
sudo ethtool -L <interface> combined 1
|
sudo ethtool -L <interface> combined 1
|
||||||
|
|
||||||
If you want to only see part of the traffic, you can program the
|
If you want to only see part of the traffic, you can program the
|
||||||
NIC through ethtool to filter out your traffic to a single queue id
|
NIC through ethtool to filter out your traffic to a single queue id
|
||||||
that you can bind your XDP socket to. Here is one example in which
|
that you can bind your XDP socket to. Here is one example in which
|
||||||
UDP traffic to and from port 4242 are sent to queue 2::
|
UDP traffic to and from port 4242 are sent to queue 2::
|
||||||
|
|
||||||
sudo ethtool -N <interface> rx-flow-hash udp4 fn
|
sudo ethtool -N <interface> rx-flow-hash udp4 fn
|
||||||
sudo ethtool -N <interface> flow-type udp4 src-port 4242 dst-port \
|
sudo ethtool -N <interface> flow-type udp4 src-port 4242 dst-port \
|
||||||
4242 action 2
|
4242 action 2
|
||||||
|
|
||||||
A number of other ways are possible all up to the capabilitites of
|
A number of other ways are possible all up to the capabilitites of
|
||||||
the NIC you have.
|
the NIC you have.
|
||||||
|
|
30
Documentation/networking/device_drivers/index.rst
Normal file
30
Documentation/networking/device_drivers/index.rst
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
.. SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
||||||
|
|
||||||
|
Vendor Device Drivers
|
||||||
|
=====================
|
||||||
|
|
||||||
|
Contents:
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 2
|
||||||
|
|
||||||
|
freescale/dpaa2/index
|
||||||
|
intel/e100
|
||||||
|
intel/e1000
|
||||||
|
intel/e1000e
|
||||||
|
intel/fm10k
|
||||||
|
intel/igb
|
||||||
|
intel/igbvf
|
||||||
|
intel/ixgb
|
||||||
|
intel/ixgbe
|
||||||
|
intel/ixgbevf
|
||||||
|
intel/i40e
|
||||||
|
intel/iavf
|
||||||
|
intel/ice
|
||||||
|
|
||||||
|
.. only:: subproject
|
||||||
|
|
||||||
|
Indices
|
||||||
|
=======
|
||||||
|
|
||||||
|
* :ref:`genindex`
|
|
@ -11,19 +11,7 @@ Contents:
|
||||||
batman-adv
|
batman-adv
|
||||||
can
|
can
|
||||||
can_ucan_protocol
|
can_ucan_protocol
|
||||||
device_drivers/freescale/dpaa2/index
|
device_drivers/index
|
||||||
device_drivers/intel/e100
|
|
||||||
device_drivers/intel/e1000
|
|
||||||
device_drivers/intel/e1000e
|
|
||||||
device_drivers/intel/fm10k
|
|
||||||
device_drivers/intel/igb
|
|
||||||
device_drivers/intel/igbvf
|
|
||||||
device_drivers/intel/ixgb
|
|
||||||
device_drivers/intel/ixgbe
|
|
||||||
device_drivers/intel/ixgbevf
|
|
||||||
device_drivers/intel/i40e
|
|
||||||
device_drivers/intel/iavf
|
|
||||||
device_drivers/intel/ice
|
|
||||||
dsa/index
|
dsa/index
|
||||||
devlink-info-versions
|
devlink-info-versions
|
||||||
ieee802154
|
ieee802154
|
||||||
|
@ -40,6 +28,8 @@ Contents:
|
||||||
checksum-offloads
|
checksum-offloads
|
||||||
segmentation-offloads
|
segmentation-offloads
|
||||||
scaling
|
scaling
|
||||||
|
tls
|
||||||
|
tls-offload
|
||||||
|
|
||||||
.. only:: subproject
|
.. only:: subproject
|
||||||
|
|
||||||
|
|
|
@ -255,6 +255,14 @@ tcp_base_mss - INTEGER
|
||||||
Path MTU discovery (MTU probing). If MTU probing is enabled,
|
Path MTU discovery (MTU probing). If MTU probing is enabled,
|
||||||
this is the initial MSS used by the connection.
|
this is the initial MSS used by the connection.
|
||||||
|
|
||||||
|
tcp_min_snd_mss - INTEGER
|
||||||
|
TCP SYN and SYNACK messages usually advertise an ADVMSS option,
|
||||||
|
as described in RFC 1122 and RFC 6691.
|
||||||
|
If this ADVMSS option is smaller than tcp_min_snd_mss,
|
||||||
|
it is silently capped to tcp_min_snd_mss.
|
||||||
|
|
||||||
|
Default : 48 (at least 8 bytes of payload per segment)
|
||||||
|
|
||||||
tcp_congestion_control - STRING
|
tcp_congestion_control - STRING
|
||||||
Set the congestion control algorithm to be used for new
|
Set the congestion control algorithm to be used for new
|
||||||
connections. The algorithm "reno" is always available, but
|
connections. The algorithm "reno" is always available, but
|
||||||
|
@ -560,10 +568,10 @@ tcp_comp_sack_delay_ns - LONG INTEGER
|
||||||
Default : 1,000,000 ns (1 ms)
|
Default : 1,000,000 ns (1 ms)
|
||||||
|
|
||||||
tcp_comp_sack_nr - INTEGER
|
tcp_comp_sack_nr - INTEGER
|
||||||
Max numer of SACK that can be compressed.
|
Max number of SACK that can be compressed.
|
||||||
Using 0 disables SACK compression.
|
Using 0 disables SACK compression.
|
||||||
|
|
||||||
Detault : 44
|
Default : 44
|
||||||
|
|
||||||
tcp_slow_start_after_idle - BOOLEAN
|
tcp_slow_start_after_idle - BOOLEAN
|
||||||
If set, provide RFC2861 behavior and time out the congestion
|
If set, provide RFC2861 behavior and time out the congestion
|
||||||
|
@ -772,6 +780,14 @@ tcp_challenge_ack_limit - INTEGER
|
||||||
in RFC 5961 (Improving TCP's Robustness to Blind In-Window Attacks)
|
in RFC 5961 (Improving TCP's Robustness to Blind In-Window Attacks)
|
||||||
Default: 100
|
Default: 100
|
||||||
|
|
||||||
|
tcp_rx_skb_cache - BOOLEAN
|
||||||
|
Controls a per TCP socket cache of one skb, that might help
|
||||||
|
performance of some workloads. This might be dangerous
|
||||||
|
on systems with a lot of TCP sockets, since it increases
|
||||||
|
memory usage.
|
||||||
|
|
||||||
|
Default: 0 (disabled)
|
||||||
|
|
||||||
UDP variables:
|
UDP variables:
|
||||||
|
|
||||||
udp_l3mdev_accept - BOOLEAN
|
udp_l3mdev_accept - BOOLEAN
|
||||||
|
|
|
@ -389,7 +389,7 @@ Multipath RDS (mprds)
|
||||||
a common (to all paths) part, and a per-path struct rds_conn_path. All
|
a common (to all paths) part, and a per-path struct rds_conn_path. All
|
||||||
I/O workqs and reconnect threads are driven from the rds_conn_path.
|
I/O workqs and reconnect threads are driven from the rds_conn_path.
|
||||||
Transports such as TCP that are multipath capable may then set up a
|
Transports such as TCP that are multipath capable may then set up a
|
||||||
TPC socket per rds_conn_path, and this is managed by the transport via
|
TCP socket per rds_conn_path, and this is managed by the transport via
|
||||||
the transport privatee cp_transport_data pointer.
|
the transport privatee cp_transport_data pointer.
|
||||||
|
|
||||||
Transports announce themselves as multipath capable by setting the
|
Transports announce themselves as multipath capable by setting the
|
||||||
|
|
|
@ -18,7 +18,7 @@ The following technologies are described:
|
||||||
* Generic Segmentation Offload - GSO
|
* Generic Segmentation Offload - GSO
|
||||||
* Generic Receive Offload - GRO
|
* Generic Receive Offload - GRO
|
||||||
* Partial Generic Segmentation Offload - GSO_PARTIAL
|
* Partial Generic Segmentation Offload - GSO_PARTIAL
|
||||||
* SCTP accelleration with GSO - GSO_BY_FRAGS
|
* SCTP acceleration with GSO - GSO_BY_FRAGS
|
||||||
|
|
||||||
|
|
||||||
TCP Segmentation Offload
|
TCP Segmentation Offload
|
||||||
|
@ -148,7 +148,7 @@ that the IPv4 ID field is incremented in the case that a given header does
|
||||||
not have the DF bit set.
|
not have the DF bit set.
|
||||||
|
|
||||||
|
|
||||||
SCTP accelleration with GSO
|
SCTP acceleration with GSO
|
||||||
===========================
|
===========================
|
||||||
|
|
||||||
SCTP - despite the lack of hardware support - can still take advantage of
|
SCTP - despite the lack of hardware support - can still take advantage of
|
||||||
|
|
1
Documentation/networking/tls-offload-layers.svg
Normal file
1
Documentation/networking/tls-offload-layers.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 49 KiB |
1
Documentation/networking/tls-offload-reorder-bad.svg
Normal file
1
Documentation/networking/tls-offload-reorder-bad.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 6.4 KiB |
1
Documentation/networking/tls-offload-reorder-good.svg
Normal file
1
Documentation/networking/tls-offload-reorder-good.svg
Normal file
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 6.4 KiB |
482
Documentation/networking/tls-offload.rst
Normal file
482
Documentation/networking/tls-offload.rst
Normal file
|
@ -0,0 +1,482 @@
|
||||||
|
.. SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
||||||
|
|
||||||
|
==================
|
||||||
|
Kernel TLS offload
|
||||||
|
==================
|
||||||
|
|
||||||
|
Kernel TLS operation
|
||||||
|
====================
|
||||||
|
|
||||||
|
Linux kernel provides TLS connection offload infrastructure. Once a TCP
|
||||||
|
connection is in ``ESTABLISHED`` state user space can enable the TLS Upper
|
||||||
|
Layer Protocol (ULP) and install the cryptographic connection state.
|
||||||
|
For details regarding the user-facing interface refer to the TLS
|
||||||
|
documentation in :ref:`Documentation/networking/tls.rst <kernel_tls>`.
|
||||||
|
|
||||||
|
``ktls`` can operate in three modes:
|
||||||
|
|
||||||
|
* Software crypto mode (``TLS_SW``) - CPU handles the cryptography.
|
||||||
|
In most basic cases only crypto operations synchronous with the CPU
|
||||||
|
can be used, but depending on calling context CPU may utilize
|
||||||
|
asynchronous crypto accelerators. The use of accelerators introduces extra
|
||||||
|
latency on socket reads (decryption only starts when a read syscall
|
||||||
|
is made) and additional I/O load on the system.
|
||||||
|
* Packet-based NIC offload mode (``TLS_HW``) - the NIC handles crypto
|
||||||
|
on a packet by packet basis, provided the packets arrive in order.
|
||||||
|
This mode integrates best with the kernel stack and is described in detail
|
||||||
|
in the remaining part of this document
|
||||||
|
(``ethtool`` flags ``tls-hw-tx-offload`` and ``tls-hw-rx-offload``).
|
||||||
|
* Full TCP NIC offload mode (``TLS_HW_RECORD``) - mode of operation where
|
||||||
|
NIC driver and firmware replace the kernel networking stack
|
||||||
|
with its own TCP handling, it is not usable in production environments
|
||||||
|
making use of the Linux networking stack for example any firewalling
|
||||||
|
abilities or QoS and packet scheduling (``ethtool`` flag ``tls-hw-record``).
|
||||||
|
|
||||||
|
The operation mode is selected automatically based on device configuration,
|
||||||
|
offload opt-in or opt-out on per-connection basis is not currently supported.
|
||||||
|
|
||||||
|
TX
|
||||||
|
--
|
||||||
|
|
||||||
|
At a high level user write requests are turned into a scatter list, the TLS ULP
|
||||||
|
intercepts them, inserts record framing, performs encryption (in ``TLS_SW``
|
||||||
|
mode) and then hands the modified scatter list to the TCP layer. From this
|
||||||
|
point on the TCP stack proceeds as normal.
|
||||||
|
|
||||||
|
In ``TLS_HW`` mode the encryption is not performed in the TLS ULP.
|
||||||
|
Instead packets reach a device driver, the driver will mark the packets
|
||||||
|
for crypto offload based on the socket the packet is attached to,
|
||||||
|
and send them to the device for encryption and transmission.
|
||||||
|
|
||||||
|
RX
|
||||||
|
--
|
||||||
|
|
||||||
|
On the receive side if the device handled decryption and authentication
|
||||||
|
successfully, the driver will set the decrypted bit in the associated
|
||||||
|
:c:type:`struct sk_buff <sk_buff>`. The packets reach the TCP stack and
|
||||||
|
are handled normally. ``ktls`` is informed when data is queued to the socket
|
||||||
|
and the ``strparser`` mechanism is used to delineate the records. Upon read
|
||||||
|
request, records are retrieved from the socket and passed to decryption routine.
|
||||||
|
If device decrypted all the segments of the record the decryption is skipped,
|
||||||
|
otherwise software path handles decryption.
|
||||||
|
|
||||||
|
.. kernel-figure:: tls-offload-layers.svg
|
||||||
|
:alt: TLS offload layers
|
||||||
|
:align: center
|
||||||
|
:figwidth: 28em
|
||||||
|
|
||||||
|
Layers of Kernel TLS stack
|
||||||
|
|
||||||
|
Device configuration
|
||||||
|
====================
|
||||||
|
|
||||||
|
During driver initialization device sets the ``NETIF_F_HW_TLS_RX`` and
|
||||||
|
``NETIF_F_HW_TLS_TX`` features and installs its
|
||||||
|
:c:type:`struct tlsdev_ops <tlsdev_ops>`
|
||||||
|
pointer in the :c:member:`tlsdev_ops` member of the
|
||||||
|
:c:type:`struct net_device <net_device>`.
|
||||||
|
|
||||||
|
When TLS cryptographic connection state is installed on a ``ktls`` socket
|
||||||
|
(note that it is done twice, once for RX and once for TX direction,
|
||||||
|
and the two are completely independent), the kernel checks if the underlying
|
||||||
|
network device is offload-capable and attempts the offload. In case offload
|
||||||
|
fails the connection is handled entirely in software using the same mechanism
|
||||||
|
as if the offload was never tried.
|
||||||
|
|
||||||
|
Offload request is performed via the :c:member:`tls_dev_add` callback of
|
||||||
|
:c:type:`struct tlsdev_ops <tlsdev_ops>`:
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
|
int (*tls_dev_add)(struct net_device *netdev, struct sock *sk,
|
||||||
|
enum tls_offload_ctx_dir direction,
|
||||||
|
struct tls_crypto_info *crypto_info,
|
||||||
|
u32 start_offload_tcp_sn);
|
||||||
|
|
||||||
|
``direction`` indicates whether the cryptographic information is for
|
||||||
|
the received or transmitted packets. Driver uses the ``sk`` parameter
|
||||||
|
to retrieve the connection 5-tuple and socket family (IPv4 vs IPv6).
|
||||||
|
Cryptographic information in ``crypto_info`` includes the key, iv, salt
|
||||||
|
as well as TLS record sequence number. ``start_offload_tcp_sn`` indicates
|
||||||
|
which TCP sequence number corresponds to the beginning of the record with
|
||||||
|
sequence number from ``crypto_info``. The driver can add its state
|
||||||
|
at the end of kernel structures (see :c:member:`driver_state` members
|
||||||
|
in ``include/net/tls.h``) to avoid additional allocations and pointer
|
||||||
|
dereferences.
|
||||||
|
|
||||||
|
TX
|
||||||
|
--
|
||||||
|
|
||||||
|
After TX state is installed, the stack guarantees that the first segment
|
||||||
|
of the stream will start exactly at the ``start_offload_tcp_sn`` sequence
|
||||||
|
number, simplifying TCP sequence number matching.
|
||||||
|
|
||||||
|
TX offload being fully initialized does not imply that all segments passing
|
||||||
|
through the driver and which belong to the offloaded socket will be after
|
||||||
|
the expected sequence number and will have kernel record information.
|
||||||
|
In particular, already encrypted data may have been queued to the socket
|
||||||
|
before installing the connection state in the kernel.
|
||||||
|
|
||||||
|
RX
|
||||||
|
--
|
||||||
|
|
||||||
|
In RX direction local networking stack has little control over the segmentation,
|
||||||
|
so the initial records' TCP sequence number may be anywhere inside the segment.
|
||||||
|
|
||||||
|
Normal operation
|
||||||
|
================
|
||||||
|
|
||||||
|
At the minimum the device maintains the following state for each connection, in
|
||||||
|
each direction:
|
||||||
|
|
||||||
|
* crypto secrets (key, iv, salt)
|
||||||
|
* crypto processing state (partial blocks, partial authentication tag, etc.)
|
||||||
|
* record metadata (sequence number, processing offset and length)
|
||||||
|
* expected TCP sequence number
|
||||||
|
|
||||||
|
There are no guarantees on record length or record segmentation. In particular
|
||||||
|
segments may start at any point of a record and contain any number of records.
|
||||||
|
Assuming segments are received in order, the device should be able to perform
|
||||||
|
crypto operations and authentication regardless of segmentation. For this
|
||||||
|
to be possible device has to keep small amount of segment-to-segment state.
|
||||||
|
This includes at least:
|
||||||
|
|
||||||
|
* partial headers (if a segment carried only a part of the TLS header)
|
||||||
|
* partial data block
|
||||||
|
* partial authentication tag (all data had been seen but part of the
|
||||||
|
authentication tag has to be written or read from the subsequent segment)
|
||||||
|
|
||||||
|
Record reassembly is not necessary for TLS offload. If the packets arrive
|
||||||
|
in order the device should be able to handle them separately and make
|
||||||
|
forward progress.
|
||||||
|
|
||||||
|
TX
|
||||||
|
--
|
||||||
|
|
||||||
|
The kernel stack performs record framing reserving space for the authentication
|
||||||
|
tag and populating all other TLS header and tailer fields.
|
||||||
|
|
||||||
|
Both the device and the driver maintain expected TCP sequence numbers
|
||||||
|
due to the possibility of retransmissions and the lack of software fallback
|
||||||
|
once the packet reaches the device.
|
||||||
|
For segments passed in order, the driver marks the packets with
|
||||||
|
a connection identifier (note that a 5-tuple lookup is insufficient to identify
|
||||||
|
packets requiring HW offload, see the :ref:`5tuple_problems` section)
|
||||||
|
and hands them to the device. The device identifies the packet as requiring
|
||||||
|
TLS handling and confirms the sequence number matches its expectation.
|
||||||
|
The device performs encryption and authentication of the record data.
|
||||||
|
It replaces the authentication tag and TCP checksum with correct values.
|
||||||
|
|
||||||
|
RX
|
||||||
|
--
|
||||||
|
|
||||||
|
Before a packet is DMAed to the host (but after NIC's embedded switching
|
||||||
|
and packet transformation functions) the device validates the Layer 4
|
||||||
|
checksum and performs a 5-tuple lookup to find any TLS connection the packet
|
||||||
|
may belong to (technically a 4-tuple
|
||||||
|
lookup is sufficient - IP addresses and TCP port numbers, as the protocol
|
||||||
|
is always TCP). If connection is matched device confirms if the TCP sequence
|
||||||
|
number is the expected one and proceeds to TLS handling (record delineation,
|
||||||
|
decryption, authentication for each record in the packet). The device leaves
|
||||||
|
the record framing unmodified, the stack takes care of record decapsulation.
|
||||||
|
Device indicates successful handling of TLS offload in the per-packet context
|
||||||
|
(descriptor) passed to the host.
|
||||||
|
|
||||||
|
Upon reception of a TLS offloaded packet, the driver sets
|
||||||
|
the :c:member:`decrypted` mark in :c:type:`struct sk_buff <sk_buff>`
|
||||||
|
corresponding to the segment. Networking stack makes sure decrypted
|
||||||
|
and non-decrypted segments do not get coalesced (e.g. by GRO or socket layer)
|
||||||
|
and takes care of partial decryption.
|
||||||
|
|
||||||
|
Resync handling
|
||||||
|
===============
|
||||||
|
|
||||||
|
In presence of packet drops or network packet reordering, the device may lose
|
||||||
|
synchronization with the TLS stream, and require a resync with the kernel's
|
||||||
|
TCP stack.
|
||||||
|
|
||||||
|
Note that resync is only attempted for connections which were successfully
|
||||||
|
added to the device table and are in TLS_HW mode. For example,
|
||||||
|
if the table was full when cryptographic state was installed in the kernel,
|
||||||
|
such connection will never get offloaded. Therefore the resync request
|
||||||
|
does not carry any cryptographic connection state.
|
||||||
|
|
||||||
|
TX
|
||||||
|
--
|
||||||
|
|
||||||
|
Segments transmitted from an offloaded socket can get out of sync
|
||||||
|
in similar ways to the receive side-retransmissions - local drops
|
||||||
|
are possible, though network reorders are not.
|
||||||
|
|
||||||
|
Whenever an out of order segment is transmitted the driver provides
|
||||||
|
the device with enough information to perform cryptographic operations.
|
||||||
|
This means most likely that the part of the record preceding the current
|
||||||
|
segment has to be passed to the device as part of the packet context,
|
||||||
|
together with its TCP sequence number and TLS record number. The device
|
||||||
|
can then initialize its crypto state, process and discard the preceding
|
||||||
|
data (to be able to insert the authentication tag) and move onto handling
|
||||||
|
the actual packet.
|
||||||
|
|
||||||
|
In this mode depending on the implementation the driver can either ask
|
||||||
|
for a continuation with the crypto state and the new sequence number
|
||||||
|
(next expected segment is the one after the out of order one), or continue
|
||||||
|
with the previous stream state - assuming that the out of order segment
|
||||||
|
was just a retransmission. The former is simpler, and does not require
|
||||||
|
retransmission detection therefore it is the recommended method until
|
||||||
|
such time it is proven inefficient.
|
||||||
|
|
||||||
|
RX
|
||||||
|
--
|
||||||
|
|
||||||
|
A small amount of RX reorder events may not require a full resynchronization.
|
||||||
|
In particular the device should not lose synchronization
|
||||||
|
when record boundary can be recovered:
|
||||||
|
|
||||||
|
.. kernel-figure:: tls-offload-reorder-good.svg
|
||||||
|
:alt: reorder of non-header segment
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
Reorder of non-header segment
|
||||||
|
|
||||||
|
Green segments are successfully decrypted, blue ones are passed
|
||||||
|
as received on wire, red stripes mark start of new records.
|
||||||
|
|
||||||
|
In above case segment 1 is received and decrypted successfully.
|
||||||
|
Segment 2 was dropped so 3 arrives out of order. The device knows
|
||||||
|
the next record starts inside 3, based on record length in segment 1.
|
||||||
|
Segment 3 is passed untouched, because due to lack of data from segment 2
|
||||||
|
the remainder of the previous record inside segment 3 cannot be handled.
|
||||||
|
The device can, however, collect the authentication algorithm's state
|
||||||
|
and partial block from the new record in segment 3 and when 4 and 5
|
||||||
|
arrive continue decryption. Finally when 2 arrives it's completely outside
|
||||||
|
of expected window of the device so it's passed as is without special
|
||||||
|
handling. ``ktls`` software fallback handles the decryption of record
|
||||||
|
spanning segments 1, 2 and 3. The device did not get out of sync,
|
||||||
|
even though two segments did not get decrypted.
|
||||||
|
|
||||||
|
Kernel synchronization may be necessary if the lost segment contained
|
||||||
|
a record header and arrived after the next record header has already passed:
|
||||||
|
|
||||||
|
.. kernel-figure:: tls-offload-reorder-bad.svg
|
||||||
|
:alt: reorder of header segment
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
Reorder of segment with a TLS header
|
||||||
|
|
||||||
|
In this example segment 2 gets dropped, and it contains a record header.
|
||||||
|
Device can only detect that segment 4 also contains a TLS header
|
||||||
|
if it knows the length of the previous record from segment 2. In this case
|
||||||
|
the device will lose synchronization with the stream.
|
||||||
|
|
||||||
|
When the device gets out of sync and the stream reaches TCP sequence
|
||||||
|
numbers more than a max size record past the expected TCP sequence number,
|
||||||
|
the device starts scanning for a known header pattern. For example
|
||||||
|
for TLS 1.2 and TLS 1.3 subsequent bytes of value ``0x03 0x03`` occur
|
||||||
|
in the SSL/TLS version field of the header. Once pattern is matched
|
||||||
|
the device continues attempting parsing headers at expected locations
|
||||||
|
(based on the length fields at guessed locations).
|
||||||
|
Whenever the expected location does not contain a valid header the scan
|
||||||
|
is restarted.
|
||||||
|
|
||||||
|
When the header is matched the device sends a confirmation request
|
||||||
|
to the kernel, asking if the guessed location is correct (if a TLS record
|
||||||
|
really starts there), and which record sequence number the given header had.
|
||||||
|
The kernel confirms the guessed location was correct and tells the device
|
||||||
|
the record sequence number. Meanwhile, the device had been parsing
|
||||||
|
and counting all records since the just-confirmed one, it adds the number
|
||||||
|
of records it had seen to the record number provided by the kernel.
|
||||||
|
At this point the device is in sync and can resume decryption at next
|
||||||
|
segment boundary.
|
||||||
|
|
||||||
|
In a pathological case the device may latch onto a sequence of matching
|
||||||
|
headers and never hear back from the kernel (there is no negative
|
||||||
|
confirmation from the kernel). The implementation may choose to periodically
|
||||||
|
restart scan. Given how unlikely falsely-matching stream is, however,
|
||||||
|
periodic restart is not deemed necessary.
|
||||||
|
|
||||||
|
Special care has to be taken if the confirmation request is passed
|
||||||
|
asynchronously to the packet stream and record may get processed
|
||||||
|
by the kernel before the confirmation request.
|
||||||
|
|
||||||
|
Error handling
|
||||||
|
==============
|
||||||
|
|
||||||
|
TX
|
||||||
|
--
|
||||||
|
|
||||||
|
Packets may be redirected or rerouted by the stack to a different
|
||||||
|
device than the selected TLS offload device. The stack will handle
|
||||||
|
such condition using the :c:func:`sk_validate_xmit_skb` helper
|
||||||
|
(TLS offload code installs :c:func:`tls_validate_xmit_skb` at this hook).
|
||||||
|
Offload maintains information about all records until the data is
|
||||||
|
fully acknowledged, so if skbs reach the wrong device they can be handled
|
||||||
|
by software fallback.
|
||||||
|
|
||||||
|
Any device TLS offload handling error on the transmission side must result
|
||||||
|
in the packet being dropped. For example if a packet got out of order
|
||||||
|
due to a bug in the stack or the device, reached the device and can't
|
||||||
|
be encrypted such packet must be dropped.
|
||||||
|
|
||||||
|
RX
|
||||||
|
--
|
||||||
|
|
||||||
|
If the device encounters any problems with TLS offload on the receive
|
||||||
|
side it should pass the packet to the host's networking stack as it was
|
||||||
|
received on the wire.
|
||||||
|
|
||||||
|
For example authentication failure for any record in the segment should
|
||||||
|
result in passing the unmodified packet to the software fallback. This means
|
||||||
|
packets should not be modified "in place". Splitting segments to handle partial
|
||||||
|
decryption is not advised. In other words either all records in the packet
|
||||||
|
had been handled successfully and authenticated or the packet has to be passed
|
||||||
|
to the host's stack as it was on the wire (recovering original packet in the
|
||||||
|
driver if device provides precise error is sufficient).
|
||||||
|
|
||||||
|
The Linux networking stack does not provide a way of reporting per-packet
|
||||||
|
decryption and authentication errors, packets with errors must simply not
|
||||||
|
have the :c:member:`decrypted` mark set.
|
||||||
|
|
||||||
|
A packet should also not be handled by the TLS offload if it contains
|
||||||
|
incorrect checksums.
|
||||||
|
|
||||||
|
Performance metrics
|
||||||
|
===================
|
||||||
|
|
||||||
|
TLS offload can be characterized by the following basic metrics:
|
||||||
|
|
||||||
|
* max connection count
|
||||||
|
* connection installation rate
|
||||||
|
* connection installation latency
|
||||||
|
* total cryptographic performance
|
||||||
|
|
||||||
|
Note that each TCP connection requires a TLS session in both directions,
|
||||||
|
the performance may be reported treating each direction separately.
|
||||||
|
|
||||||
|
Max connection count
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
The number of connections device can support can be exposed via
|
||||||
|
``devlink resource`` API.
|
||||||
|
|
||||||
|
Total cryptographic performance
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
Offload performance may depend on segment and record size.
|
||||||
|
|
||||||
|
Overload of the cryptographic subsystem of the device should not have
|
||||||
|
significant performance impact on non-offloaded streams.
|
||||||
|
|
||||||
|
Statistics
|
||||||
|
==========
|
||||||
|
|
||||||
|
Following minimum set of TLS-related statistics should be reported
|
||||||
|
by the driver:
|
||||||
|
|
||||||
|
* ``rx_tls_decrypted`` - number of successfully decrypted TLS segments
|
||||||
|
* ``tx_tls_encrypted`` - number of in-order TLS segments passed to device
|
||||||
|
for encryption
|
||||||
|
* ``tx_tls_ooo`` - number of TX packets which were part of a TLS stream
|
||||||
|
but did not arrive in the expected order
|
||||||
|
* ``tx_tls_drop_no_sync_data`` - number of TX packets dropped because
|
||||||
|
they arrived out of order and associated record could not be found
|
||||||
|
(see also :ref:`pre_tls_data`)
|
||||||
|
|
||||||
|
Notable corner cases, exceptions and additional requirements
|
||||||
|
============================================================
|
||||||
|
|
||||||
|
.. _5tuple_problems:
|
||||||
|
|
||||||
|
5-tuple matching limitations
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
The device can only recognize received packets based on the 5-tuple
|
||||||
|
of the socket. Current ``ktls`` implementation will not offload sockets
|
||||||
|
routed through software interfaces such as those used for tunneling
|
||||||
|
or virtual networking. However, many packet transformations performed
|
||||||
|
by the networking stack (most notably any BPF logic) do not require
|
||||||
|
any intermediate software device, therefore a 5-tuple match may
|
||||||
|
consistently miss at the device level. In such cases the device
|
||||||
|
should still be able to perform TX offload (encryption) and should
|
||||||
|
fallback cleanly to software decryption (RX).
|
||||||
|
|
||||||
|
Out of order
|
||||||
|
------------
|
||||||
|
|
||||||
|
Introducing extra processing in NICs should not cause packets to be
|
||||||
|
transmitted or received out of order, for example pure ACK packets
|
||||||
|
should not be reordered with respect to data segments.
|
||||||
|
|
||||||
|
Ingress reorder
|
||||||
|
---------------
|
||||||
|
|
||||||
|
A device is permitted to perform packet reordering for consecutive
|
||||||
|
TCP segments (i.e. placing packets in the correct order) but any form
|
||||||
|
of additional buffering is disallowed.
|
||||||
|
|
||||||
|
Coexistence with standard networking offload features
|
||||||
|
-----------------------------------------------------
|
||||||
|
|
||||||
|
Offloaded ``ktls`` sockets should support standard TCP stack features
|
||||||
|
transparently. Enabling device TLS offload should not cause any difference
|
||||||
|
in packets as seen on the wire.
|
||||||
|
|
||||||
|
Transport layer transparency
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
The device should not modify any packet headers for the purpose
|
||||||
|
of the simplifying TLS offload.
|
||||||
|
|
||||||
|
The device should not depend on any packet headers beyond what is strictly
|
||||||
|
necessary for TLS offload.
|
||||||
|
|
||||||
|
Segment drops
|
||||||
|
-------------
|
||||||
|
|
||||||
|
Dropping packets is acceptable only in the event of catastrophic
|
||||||
|
system errors and should never be used as an error handling mechanism
|
||||||
|
in cases arising from normal operation. In other words, reliance
|
||||||
|
on TCP retransmissions to handle corner cases is not acceptable.
|
||||||
|
|
||||||
|
TLS device features
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
Drivers should ignore the changes to TLS the device feature flags.
|
||||||
|
These flags will be acted upon accordingly by the core ``ktls`` code.
|
||||||
|
TLS device feature flags only control adding of new TLS connection
|
||||||
|
offloads, old connections will remain active after flags are cleared.
|
||||||
|
|
||||||
|
Known bugs
|
||||||
|
==========
|
||||||
|
|
||||||
|
skb_orphan() leaks clear text
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Currently drivers depend on the :c:member:`sk` member of
|
||||||
|
:c:type:`struct sk_buff <sk_buff>` to identify segments requiring
|
||||||
|
encryption. Any operation which removes or does not preserve the socket
|
||||||
|
association such as :c:func:`skb_orphan` or :c:func:`skb_clone`
|
||||||
|
will cause the driver to miss the packets and lead to clear text leaks.
|
||||||
|
|
||||||
|
Redirects leak clear text
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
In the RX direction, if segment has already been decrypted by the device
|
||||||
|
and it gets redirected or mirrored - clear text will be transmitted out.
|
||||||
|
|
||||||
|
.. _pre_tls_data:
|
||||||
|
|
||||||
|
Transmission of pre-TLS data
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
User can enqueue some already encrypted and framed records before enabling
|
||||||
|
``ktls`` on the socket. Those records have to get sent as they are. This is
|
||||||
|
perfectly easy to handle in the software case - such data will be waiting
|
||||||
|
in the TCP layer, TLS ULP won't see it. In the offloaded case when pre-queued
|
||||||
|
segment reaches transmission point it appears to be out of order (before the
|
||||||
|
expected TCP sequence number) and the stack does not have a record information
|
||||||
|
associated.
|
||||||
|
|
||||||
|
All segments without record information cannot, however, be assumed to be
|
||||||
|
pre-queued data, because a race condition exists between TCP stack queuing
|
||||||
|
a retransmission, the driver seeing the retransmission and TCP ACK arriving
|
||||||
|
for the retransmitted data.
|
|
@ -1,3 +1,9 @@
|
||||||
|
.. _kernel_tls:
|
||||||
|
|
||||||
|
==========
|
||||||
|
Kernel TLS
|
||||||
|
==========
|
||||||
|
|
||||||
Overview
|
Overview
|
||||||
========
|
========
|
||||||
|
|
||||||
|
@ -12,6 +18,8 @@ Creating a TLS connection
|
||||||
|
|
||||||
First create a new TCP socket and set the TLS ULP.
|
First create a new TCP socket and set the TLS ULP.
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
sock = socket(AF_INET, SOCK_STREAM, 0);
|
sock = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
setsockopt(sock, SOL_TCP, TCP_ULP, "tls", sizeof("tls"));
|
setsockopt(sock, SOL_TCP, TCP_ULP, "tls", sizeof("tls"));
|
||||||
|
|
||||||
|
@ -21,6 +29,8 @@ handshake is complete, we have all the parameters required to move the
|
||||||
data-path to the kernel. There is a separate socket option for moving
|
data-path to the kernel. There is a separate socket option for moving
|
||||||
the transmit and the receive into the kernel.
|
the transmit and the receive into the kernel.
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
/* From linux/tls.h */
|
/* From linux/tls.h */
|
||||||
struct tls_crypto_info {
|
struct tls_crypto_info {
|
||||||
unsigned short version;
|
unsigned short version;
|
||||||
|
@ -58,6 +68,8 @@ After setting the TLS_TX socket option all application data sent over this
|
||||||
socket is encrypted using TLS and the parameters provided in the socket option.
|
socket is encrypted using TLS and the parameters provided in the socket option.
|
||||||
For example, we can send an encrypted hello world record as follows:
|
For example, we can send an encrypted hello world record as follows:
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
const char *msg = "hello world\n";
|
const char *msg = "hello world\n";
|
||||||
send(sock, msg, strlen(msg));
|
send(sock, msg, strlen(msg));
|
||||||
|
|
||||||
|
@ -67,6 +79,8 @@ to the encrypted kernel send buffer if possible.
|
||||||
The sendfile system call will send the file's data over TLS records of maximum
|
The sendfile system call will send the file's data over TLS records of maximum
|
||||||
length (2^14).
|
length (2^14).
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
file = open(filename, O_RDONLY);
|
file = open(filename, O_RDONLY);
|
||||||
fstat(file, &stat);
|
fstat(file, &stat);
|
||||||
sendfile(sock, file, &offset, stat.st_size);
|
sendfile(sock, file, &offset, stat.st_size);
|
||||||
|
@ -89,6 +103,8 @@ After setting the TLS_RX socket option, all recv family socket calls
|
||||||
are decrypted using TLS parameters provided. A full TLS record must
|
are decrypted using TLS parameters provided. A full TLS record must
|
||||||
be received before decryption can happen.
|
be received before decryption can happen.
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
char buffer[16384];
|
char buffer[16384];
|
||||||
recv(sock, buffer, 16384);
|
recv(sock, buffer, 16384);
|
||||||
|
|
||||||
|
@ -97,12 +113,12 @@ large enough, and no additional allocations occur. If the userspace
|
||||||
buffer is too small, data is decrypted in the kernel and copied to
|
buffer is too small, data is decrypted in the kernel and copied to
|
||||||
userspace.
|
userspace.
|
||||||
|
|
||||||
EINVAL is returned if the TLS version in the received message does not
|
``EINVAL`` is returned if the TLS version in the received message does not
|
||||||
match the version passed in setsockopt.
|
match the version passed in setsockopt.
|
||||||
|
|
||||||
EMSGSIZE is returned if the received message is too big.
|
``EMSGSIZE`` is returned if the received message is too big.
|
||||||
|
|
||||||
EBADMSG is returned if decryption failed for any other reason.
|
``EBADMSG`` is returned if decryption failed for any other reason.
|
||||||
|
|
||||||
Send TLS control messages
|
Send TLS control messages
|
||||||
-------------------------
|
-------------------------
|
||||||
|
@ -113,9 +129,11 @@ These messages can be sent over the socket by providing the TLS record type
|
||||||
via a CMSG. For example the following function sends @data of @length bytes
|
via a CMSG. For example the following function sends @data of @length bytes
|
||||||
using a record of type @record_type.
|
using a record of type @record_type.
|
||||||
|
|
||||||
/* send TLS control message using record_type */
|
.. code-block:: c
|
||||||
|
|
||||||
|
/* send TLS control message using record_type */
|
||||||
static int klts_send_ctrl_message(int sock, unsigned char record_type,
|
static int klts_send_ctrl_message(int sock, unsigned char record_type,
|
||||||
void *data, size_t length)
|
void *data, size_t length)
|
||||||
{
|
{
|
||||||
struct msghdr msg = {0};
|
struct msghdr msg = {0};
|
||||||
int cmsg_len = sizeof(record_type);
|
int cmsg_len = sizeof(record_type);
|
||||||
|
@ -151,6 +169,8 @@ type passed via cmsg. If no cmsg buffer is provided, an error is
|
||||||
returned if a control message is received. Data messages may be
|
returned if a control message is received. Data messages may be
|
||||||
received without a cmsg buffer set.
|
received without a cmsg buffer set.
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
char buffer[16384];
|
char buffer[16384];
|
||||||
char cmsg[CMSG_SPACE(sizeof(unsigned char))];
|
char cmsg[CMSG_SPACE(sizeof(unsigned char))];
|
||||||
struct msghdr msg = {0};
|
struct msghdr msg = {0};
|
||||||
|
@ -186,12 +206,10 @@ Integrating in to userspace TLS library
|
||||||
At a high level, the kernel TLS ULP is a replacement for the record
|
At a high level, the kernel TLS ULP is a replacement for the record
|
||||||
layer of a userspace TLS library.
|
layer of a userspace TLS library.
|
||||||
|
|
||||||
A patchset to OpenSSL to use ktls as the record layer is here:
|
A patchset to OpenSSL to use ktls as the record layer is
|
||||||
|
`here <https://github.com/Mellanox/openssl/commits/tls_rx2>`_.
|
||||||
|
|
||||||
https://github.com/Mellanox/openssl/commits/tls_rx2
|
`An example <https://github.com/ktls/af_ktls-tool/commits/RX>`_
|
||||||
|
of calling send directly after a handshake using gnutls.
|
||||||
An example of calling send directly after a handshake using
|
Since it doesn't implement a full record layer, control
|
||||||
gnutls. Since it doesn't implement a full record layer, control
|
messages are not supported.
|
||||||
messages are not supported:
|
|
||||||
|
|
||||||
https://github.com/ktls/af_ktls-tool/commits/RX
|
|
|
@ -37,7 +37,19 @@ import glob
|
||||||
from docutils import nodes, statemachine
|
from docutils import nodes, statemachine
|
||||||
from docutils.statemachine import ViewList
|
from docutils.statemachine import ViewList
|
||||||
from docutils.parsers.rst import directives, Directive
|
from docutils.parsers.rst import directives, Directive
|
||||||
from sphinx.ext.autodoc import AutodocReporter
|
|
||||||
|
#
|
||||||
|
# AutodocReporter is only good up to Sphinx 1.7
|
||||||
|
#
|
||||||
|
import sphinx
|
||||||
|
|
||||||
|
Use_SSI = sphinx.__version__[:3] >= '1.7'
|
||||||
|
if Use_SSI:
|
||||||
|
from sphinx.util.docutils import switch_source_input
|
||||||
|
else:
|
||||||
|
from sphinx.ext.autodoc import AutodocReporter
|
||||||
|
|
||||||
|
import kernellog
|
||||||
|
|
||||||
__version__ = '1.0'
|
__version__ = '1.0'
|
||||||
|
|
||||||
|
@ -90,7 +102,8 @@ class KernelDocDirective(Directive):
|
||||||
cmd += [filename]
|
cmd += [filename]
|
||||||
|
|
||||||
try:
|
try:
|
||||||
env.app.verbose('calling kernel-doc \'%s\'' % (" ".join(cmd)))
|
kernellog.verbose(env.app,
|
||||||
|
'calling kernel-doc \'%s\'' % (" ".join(cmd)))
|
||||||
|
|
||||||
p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
||||||
out, err = p.communicate()
|
out, err = p.communicate()
|
||||||
|
@ -100,7 +113,8 @@ class KernelDocDirective(Directive):
|
||||||
if p.returncode != 0:
|
if p.returncode != 0:
|
||||||
sys.stderr.write(err)
|
sys.stderr.write(err)
|
||||||
|
|
||||||
env.app.warn('kernel-doc \'%s\' failed with return code %d' % (" ".join(cmd), p.returncode))
|
kernellog.warn(env.app,
|
||||||
|
'kernel-doc \'%s\' failed with return code %d' % (" ".join(cmd), p.returncode))
|
||||||
return [nodes.error(None, nodes.paragraph(text = "kernel-doc missing"))]
|
return [nodes.error(None, nodes.paragraph(text = "kernel-doc missing"))]
|
||||||
elif env.config.kerneldoc_verbosity > 0:
|
elif env.config.kerneldoc_verbosity > 0:
|
||||||
sys.stderr.write(err)
|
sys.stderr.write(err)
|
||||||
|
@ -121,20 +135,28 @@ class KernelDocDirective(Directive):
|
||||||
lineoffset += 1
|
lineoffset += 1
|
||||||
|
|
||||||
node = nodes.section()
|
node = nodes.section()
|
||||||
buf = self.state.memo.title_styles, self.state.memo.section_level, self.state.memo.reporter
|
self.do_parse(result, node)
|
||||||
|
|
||||||
|
return node.children
|
||||||
|
|
||||||
|
except Exception as e: # pylint: disable=W0703
|
||||||
|
kernellog.warn(env.app, 'kernel-doc \'%s\' processing failed with: %s' %
|
||||||
|
(" ".join(cmd), str(e)))
|
||||||
|
return [nodes.error(None, nodes.paragraph(text = "kernel-doc missing"))]
|
||||||
|
|
||||||
|
def do_parse(self, result, node):
|
||||||
|
if Use_SSI:
|
||||||
|
with switch_source_input(self.state, result):
|
||||||
|
self.state.nested_parse(result, 0, node, match_titles=1)
|
||||||
|
else:
|
||||||
|
save = self.state.memo.title_styles, self.state.memo.section_level, self.state.memo.reporter
|
||||||
self.state.memo.reporter = AutodocReporter(result, self.state.memo.reporter)
|
self.state.memo.reporter = AutodocReporter(result, self.state.memo.reporter)
|
||||||
self.state.memo.title_styles, self.state.memo.section_level = [], 0
|
self.state.memo.title_styles, self.state.memo.section_level = [], 0
|
||||||
try:
|
try:
|
||||||
self.state.nested_parse(result, 0, node, match_titles=1)
|
self.state.nested_parse(result, 0, node, match_titles=1)
|
||||||
finally:
|
finally:
|
||||||
self.state.memo.title_styles, self.state.memo.section_level, self.state.memo.reporter = buf
|
self.state.memo.title_styles, self.state.memo.section_level, self.state.memo.reporter = save
|
||||||
|
|
||||||
return node.children
|
|
||||||
|
|
||||||
except Exception as e: # pylint: disable=W0703
|
|
||||||
env.app.warn('kernel-doc \'%s\' processing failed with: %s' %
|
|
||||||
(" ".join(cmd), str(e)))
|
|
||||||
return [nodes.error(None, nodes.paragraph(text = "kernel-doc missing"))]
|
|
||||||
|
|
||||||
def setup(app):
|
def setup(app):
|
||||||
app.add_config_value('kerneldoc_bin', None, 'env')
|
app.add_config_value('kerneldoc_bin', None, 'env')
|
||||||
|
|
28
Documentation/sphinx/kernellog.py
Normal file
28
Documentation/sphinx/kernellog.py
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
#
|
||||||
|
# Sphinx has deprecated its older logging interface, but the replacement
|
||||||
|
# only goes back to 1.6. So here's a wrapper layer to keep around for
|
||||||
|
# as long as we support 1.4.
|
||||||
|
#
|
||||||
|
import sphinx
|
||||||
|
|
||||||
|
if sphinx.__version__[:3] >= '1.6':
|
||||||
|
UseLogging = True
|
||||||
|
from sphinx.util import logging
|
||||||
|
logger = logging.getLogger('kerneldoc')
|
||||||
|
else:
|
||||||
|
UseLogging = False
|
||||||
|
|
||||||
|
def warn(app, message):
|
||||||
|
if UseLogging:
|
||||||
|
logger.warning(message)
|
||||||
|
else:
|
||||||
|
app.warn(message)
|
||||||
|
|
||||||
|
def verbose(app, message):
|
||||||
|
if UseLogging:
|
||||||
|
logger.verbose(message)
|
||||||
|
else:
|
||||||
|
app.verbose(message)
|
||||||
|
|
||||||
|
|
|
@ -60,6 +60,8 @@ import sphinx
|
||||||
from sphinx.util.nodes import clean_astext
|
from sphinx.util.nodes import clean_astext
|
||||||
from six import iteritems
|
from six import iteritems
|
||||||
|
|
||||||
|
import kernellog
|
||||||
|
|
||||||
PY3 = sys.version_info[0] == 3
|
PY3 = sys.version_info[0] == 3
|
||||||
|
|
||||||
if PY3:
|
if PY3:
|
||||||
|
@ -171,20 +173,20 @@ def setupTools(app):
|
||||||
This function is called once, when the builder is initiated.
|
This function is called once, when the builder is initiated.
|
||||||
"""
|
"""
|
||||||
global dot_cmd, convert_cmd # pylint: disable=W0603
|
global dot_cmd, convert_cmd # pylint: disable=W0603
|
||||||
app.verbose("kfigure: check installed tools ...")
|
kernellog.verbose(app, "kfigure: check installed tools ...")
|
||||||
|
|
||||||
dot_cmd = which('dot')
|
dot_cmd = which('dot')
|
||||||
convert_cmd = which('convert')
|
convert_cmd = which('convert')
|
||||||
|
|
||||||
if dot_cmd:
|
if dot_cmd:
|
||||||
app.verbose("use dot(1) from: " + dot_cmd)
|
kernellog.verbose(app, "use dot(1) from: " + dot_cmd)
|
||||||
else:
|
else:
|
||||||
app.warn("dot(1) not found, for better output quality install "
|
kernellog.warn(app, "dot(1) not found, for better output quality install "
|
||||||
"graphviz from http://www.graphviz.org")
|
"graphviz from http://www.graphviz.org")
|
||||||
if convert_cmd:
|
if convert_cmd:
|
||||||
app.verbose("use convert(1) from: " + convert_cmd)
|
kernellog.verbose(app, "use convert(1) from: " + convert_cmd)
|
||||||
else:
|
else:
|
||||||
app.warn(
|
kernellog.warn(app,
|
||||||
"convert(1) not found, for SVG to PDF conversion install "
|
"convert(1) not found, for SVG to PDF conversion install "
|
||||||
"ImageMagick (https://www.imagemagick.org)")
|
"ImageMagick (https://www.imagemagick.org)")
|
||||||
|
|
||||||
|
@ -220,12 +222,13 @@ def convert_image(img_node, translator, src_fname=None):
|
||||||
|
|
||||||
# in kernel builds, use 'make SPHINXOPTS=-v' to see verbose messages
|
# in kernel builds, use 'make SPHINXOPTS=-v' to see verbose messages
|
||||||
|
|
||||||
app.verbose('assert best format for: ' + img_node['uri'])
|
kernellog.verbose(app, 'assert best format for: ' + img_node['uri'])
|
||||||
|
|
||||||
if in_ext == '.dot':
|
if in_ext == '.dot':
|
||||||
|
|
||||||
if not dot_cmd:
|
if not dot_cmd:
|
||||||
app.verbose("dot from graphviz not available / include DOT raw.")
|
kernellog.verbose(app,
|
||||||
|
"dot from graphviz not available / include DOT raw.")
|
||||||
img_node.replace_self(file2literal(src_fname))
|
img_node.replace_self(file2literal(src_fname))
|
||||||
|
|
||||||
elif translator.builder.format == 'latex':
|
elif translator.builder.format == 'latex':
|
||||||
|
@ -252,7 +255,8 @@ def convert_image(img_node, translator, src_fname=None):
|
||||||
|
|
||||||
if translator.builder.format == 'latex':
|
if translator.builder.format == 'latex':
|
||||||
if convert_cmd is None:
|
if convert_cmd is None:
|
||||||
app.verbose("no SVG to PDF conversion available / include SVG raw.")
|
kernellog.verbose(app,
|
||||||
|
"no SVG to PDF conversion available / include SVG raw.")
|
||||||
img_node.replace_self(file2literal(src_fname))
|
img_node.replace_self(file2literal(src_fname))
|
||||||
else:
|
else:
|
||||||
dst_fname = path.join(translator.builder.outdir, fname + '.pdf')
|
dst_fname = path.join(translator.builder.outdir, fname + '.pdf')
|
||||||
|
@ -265,18 +269,19 @@ def convert_image(img_node, translator, src_fname=None):
|
||||||
_name = dst_fname[len(translator.builder.outdir) + 1:]
|
_name = dst_fname[len(translator.builder.outdir) + 1:]
|
||||||
|
|
||||||
if isNewer(dst_fname, src_fname):
|
if isNewer(dst_fname, src_fname):
|
||||||
app.verbose("convert: {out}/%s already exists and is newer" % _name)
|
kernellog.verbose(app,
|
||||||
|
"convert: {out}/%s already exists and is newer" % _name)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
ok = False
|
ok = False
|
||||||
mkdir(path.dirname(dst_fname))
|
mkdir(path.dirname(dst_fname))
|
||||||
|
|
||||||
if in_ext == '.dot':
|
if in_ext == '.dot':
|
||||||
app.verbose('convert DOT to: {out}/' + _name)
|
kernellog.verbose(app, 'convert DOT to: {out}/' + _name)
|
||||||
ok = dot2format(app, src_fname, dst_fname)
|
ok = dot2format(app, src_fname, dst_fname)
|
||||||
|
|
||||||
elif in_ext == '.svg':
|
elif in_ext == '.svg':
|
||||||
app.verbose('convert SVG to: {out}/' + _name)
|
kernellog.verbose(app, 'convert SVG to: {out}/' + _name)
|
||||||
ok = svg2pdf(app, src_fname, dst_fname)
|
ok = svg2pdf(app, src_fname, dst_fname)
|
||||||
|
|
||||||
if not ok:
|
if not ok:
|
||||||
|
@ -305,7 +310,8 @@ def dot2format(app, dot_fname, out_fname):
|
||||||
with open(out_fname, "w") as out:
|
with open(out_fname, "w") as out:
|
||||||
exit_code = subprocess.call(cmd, stdout = out)
|
exit_code = subprocess.call(cmd, stdout = out)
|
||||||
if exit_code != 0:
|
if exit_code != 0:
|
||||||
app.warn("Error #%d when calling: %s" % (exit_code, " ".join(cmd)))
|
kernellog.warn(app,
|
||||||
|
"Error #%d when calling: %s" % (exit_code, " ".join(cmd)))
|
||||||
return bool(exit_code == 0)
|
return bool(exit_code == 0)
|
||||||
|
|
||||||
def svg2pdf(app, svg_fname, pdf_fname):
|
def svg2pdf(app, svg_fname, pdf_fname):
|
||||||
|
@ -322,7 +328,7 @@ def svg2pdf(app, svg_fname, pdf_fname):
|
||||||
# use stdout and stderr from parent
|
# use stdout and stderr from parent
|
||||||
exit_code = subprocess.call(cmd)
|
exit_code = subprocess.call(cmd)
|
||||||
if exit_code != 0:
|
if exit_code != 0:
|
||||||
app.warn("Error #%d when calling: %s" % (exit_code, " ".join(cmd)))
|
kernellog.warn(app, "Error #%d when calling: %s" % (exit_code, " ".join(cmd)))
|
||||||
return bool(exit_code == 0)
|
return bool(exit_code == 0)
|
||||||
|
|
||||||
|
|
||||||
|
@ -415,15 +421,15 @@ def visit_kernel_render(self, node):
|
||||||
app = self.builder.app
|
app = self.builder.app
|
||||||
srclang = node.get('srclang')
|
srclang = node.get('srclang')
|
||||||
|
|
||||||
app.verbose('visit kernel-render node lang: "%s"' % (srclang))
|
kernellog.verbose(app, 'visit kernel-render node lang: "%s"' % (srclang))
|
||||||
|
|
||||||
tmp_ext = RENDER_MARKUP_EXT.get(srclang, None)
|
tmp_ext = RENDER_MARKUP_EXT.get(srclang, None)
|
||||||
if tmp_ext is None:
|
if tmp_ext is None:
|
||||||
app.warn('kernel-render: "%s" unknown / include raw.' % (srclang))
|
kernellog.warn(app, 'kernel-render: "%s" unknown / include raw.' % (srclang))
|
||||||
return
|
return
|
||||||
|
|
||||||
if not dot_cmd and tmp_ext == '.dot':
|
if not dot_cmd and tmp_ext == '.dot':
|
||||||
app.verbose("dot from graphviz not available / include raw.")
|
kernellog.verbose(app, "dot from graphviz not available / include raw.")
|
||||||
return
|
return
|
||||||
|
|
||||||
literal_block = node[0]
|
literal_block = node[0]
|
||||||
|
|
|
@ -76,70 +76,30 @@ Additional Information and userspace tools
|
||||||
Requirements
|
Requirements
|
||||||
============
|
============
|
||||||
|
|
||||||
A host with a USB port. Ideally, either a UHCI (Intel) or OHCI
|
A host with a USB port running a Linux kernel with RIO 500 support enabled.
|
||||||
(Compaq and others) hardware port should work.
|
|
||||||
|
|
||||||
A Linux development kernel (2.3.x) with USB support enabled or a
|
The driver is a module called rio500, which should be automatically loaded
|
||||||
backported version to linux-2.2.x. See http://www.linux-usb.org for
|
as you plug in your device. If that fails you can manually load it with
|
||||||
more information on accomplishing this.
|
|
||||||
|
|
||||||
A Linux kernel with RIO 500 support enabled.
|
modprobe rio500
|
||||||
|
|
||||||
'lspci' which is only needed to determine the type of USB hardware
|
Udev should automatically create a device node as soon as plug in your device.
|
||||||
available in your machine.
|
If that fails, you can manually add a device for the USB rio500::
|
||||||
|
|
||||||
Configuration
|
|
||||||
|
|
||||||
Using `lspci -v`, determine the type of USB hardware available.
|
|
||||||
|
|
||||||
If you see something like::
|
|
||||||
|
|
||||||
USB Controller: ......
|
|
||||||
Flags: .....
|
|
||||||
I/O ports at ....
|
|
||||||
|
|
||||||
Then you have a UHCI based controller.
|
|
||||||
|
|
||||||
If you see something like::
|
|
||||||
|
|
||||||
USB Controller: .....
|
|
||||||
Flags: ....
|
|
||||||
Memory at .....
|
|
||||||
|
|
||||||
Then you have a OHCI based controller.
|
|
||||||
|
|
||||||
Using `make menuconfig` or your preferred method for configuring the
|
|
||||||
kernel, select 'Support for USB', 'OHCI/UHCI' depending on your
|
|
||||||
hardware (determined from the steps above), 'USB Diamond Rio500 support', and
|
|
||||||
'Preliminary USB device filesystem'. Compile and install the modules
|
|
||||||
(you may need to execute `depmod -a` to update the module
|
|
||||||
dependencies).
|
|
||||||
|
|
||||||
Add a device for the USB rio500::
|
|
||||||
|
|
||||||
mknod /dev/usb/rio500 c 180 64
|
mknod /dev/usb/rio500 c 180 64
|
||||||
|
|
||||||
Set appropriate permissions for /dev/usb/rio500 (don't forget about
|
In that case, set appropriate permissions for /dev/usb/rio500 (don't forget
|
||||||
group and world permissions). Both read and write permissions are
|
about group and world permissions). Both read and write permissions are
|
||||||
required for proper operation.
|
required for proper operation.
|
||||||
|
|
||||||
Load the appropriate modules (if compiled as modules):
|
|
||||||
|
|
||||||
OHCI::
|
|
||||||
|
|
||||||
modprobe usbcore
|
|
||||||
modprobe usb-ohci
|
|
||||||
modprobe rio500
|
|
||||||
|
|
||||||
UHCI::
|
|
||||||
|
|
||||||
modprobe usbcore
|
|
||||||
modprobe usb-uhci (or uhci)
|
|
||||||
modprobe rio500
|
|
||||||
|
|
||||||
That's it. The Rio500 Utils at: http://rio500.sourceforge.net should
|
That's it. The Rio500 Utils at: http://rio500.sourceforge.net should
|
||||||
be able to access the rio500.
|
be able to access the rio500.
|
||||||
|
|
||||||
|
Limits
|
||||||
|
======
|
||||||
|
|
||||||
|
You can use only a single rio500 device at a time with your computer.
|
||||||
|
|
||||||
Bugs
|
Bugs
|
||||||
====
|
====
|
||||||
|
|
||||||
|
|
|
@ -1079,7 +1079,7 @@ yet and must be cleared on entry.
|
||||||
|
|
||||||
4.35 KVM_SET_USER_MEMORY_REGION
|
4.35 KVM_SET_USER_MEMORY_REGION
|
||||||
|
|
||||||
Capability: KVM_CAP_USER_MEM
|
Capability: KVM_CAP_USER_MEMORY
|
||||||
Architectures: all
|
Architectures: all
|
||||||
Type: vm ioctl
|
Type: vm ioctl
|
||||||
Parameters: struct kvm_userspace_memory_region (in)
|
Parameters: struct kvm_userspace_memory_region (in)
|
||||||
|
@ -3857,43 +3857,59 @@ Type: vcpu ioctl
|
||||||
Parameters: struct kvm_nested_state (in/out)
|
Parameters: struct kvm_nested_state (in/out)
|
||||||
Returns: 0 on success, -1 on error
|
Returns: 0 on success, -1 on error
|
||||||
Errors:
|
Errors:
|
||||||
E2BIG: the total state size (including the fixed-size part of struct
|
E2BIG: the total state size exceeds the value of 'size' specified by
|
||||||
kvm_nested_state) exceeds the value of 'size' specified by
|
|
||||||
the user; the size required will be written into size.
|
the user; the size required will be written into size.
|
||||||
|
|
||||||
struct kvm_nested_state {
|
struct kvm_nested_state {
|
||||||
__u16 flags;
|
__u16 flags;
|
||||||
__u16 format;
|
__u16 format;
|
||||||
__u32 size;
|
__u32 size;
|
||||||
|
|
||||||
union {
|
union {
|
||||||
struct kvm_vmx_nested_state vmx;
|
struct kvm_vmx_nested_state_hdr vmx;
|
||||||
struct kvm_svm_nested_state svm;
|
struct kvm_svm_nested_state_hdr svm;
|
||||||
|
|
||||||
|
/* Pad the header to 128 bytes. */
|
||||||
__u8 pad[120];
|
__u8 pad[120];
|
||||||
};
|
} hdr;
|
||||||
__u8 data[0];
|
|
||||||
|
union {
|
||||||
|
struct kvm_vmx_nested_state_data vmx[0];
|
||||||
|
struct kvm_svm_nested_state_data svm[0];
|
||||||
|
} data;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define KVM_STATE_NESTED_GUEST_MODE 0x00000001
|
#define KVM_STATE_NESTED_GUEST_MODE 0x00000001
|
||||||
#define KVM_STATE_NESTED_RUN_PENDING 0x00000002
|
#define KVM_STATE_NESTED_RUN_PENDING 0x00000002
|
||||||
|
#define KVM_STATE_NESTED_EVMCS 0x00000004
|
||||||
|
|
||||||
#define KVM_STATE_NESTED_SMM_GUEST_MODE 0x00000001
|
#define KVM_STATE_NESTED_FORMAT_VMX 0
|
||||||
#define KVM_STATE_NESTED_SMM_VMXON 0x00000002
|
#define KVM_STATE_NESTED_FORMAT_SVM 1
|
||||||
|
|
||||||
struct kvm_vmx_nested_state {
|
#define KVM_STATE_NESTED_VMX_VMCS_SIZE 0x1000
|
||||||
|
|
||||||
|
#define KVM_STATE_NESTED_VMX_SMM_GUEST_MODE 0x00000001
|
||||||
|
#define KVM_STATE_NESTED_VMX_SMM_VMXON 0x00000002
|
||||||
|
|
||||||
|
struct kvm_vmx_nested_state_hdr {
|
||||||
__u64 vmxon_pa;
|
__u64 vmxon_pa;
|
||||||
__u64 vmcs_pa;
|
__u64 vmcs12_pa;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
__u16 flags;
|
__u16 flags;
|
||||||
} smm;
|
} smm;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct kvm_vmx_nested_state_data {
|
||||||
|
__u8 vmcs12[KVM_STATE_NESTED_VMX_VMCS_SIZE];
|
||||||
|
__u8 shadow_vmcs12[KVM_STATE_NESTED_VMX_VMCS_SIZE];
|
||||||
|
};
|
||||||
|
|
||||||
This ioctl copies the vcpu's nested virtualization state from the kernel to
|
This ioctl copies the vcpu's nested virtualization state from the kernel to
|
||||||
userspace.
|
userspace.
|
||||||
|
|
||||||
The maximum size of the state, including the fixed-size part of struct
|
The maximum size of the state can be retrieved by passing KVM_CAP_NESTED_STATE
|
||||||
kvm_nested_state, can be retrieved by passing KVM_CAP_NESTED_STATE to
|
to the KVM_CHECK_EXTENSION ioctl().
|
||||||
the KVM_CHECK_EXTENSION ioctl().
|
|
||||||
|
|
||||||
4.115 KVM_SET_NESTED_STATE
|
4.115 KVM_SET_NESTED_STATE
|
||||||
|
|
||||||
|
@ -3903,8 +3919,8 @@ Type: vcpu ioctl
|
||||||
Parameters: struct kvm_nested_state (in)
|
Parameters: struct kvm_nested_state (in)
|
||||||
Returns: 0 on success, -1 on error
|
Returns: 0 on success, -1 on error
|
||||||
|
|
||||||
This copies the vcpu's kvm_nested_state struct from userspace to the kernel. For
|
This copies the vcpu's kvm_nested_state struct from userspace to the kernel.
|
||||||
the definition of struct kvm_nested_state, see KVM_GET_NESTED_STATE.
|
For the definition of struct kvm_nested_state, see KVM_GET_NESTED_STATE.
|
||||||
|
|
||||||
4.116 KVM_(UN)REGISTER_COALESCED_MMIO
|
4.116 KVM_(UN)REGISTER_COALESCED_MMIO
|
||||||
|
|
||||||
|
|
|
@ -288,15 +288,17 @@ For instance if the device flags for device entries are:
|
||||||
WRITE (1 << 62)
|
WRITE (1 << 62)
|
||||||
|
|
||||||
Now let say that device driver wants to fault with at least read a range then
|
Now let say that device driver wants to fault with at least read a range then
|
||||||
it does set:
|
it does set::
|
||||||
range->default_flags = (1 << 63)
|
|
||||||
|
range->default_flags = (1 << 63);
|
||||||
range->pfn_flags_mask = 0;
|
range->pfn_flags_mask = 0;
|
||||||
|
|
||||||
and calls hmm_range_fault() as described above. This will fill fault all page
|
and calls hmm_range_fault() as described above. This will fill fault all page
|
||||||
in the range with at least read permission.
|
in the range with at least read permission.
|
||||||
|
|
||||||
Now let say driver wants to do the same except for one page in the range for
|
Now let say driver wants to do the same except for one page in the range for
|
||||||
which its want to have write. Now driver set:
|
which its want to have write. Now driver set::
|
||||||
|
|
||||||
range->default_flags = (1 << 63);
|
range->default_flags = (1 << 63);
|
||||||
range->pfn_flags_mask = (1 << 62);
|
range->pfn_flags_mask = (1 << 62);
|
||||||
range->pfns[index_of_write] = (1 << 62);
|
range->pfns[index_of_write] = (1 << 62);
|
||||||
|
|
98
MAINTAINERS
98
MAINTAINERS
|
@ -364,7 +364,7 @@ F: drivers/acpi/fan.c
|
||||||
|
|
||||||
ACPI FOR ARM64 (ACPI/arm64)
|
ACPI FOR ARM64 (ACPI/arm64)
|
||||||
M: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
|
M: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
|
||||||
M: Hanjun Guo <hanjun.guo@linaro.org>
|
M: Hanjun Guo <guohanjun@huawei.com>
|
||||||
M: Sudeep Holla <sudeep.holla@arm.com>
|
M: Sudeep Holla <sudeep.holla@arm.com>
|
||||||
L: linux-acpi@vger.kernel.org
|
L: linux-acpi@vger.kernel.org
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
|
@ -696,6 +696,7 @@ F: drivers/input/mouse/alps.*
|
||||||
ALTERA I2C CONTROLLER DRIVER
|
ALTERA I2C CONTROLLER DRIVER
|
||||||
M: Thor Thayer <thor.thayer@linux.intel.com>
|
M: Thor Thayer <thor.thayer@linux.intel.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-altera.txt
|
||||||
F: drivers/i2c/busses/i2c-altera.c
|
F: drivers/i2c/busses/i2c-altera.c
|
||||||
|
|
||||||
ALTERA MAILBOX DRIVER
|
ALTERA MAILBOX DRIVER
|
||||||
|
@ -1174,6 +1175,7 @@ S: Maintained
|
||||||
F: Documentation/devicetree/bindings/arm/arm-boards
|
F: Documentation/devicetree/bindings/arm/arm-boards
|
||||||
F: Documentation/devicetree/bindings/auxdisplay/arm-charlcd.txt
|
F: Documentation/devicetree/bindings/auxdisplay/arm-charlcd.txt
|
||||||
F: Documentation/devicetree/bindings/clock/arm-integrator.txt
|
F: Documentation/devicetree/bindings/clock/arm-integrator.txt
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-versatile.txt
|
||||||
F: Documentation/devicetree/bindings/interrupt-controller/arm,versatile-fpga-irq.txt
|
F: Documentation/devicetree/bindings/interrupt-controller/arm,versatile-fpga-irq.txt
|
||||||
F: Documentation/devicetree/bindings/mtd/arm-versatile.txt
|
F: Documentation/devicetree/bindings/mtd/arm-versatile.txt
|
||||||
F: arch/arm/mach-integrator/
|
F: arch/arm/mach-integrator/
|
||||||
|
@ -1233,7 +1235,7 @@ F: arch/arm/lib/floppydma.S
|
||||||
F: arch/arm/include/asm/floppy.h
|
F: arch/arm/include/asm/floppy.h
|
||||||
|
|
||||||
ARM PMU PROFILING AND DEBUGGING
|
ARM PMU PROFILING AND DEBUGGING
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
M: Mark Rutland <mark.rutland@arm.com>
|
M: Mark Rutland <mark.rutland@arm.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
|
@ -1288,7 +1290,7 @@ ARM PRIMECELL SSP PL022 SPI DRIVER
|
||||||
M: Linus Walleij <linus.walleij@linaro.org>
|
M: Linus Walleij <linus.walleij@linaro.org>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/devicetree/bindings/spi/spi_pl022.txt
|
F: Documentation/devicetree/bindings/spi/spi-pl022.yaml
|
||||||
F: drivers/spi/spi-pl022.c
|
F: drivers/spi/spi-pl022.c
|
||||||
|
|
||||||
ARM PRIMECELL UART PL010 AND PL011 DRIVERS
|
ARM PRIMECELL UART PL010 AND PL011 DRIVERS
|
||||||
|
@ -1305,7 +1307,7 @@ F: Documentation/devicetree/bindings/interrupt-controller/arm,vic.txt
|
||||||
F: drivers/irqchip/irq-vic.c
|
F: drivers/irqchip/irq-vic.c
|
||||||
|
|
||||||
ARM SMMU DRIVERS
|
ARM SMMU DRIVERS
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
R: Robin Murphy <robin.murphy@arm.com>
|
R: Robin Murphy <robin.murphy@arm.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
@ -1781,6 +1783,7 @@ ARM/LPC18XX ARCHITECTURE
|
||||||
M: Vladimir Zapolskiy <vz@mleia.com>
|
M: Vladimir Zapolskiy <vz@mleia.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-lpc2k.txt
|
||||||
F: arch/arm/boot/dts/lpc43*
|
F: arch/arm/boot/dts/lpc43*
|
||||||
F: drivers/i2c/busses/i2c-lpc2k.c
|
F: drivers/i2c/busses/i2c-lpc2k.c
|
||||||
F: drivers/memory/pl172.c
|
F: drivers/memory/pl172.c
|
||||||
|
@ -1794,6 +1797,7 @@ M: Sylvain Lemieux <slemieux.tyco@gmail.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
T: git git://github.com/vzapolskiy/linux-lpc32xx.git
|
T: git git://github.com/vzapolskiy/linux-lpc32xx.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-pnx.txt
|
||||||
F: arch/arm/boot/dts/lpc32*
|
F: arch/arm/boot/dts/lpc32*
|
||||||
F: arch/arm/mach-lpc32xx/
|
F: arch/arm/mach-lpc32xx/
|
||||||
F: drivers/i2c/busses/i2c-pnx.c
|
F: drivers/i2c/busses/i2c-pnx.c
|
||||||
|
@ -1918,6 +1922,8 @@ ARM/NOMADIK/U300/Ux500 ARCHITECTURES
|
||||||
M: Linus Walleij <linus.walleij@linaro.org>
|
M: Linus Walleij <linus.walleij@linaro.org>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-nomadik.txt
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-stu300.txt
|
||||||
F: arch/arm/mach-nomadik/
|
F: arch/arm/mach-nomadik/
|
||||||
F: arch/arm/mach-u300/
|
F: arch/arm/mach-u300/
|
||||||
F: arch/arm/mach-ux500/
|
F: arch/arm/mach-ux500/
|
||||||
|
@ -2079,7 +2085,7 @@ F: drivers/tty/serial/msm_serial.c
|
||||||
F: drivers/usb/dwc3/dwc3-qcom.c
|
F: drivers/usb/dwc3/dwc3-qcom.c
|
||||||
F: include/dt-bindings/*/qcom*
|
F: include/dt-bindings/*/qcom*
|
||||||
F: include/linux/*/qcom*
|
F: include/linux/*/qcom*
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/agross/linux.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/qcom/linux.git
|
||||||
|
|
||||||
ARM/RADISYS ENP2611 MACHINE SUPPORT
|
ARM/RADISYS ENP2611 MACHINE SUPPORT
|
||||||
M: Lennert Buytenhek <kernel@wantstofly.org>
|
M: Lennert Buytenhek <kernel@wantstofly.org>
|
||||||
|
@ -2140,6 +2146,7 @@ L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
L: linux-rockchip@lists.infradead.org
|
L: linux-rockchip@lists.infradead.org
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/mmind/linux-rockchip.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/mmind/linux-rockchip.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-rk3x.txt
|
||||||
F: arch/arm/boot/dts/rk3*
|
F: arch/arm/boot/dts/rk3*
|
||||||
F: arch/arm/boot/dts/rv1108*
|
F: arch/arm/boot/dts/rv1108*
|
||||||
F: arch/arm/mach-rockchip/
|
F: arch/arm/mach-rockchip/
|
||||||
|
@ -2275,6 +2282,7 @@ M: Patrice Chotard <patrice.chotard@st.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
W: http://www.stlinux.com
|
W: http://www.stlinux.com
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-st.txt
|
||||||
F: arch/arm/mach-sti/
|
F: arch/arm/mach-sti/
|
||||||
F: arch/arm/boot/dts/sti*
|
F: arch/arm/boot/dts/sti*
|
||||||
F: drivers/char/hw_random/st-rng.c
|
F: drivers/char/hw_random/st-rng.c
|
||||||
|
@ -2466,6 +2474,7 @@ ARM/VT8500 ARM ARCHITECTURE
|
||||||
M: Tony Prisk <linux@prisktech.co.nz>
|
M: Tony Prisk <linux@prisktech.co.nz>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-wmt.txt
|
||||||
F: arch/arm/mach-vt8500/
|
F: arch/arm/mach-vt8500/
|
||||||
F: drivers/clocksource/timer-vt8500.c
|
F: drivers/clocksource/timer-vt8500.c
|
||||||
F: drivers/i2c/busses/i2c-wmt.c
|
F: drivers/i2c/busses/i2c-wmt.c
|
||||||
|
@ -2531,6 +2540,8 @@ F: drivers/cpuidle/cpuidle-zynq.c
|
||||||
F: drivers/block/xsysace.c
|
F: drivers/block/xsysace.c
|
||||||
N: zynq
|
N: zynq
|
||||||
N: xilinx
|
N: xilinx
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-cadence.txt
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-xiic.txt
|
||||||
F: drivers/clocksource/timer-cadence-ttc.c
|
F: drivers/clocksource/timer-cadence-ttc.c
|
||||||
F: drivers/i2c/busses/i2c-cadence.c
|
F: drivers/i2c/busses/i2c-cadence.c
|
||||||
F: drivers/mmc/host/sdhci-of-arasan.c
|
F: drivers/mmc/host/sdhci-of-arasan.c
|
||||||
|
@ -2539,7 +2550,7 @@ F: drivers/i2c/busses/i2c-xiic.c
|
||||||
|
|
||||||
ARM64 PORT (AARCH64 ARCHITECTURE)
|
ARM64 PORT (AARCH64 ARCHITECTURE)
|
||||||
M: Catalin Marinas <catalin.marinas@arm.com>
|
M: Catalin Marinas <catalin.marinas@arm.com>
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
@ -2627,7 +2638,7 @@ F: Documentation/devicetree/bindings/eeprom/at24.txt
|
||||||
F: drivers/misc/eeprom/at24.c
|
F: drivers/misc/eeprom/at24.c
|
||||||
|
|
||||||
ATA OVER ETHERNET (AOE) DRIVER
|
ATA OVER ETHERNET (AOE) DRIVER
|
||||||
M: "Ed L. Cashin" <ed.cashin@acm.org>
|
M: "Justin Sanders" <justin@coraid.com>
|
||||||
W: http://www.openaoe.org/
|
W: http://www.openaoe.org/
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/aoe/
|
F: Documentation/aoe/
|
||||||
|
@ -2723,7 +2734,7 @@ S: Maintained
|
||||||
F: drivers/net/wireless/atmel/atmel*
|
F: drivers/net/wireless/atmel/atmel*
|
||||||
|
|
||||||
ATOMIC INFRASTRUCTURE
|
ATOMIC INFRASTRUCTURE
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
M: Peter Zijlstra <peterz@infradead.org>
|
M: Peter Zijlstra <peterz@infradead.org>
|
||||||
R: Boqun Feng <boqun.feng@gmail.com>
|
R: Boqun Feng <boqun.feng@gmail.com>
|
||||||
L: linux-kernel@vger.kernel.org
|
L: linux-kernel@vger.kernel.org
|
||||||
|
@ -2768,7 +2779,7 @@ AVIA HX711 ANALOG DIGITAL CONVERTER IIO DRIVER
|
||||||
M: Andreas Klinger <ak@it-klinger.de>
|
M: Andreas Klinger <ak@it-klinger.de>
|
||||||
L: linux-iio@vger.kernel.org
|
L: linux-iio@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/devicetree/bindings/iio/adc/avia-hx711.txt
|
F: Documentation/devicetree/bindings/iio/adc/avia-hx711.yaml
|
||||||
F: drivers/iio/adc/hx711.c
|
F: drivers/iio/adc/hx711.c
|
||||||
|
|
||||||
AX.25 NETWORK LAYER
|
AX.25 NETWORK LAYER
|
||||||
|
@ -3049,8 +3060,9 @@ S: Maintained
|
||||||
F: arch/riscv/net/
|
F: arch/riscv/net/
|
||||||
|
|
||||||
BPF JIT for S390
|
BPF JIT for S390
|
||||||
M: Martin Schwidefsky <schwidefsky@de.ibm.com>
|
|
||||||
M: Heiko Carstens <heiko.carstens@de.ibm.com>
|
M: Heiko Carstens <heiko.carstens@de.ibm.com>
|
||||||
|
M: Vasily Gorbik <gor@linux.ibm.com>
|
||||||
|
M: Christian Borntraeger <borntraeger@de.ibm.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
L: bpf@vger.kernel.org
|
L: bpf@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
@ -3109,7 +3121,8 @@ F: arch/arm/mach-bcm/
|
||||||
|
|
||||||
BROADCOM BCM2835 ARM ARCHITECTURE
|
BROADCOM BCM2835 ARM ARCHITECTURE
|
||||||
M: Eric Anholt <eric@anholt.net>
|
M: Eric Anholt <eric@anholt.net>
|
||||||
M: Stefan Wahren <stefan.wahren@i2se.com>
|
M: Stefan Wahren <wahrenst@gmx.net>
|
||||||
|
L: bcm-kernel-feedback-list@broadcom.com
|
||||||
L: linux-rpi-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-rpi-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
T: git git://github.com/anholt/linux
|
T: git git://github.com/anholt/linux
|
||||||
|
@ -3139,6 +3152,7 @@ F: arch/arm/boot/dts/bcm953012*
|
||||||
|
|
||||||
BROADCOM BCM53573 ARM ARCHITECTURE
|
BROADCOM BCM53573 ARM ARCHITECTURE
|
||||||
M: Rafał Miłecki <rafal@milecki.pl>
|
M: Rafał Miłecki <rafal@milecki.pl>
|
||||||
|
L: bcm-kernel-feedback-list@broadcom.com
|
||||||
L: linux-arm-kernel@lists.infradead.org
|
L: linux-arm-kernel@lists.infradead.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: arch/arm/boot/dts/bcm53573*
|
F: arch/arm/boot/dts/bcm53573*
|
||||||
|
@ -3915,19 +3929,32 @@ W: https://github.com/CirrusLogic/linux-drivers/wiki
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/devicetree/bindings/mfd/madera.txt
|
F: Documentation/devicetree/bindings/mfd/madera.txt
|
||||||
F: Documentation/devicetree/bindings/pinctrl/cirrus,madera-pinctrl.txt
|
F: Documentation/devicetree/bindings/pinctrl/cirrus,madera-pinctrl.txt
|
||||||
|
F: Documentation/devicetree/bindings/sound/madera.txt
|
||||||
|
F: include/dt-bindings/sound/madera*
|
||||||
F: include/linux/irqchip/irq-madera*
|
F: include/linux/irqchip/irq-madera*
|
||||||
F: include/linux/mfd/madera/*
|
F: include/linux/mfd/madera/*
|
||||||
|
F: include/sound/madera*
|
||||||
F: drivers/gpio/gpio-madera*
|
F: drivers/gpio/gpio-madera*
|
||||||
F: drivers/irqchip/irq-madera*
|
F: drivers/irqchip/irq-madera*
|
||||||
F: drivers/mfd/madera*
|
F: drivers/mfd/madera*
|
||||||
F: drivers/mfd/cs47l*
|
F: drivers/mfd/cs47l*
|
||||||
F: drivers/pinctrl/cirrus/*
|
F: drivers/pinctrl/cirrus/*
|
||||||
|
F: sound/soc/codecs/cs47l*
|
||||||
|
F: sound/soc/codecs/madera*
|
||||||
|
|
||||||
CLANG-FORMAT FILE
|
CLANG-FORMAT FILE
|
||||||
M: Miguel Ojeda <miguel.ojeda.sandonis@gmail.com>
|
M: Miguel Ojeda <miguel.ojeda.sandonis@gmail.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: .clang-format
|
F: .clang-format
|
||||||
|
|
||||||
|
CLANG/LLVM BUILD SUPPORT
|
||||||
|
L: clang-built-linux@googlegroups.com
|
||||||
|
W: https://clangbuiltlinux.github.io/
|
||||||
|
B: https://github.com/ClangBuiltLinux/linux/issues
|
||||||
|
C: irc://chat.freenode.net/clangbuiltlinux
|
||||||
|
S: Supported
|
||||||
|
K: \b(?i:clang|llvm)\b
|
||||||
|
|
||||||
CLEANCACHE API
|
CLEANCACHE API
|
||||||
M: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
|
M: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
|
||||||
L: linux-kernel@vger.kernel.org
|
L: linux-kernel@vger.kernel.org
|
||||||
|
@ -6222,7 +6249,6 @@ F: include/linux/ipmi-fru.h
|
||||||
K: fmc_d.*register
|
K: fmc_d.*register
|
||||||
|
|
||||||
FPGA MANAGER FRAMEWORK
|
FPGA MANAGER FRAMEWORK
|
||||||
M: Alan Tull <atull@kernel.org>
|
|
||||||
M: Moritz Fischer <mdf@kernel.org>
|
M: Moritz Fischer <mdf@kernel.org>
|
||||||
L: linux-fpga@vger.kernel.org
|
L: linux-fpga@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
@ -7341,6 +7367,7 @@ I2C MV64XXX MARVELL AND ALLWINNER DRIVER
|
||||||
M: Gregory CLEMENT <gregory.clement@bootlin.com>
|
M: Gregory CLEMENT <gregory.clement@bootlin.com>
|
||||||
L: linux-i2c@vger.kernel.org
|
L: linux-i2c@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-mv64xxx.txt
|
||||||
F: drivers/i2c/busses/i2c-mv64xxx.c
|
F: drivers/i2c/busses/i2c-mv64xxx.c
|
||||||
|
|
||||||
I2C OVER PARALLEL PORT
|
I2C OVER PARALLEL PORT
|
||||||
|
@ -8553,7 +8580,7 @@ S: Odd Fixes
|
||||||
|
|
||||||
KERNEL NFSD, SUNRPC, AND LOCKD SERVERS
|
KERNEL NFSD, SUNRPC, AND LOCKD SERVERS
|
||||||
M: "J. Bruce Fields" <bfields@fieldses.org>
|
M: "J. Bruce Fields" <bfields@fieldses.org>
|
||||||
M: Jeff Layton <jlayton@kernel.org>
|
M: Chuck Lever <chuck.lever@oracle.com>
|
||||||
L: linux-nfs@vger.kernel.org
|
L: linux-nfs@vger.kernel.org
|
||||||
W: http://nfs.sourceforge.net/
|
W: http://nfs.sourceforge.net/
|
||||||
T: git git://linux-nfs.org/~bfields/linux.git
|
T: git git://linux-nfs.org/~bfields/linux.git
|
||||||
|
@ -8611,14 +8638,12 @@ F: arch/x86/include/asm/svm.h
|
||||||
F: arch/x86/kvm/svm.c
|
F: arch/x86/kvm/svm.c
|
||||||
|
|
||||||
KERNEL VIRTUAL MACHINE FOR ARM/ARM64 (KVM/arm, KVM/arm64)
|
KERNEL VIRTUAL MACHINE FOR ARM/ARM64 (KVM/arm, KVM/arm64)
|
||||||
M: Christoffer Dall <christoffer.dall@arm.com>
|
|
||||||
M: Marc Zyngier <marc.zyngier@arm.com>
|
M: Marc Zyngier <marc.zyngier@arm.com>
|
||||||
R: James Morse <james.morse@arm.com>
|
R: James Morse <james.morse@arm.com>
|
||||||
R: Julien Thierry <julien.thierry@arm.com>
|
R: Julien Thierry <julien.thierry@arm.com>
|
||||||
R: Suzuki K Pouloze <suzuki.poulose@arm.com>
|
R: Suzuki K Pouloze <suzuki.poulose@arm.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
L: kvmarm@lists.cs.columbia.edu
|
L: kvmarm@lists.cs.columbia.edu
|
||||||
W: http://systems.cs.columbia.edu/projects/kvm-arm
|
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: arch/arm/include/uapi/asm/kvm*
|
F: arch/arm/include/uapi/asm/kvm*
|
||||||
|
@ -9110,7 +9135,7 @@ F: drivers/misc/lkdtm/*
|
||||||
LINUX KERNEL MEMORY CONSISTENCY MODEL (LKMM)
|
LINUX KERNEL MEMORY CONSISTENCY MODEL (LKMM)
|
||||||
M: Alan Stern <stern@rowland.harvard.edu>
|
M: Alan Stern <stern@rowland.harvard.edu>
|
||||||
M: Andrea Parri <andrea.parri@amarulasolutions.com>
|
M: Andrea Parri <andrea.parri@amarulasolutions.com>
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
M: Peter Zijlstra <peterz@infradead.org>
|
M: Peter Zijlstra <peterz@infradead.org>
|
||||||
M: Boqun Feng <boqun.feng@gmail.com>
|
M: Boqun Feng <boqun.feng@gmail.com>
|
||||||
M: Nicholas Piggin <npiggin@gmail.com>
|
M: Nicholas Piggin <npiggin@gmail.com>
|
||||||
|
@ -9218,7 +9243,7 @@ F: Documentation/admin-guide/LSM/LoadPin.rst
|
||||||
LOCKING PRIMITIVES
|
LOCKING PRIMITIVES
|
||||||
M: Peter Zijlstra <peterz@infradead.org>
|
M: Peter Zijlstra <peterz@infradead.org>
|
||||||
M: Ingo Molnar <mingo@redhat.com>
|
M: Ingo Molnar <mingo@redhat.com>
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
L: linux-kernel@vger.kernel.org
|
L: linux-kernel@vger.kernel.org
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git locking/core
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git locking/core
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
@ -10539,7 +10564,7 @@ F: arch/arm/boot/dts/mmp*
|
||||||
F: arch/arm/mach-mmp/
|
F: arch/arm/mach-mmp/
|
||||||
|
|
||||||
MMU GATHER AND TLB INVALIDATION
|
MMU GATHER AND TLB INVALIDATION
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
M: "Aneesh Kumar K.V" <aneesh.kumar@linux.ibm.com>
|
M: "Aneesh Kumar K.V" <aneesh.kumar@linux.ibm.com>
|
||||||
M: Andrew Morton <akpm@linux-foundation.org>
|
M: Andrew Morton <akpm@linux-foundation.org>
|
||||||
M: Nick Piggin <npiggin@gmail.com>
|
M: Nick Piggin <npiggin@gmail.com>
|
||||||
|
@ -11068,10 +11093,8 @@ S: Supported
|
||||||
F: drivers/net/ethernet/qlogic/netxen/
|
F: drivers/net/ethernet/qlogic/netxen/
|
||||||
|
|
||||||
NFC SUBSYSTEM
|
NFC SUBSYSTEM
|
||||||
M: Samuel Ortiz <sameo@linux.intel.com>
|
L: netdev@vger.kernel.org
|
||||||
L: linux-wireless@vger.kernel.org
|
S: Orphan
|
||||||
L: linux-nfc@lists.01.org (subscribers-only)
|
|
||||||
S: Supported
|
|
||||||
F: net/nfc/
|
F: net/nfc/
|
||||||
F: include/net/nfc/
|
F: include/net/nfc/
|
||||||
F: include/uapi/linux/nfc.h
|
F: include/uapi/linux/nfc.h
|
||||||
|
@ -11228,7 +11251,7 @@ F: drivers/video/fbdev/riva/
|
||||||
F: drivers/video/fbdev/nvidia/
|
F: drivers/video/fbdev/nvidia/
|
||||||
|
|
||||||
NVM EXPRESS DRIVER
|
NVM EXPRESS DRIVER
|
||||||
M: Keith Busch <keith.busch@intel.com>
|
M: Keith Busch <kbusch@kernel.org>
|
||||||
M: Jens Axboe <axboe@fb.com>
|
M: Jens Axboe <axboe@fb.com>
|
||||||
M: Christoph Hellwig <hch@lst.de>
|
M: Christoph Hellwig <hch@lst.de>
|
||||||
M: Sagi Grimberg <sagi@grimberg.me>
|
M: Sagi Grimberg <sagi@grimberg.me>
|
||||||
|
@ -11728,6 +11751,7 @@ M: Peter Korsgaard <peter@korsgaard.com>
|
||||||
M: Andrew Lunn <andrew@lunn.ch>
|
M: Andrew Lunn <andrew@lunn.ch>
|
||||||
L: linux-i2c@vger.kernel.org
|
L: linux-i2c@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-ocores.txt
|
||||||
F: Documentation/i2c/busses/i2c-ocores
|
F: Documentation/i2c/busses/i2c-ocores
|
||||||
F: drivers/i2c/busses/i2c-ocores.c
|
F: drivers/i2c/busses/i2c-ocores.c
|
||||||
F: include/linux/platform_data/i2c-ocores.h
|
F: include/linux/platform_data/i2c-ocores.h
|
||||||
|
@ -12029,7 +12053,7 @@ S: Maintained
|
||||||
F: drivers/pci/controller/dwc/*layerscape*
|
F: drivers/pci/controller/dwc/*layerscape*
|
||||||
|
|
||||||
PCI DRIVER FOR GENERIC OF HOSTS
|
PCI DRIVER FOR GENERIC OF HOSTS
|
||||||
M: Will Deacon <will.deacon@arm.com>
|
M: Will Deacon <will@kernel.org>
|
||||||
L: linux-pci@vger.kernel.org
|
L: linux-pci@vger.kernel.org
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
@ -13047,7 +13071,6 @@ F: Documentation/devicetree/bindings/net/qcom,dwmac.txt
|
||||||
|
|
||||||
QUALCOMM GENERIC INTERFACE I2C DRIVER
|
QUALCOMM GENERIC INTERFACE I2C DRIVER
|
||||||
M: Alok Chauhan <alokc@codeaurora.org>
|
M: Alok Chauhan <alokc@codeaurora.org>
|
||||||
M: Karthikeyan Ramasubramanian <kramasub@codeaurora.org>
|
|
||||||
L: linux-i2c@vger.kernel.org
|
L: linux-i2c@vger.kernel.org
|
||||||
L: linux-arm-msm@vger.kernel.org
|
L: linux-arm-msm@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
|
@ -13367,6 +13390,7 @@ F: drivers/clk/renesas/
|
||||||
RENESAS EMEV2 I2C DRIVER
|
RENESAS EMEV2 I2C DRIVER
|
||||||
M: Wolfram Sang <wsa+renesas@sang-engineering.com>
|
M: Wolfram Sang <wsa+renesas@sang-engineering.com>
|
||||||
S: Supported
|
S: Supported
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-emev2.txt
|
||||||
F: drivers/i2c/busses/i2c-emev2.c
|
F: drivers/i2c/busses/i2c-emev2.c
|
||||||
|
|
||||||
RENESAS ETHERNET DRIVERS
|
RENESAS ETHERNET DRIVERS
|
||||||
|
@ -13388,6 +13412,8 @@ F: drivers/iio/adc/rcar-gyroadc.c
|
||||||
RENESAS R-CAR I2C DRIVERS
|
RENESAS R-CAR I2C DRIVERS
|
||||||
M: Wolfram Sang <wsa+renesas@sang-engineering.com>
|
M: Wolfram Sang <wsa+renesas@sang-engineering.com>
|
||||||
S: Supported
|
S: Supported
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-rcar.txt
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-sh_mobile.txt
|
||||||
F: drivers/i2c/busses/i2c-rcar.c
|
F: drivers/i2c/busses/i2c-rcar.c
|
||||||
F: drivers/i2c/busses/i2c-sh_mobile.c
|
F: drivers/i2c/busses/i2c-sh_mobile.c
|
||||||
|
|
||||||
|
@ -13618,8 +13644,9 @@ S: Maintained
|
||||||
F: drivers/video/fbdev/savage/
|
F: drivers/video/fbdev/savage/
|
||||||
|
|
||||||
S390
|
S390
|
||||||
M: Martin Schwidefsky <schwidefsky@de.ibm.com>
|
|
||||||
M: Heiko Carstens <heiko.carstens@de.ibm.com>
|
M: Heiko Carstens <heiko.carstens@de.ibm.com>
|
||||||
|
M: Vasily Gorbik <gor@linux.ibm.com>
|
||||||
|
M: Christian Borntraeger <borntraeger@de.ibm.com>
|
||||||
L: linux-s390@vger.kernel.org
|
L: linux-s390@vger.kernel.org
|
||||||
W: http://www.ibm.com/developerworks/linux/linux390/
|
W: http://www.ibm.com/developerworks/linux/linux390/
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux.git
|
||||||
|
@ -14322,6 +14349,15 @@ S: Supported
|
||||||
K: sifive
|
K: sifive
|
||||||
N: sifive
|
N: sifive
|
||||||
|
|
||||||
|
SIFIVE FU540 SYSTEM-ON-CHIP
|
||||||
|
M: Paul Walmsley <paul.walmsley@sifive.com>
|
||||||
|
M: Palmer Dabbelt <palmer@sifive.com>
|
||||||
|
L: linux-riscv@lists.infradead.org
|
||||||
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/pjw/sifive.git
|
||||||
|
S: Supported
|
||||||
|
K: fu540
|
||||||
|
N: fu540
|
||||||
|
|
||||||
SILEAD TOUCHSCREEN DRIVER
|
SILEAD TOUCHSCREEN DRIVER
|
||||||
M: Hans de Goede <hdegoede@redhat.com>
|
M: Hans de Goede <hdegoede@redhat.com>
|
||||||
L: linux-input@vger.kernel.org
|
L: linux-input@vger.kernel.org
|
||||||
|
@ -14353,7 +14389,7 @@ SIMPLEFB FB DRIVER
|
||||||
M: Hans de Goede <hdegoede@redhat.com>
|
M: Hans de Goede <hdegoede@redhat.com>
|
||||||
L: linux-fbdev@vger.kernel.org
|
L: linux-fbdev@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/devicetree/bindings/display/simple-framebuffer.txt
|
F: Documentation/devicetree/bindings/display/simple-framebuffer.yaml
|
||||||
F: drivers/video/fbdev/simplefb.c
|
F: drivers/video/fbdev/simplefb.c
|
||||||
F: include/linux/platform_data/simplefb.h
|
F: include/linux/platform_data/simplefb.h
|
||||||
|
|
||||||
|
@ -14382,7 +14418,7 @@ F: lib/test_siphash.c
|
||||||
F: include/linux/siphash.h
|
F: include/linux/siphash.h
|
||||||
|
|
||||||
SIOX
|
SIOX
|
||||||
M: Gavin Schenk <g.schenk@eckelmann.de>
|
M: Thorsten Scherer <t.scherer@eckelmann.de>
|
||||||
M: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
M: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
|
||||||
R: Pengutronix Kernel Team <kernel@pengutronix.de>
|
R: Pengutronix Kernel Team <kernel@pengutronix.de>
|
||||||
S: Supported
|
S: Supported
|
||||||
|
@ -14981,7 +15017,7 @@ S: Odd Fixes
|
||||||
F: drivers/net/ethernet/adaptec/starfire*
|
F: drivers/net/ethernet/adaptec/starfire*
|
||||||
|
|
||||||
STEC S1220 SKD DRIVER
|
STEC S1220 SKD DRIVER
|
||||||
M: Bart Van Assche <bart.vanassche@wdc.com>
|
M: Damien Le Moal <Damien.LeMoal@wdc.com>
|
||||||
L: linux-block@vger.kernel.org
|
L: linux-block@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/block/skd*[ch]
|
F: drivers/block/skd*[ch]
|
||||||
|
@ -15676,6 +15712,7 @@ R: Bartosz Golaszewski <bgolaszewski@baylibre.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/nsekhar/linux-davinci.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/nsekhar/linux-davinci.git
|
||||||
S: Supported
|
S: Supported
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-davinci.txt
|
||||||
F: arch/arm/mach-davinci/
|
F: arch/arm/mach-davinci/
|
||||||
F: drivers/i2c/busses/i2c-davinci.c
|
F: drivers/i2c/busses/i2c-davinci.c
|
||||||
F: arch/arm/boot/dts/da850*
|
F: arch/arm/boot/dts/da850*
|
||||||
|
@ -17297,7 +17334,7 @@ F: Documentation/ABI/stable/sysfs-hypervisor-xen
|
||||||
F: Documentation/ABI/testing/sysfs-hypervisor-xen
|
F: Documentation/ABI/testing/sysfs-hypervisor-xen
|
||||||
|
|
||||||
XEN NETWORK BACKEND DRIVER
|
XEN NETWORK BACKEND DRIVER
|
||||||
M: Wei Liu <wei.liu2@citrix.com>
|
M: Wei Liu <wei.liu@kernel.org>
|
||||||
M: Paul Durrant <paul.durrant@citrix.com>
|
M: Paul Durrant <paul.durrant@citrix.com>
|
||||||
L: xen-devel@lists.xenproject.org (moderated for non-subscribers)
|
L: xen-devel@lists.xenproject.org (moderated for non-subscribers)
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
|
@ -17379,6 +17416,7 @@ M: Jan Glauber <jglauber@cavium.com>
|
||||||
L: linux-i2c@vger.kernel.org
|
L: linux-i2c@vger.kernel.org
|
||||||
W: http://www.cavium.com
|
W: http://www.cavium.com
|
||||||
S: Supported
|
S: Supported
|
||||||
|
F: Documentation/devicetree/bindings/i2c/i2c-xlp9xx.txt
|
||||||
F: drivers/i2c/busses/i2c-xlp9xx.c
|
F: drivers/i2c/busses/i2c-xlp9xx.c
|
||||||
|
|
||||||
XRA1403 GPIO EXPANDER
|
XRA1403 GPIO EXPANDER
|
||||||
|
|
9
Makefile
9
Makefile
|
@ -2,8 +2,8 @@
|
||||||
VERSION = 5
|
VERSION = 5
|
||||||
PATCHLEVEL = 2
|
PATCHLEVEL = 2
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc1
|
EXTRAVERSION = -rc7
|
||||||
NAME = Shy Crocodile
|
NAME = Bobtail Squid
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
# To see a list of typical targets execute "make help"
|
# To see a list of typical targets execute "make help"
|
||||||
|
@ -1228,9 +1228,8 @@ kselftest-clean:
|
||||||
PHONY += kselftest-merge
|
PHONY += kselftest-merge
|
||||||
kselftest-merge:
|
kselftest-merge:
|
||||||
$(if $(wildcard $(objtree)/.config),, $(error No .config exists, config your kernel first!))
|
$(if $(wildcard $(objtree)/.config),, $(error No .config exists, config your kernel first!))
|
||||||
$(Q)$(CONFIG_SHELL) $(srctree)/scripts/kconfig/merge_config.sh \
|
$(Q)find $(srctree)/tools/testing/selftests -name config | \
|
||||||
-m $(objtree)/.config \
|
xargs $(srctree)/scripts/kconfig/merge_config.sh -m $(objtree)/.config
|
||||||
$(srctree)/tools/testing/selftests/*/config
|
|
||||||
+$(Q)$(MAKE) -f $(srctree)/Makefile olddefconfig
|
+$(Q)$(MAKE) -f $(srctree)/Makefile olddefconfig
|
||||||
|
|
||||||
# ---------------------------------------------------------------------------
|
# ---------------------------------------------------------------------------
|
||||||
|
|
|
@ -1,10 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
/*
|
/*
|
||||||
* Copyright (C) Paul Mackerras 1997.
|
* Copyright (C) Paul Mackerras 1997.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version
|
|
||||||
* 2 of the License, or (at your option) any later version.
|
|
||||||
*/
|
*/
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Arch specific extensions to struct device
|
* Arch specific extensions to struct device
|
||||||
*
|
|
||||||
* This file is released under the GPLv2
|
|
||||||
*/
|
*/
|
||||||
#include <asm-generic/device.h>
|
#include <asm-generic/device.h>
|
||||||
|
|
||||||
|
|
|
@ -1,16 +1,8 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
/*
|
/*
|
||||||
* include/asm-alpha/xor.h
|
* include/asm-alpha/xor.h
|
||||||
*
|
*
|
||||||
* Optimized RAID-5 checksumming functions for alpha EV5 and EV6
|
* Optimized RAID-5 checksumming functions for alpha EV5 and EV6
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
* any later version.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* (for example /usr/src/linux/COPYING); if not, write to the Free
|
|
||||||
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
extern void xor_alpha_2(unsigned long, unsigned long *, unsigned long *);
|
extern void xor_alpha_2(unsigned long, unsigned long *, unsigned long *);
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
generated-y += unistd_32.h
|
generated-y += unistd_32.h
|
||||||
|
|
|
@ -1,19 +1,7 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
/* Kernel module help for Alpha.
|
/* Kernel module help for Alpha.
|
||||||
Copyright (C) 2002 Richard Henderson.
|
Copyright (C) 2002 Richard Henderson.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation; either version 2 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
|
||||||
along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
*/
|
||||||
#include <linux/moduleloader.h>
|
#include <linux/moduleloader.h>
|
||||||
#include <linux/elf.h>
|
#include <linux/elf.h>
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* srm_env.c - Access to SRM environment
|
* srm_env.c - Access to SRM environment
|
||||||
* variables through linux' procfs
|
* variables through linux' procfs
|
||||||
|
@ -9,23 +10,6 @@
|
||||||
* <J.A.K.Mouw@its.tudelft.nl>. It is based on an idea
|
* <J.A.K.Mouw@its.tudelft.nl>. It is based on an idea
|
||||||
* provided by DEC^WCompaq^WIntel's "Jumpstart" CD. They
|
* provided by DEC^WCompaq^WIntel's "Jumpstart" CD. They
|
||||||
* included a patch like this as well. Thanks for idea!
|
* included a patch like this as well. Thanks for idea!
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute
|
|
||||||
* it and/or modify it under the terms of the GNU General
|
|
||||||
* Public License version 2 as published by the Free Software
|
|
||||||
* Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be
|
|
||||||
* useful, but WITHOUT ANY WARRANTY; without even the implied
|
|
||||||
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
||||||
* PURPOSE. See the GNU General Public License for more
|
|
||||||
* details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public
|
|
||||||
* License along with this program; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place,
|
|
||||||
* Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
#
|
#
|
||||||
# Makefile for the FPU instruction emulation.
|
# Makefile for the FPU instruction emulation.
|
||||||
#
|
#
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
#
|
#
|
||||||
# Makefile for the linux alpha-specific parts of the memory manager.
|
# Makefile for the linux alpha-specific parts of the memory manager.
|
||||||
#
|
#
|
||||||
|
|
|
@ -1,2 +1,3 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
obj-y += kernel/
|
obj-y += kernel/
|
||||||
obj-y += mm/
|
obj-y += mm/
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
#
|
#
|
||||||
# Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
|
# Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License version 2 as
|
|
||||||
# published by the Free Software Foundation.
|
|
||||||
#
|
|
||||||
|
|
||||||
config ARC
|
config ARC
|
||||||
def_bool y
|
def_bool y
|
||||||
|
|
|
@ -1,13 +1,14 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
#
|
#
|
||||||
# Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
|
# Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License version 2 as
|
|
||||||
# published by the Free Software Foundation.
|
|
||||||
#
|
|
||||||
|
|
||||||
KBUILD_DEFCONFIG := nsim_hs_defconfig
|
KBUILD_DEFCONFIG := nsim_hs_defconfig
|
||||||
|
|
||||||
|
ifeq ($(CROSS_COMPILE),)
|
||||||
|
CROSS_COMPILE := $(call cc-cross-prefix, arc-linux- arceb-linux-)
|
||||||
|
endif
|
||||||
|
|
||||||
cflags-y += -fno-common -pipe -fno-builtin -mmedium-calls -D__linux__
|
cflags-y += -fno-common -pipe -fno-builtin -mmedium-calls -D__linux__
|
||||||
cflags-$(CONFIG_ISA_ARCOMPACT) += -mA7
|
cflags-$(CONFIG_ISA_ARCOMPACT) += -mA7
|
||||||
cflags-$(CONFIG_ISA_ARCV2) += -mcpu=hs38
|
cflags-$(CONFIG_ISA_ARCV2) += -mcpu=hs38
|
||||||
|
|
|
@ -1,22 +1,10 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Abilis Systems TB100 SOC device tree
|
* Abilis Systems TB100 SOC device tree
|
||||||
*
|
*
|
||||||
* Copyright (C) Abilis Systems 2013
|
* Copyright (C) Abilis Systems 2013
|
||||||
*
|
*
|
||||||
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/include/ "abilis_tb10x.dtsi"
|
/include/ "abilis_tb10x.dtsi"
|
||||||
|
|
|
@ -1,22 +1,10 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Abilis Systems TB100 Development Kit PCB device tree
|
* Abilis Systems TB100 Development Kit PCB device tree
|
||||||
*
|
*
|
||||||
* Copyright (C) Abilis Systems 2013
|
* Copyright (C) Abilis Systems 2013
|
||||||
*
|
*
|
||||||
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
|
@ -1,22 +1,10 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Abilis Systems TB101 SOC device tree
|
* Abilis Systems TB101 SOC device tree
|
||||||
*
|
*
|
||||||
* Copyright (C) Abilis Systems 2013
|
* Copyright (C) Abilis Systems 2013
|
||||||
*
|
*
|
||||||
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/include/ "abilis_tb10x.dtsi"
|
/include/ "abilis_tb10x.dtsi"
|
||||||
|
|
|
@ -1,22 +1,10 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Abilis Systems TB101 Development Kit PCB device tree
|
* Abilis Systems TB101 Development Kit PCB device tree
|
||||||
*
|
*
|
||||||
* Copyright (C) Abilis Systems 2013
|
* Copyright (C) Abilis Systems 2013
|
||||||
*
|
*
|
||||||
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
* Author: Christian Ruppert <christian.ruppert@abilis.com>
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Add table
Add a link
Reference in a new issue