Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next
Resolve conflict betweenalistair/sunxi64-5.4-dsid2912cb15b
("treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 500") removing the GPL disclaimer andfe03d47456
("Update my email address") which updates Jozsef Kadlecsik's email. Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
commit
1c5ba67d22
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,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.
|
||||||
|
|
|
@ -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
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -16,6 +16,8 @@ Required properties:
|
||||||
Optional properties:
|
Optional properties:
|
||||||
|
|
||||||
- reset-gpios : Should be a gpio specifier for a reset line
|
- reset-gpios : Should be a gpio specifier for a reset line
|
||||||
|
- microchip,synclko-125 : Set if the output SYNCLKO frequency should be set to
|
||||||
|
125MHz instead of 25MHz.
|
||||||
|
|
||||||
See Documentation/devicetree/bindings/net/dsa/dsa.txt for a list of additional
|
See Documentation/devicetree/bindings/net/dsa/dsa.txt for a list of additional
|
||||||
required and optional properties.
|
required and optional properties.
|
||||||
|
|
|
@ -104,6 +104,23 @@ Required properties:
|
||||||
- 10Gb mac<->mac forced mode : 11
|
- 10Gb mac<->mac forced mode : 11
|
||||||
----phy-handle: phandle to PHY device
|
----phy-handle: phandle to PHY device
|
||||||
|
|
||||||
|
- cpts: sub-node time synchronization (CPTS) submodule configuration
|
||||||
|
-- clocks: CPTS reference clock. Should point on cpts-refclk-mux clock.
|
||||||
|
-- clock-names: should be "cpts"
|
||||||
|
-- cpts-refclk-mux: multiplexer clock definition sub-node for CPTS reference (RFTCLK) clock
|
||||||
|
--- #clock-cells: should be 0
|
||||||
|
--- clocks: list of CPTS reference (RFTCLK) clock's parents as defined in Data manual
|
||||||
|
--- ti,mux-tbl: array of multiplexer indexes as defined in Data manual
|
||||||
|
--- assigned-clocks: should point on cpts-refclk-mux clock
|
||||||
|
--- assigned-clock-parents: should point on required RFTCLK clock parent to be selected
|
||||||
|
-- cpts_clock_mult: (optional) Numerator to convert input clock ticks
|
||||||
|
into nanoseconds
|
||||||
|
-- cpts_clock_shift: (optional) Denominator to convert input clock ticks into
|
||||||
|
nanoseconds.
|
||||||
|
Mult and shift will be calculated basing on CPTS
|
||||||
|
rftclk frequency if both cpts_clock_shift and
|
||||||
|
cpts_clock_mult properties are not provided.
|
||||||
|
|
||||||
Optional properties:
|
Optional properties:
|
||||||
- enable-ale: NetCP driver keeps the address learning feature in the ethernet
|
- enable-ale: NetCP driver keeps the address learning feature in the ethernet
|
||||||
switch module disabled. This attribute is to enable the address
|
switch module disabled. This attribute is to enable the address
|
||||||
|
@ -168,6 +185,23 @@ netcp: netcp@2000000 {
|
||||||
tx-queue = <648>;
|
tx-queue = <648>;
|
||||||
tx-channel = <8>;
|
tx-channel = <8>;
|
||||||
|
|
||||||
|
cpts {
|
||||||
|
clocks = <&cpts_refclk_mux>;
|
||||||
|
clock-names = "cpts";
|
||||||
|
|
||||||
|
cpts_refclk_mux: cpts-refclk-mux {
|
||||||
|
#clock-cells = <0>;
|
||||||
|
clocks = <&chipclk12>, <&chipclk13>,
|
||||||
|
<&timi0>, <&timi1>,
|
||||||
|
<&tsipclka>, <&tsrefclk>,
|
||||||
|
<&tsipclkb>;
|
||||||
|
ti,mux-tbl = <0x0>, <0x1>, <0x2>,
|
||||||
|
<0x3>, <0x4>, <0x8>, <0xC>;
|
||||||
|
assigned-clocks = <&cpts_refclk_mux>;
|
||||||
|
assigned-clock-parents = <&chipclk12>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
interfaces {
|
interfaces {
|
||||||
gbe0: interface-0 {
|
gbe0: interface-0 {
|
||||||
slave-port = <0>;
|
slave-port = <0>;
|
||||||
|
@ -219,3 +253,13 @@ netcp: netcp@2000000 {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
CPTS board configuration - select external CPTS RFTCLK:
|
||||||
|
|
||||||
|
&tsrefclk{
|
||||||
|
clock-frequency = <500000000>;
|
||||||
|
};
|
||||||
|
|
||||||
|
&cpts_refclk_mux {
|
||||||
|
assigned-clock-parents = <&tsrefclk>;
|
||||||
|
};
|
||||||
|
|
|
@ -15,8 +15,11 @@ Required properties:
|
||||||
Use "atmel,sama5d4-gem" for the GEM IP (10/100) available on Atmel sama5d4 SoCs.
|
Use "atmel,sama5d4-gem" for the GEM IP (10/100) available on Atmel sama5d4 SoCs.
|
||||||
Use "cdns,zynq-gem" Xilinx Zynq-7xxx SoC.
|
Use "cdns,zynq-gem" Xilinx Zynq-7xxx SoC.
|
||||||
Use "cdns,zynqmp-gem" for Zynq Ultrascale+ MPSoC.
|
Use "cdns,zynqmp-gem" for Zynq Ultrascale+ MPSoC.
|
||||||
|
Use "sifive,fu540-macb" for SiFive FU540-C000 SoC.
|
||||||
Or the generic form: "cdns,emac".
|
Or the generic form: "cdns,emac".
|
||||||
- reg: Address and length of the register set for the device
|
- reg: Address and length of the register set for the device
|
||||||
|
For "sifive,fu540-macb", second range is required to specify the
|
||||||
|
address and length of the registers for GEMGXL Management block.
|
||||||
- interrupts: Should contain macb interrupt
|
- interrupts: Should contain macb interrupt
|
||||||
- phy-mode: See ethernet.txt file in the same directory.
|
- phy-mode: See ethernet.txt file in the same directory.
|
||||||
- clock-names: Tuple listing input clock names.
|
- clock-names: Tuple listing input clock names.
|
||||||
|
|
|
@ -6,11 +6,17 @@ present in Documentation/devicetree/bindings/net/stmmac.txt.
|
||||||
The device node has additional properties:
|
The device node has additional properties:
|
||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
- compatible : Should contain "altr,socfpga-stmmac" along with
|
- compatible : For Cyclone5/Arria5 SoCs it should contain
|
||||||
"snps,dwmac" and any applicable more detailed
|
"altr,socfpga-stmmac". For Arria10/Agilex/Stratix10 SoCs
|
||||||
|
"altr,socfpga-stmmac-a10-s10".
|
||||||
|
Along with "snps,dwmac" and any applicable more detailed
|
||||||
designware version numbers documented in stmmac.txt
|
designware version numbers documented in stmmac.txt
|
||||||
- altr,sysmgr-syscon : Should be the phandle to the system manager node that
|
- altr,sysmgr-syscon : Should be the phandle to the system manager node that
|
||||||
encompasses the glue register, the register offset, and the register shift.
|
encompasses the glue register, the register offset, and the register shift.
|
||||||
|
On Cyclone5/Arria5, the register shift represents the PHY mode bits, while
|
||||||
|
on the Arria10/Stratix10/Agilex platforms, the register shift represents
|
||||||
|
bit for each emac to enable/disable signals from the FPGA fabric to the
|
||||||
|
EMAC modules.
|
||||||
- altr,f2h_ptp_ref_clk use f2h_ptp_ref_clk instead of default eosc1 clock
|
- altr,f2h_ptp_ref_clk use f2h_ptp_ref_clk instead of default eosc1 clock
|
||||||
for ptp ref clk. This affects all emacs as the clock is common.
|
for ptp ref clk. This affects all emacs as the clock is common.
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
* Wiznet w5x00
|
||||||
|
|
||||||
|
This is a standalone 10/100 MBit Ethernet controller with SPI interface.
|
||||||
|
|
||||||
|
For each device connected to a SPI bus, define a child node within
|
||||||
|
the SPI master node.
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: Should be one of the following strings:
|
||||||
|
"wiznet,w5100"
|
||||||
|
"wiznet,w5200"
|
||||||
|
"wiznet,w5500"
|
||||||
|
- reg: Specify the SPI chip select the chip is wired to.
|
||||||
|
- interrupts: Specify the interrupt index within the interrupt controller (referred
|
||||||
|
to above in interrupt-parent) and interrupt type. w5x00 natively
|
||||||
|
generates falling edge interrupts, however, additional board logic
|
||||||
|
might invert the signal.
|
||||||
|
- pinctrl-names: List of assigned state names, see pinctrl binding documentation.
|
||||||
|
- pinctrl-0: List of phandles to configure the GPIO pin used as interrupt line,
|
||||||
|
see also generic and your platform specific pinctrl binding
|
||||||
|
documentation.
|
||||||
|
|
||||||
|
Optional properties:
|
||||||
|
- spi-max-frequency: Maximum frequency of the SPI bus when accessing the w5500.
|
||||||
|
According to the w5500 datasheet, the chip allows a maximum of 80 MHz, however,
|
||||||
|
board designs may need to limit this value.
|
||||||
|
- local-mac-address: See ethernet.txt in the same directory.
|
||||||
|
|
||||||
|
|
||||||
|
Example (for Raspberry Pi with pin control stuff for GPIO irq):
|
||||||
|
|
||||||
|
&spi {
|
||||||
|
ethernet@0: w5500@0 {
|
||||||
|
compatible = "wiznet,w5500";
|
||||||
|
reg = <0>;
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <ð1_pins>;
|
||||||
|
interrupt-parent = <&gpio>;
|
||||||
|
interrupts = <25 IRQ_TYPE_EDGE_FALLING>;
|
||||||
|
spi-max-frequency = <30000000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpio {
|
||||||
|
eth1_pins: eth1_pins {
|
||||||
|
brcm,pins = <25>;
|
||||||
|
brcm,function = <0>; /* in */
|
||||||
|
brcm,pull = <0>; /* none */
|
||||||
|
};
|
||||||
|
};
|
|
@ -17,8 +17,15 @@ For more details about mdio please refer phy.txt file in the same directory.
|
||||||
Required properties:
|
Required properties:
|
||||||
- compatible : Must be one of "xlnx,axi-ethernet-1.00.a",
|
- compatible : Must be one of "xlnx,axi-ethernet-1.00.a",
|
||||||
"xlnx,axi-ethernet-1.01.a", "xlnx,axi-ethernet-2.01.a"
|
"xlnx,axi-ethernet-1.01.a", "xlnx,axi-ethernet-2.01.a"
|
||||||
- reg : Address and length of the IO space.
|
- reg : Address and length of the IO space, as well as the address
|
||||||
- interrupts : Should be a list of two interrupt, TX and RX.
|
and length of the AXI DMA controller IO space, unless
|
||||||
|
axistream-connected is specified, in which case the reg
|
||||||
|
attribute of the node referenced by it is used.
|
||||||
|
- interrupts : Should be a list of 2 or 3 interrupts: TX DMA, RX DMA,
|
||||||
|
and optionally Ethernet core. If axistream-connected is
|
||||||
|
specified, the TX/RX DMA interrupts should be on that node
|
||||||
|
instead, and only the Ethernet core interrupt is optionally
|
||||||
|
specified here.
|
||||||
- phy-handle : Should point to the external phy device.
|
- phy-handle : Should point to the external phy device.
|
||||||
See ethernet.txt file in the same directory.
|
See ethernet.txt file in the same directory.
|
||||||
- xlnx,rxmem : Set to allocated memory buffer for Rx/Tx in the hardware
|
- xlnx,rxmem : Set to allocated memory buffer for Rx/Tx in the hardware
|
||||||
|
@ -31,15 +38,29 @@ Optional properties:
|
||||||
1 to enable partial TX checksum offload,
|
1 to enable partial TX checksum offload,
|
||||||
2 to enable full TX checksum offload
|
2 to enable full TX checksum offload
|
||||||
- xlnx,rxcsum : Same values as xlnx,txcsum but for RX checksum offload
|
- xlnx,rxcsum : Same values as xlnx,txcsum but for RX checksum offload
|
||||||
|
- clocks : AXI bus clock for the device. Refer to common clock bindings.
|
||||||
|
Used to calculate MDIO clock divisor. If not specified, it is
|
||||||
|
auto-detected from the CPU clock (but only on platforms where
|
||||||
|
this is possible). New device trees should specify this - the
|
||||||
|
auto detection is only for backward compatibility.
|
||||||
|
- axistream-connected: Reference to another node which contains the resources
|
||||||
|
for the AXI DMA controller used by this device.
|
||||||
|
If this is specified, the DMA-related resources from that
|
||||||
|
device (DMA registers and DMA TX/RX interrupts) rather
|
||||||
|
than this one will be used.
|
||||||
|
- mdio : Child node for MDIO bus. Must be defined if PHY access is
|
||||||
|
required through the core's MDIO interface (i.e. always,
|
||||||
|
unless the PHY is accessed through a different bus).
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
axi_ethernet_eth: ethernet@40c00000 {
|
axi_ethernet_eth: ethernet@40c00000 {
|
||||||
compatible = "xlnx,axi-ethernet-1.00.a";
|
compatible = "xlnx,axi-ethernet-1.00.a";
|
||||||
device_type = "network";
|
device_type = "network";
|
||||||
interrupt-parent = <µblaze_0_axi_intc>;
|
interrupt-parent = <µblaze_0_axi_intc>;
|
||||||
interrupts = <2 0>;
|
interrupts = <2 0 1>;
|
||||||
|
clocks = <&axi_clk>;
|
||||||
phy-mode = "mii";
|
phy-mode = "mii";
|
||||||
reg = <0x40c00000 0x40000>;
|
reg = <0x40c00000 0x40000 0x50c00000 0x40000>;
|
||||||
xlnx,rxcsum = <0x2>;
|
xlnx,rxcsum = <0x2>;
|
||||||
xlnx,rxmem = <0x800>;
|
xlnx,rxmem = <0x800>;
|
||||||
xlnx,txcsum = <0x2>;
|
xlnx,txcsum = <0x2>;
|
||||||
|
|
|
@ -4,7 +4,8 @@ General Properties:
|
||||||
|
|
||||||
- compatible Should be "fsl,etsec-ptp" for eTSEC
|
- compatible Should be "fsl,etsec-ptp" for eTSEC
|
||||||
Should be "fsl,fman-ptp-timer" for DPAA FMan
|
Should be "fsl,fman-ptp-timer" for DPAA FMan
|
||||||
Should be "fsl,enetc-ptp" for ENETC
|
Should be "fsl,dpaa2-ptp" for DPAA2
|
||||||
|
Should be "fsl,enetc-ptp" for ENETC
|
||||||
- reg Offset and length of the register set for the device
|
- reg Offset and length of the register set for the device
|
||||||
- interrupts There should be at least two interrupts. Some devices
|
- interrupts There should be at least two interrupts. Some devices
|
||||||
have as many as four PTP related interrupts.
|
have as many as four PTP related interrupts.
|
||||||
|
|
|
@ -0,0 +1,168 @@
|
||||||
|
# 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 {
|
||||||
|
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";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
...
|
|
@ -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
|
||||||
|
...
|
|
@ -226,9 +226,6 @@ TBD
|
||||||
.. kernel-doc:: include/net/mac80211.h
|
.. kernel-doc:: include/net/mac80211.h
|
||||||
:functions: ieee80211_tx_rate_control
|
:functions: ieee80211_tx_rate_control
|
||||||
|
|
||||||
.. kernel-doc:: include/net/mac80211.h
|
|
||||||
:functions: rate_control_send_low
|
|
||||||
|
|
||||||
TBD
|
TBD
|
||||||
|
|
||||||
This part of the book describes mac80211 internals.
|
This part of the book describes mac80211 internals.
|
||||||
|
|
|
@ -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"
|
||||||
|
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -21,6 +21,7 @@ Contents:
|
||||||
intel/i40e
|
intel/i40e
|
||||||
intel/iavf
|
intel/iavf
|
||||||
intel/ice
|
intel/ice
|
||||||
|
mellanox/mlx5
|
||||||
|
|
||||||
.. only:: subproject
|
.. only:: subproject
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,173 @@
|
||||||
|
.. SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB
|
||||||
|
|
||||||
|
=================================================
|
||||||
|
Mellanox ConnectX(R) mlx5 core VPI Network Driver
|
||||||
|
=================================================
|
||||||
|
|
||||||
|
Copyright (c) 2019, Mellanox Technologies LTD.
|
||||||
|
|
||||||
|
Contents
|
||||||
|
========
|
||||||
|
|
||||||
|
- `Enabling the driver and kconfig options`_
|
||||||
|
- `Devlink health reporters`_
|
||||||
|
|
||||||
|
Enabling the driver and kconfig options
|
||||||
|
================================================
|
||||||
|
|
||||||
|
| mlx5 core is modular and most of the major mlx5 core driver features can be selected (compiled in/out)
|
||||||
|
| at build time via kernel Kconfig flags.
|
||||||
|
| Basic features, ethernet net device rx/tx offloads and XDP, are available with the most basic flags
|
||||||
|
| CONFIG_MLX5_CORE=y/m and CONFIG_MLX5_CORE_EN=y.
|
||||||
|
| For the list of advanced features please see below.
|
||||||
|
|
||||||
|
**CONFIG_MLX5_CORE=(y/m/n)** (module mlx5_core.ko)
|
||||||
|
|
||||||
|
| The driver can be enabled by choosing CONFIG_MLX5_CORE=y/m in kernel config.
|
||||||
|
| This will provide mlx5 core driver for mlx5 ulps to interface with (mlx5e, mlx5_ib).
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_CORE_EN=(y/n)**
|
||||||
|
|
||||||
|
| Choosing this option will allow basic ethernet netdevice support with all of the standard rx/tx offloads.
|
||||||
|
| mlx5e is the mlx5 ulp driver which provides netdevice kernel interface, when chosen, mlx5e will be
|
||||||
|
| built-in into mlx5_core.ko.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_EN_ARFS=(y/n)**
|
||||||
|
|
||||||
|
| Enables Hardware-accelerated receive flow steering (arfs) support, and ntuple filtering.
|
||||||
|
| https://community.mellanox.com/s/article/howto-configure-arfs-on-connectx-4
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_EN_RXNFC=(y/n)**
|
||||||
|
|
||||||
|
| Enables ethtool receive network flow classification, which allows user defined
|
||||||
|
| flow rules to direct traffic into arbitrary rx queue via ethtool set/get_rxnfc API.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_CORE_EN_DCB=(y/n)**:
|
||||||
|
|
||||||
|
| Enables `Data Center Bridging (DCB) Support <https://community.mellanox.com/s/article/howto-auto-config-pfc-and-ets-on-connectx-4-via-lldp-dcbx>`_.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_MPFS=(y/n)**
|
||||||
|
|
||||||
|
| Ethernet Multi-Physical Function Switch (MPFS) support in ConnectX NIC.
|
||||||
|
| MPFs is required for when `Multi-Host <http://www.mellanox.com/page/multihost>`_ configuration is enabled to allow passing
|
||||||
|
| user configured unicast MAC addresses to the requesting PF.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_ESWITCH=(y/n)**
|
||||||
|
|
||||||
|
| Ethernet SRIOV E-Switch support in ConnectX NIC. E-Switch provides internal SRIOV packet steering
|
||||||
|
| and switching for the enabled VFs and PF in two available modes:
|
||||||
|
| 1) `Legacy SRIOV mode (L2 mac vlan steering based) <https://community.mellanox.com/s/article/howto-configure-sr-iov-for-connectx-4-connectx-5-with-kvm--ethernet-x>`_.
|
||||||
|
| 2) `Switchdev mode (eswitch offloads) <https://www.mellanox.com/related-docs/prod_software/ASAP2_Hardware_Offloading_for_vSwitches_User_Manual_v4.4.pdf>`_.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_CORE_IPOIB=(y/n)**
|
||||||
|
|
||||||
|
| IPoIB offloads & acceleration support.
|
||||||
|
| Requires CONFIG_MLX5_CORE_EN to provide an accelerated interface for the rdma
|
||||||
|
| IPoIB ulp netdevice.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_FPGA=(y/n)**
|
||||||
|
|
||||||
|
| Build support for the Innova family of network cards by Mellanox Technologies.
|
||||||
|
| Innova network cards are comprised of a ConnectX chip and an FPGA chip on one board.
|
||||||
|
| If you select this option, the mlx5_core driver will include the Innova FPGA core and allow
|
||||||
|
| building sandbox-specific client drivers.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_EN_IPSEC=(y/n)**
|
||||||
|
|
||||||
|
| Enables `IPSec XFRM cryptography-offload accelaration <http://www.mellanox.com/related-docs/prod_software/Mellanox_Innova_IPsec_Ethernet_Adapter_Card_User_Manual.pdf>`_.
|
||||||
|
|
||||||
|
**CONFIG_MLX5_EN_TLS=(y/n)**
|
||||||
|
|
||||||
|
| TLS cryptography-offload accelaration.
|
||||||
|
|
||||||
|
|
||||||
|
**CONFIG_MLX5_INFINIBAND=(y/n/m)** (module mlx5_ib.ko)
|
||||||
|
|
||||||
|
| Provides low-level InfiniBand/RDMA and `RoCE <https://community.mellanox.com/s/article/recommended-network-configuration-examples-for-roce-deployment>`_ support.
|
||||||
|
|
||||||
|
|
||||||
|
**External options** ( Choose if the corresponding mlx5 feature is required )
|
||||||
|
|
||||||
|
- CONFIG_PTP_1588_CLOCK: When chosen, mlx5 ptp support will be enabled
|
||||||
|
- CONFIG_VXLAN: When chosen, mlx5 vxaln support will be enabled.
|
||||||
|
- CONFIG_MLXFW: When chosen, mlx5 firmware flashing support will be enabled (via devlink and ethtool).
|
||||||
|
|
||||||
|
|
||||||
|
Devlink health reporters
|
||||||
|
========================
|
||||||
|
|
||||||
|
tx reporter
|
||||||
|
-----------
|
||||||
|
The tx reporter is responsible of two error scenarios:
|
||||||
|
|
||||||
|
- TX timeout
|
||||||
|
Report on kernel tx timeout detection.
|
||||||
|
Recover by searching lost interrupts.
|
||||||
|
- TX error completion
|
||||||
|
Report on error tx completion.
|
||||||
|
Recover by flushing the TX queue and reset it.
|
||||||
|
|
||||||
|
TX reporter also support Diagnose callback, on which it provides
|
||||||
|
real time information of its send queues status.
|
||||||
|
|
||||||
|
User commands examples:
|
||||||
|
|
||||||
|
- Diagnose send queues status::
|
||||||
|
|
||||||
|
$ devlink health diagnose pci/0000:82:00.0 reporter tx
|
||||||
|
|
||||||
|
- Show number of tx errors indicated, number of recover flows ended successfully,
|
||||||
|
is autorecover enabled and graceful period from last recover::
|
||||||
|
|
||||||
|
$ devlink health show pci/0000:82:00.0 reporter tx
|
||||||
|
|
||||||
|
fw reporter
|
||||||
|
-----------
|
||||||
|
The fw reporter implements diagnose and dump callbacks.
|
||||||
|
It follows symptoms of fw error such as fw syndrome by triggering
|
||||||
|
fw core dump and storing it into the dump buffer.
|
||||||
|
The fw reporter diagnose command can be triggered any time by the user to check
|
||||||
|
current fw status.
|
||||||
|
|
||||||
|
User commands examples:
|
||||||
|
|
||||||
|
- Check fw heath status::
|
||||||
|
|
||||||
|
$ devlink health diagnose pci/0000:82:00.0 reporter fw
|
||||||
|
|
||||||
|
- Read FW core dump if already stored or trigger new one::
|
||||||
|
|
||||||
|
$ devlink health dump show pci/0000:82:00.0 reporter fw
|
||||||
|
|
||||||
|
NOTE: This command can run only on the PF which has fw tracer ownership,
|
||||||
|
running it on other PF or any VF will return "Operation not permitted".
|
||||||
|
|
||||||
|
fw fatal reporter
|
||||||
|
-----------------
|
||||||
|
The fw fatal reporter implements dump and recover callbacks.
|
||||||
|
It follows fatal errors indications by CR-space dump and recover flow.
|
||||||
|
The CR-space dump uses vsc interface which is valid even if the FW command
|
||||||
|
interface is not functional, which is the case in most FW fatal errors.
|
||||||
|
The recover function runs recover flow which reloads the driver and triggers fw
|
||||||
|
reset if needed.
|
||||||
|
|
||||||
|
User commands examples:
|
||||||
|
|
||||||
|
- Run fw recover flow manually::
|
||||||
|
|
||||||
|
$ devlink health recover pci/0000:82:00.0 reporter fw_fatal
|
||||||
|
|
||||||
|
- Read FW CR-space dump if already strored or trigger new one::
|
||||||
|
|
||||||
|
$ devlink health dump show pci/0000:82:00.1 reporter fw_fatal
|
||||||
|
|
||||||
|
NOTE: This command can run only on PF.
|
|
@ -80,6 +80,7 @@ fib_multipath_hash_policy - INTEGER
|
||||||
Possible values:
|
Possible values:
|
||||||
0 - Layer 3
|
0 - Layer 3
|
||||||
1 - Layer 4
|
1 - Layer 4
|
||||||
|
2 - Layer 3 or inner Layer 3 if present
|
||||||
|
|
||||||
fib_sync_mem - UNSIGNED INTEGER
|
fib_sync_mem - UNSIGNED INTEGER
|
||||||
Amount of dirty memory from fib entries that can be backlogged before
|
Amount of dirty memory from fib entries that can be backlogged before
|
||||||
|
@ -255,6 +256,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
|
||||||
|
@ -792,6 +801,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
|
||||||
|
@ -1429,14 +1446,24 @@ flowlabel_state_ranges - BOOLEAN
|
||||||
FALSE: disabled
|
FALSE: disabled
|
||||||
Default: true
|
Default: true
|
||||||
|
|
||||||
flowlabel_reflect - BOOLEAN
|
flowlabel_reflect - INTEGER
|
||||||
Automatically reflect the flow label. Needed for Path MTU
|
Control flow label reflection. Needed for Path MTU
|
||||||
Discovery to work with Equal Cost Multipath Routing in anycast
|
Discovery to work with Equal Cost Multipath Routing in anycast
|
||||||
environments. See RFC 7690 and:
|
environments. See RFC 7690 and:
|
||||||
https://tools.ietf.org/html/draft-wang-6man-flow-label-reflection-01
|
https://tools.ietf.org/html/draft-wang-6man-flow-label-reflection-01
|
||||||
TRUE: enabled
|
|
||||||
FALSE: disabled
|
This is a mask of two bits.
|
||||||
Default: FALSE
|
1: enabled for established flows
|
||||||
|
|
||||||
|
Note that this prevents automatic flowlabel changes, as done
|
||||||
|
in "tcp: change IPv6 flow-label upon receiving spurious retransmission"
|
||||||
|
and "tcp: Change txhash on every SYN and RTO retransmit"
|
||||||
|
|
||||||
|
2: enabled for TCP RESET packets (no active listener)
|
||||||
|
If set, a RST packet sent in response to a SYN packet on a closed
|
||||||
|
port will reflect the incoming flow label.
|
||||||
|
|
||||||
|
Default: 0
|
||||||
|
|
||||||
fib_multipath_hash_policy - INTEGER
|
fib_multipath_hash_policy - INTEGER
|
||||||
Controls which hash policy to use for multipath routes.
|
Controls which hash policy to use for multipath routes.
|
||||||
|
|
|
@ -202,7 +202,8 @@ the PHY/controller, of which the PHY needs to be aware.
|
||||||
|
|
||||||
*interface* is a u32 which specifies the connection type used
|
*interface* is a u32 which specifies the connection type used
|
||||||
between the controller and the PHY. Examples are GMII, MII,
|
between the controller and the PHY. Examples are GMII, MII,
|
||||||
RGMII, and SGMII. For a full list, see include/linux/phy.h
|
RGMII, and SGMII. See "PHY interface mode" below. For a full
|
||||||
|
list, see include/linux/phy.h
|
||||||
|
|
||||||
Now just make sure that phydev->supported and phydev->advertising have any
|
Now just make sure that phydev->supported and phydev->advertising have any
|
||||||
values pruned from them which don't make sense for your controller (a 10/100
|
values pruned from them which don't make sense for your controller (a 10/100
|
||||||
|
@ -225,6 +226,48 @@ When you want to disconnect from the network (even if just briefly), you call
|
||||||
phy_stop(phydev). This function also stops the phylib state machine and
|
phy_stop(phydev). This function also stops the phylib state machine and
|
||||||
disables PHY interrupts.
|
disables PHY interrupts.
|
||||||
|
|
||||||
|
PHY interface modes
|
||||||
|
===================
|
||||||
|
|
||||||
|
The PHY interface mode supplied in the phy_connect() family of functions
|
||||||
|
defines the initial operating mode of the PHY interface. This is not
|
||||||
|
guaranteed to remain constant; there are PHYs which dynamically change
|
||||||
|
their interface mode without software interaction depending on the
|
||||||
|
negotiation results.
|
||||||
|
|
||||||
|
Some of the interface modes are described below:
|
||||||
|
|
||||||
|
``PHY_INTERFACE_MODE_1000BASEX``
|
||||||
|
This defines the 1000BASE-X single-lane serdes link as defined by the
|
||||||
|
802.3 standard section 36. The link operates at a fixed bit rate of
|
||||||
|
1.25Gbaud using a 10B/8B encoding scheme, resulting in an underlying
|
||||||
|
data rate of 1Gbps. Embedded in the data stream is a 16-bit control
|
||||||
|
word which is used to negotiate the duplex and pause modes with the
|
||||||
|
remote end. This does not include "up-clocked" variants such as 2.5Gbps
|
||||||
|
speeds (see below.)
|
||||||
|
|
||||||
|
``PHY_INTERFACE_MODE_2500BASEX``
|
||||||
|
This defines a variant of 1000BASE-X which is clocked 2.5 times faster,
|
||||||
|
than the 802.3 standard giving a fixed bit rate of 3.125Gbaud.
|
||||||
|
|
||||||
|
``PHY_INTERFACE_MODE_SGMII``
|
||||||
|
This is used for Cisco SGMII, which is a modification of 1000BASE-X
|
||||||
|
as defined by the 802.3 standard. The SGMII link consists of a single
|
||||||
|
serdes lane running at a fixed bit rate of 1.25Gbaud with 10B/8B
|
||||||
|
encoding. The underlying data rate is 1Gbps, with the slower speeds of
|
||||||
|
100Mbps and 10Mbps being achieved through replication of each data symbol.
|
||||||
|
The 802.3 control word is re-purposed to send the negotiated speed and
|
||||||
|
duplex information from to the MAC, and for the MAC to acknowledge
|
||||||
|
receipt. This does not include "up-clocked" variants such as 2.5Gbps
|
||||||
|
speeds.
|
||||||
|
|
||||||
|
Note: mismatched SGMII vs 1000BASE-X configuration on a link can
|
||||||
|
successfully pass data in some circumstances, but the 16-bit control
|
||||||
|
word will not be correctly interpreted, which may cause mismatches in
|
||||||
|
duplex, pause or other settings. This is dependent on the MAC and/or
|
||||||
|
PHY behaviour.
|
||||||
|
|
||||||
|
|
||||||
Pause frames / flow control
|
Pause frames / flow control
|
||||||
===========================
|
===========================
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -206,7 +206,11 @@ TX
|
||||||
|
|
||||||
Segments transmitted from an offloaded socket can get out of sync
|
Segments transmitted from an offloaded socket can get out of sync
|
||||||
in similar ways to the receive side-retransmissions - local drops
|
in similar ways to the receive side-retransmissions - local drops
|
||||||
are possible, though network reorders are not.
|
are possible, though network reorders are not. There are currently
|
||||||
|
two mechanisms for dealing with out of order segments.
|
||||||
|
|
||||||
|
Crypto state rebuilding
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Whenever an out of order segment is transmitted the driver provides
|
Whenever an out of order segment is transmitted the driver provides
|
||||||
the device with enough information to perform cryptographic operations.
|
the device with enough information to perform cryptographic operations.
|
||||||
|
@ -225,6 +229,35 @@ was just a retransmission. The former is simpler, and does not require
|
||||||
retransmission detection therefore it is the recommended method until
|
retransmission detection therefore it is the recommended method until
|
||||||
such time it is proven inefficient.
|
such time it is proven inefficient.
|
||||||
|
|
||||||
|
Next record sync
|
||||||
|
~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Whenever an out of order segment is detected the driver requests
|
||||||
|
that the ``ktls`` software fallback code encrypt it. If the segment's
|
||||||
|
sequence number is lower than expected the driver assumes retransmission
|
||||||
|
and doesn't change device state. If the segment is in the future, it
|
||||||
|
may imply a local drop, the driver asks the stack to sync the device
|
||||||
|
to the next record state and falls back to software.
|
||||||
|
|
||||||
|
Resync request is indicated with:
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
|
void tls_offload_tx_resync_request(struct sock *sk, u32 got_seq, u32 exp_seq)
|
||||||
|
|
||||||
|
Until resync is complete driver should not access its expected TCP
|
||||||
|
sequence number (as it will be updated from a different context).
|
||||||
|
Following helper should be used to test if resync is complete:
|
||||||
|
|
||||||
|
.. code-block:: c
|
||||||
|
|
||||||
|
bool tls_offload_tx_resync_pending(struct sock *sk)
|
||||||
|
|
||||||
|
Next time ``ktls`` pushes a record it will first send its TCP sequence number
|
||||||
|
and TLS record number to the driver. Stack will also make sure that
|
||||||
|
the new record will start on a segment boundary (like it does when
|
||||||
|
the connection is initially added).
|
||||||
|
|
||||||
RX
|
RX
|
||||||
--
|
--
|
||||||
|
|
||||||
|
@ -268,6 +301,9 @@ 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
|
if it knows the length of the previous record from segment 2. In this case
|
||||||
the device will lose synchronization with the stream.
|
the device will lose synchronization with the stream.
|
||||||
|
|
||||||
|
Stream scan resynchronization
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
When the device gets out of sync and the stream reaches TCP sequence
|
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,
|
numbers more than a max size record past the expected TCP sequence number,
|
||||||
the device starts scanning for a known header pattern. For example
|
the device starts scanning for a known header pattern. For example
|
||||||
|
@ -298,6 +334,22 @@ Special care has to be taken if the confirmation request is passed
|
||||||
asynchronously to the packet stream and record may get processed
|
asynchronously to the packet stream and record may get processed
|
||||||
by the kernel before the confirmation request.
|
by the kernel before the confirmation request.
|
||||||
|
|
||||||
|
Stack-driven resynchronization
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The driver may also request the stack to perform resynchronization
|
||||||
|
whenever it sees the records are no longer getting decrypted.
|
||||||
|
If the connection is configured in this mode the stack automatically
|
||||||
|
schedules resynchronization after it has received two completely encrypted
|
||||||
|
records.
|
||||||
|
|
||||||
|
The stack waits for the socket to drain and informs the device about
|
||||||
|
the next expected record number and its TCP sequence number. If the
|
||||||
|
records continue to be received fully encrypted stack retries the
|
||||||
|
synchronization with an exponential back off (first after 2 encrypted
|
||||||
|
records, then after 4 records, after 8, after 16... up until every
|
||||||
|
128 records).
|
||||||
|
|
||||||
Error handling
|
Error handling
|
||||||
==============
|
==============
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
75
MAINTAINERS
75
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)
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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,7 @@ 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: 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
|
||||||
|
@ -4910,13 +4922,6 @@ L: linux-kernel@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/staging/fsl-dpaa2/ethsw
|
F: drivers/staging/fsl-dpaa2/ethsw
|
||||||
|
|
||||||
DPAA2 PTP CLOCK DRIVER
|
|
||||||
M: Yangbo Lu <yangbo.lu@nxp.com>
|
|
||||||
L: netdev@vger.kernel.org
|
|
||||||
S: Maintained
|
|
||||||
F: drivers/net/ethernet/freescale/dpaa2/dpaa2-ptp*
|
|
||||||
F: drivers/net/ethernet/freescale/dpaa2/dprtc*
|
|
||||||
|
|
||||||
DPT_I2O SCSI RAID DRIVER
|
DPT_I2O SCSI RAID DRIVER
|
||||||
M: Adaptec OEM Raid Solutions <aacraid@microsemi.com>
|
M: Adaptec OEM Raid Solutions <aacraid@microsemi.com>
|
||||||
L: linux-scsi@vger.kernel.org
|
L: linux-scsi@vger.kernel.org
|
||||||
|
@ -6222,7 +6227,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
|
||||||
|
@ -6359,6 +6363,8 @@ FREESCALE QORIQ PTP CLOCK DRIVER
|
||||||
M: Yangbo Lu <yangbo.lu@nxp.com>
|
M: Yangbo Lu <yangbo.lu@nxp.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: drivers/net/ethernet/freescale/dpaa2/dpaa2-ptp*
|
||||||
|
F: drivers/net/ethernet/freescale/dpaa2/dprtc*
|
||||||
F: drivers/net/ethernet/freescale/enetc/enetc_ptp.c
|
F: drivers/net/ethernet/freescale/enetc/enetc_ptp.c
|
||||||
F: drivers/ptp/ptp_qoriq.c
|
F: drivers/ptp/ptp_qoriq.c
|
||||||
F: drivers/ptp/ptp_qoriq_debugfs.c
|
F: drivers/ptp/ptp_qoriq_debugfs.c
|
||||||
|
@ -7339,6 +7345,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
|
||||||
|
@ -8559,7 +8566,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
|
||||||
|
@ -9114,7 +9121,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>
|
||||||
|
@ -9222,7 +9229,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
|
||||||
|
@ -10095,6 +10102,7 @@ Q: http://patchwork.ozlabs.org/project/netdev/list/
|
||||||
S: Supported
|
S: Supported
|
||||||
F: drivers/net/ethernet/mellanox/mlx5/core/
|
F: drivers/net/ethernet/mellanox/mlx5/core/
|
||||||
F: include/linux/mlx5/
|
F: include/linux/mlx5/
|
||||||
|
F: Documentation/networking/device_drivers/mellanox/
|
||||||
|
|
||||||
MELLANOX MLX5 IB driver
|
MELLANOX MLX5 IB driver
|
||||||
M: Leon Romanovsky <leonro@mellanox.com>
|
M: Leon Romanovsky <leonro@mellanox.com>
|
||||||
|
@ -10543,7 +10551,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>
|
||||||
|
@ -11739,6 +11747,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
|
||||||
|
@ -12040,7 +12049,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
|
||||||
|
@ -13058,7 +13067,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
|
||||||
|
@ -13378,6 +13386,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
|
||||||
|
@ -13399,6 +13408,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
|
||||||
|
|
||||||
|
@ -13629,8 +13640,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
|
||||||
|
@ -14333,6 +14345,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
|
||||||
|
@ -14393,7 +14414,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
|
||||||
|
@ -14992,7 +15013,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]
|
||||||
|
@ -15687,6 +15708,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*
|
||||||
|
@ -17308,7 +17330,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
|
||||||
|
@ -17390,6 +17412,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
|
||||||
|
|
7
Makefile
7
Makefile
|
@ -2,7 +2,7 @@
|
||||||
VERSION = 5
|
VERSION = 5
|
||||||
PATCHLEVEL = 2
|
PATCHLEVEL = 2
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc2
|
EXTRAVERSION = -rc5
|
||||||
NAME = Golden Lions
|
NAME = Golden Lions
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -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 +1,2 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
generated-y += unistd_32.h
|
generated-y += unistd_32.h
|
||||||
|
|
|
@ -122,6 +122,8 @@
|
||||||
#define SO_RCVTIMEO_NEW 66
|
#define SO_RCVTIMEO_NEW 66
|
||||||
#define SO_SNDTIMEO_NEW 67
|
#define SO_SNDTIMEO_NEW 67
|
||||||
|
|
||||||
|
#define SO_DETACH_REUSEPORT_BPF 68
|
||||||
|
|
||||||
#if !defined(__KERNEL__)
|
#if !defined(__KERNEL__)
|
||||||
|
|
||||||
#if __BITS_PER_LONG == 64
|
#if __BITS_PER_LONG == 64
|
||||||
|
|
|
@ -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,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,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.
|
|
||||||
#
|
|
||||||
|
|
||||||
KBUILD_DEFCONFIG := nsim_hs_defconfig
|
KBUILD_DEFCONFIG := nsim_hs_defconfig
|
||||||
|
|
||||||
|
|
|
@ -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/;
|
||||||
|
|
|
@ -1,22 +1,10 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Abilis Systems TB10X SOC device tree
|
* Abilis Systems TB10X 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
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014, 2015 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014, 2015 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013-15 Synopsys, Inc. (www.synopsys.com)
|
||||||
*
|
*
|
||||||
* ARC AXS101 S/W development platform
|
* ARC AXS101 S/W development platform
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Support for peripherals on the AXS10x mainboard
|
* Support for peripherals on the AXS10x mainboard
|
||||||
*
|
*
|
||||||
* Copyright (C) 2013-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
|
|
|
@ -1,17 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright(c) 2015 EZchip Technologies.
|
* Copyright(c) 2015 EZchip Technologies.
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms and conditions of the GNU General Public License,
|
|
||||||
* version 2, as published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope 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.
|
|
||||||
*
|
|
||||||
* The full GNU General Public License is included in this distribution in
|
|
||||||
* the file called "COPYING".
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016-2014 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2016-2014 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016-2014 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2016-2014 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2017 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -11,7 +8,6 @@
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
#include <dt-bindings/net/ti-dp83867.h>
|
|
||||||
#include <dt-bindings/reset/snps,hsdk-reset.h>
|
#include <dt-bindings/reset/snps,hsdk-reset.h>
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
|
@ -167,6 +163,24 @@
|
||||||
#clock-cells = <0>;
|
#clock-cells = <0>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
gpu_core_clk: gpu-core-clk {
|
||||||
|
compatible = "fixed-clock";
|
||||||
|
clock-frequency = <400000000>;
|
||||||
|
#clock-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
gpu_dma_clk: gpu-dma-clk {
|
||||||
|
compatible = "fixed-clock";
|
||||||
|
clock-frequency = <400000000>;
|
||||||
|
#clock-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
|
gpu_cfg_clk: gpu-cfg-clk {
|
||||||
|
compatible = "fixed-clock";
|
||||||
|
clock-frequency = <200000000>;
|
||||||
|
#clock-cells = <0>;
|
||||||
|
};
|
||||||
|
|
||||||
dmac_core_clk: dmac-core-clk {
|
dmac_core_clk: dmac-core-clk {
|
||||||
compatible = "fixed-clock";
|
compatible = "fixed-clock";
|
||||||
clock-frequency = <400000000>;
|
clock-frequency = <400000000>;
|
||||||
|
@ -187,6 +201,7 @@
|
||||||
interrupt-names = "macirq";
|
interrupt-names = "macirq";
|
||||||
phy-mode = "rgmii";
|
phy-mode = "rgmii";
|
||||||
snps,pbl = <32>;
|
snps,pbl = <32>;
|
||||||
|
snps,multicast-filter-bins = <256>;
|
||||||
clocks = <&gmacclk>;
|
clocks = <&gmacclk>;
|
||||||
clock-names = "stmmaceth";
|
clock-names = "stmmaceth";
|
||||||
phy-handle = <&phy0>;
|
phy-handle = <&phy0>;
|
||||||
|
@ -195,15 +210,15 @@
|
||||||
mac-address = [00 00 00 00 00 00]; /* Filled in by U-Boot */
|
mac-address = [00 00 00 00 00 00]; /* Filled in by U-Boot */
|
||||||
dma-coherent;
|
dma-coherent;
|
||||||
|
|
||||||
|
tx-fifo-depth = <4096>;
|
||||||
|
rx-fifo-depth = <4096>;
|
||||||
|
|
||||||
mdio {
|
mdio {
|
||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
compatible = "snps,dwmac-mdio";
|
compatible = "snps,dwmac-mdio";
|
||||||
phy0: ethernet-phy@0 {
|
phy0: ethernet-phy@0 {
|
||||||
reg = <0>;
|
reg = <0>;
|
||||||
ti,rx-internal-delay = <DP83867_RGMIIDCTL_2_00_NS>;
|
|
||||||
ti,tx-internal-delay = <DP83867_RGMIIDCTL_2_00_NS>;
|
|
||||||
ti,fifo-depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -237,6 +252,14 @@
|
||||||
dma-coherent;
|
dma-coherent;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
creg_gpio: gpio@14b0 {
|
||||||
|
compatible = "snps,creg-gpio-hsdk";
|
||||||
|
reg = <0x14b0 0x4>;
|
||||||
|
gpio-controller;
|
||||||
|
#gpio-cells = <2>;
|
||||||
|
ngpios = <2>;
|
||||||
|
};
|
||||||
|
|
||||||
gpio: gpio@3000 {
|
gpio: gpio@3000 {
|
||||||
compatible = "snps,dw-apb-gpio";
|
compatible = "snps,dw-apb-gpio";
|
||||||
reg = <0x3000 0x20>;
|
reg = <0x3000 0x20>;
|
||||||
|
@ -252,6 +275,17 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
gpu_3d: gpu@90000 {
|
||||||
|
compatible = "vivante,gc";
|
||||||
|
reg = <0x90000 0x4000>;
|
||||||
|
clocks = <&gpu_dma_clk>,
|
||||||
|
<&gpu_cfg_clk>,
|
||||||
|
<&gpu_core_clk>,
|
||||||
|
<&gpu_core_clk>;
|
||||||
|
clock-names = "bus", "reg", "core", "shader";
|
||||||
|
interrupts = <28>;
|
||||||
|
};
|
||||||
|
|
||||||
dmac: dmac@80000 {
|
dmac: dmac@80000 {
|
||||||
compatible = "snps,axi-dma-1.01a";
|
compatible = "snps,axi-dma-1.01a";
|
||||||
reg = <0x80000 0x400>;
|
reg = <0x80000 0x400>;
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2012 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2012 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2016 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2016 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013, 2014 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013, 2014 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014, 2015 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014, 2015 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Support for peripherals on the AXS10x mainboard (VDK version)
|
* Support for peripherals on the AXS10x mainboard (VDK version)
|
||||||
*
|
*
|
||||||
* Copyright (C) 2013-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013 Synopsys, Inc. (www.synopsys.com)
|
||||||
*
|
*
|
||||||
* ARC HS38 Virtual Development Kit (VDK)
|
* ARC HS38 Virtual Development Kit (VDK)
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-only
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013 Synopsys, Inc. (www.synopsys.com)
|
||||||
*
|
*
|
||||||
* ARC HS38 Virtual Development Kit, SMP version (VDK)
|
* ARC HS38 Virtual Development Kit, SMP version (VDK)
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
*/
|
||||||
/dts-v1/;
|
/dts-v1/;
|
||||||
|
|
||||||
|
|
|
@ -49,10 +49,12 @@ CONFIG_SERIAL_OF_PLATFORM=y
|
||||||
CONFIG_GPIOLIB=y
|
CONFIG_GPIOLIB=y
|
||||||
CONFIG_GPIO_SYSFS=y
|
CONFIG_GPIO_SYSFS=y
|
||||||
CONFIG_GPIO_DWAPB=y
|
CONFIG_GPIO_DWAPB=y
|
||||||
|
CONFIG_GPIO_SNPS_CREG=y
|
||||||
# CONFIG_HWMON is not set
|
# CONFIG_HWMON is not set
|
||||||
CONFIG_DRM=y
|
CONFIG_DRM=y
|
||||||
# CONFIG_DRM_FBDEV_EMULATION is not set
|
# CONFIG_DRM_FBDEV_EMULATION is not set
|
||||||
CONFIG_DRM_UDL=y
|
CONFIG_DRM_UDL=y
|
||||||
|
CONFIG_DRM_ETNAVIV=y
|
||||||
CONFIG_FB=y
|
CONFIG_FB=y
|
||||||
CONFIG_FRAMEBUFFER_CONSOLE=y
|
CONFIG_FRAMEBUFFER_CONSOLE=y
|
||||||
CONFIG_USB_EHCI_HCD=y
|
CONFIG_USB_EHCI_HCD=y
|
||||||
|
@ -64,7 +66,6 @@ CONFIG_MMC=y
|
||||||
CONFIG_MMC_SDHCI=y
|
CONFIG_MMC_SDHCI=y
|
||||||
CONFIG_MMC_SDHCI_PLTFM=y
|
CONFIG_MMC_SDHCI_PLTFM=y
|
||||||
CONFIG_MMC_DW=y
|
CONFIG_MMC_DW=y
|
||||||
# CONFIG_IOMMU_SUPPORT is not set
|
|
||||||
CONFIG_EXT3_FS=y
|
CONFIG_EXT3_FS=y
|
||||||
CONFIG_VFAT_FS=y
|
CONFIG_VFAT_FS=y
|
||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_ARC_ARCREGS_H
|
#ifndef _ASM_ARC_ARCREGS_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <generated/asm-offsets.h>
|
#include <generated/asm-offsets.h>
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_ARC_ATOMIC_H
|
#ifndef _ASM_ARC_ATOMIC_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_BARRIER_H
|
#ifndef __ASM_BARRIER_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_BITOPS_H
|
#ifndef _ASM_BITOPS_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_ARC_BUG_H
|
#ifndef _ASM_ARC_BUG_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ARC_ASM_CACHE_H
|
#ifndef __ARC_ASM_CACHE_H
|
||||||
|
|
|
@ -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.
|
|
||||||
*
|
|
||||||
* vineetg: May 2011: for Non-aliasing VIPT D-cache following can be NOPs
|
* vineetg: May 2011: for Non-aliasing VIPT D-cache following can be NOPs
|
||||||
* -flush_cache_dup_mm (fork)
|
* -flush_cache_dup_mm (fork)
|
||||||
* -likewise for flush_cache_mm (exit/execve)
|
* -likewise for flush_cache_mm (exit/execve)
|
||||||
|
|
|
@ -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.
|
|
||||||
*
|
|
||||||
* Joern Rennecke <joern.rennecke@embecosm.com>: Jan 2012
|
* Joern Rennecke <joern.rennecke@embecosm.com>: Jan 2012
|
||||||
* -Insn Scheduling improvements to csum core routines.
|
* -Insn Scheduling improvements to csum core routines.
|
||||||
* = csum_fold( ) largely derived from ARM version.
|
* = csum_fold( ) largely derived from ARM version.
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_ARC_CMPXCHG_H
|
#ifndef __ASM_ARC_CMPXCHG_H
|
||||||
|
@ -92,8 +89,11 @@ __cmpxchg(volatile void *ptr, unsigned long expected, unsigned long new)
|
||||||
|
|
||||||
#endif /* CONFIG_ARC_HAS_LLSC */
|
#endif /* CONFIG_ARC_HAS_LLSC */
|
||||||
|
|
||||||
#define cmpxchg(ptr, o, n) ((typeof(*(ptr)))__cmpxchg((ptr), \
|
#define cmpxchg(ptr, o, n) ({ \
|
||||||
(unsigned long)(o), (unsigned long)(n)))
|
(typeof(*(ptr)))__cmpxchg((ptr), \
|
||||||
|
(unsigned long)(o), \
|
||||||
|
(unsigned long)(n)); \
|
||||||
|
})
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* atomic_cmpxchg is same as cmpxchg
|
* atomic_cmpxchg is same as cmpxchg
|
||||||
|
@ -198,8 +198,11 @@ static inline unsigned long __xchg(unsigned long val, volatile void *ptr,
|
||||||
return __xchg_bad_pointer();
|
return __xchg_bad_pointer();
|
||||||
}
|
}
|
||||||
|
|
||||||
#define xchg(ptr, with) ((typeof(*(ptr)))__xchg((unsigned long)(with), (ptr), \
|
#define xchg(ptr, with) ({ \
|
||||||
sizeof(*(ptr))))
|
(typeof(*(ptr)))__xchg((unsigned long)(with), \
|
||||||
|
(ptr), \
|
||||||
|
sizeof(*(ptr))); \
|
||||||
|
})
|
||||||
|
|
||||||
#endif /* CONFIG_ARC_PLAT_EZNPS */
|
#endif /* CONFIG_ARC_PLAT_EZNPS */
|
||||||
|
|
||||||
|
|
|
@ -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.
|
|
||||||
*
|
|
||||||
* Vineetg: May 16th, 2008
|
* Vineetg: May 16th, 2008
|
||||||
* - Current macro is now implemented as "global register" r25
|
* - Current macro is now implemented as "global register" r25
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -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.
|
|
||||||
*
|
|
||||||
* Delay routines using pre computed loops_per_jiffy value.
|
* Delay routines using pre computed loops_per_jiffy value.
|
||||||
*
|
*
|
||||||
* vineetg: Feb 2012
|
* vineetg: Feb 2012
|
||||||
|
|
|
@ -1,12 +1,9 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* several functions that help interpret ARC instructions
|
* several functions that help interpret ARC instructions
|
||||||
* used for unaligned accesses, kprobes and kgdb
|
* used for unaligned accesses, kprobes and kgdb
|
||||||
*
|
*
|
||||||
* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ARC_DISASM_H__
|
#ifndef __ARC_DISASM_H__
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef ASM_ARC_DMA_H
|
#ifndef ASM_ARC_DMA_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2016-17 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2016-17 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_ARC_DWARF_H
|
#ifndef _ASM_ARC_DWARF_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_ARC_ELF_H
|
#ifndef __ASM_ARC_ELF_H
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
||||||
* 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.
|
|
||||||
*
|
|
||||||
* Vineetg: March 2009 (Supporting 2 levels of Interrupts)
|
* Vineetg: March 2009 (Supporting 2 levels of Interrupts)
|
||||||
* Stack switching code can no longer reliably rely on the fact that
|
* Stack switching code can no longer reliably rely on the fact that
|
||||||
* if we are NOT in user mode, stack is switched to kernel mode.
|
* if we are NOT in user mode, stack is switched to kernel mode.
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
||||||
* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_ARC_ENTRY_H
|
#ifndef __ASM_ARC_ENTRY_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_ARC_EXEC_H
|
#ifndef __ASM_ARC_EXEC_H
|
||||||
|
|
|
@ -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.
|
|
||||||
*
|
|
||||||
* Vineetg: August 2010: From Android kernel work
|
* Vineetg: August 2010: From Android kernel work
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,6 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2015 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2015 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.
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_HIGHMEM_H
|
#ifndef _ASM_HIGHMEM_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2013-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _ASM_ARC_IO_H
|
#ifndef _ASM_ARC_IO_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_ARC_IRQ_H
|
#ifndef __ASM_ARC_IRQ_H
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
|
* Copyright (C) 2014-15 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.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ASM_IRQFLAGS_ARCV2_H
|
#ifndef __ASM_IRQFLAGS_ARCV2_H
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue