mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
Linux 6.4-rc5
-----BEGIN PGP SIGNATURE----- iQFSBAABCAA8FiEEq68RxlopcLEwq+PEeb4+QwBBGIYFAmR80iseHHRvcnZhbGRz QGxpbnV4LWZvdW5kYXRpb24ub3JnAAoJEHm+PkMAQRiGhxkH/2+2NEZjO5SCj9z6 FGrJunmXMOqoryoC3oL953Zhp3oeB/gB7GDdFQLg8tv0QprD6W0L9uorIgFi3lWU doGWKSjFVEdu6RoUV09bTwm1DislZKJF3NCwTyeb44c3HnTzUvd/zFrY29YNRi9C j5KXQIq91dke3qQi/3uCLFRKvmr2ss/lXapScwXFhQjaM2VmAMc51xIxkuRz3H01 EmcbJx3Rj9zPxx3Nc7ONMvtHE5+xuVsMdq3dLFCS9Xc/f+qbCCQdRIy9AjaRuR4c F5nRjwDjq0iv2diF0gK4WtD8fvxVuLaqS0RAi0jsOKVfLphLwkqkPQbbMd5K8qwJ xTNAiW0= =FwWR -----END PGP SIGNATURE----- Merge tag 'v6.4-rc5' into media_stage Linux 6.4-rc5 * tag 'v6.4-rc5': (919 commits) Linux 6.4-rc5 leds: qcom-lpg: Fix PWM period limits selftests/ftrace: Choose target function for filter test from samples KVM: selftests: Add test for race in kvm_recalculate_apic_map() KVM: x86: Bail from kvm_recalculate_phys_map() if x2APIC ID is out-of-bounds KVM: x86: Account fastpath-only VM-Exits in vCPU stats KVM: SVM: vNMI pending bit is V_NMI_PENDING_MASK not V_NMI_BLOCKING_MASK KVM: x86/mmu: Grab memslot for correct address space in NX recovery worker tpm, tpm_tis: correct tpm_tis_flags enumeration values Revert "ext4: remove ac->ac_found > sbi->s_mb_min_to_scan dead check in ext4_mb_check_limits" media: uvcvideo: Don't expose unsupported formats to userspace media: v4l2-subdev: Fix missing kerneldoc for client_caps media: staging: media: imx: initialize hs_settle to avoid warning media: v4l2-mc: Drop subdev check in v4l2_create_fwnode_links_to_pad() riscv: Implement missing huge_ptep_get riscv: Fix huge_ptep_set_wrprotect when PTE is a NAPOT module/decompress: Fix error checking on zstd decompression fork, vhost: Use CLONE_THREAD to fix freezer/ps regression dt-bindings: serial: 8250_omap: add rs485-rts-active-high selinux: don't use make's grouped targets feature yet ...
This commit is contained in:
commit
be9aac1874
5
.mailmap
5
.mailmap
@ -364,6 +364,11 @@ Nicolas Pitre <nico@fluxnic.net> <nico@linaro.org>
|
|||||||
Nicolas Saenz Julienne <nsaenz@kernel.org> <nsaenzjulienne@suse.de>
|
Nicolas Saenz Julienne <nsaenz@kernel.org> <nsaenzjulienne@suse.de>
|
||||||
Nicolas Saenz Julienne <nsaenz@kernel.org> <nsaenzjulienne@suse.com>
|
Nicolas Saenz Julienne <nsaenz@kernel.org> <nsaenzjulienne@suse.com>
|
||||||
Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
|
Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
|
||||||
|
Nikolay Aleksandrov <razor@blackwall.org> <naleksan@redhat.com>
|
||||||
|
Nikolay Aleksandrov <razor@blackwall.org> <nikolay@redhat.com>
|
||||||
|
Nikolay Aleksandrov <razor@blackwall.org> <nikolay@cumulusnetworks.com>
|
||||||
|
Nikolay Aleksandrov <razor@blackwall.org> <nikolay@nvidia.com>
|
||||||
|
Nikolay Aleksandrov <razor@blackwall.org> <nikolay@isovalent.com>
|
||||||
Oleksandr Natalenko <oleksandr@natalenko.name> <oleksandr@redhat.com>
|
Oleksandr Natalenko <oleksandr@natalenko.name> <oleksandr@redhat.com>
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <bug-track@fisher-privat.net>
|
Oleksij Rempel <linux@rempel-privat.de> <bug-track@fisher-privat.net>
|
||||||
Oleksij Rempel <linux@rempel-privat.de> <external.Oleksij.Rempel@de.bosch.com>
|
Oleksij Rempel <linux@rempel-privat.de> <external.Oleksij.Rempel@de.bosch.com>
|
||||||
|
4
CREDITS
4
CREDITS
@ -1706,6 +1706,10 @@ S: Panoramastrasse 18
|
|||||||
S: D-69126 Heidelberg
|
S: D-69126 Heidelberg
|
||||||
S: Germany
|
S: Germany
|
||||||
|
|
||||||
|
N: Neil Horman
|
||||||
|
M: nhorman@tuxdriver.com
|
||||||
|
D: SCTP protocol maintainer.
|
||||||
|
|
||||||
N: Simon Horman
|
N: Simon Horman
|
||||||
M: horms@verge.net.au
|
M: horms@verge.net.au
|
||||||
D: Renesas ARM/ARM64 SoC maintainer
|
D: Renesas ARM/ARM64 SoC maintainer
|
||||||
|
@ -5,5 +5,5 @@ Changes
|
|||||||
See https://wiki.samba.org/index.php/LinuxCIFSKernel for summary
|
See https://wiki.samba.org/index.php/LinuxCIFSKernel for summary
|
||||||
information about fixes/improvements to CIFS/SMB2/SMB3 support (changes
|
information about fixes/improvements to CIFS/SMB2/SMB3 support (changes
|
||||||
to cifs.ko module) by kernel version (and cifs internal module version).
|
to cifs.ko module) by kernel version (and cifs internal module version).
|
||||||
This may be easier to read than parsing the output of "git log fs/cifs"
|
This may be easier to read than parsing the output of
|
||||||
by release.
|
"git log fs/smb/client" by release.
|
||||||
|
@ -45,7 +45,7 @@ Installation instructions
|
|||||||
|
|
||||||
If you have built the CIFS vfs as module (successfully) simply
|
If you have built the CIFS vfs as module (successfully) simply
|
||||||
type ``make modules_install`` (or if you prefer, manually copy the file to
|
type ``make modules_install`` (or if you prefer, manually copy the file to
|
||||||
the modules directory e.g. /lib/modules/2.4.10-4GB/kernel/fs/cifs/cifs.ko).
|
the modules directory e.g. /lib/modules/6.3.0-060300-generic/kernel/fs/smb/client/cifs.ko).
|
||||||
|
|
||||||
If you have built the CIFS vfs into the kernel itself, follow the instructions
|
If you have built the CIFS vfs into the kernel itself, follow the instructions
|
||||||
for your distribution on how to install a new kernel (usually you
|
for your distribution on how to install a new kernel (usually you
|
||||||
@ -66,15 +66,15 @@ If cifs is built as a module, then the size and number of network buffers
|
|||||||
and maximum number of simultaneous requests to one server can be configured.
|
and maximum number of simultaneous requests to one server can be configured.
|
||||||
Changing these from their defaults is not recommended. By executing modinfo::
|
Changing these from their defaults is not recommended. By executing modinfo::
|
||||||
|
|
||||||
modinfo kernel/fs/cifs/cifs.ko
|
modinfo <path to cifs.ko>
|
||||||
|
|
||||||
on kernel/fs/cifs/cifs.ko the list of configuration changes that can be made
|
on kernel/fs/smb/client/cifs.ko the list of configuration changes that can be made
|
||||||
at module initialization time (by running insmod cifs.ko) can be seen.
|
at module initialization time (by running insmod cifs.ko) can be seen.
|
||||||
|
|
||||||
Recommendations
|
Recommendations
|
||||||
===============
|
===============
|
||||||
|
|
||||||
To improve security the SMB2.1 dialect or later (usually will get SMB3) is now
|
To improve security the SMB2.1 dialect or later (usually will get SMB3.1.1) is now
|
||||||
the new default. To use old dialects (e.g. to mount Windows XP) use "vers=1.0"
|
the new default. To use old dialects (e.g. to mount Windows XP) use "vers=1.0"
|
||||||
on mount (or vers=2.0 for Windows Vista). Note that the CIFS (vers=1.0) is
|
on mount (or vers=2.0 for Windows Vista). Note that the CIFS (vers=1.0) is
|
||||||
much older and less secure than the default dialect SMB3 which includes
|
much older and less secure than the default dialect SMB3 which includes
|
||||||
|
@ -215,12 +215,14 @@ again.
|
|||||||
reduce the compile time enormously, especially if you are running an
|
reduce the compile time enormously, especially if you are running an
|
||||||
universal kernel from a commodity Linux distribution.
|
universal kernel from a commodity Linux distribution.
|
||||||
|
|
||||||
There is a catch: the make target 'localmodconfig' will disable kernel
|
There is a catch: 'localmodconfig' is likely to disable kernel features you
|
||||||
features you have not directly or indirectly through some program utilized
|
did not use since you booted your Linux -- like drivers for currently
|
||||||
since you booted the system. You can reduce or nearly eliminate that risk by
|
disconnected peripherals or a virtualization software not haven't used yet.
|
||||||
using tricks outlined in the reference section; for quick testing purposes
|
You can reduce or nearly eliminate that risk with tricks the reference
|
||||||
that risk is often negligible, but it is an aspect you want to keep in mind
|
section outlines; but when building a kernel just for quick testing purposes
|
||||||
in case your kernel behaves oddly.
|
it is often negligible if such features are missing. But you should keep that
|
||||||
|
aspect in mind when using a kernel built with this make target, as it might
|
||||||
|
be the reason why something you only use occasionally stopped working.
|
||||||
|
|
||||||
[:ref:`details<configuration>`]
|
[:ref:`details<configuration>`]
|
||||||
|
|
||||||
@ -271,6 +273,9 @@ again.
|
|||||||
does nothing at all; in that case you have to manually install your kernel,
|
does nothing at all; in that case you have to manually install your kernel,
|
||||||
as outlined in the reference section.
|
as outlined in the reference section.
|
||||||
|
|
||||||
|
If you are running a immutable Linux distribution, check its documentation
|
||||||
|
and the web to find out how to install your own kernel there.
|
||||||
|
|
||||||
[:ref:`details<install>`]
|
[:ref:`details<install>`]
|
||||||
|
|
||||||
.. _another_sbs:
|
.. _another_sbs:
|
||||||
@ -291,29 +296,29 @@ again.
|
|||||||
version you care about, as git otherwise might retrieve the entire commit
|
version you care about, as git otherwise might retrieve the entire commit
|
||||||
history::
|
history::
|
||||||
|
|
||||||
git fetch --shallow-exclude=v6.1 origin
|
git fetch --shallow-exclude=v6.0 origin
|
||||||
|
|
||||||
If you modified the sources (for example by applying a patch), you now need
|
Now switch to the version you are interested in -- but be aware the command
|
||||||
to discard those modifications; that's because git otherwise will not be able
|
used here will discard any modifications you performed, as they would
|
||||||
to switch to the sources of another version due to potential conflicting
|
conflict with the sources you want to checkout::
|
||||||
changes::
|
|
||||||
|
|
||||||
git reset --hard
|
git checkout --force --detach origin/master
|
||||||
|
|
||||||
Now checkout the version you are interested in, as explained above::
|
|
||||||
|
|
||||||
git checkout --detach origin/master
|
|
||||||
|
|
||||||
At this point you might want to patch the sources again or set/modify a build
|
At this point you might want to patch the sources again or set/modify a build
|
||||||
tag, as explained earlier; afterwards adjust the build configuration to the
|
tag, as explained earlier. Afterwards adjust the build configuration to the
|
||||||
new codebase and build your next kernel::
|
new codebase using olddefconfig, which will now adjust the configuration file
|
||||||
|
you prepared earlier using localmodconfig (~/linux/.config) for your next
|
||||||
|
kernel::
|
||||||
|
|
||||||
# reminder: if you want to apply patches, do it at this point
|
# reminder: if you want to apply patches, do it at this point
|
||||||
# reminder: you might want to update your build tag at this point
|
# reminder: you might want to update your build tag at this point
|
||||||
make olddefconfig
|
make olddefconfig
|
||||||
|
|
||||||
|
Now build your kernel::
|
||||||
|
|
||||||
make -j $(nproc --all)
|
make -j $(nproc --all)
|
||||||
|
|
||||||
Install the kernel as outlined above::
|
Afterwards install the kernel as outlined above::
|
||||||
|
|
||||||
command -v installkernel && sudo make modules_install install
|
command -v installkernel && sudo make modules_install install
|
||||||
|
|
||||||
@ -584,11 +589,11 @@ versions and individual commits at hand at any time::
|
|||||||
curl -L \
|
curl -L \
|
||||||
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/clone.bundle \
|
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/clone.bundle \
|
||||||
-o linux-stable.git.bundle
|
-o linux-stable.git.bundle
|
||||||
git clone clone.bundle ~/linux/
|
git clone linux-stable.git.bundle ~/linux/
|
||||||
rm linux-stable.git.bundle
|
rm linux-stable.git.bundle
|
||||||
cd ~/linux/
|
cd ~/linux/
|
||||||
git remote set-url origin
|
git remote set-url origin \
|
||||||
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
|
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
|
||||||
git fetch origin
|
git fetch origin
|
||||||
git checkout --detach origin/master
|
git checkout --detach origin/master
|
||||||
|
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
=====
|
======
|
||||||
cdrom
|
CD-ROM
|
||||||
=====
|
======
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
@ -32,7 +32,7 @@ properties:
|
|||||||
maxItems: 1
|
maxItems: 1
|
||||||
|
|
||||||
iommus:
|
iommus:
|
||||||
maxItems: 1
|
maxItems: 4
|
||||||
|
|
||||||
power-domains:
|
power-domains:
|
||||||
maxItems: 1
|
maxItems: 1
|
||||||
|
@ -82,6 +82,18 @@ properties:
|
|||||||
Indicates if the DSI controller is driving a panel which needs
|
Indicates if the DSI controller is driving a panel which needs
|
||||||
2 DSI links.
|
2 DSI links.
|
||||||
|
|
||||||
|
qcom,master-dsi:
|
||||||
|
type: boolean
|
||||||
|
description: |
|
||||||
|
Indicates if the DSI controller is the master DSI controller when
|
||||||
|
qcom,dual-dsi-mode enabled.
|
||||||
|
|
||||||
|
qcom,sync-dual-dsi:
|
||||||
|
type: boolean
|
||||||
|
description: |
|
||||||
|
Indicates if the DSI controller needs to sync the other DSI controller
|
||||||
|
with MIPI DCS commands when qcom,dual-dsi-mode enabled.
|
||||||
|
|
||||||
assigned-clocks:
|
assigned-clocks:
|
||||||
minItems: 2
|
minItems: 2
|
||||||
maxItems: 4
|
maxItems: 4
|
||||||
|
@ -7,7 +7,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Lattice Slave SPI sysCONFIG FPGA manager
|
title: Lattice Slave SPI sysCONFIG FPGA manager
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Ivan Bornyakov <i.bornyakov@metrotek.ru>
|
- Vladimir Georgiev <v.georgiev@metrotek.ru>
|
||||||
|
|
||||||
description: |
|
description: |
|
||||||
Lattice sysCONFIG port, which is used for FPGA configuration, among others,
|
Lattice sysCONFIG port, which is used for FPGA configuration, among others,
|
||||||
|
@ -7,7 +7,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Microchip Polarfire FPGA manager.
|
title: Microchip Polarfire FPGA manager.
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Ivan Bornyakov <i.bornyakov@metrotek.ru>
|
- Vladimir Georgiev <v.georgiev@metrotek.ru>
|
||||||
|
|
||||||
description:
|
description:
|
||||||
Device Tree Bindings for Microchip Polarfire FPGA Manager using slave SPI to
|
Device Tree Bindings for Microchip Polarfire FPGA Manager using slave SPI to
|
||||||
|
@ -39,6 +39,12 @@ properties:
|
|||||||
power-domains:
|
power-domains:
|
||||||
maxItems: 1
|
maxItems: 1
|
||||||
|
|
||||||
|
vref-supply:
|
||||||
|
description: |
|
||||||
|
External ADC reference voltage supply on VREFH pad. If VERID[MVI] is
|
||||||
|
set, there are additional, internal reference voltages selectable.
|
||||||
|
VREFH1 is always from VREFH pad.
|
||||||
|
|
||||||
"#io-channel-cells":
|
"#io-channel-cells":
|
||||||
const: 1
|
const: 1
|
||||||
|
|
||||||
@ -72,6 +78,7 @@ examples:
|
|||||||
assigned-clocks = <&clk IMX_SC_R_ADC_0>;
|
assigned-clocks = <&clk IMX_SC_R_ADC_0>;
|
||||||
assigned-clock-rates = <24000000>;
|
assigned-clock-rates = <24000000>;
|
||||||
power-domains = <&pd IMX_SC_R_ADC_0>;
|
power-domains = <&pd IMX_SC_R_ADC_0>;
|
||||||
|
vref-supply = <®_1v8>;
|
||||||
#io-channel-cells = <1>;
|
#io-channel-cells = <1>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -90,7 +90,7 @@ patternProperties:
|
|||||||
of the MAX chips to the GyroADC, while MISO line of each Maxim
|
of the MAX chips to the GyroADC, while MISO line of each Maxim
|
||||||
ADC connects to a shared input pin of the GyroADC.
|
ADC connects to a shared input pin of the GyroADC.
|
||||||
enum:
|
enum:
|
||||||
- adi,7476
|
- adi,ad7476
|
||||||
- fujitsu,mb88101a
|
- fujitsu,mb88101a
|
||||||
- maxim,max1162
|
- maxim,max1162
|
||||||
- maxim,max11100
|
- maxim,max11100
|
||||||
|
@ -166,6 +166,12 @@ properties:
|
|||||||
resets:
|
resets:
|
||||||
maxItems: 1
|
maxItems: 1
|
||||||
|
|
||||||
|
mediatek,broken-save-restore-fw:
|
||||||
|
type: boolean
|
||||||
|
description:
|
||||||
|
Asserts that the firmware on this device has issues saving and restoring
|
||||||
|
GICR registers when the GIC redistributors are powered off.
|
||||||
|
|
||||||
dependencies:
|
dependencies:
|
||||||
mbi-ranges: [ msi-controller ]
|
mbi-ranges: [ msi-controller ]
|
||||||
msi-controller: [ mbi-ranges ]
|
msi-controller: [ mbi-ranges ]
|
||||||
|
@ -21,11 +21,22 @@ properties:
|
|||||||
|
|
||||||
st,can-primary:
|
st,can-primary:
|
||||||
description:
|
description:
|
||||||
Primary and secondary mode of the bxCAN peripheral is only relevant
|
Primary mode of the bxCAN peripheral is only relevant if the chip has
|
||||||
if the chip has two CAN peripherals. In that case they share some
|
two CAN peripherals in dual CAN configuration. In that case they share
|
||||||
of the required logic.
|
some of the required logic.
|
||||||
|
Not to be used if the peripheral is in single CAN configuration.
|
||||||
To avoid misunderstandings, it should be noted that ST documentation
|
To avoid misunderstandings, it should be noted that ST documentation
|
||||||
uses the terms master/slave instead of primary/secondary.
|
uses the terms master instead of primary.
|
||||||
|
type: boolean
|
||||||
|
|
||||||
|
st,can-secondary:
|
||||||
|
description:
|
||||||
|
Secondary mode of the bxCAN peripheral is only relevant if the chip
|
||||||
|
has two CAN peripherals in dual CAN configuration. In that case they
|
||||||
|
share some of the required logic.
|
||||||
|
Not to be used if the peripheral is in single CAN configuration.
|
||||||
|
To avoid misunderstandings, it should be noted that ST documentation
|
||||||
|
uses the terms slave instead of secondary.
|
||||||
type: boolean
|
type: boolean
|
||||||
|
|
||||||
reg:
|
reg:
|
||||||
|
@ -70,6 +70,7 @@ properties:
|
|||||||
dsr-gpios: true
|
dsr-gpios: true
|
||||||
rng-gpios: true
|
rng-gpios: true
|
||||||
dcd-gpios: true
|
dcd-gpios: true
|
||||||
|
rs485-rts-active-high: true
|
||||||
rts-gpio: true
|
rts-gpio: true
|
||||||
power-domains: true
|
power-domains: true
|
||||||
clock-frequency: true
|
clock-frequency: true
|
||||||
|
@ -55,7 +55,9 @@ properties:
|
|||||||
description: TDM TX current sense time slot.
|
description: TDM TX current sense time slot.
|
||||||
|
|
||||||
'#sound-dai-cells':
|
'#sound-dai-cells':
|
||||||
const: 1
|
# The codec has a single DAI, the #sound-dai-cells=<1>; case is left in for backward
|
||||||
|
# compatibility but is deprecated.
|
||||||
|
enum: [0, 1]
|
||||||
|
|
||||||
required:
|
required:
|
||||||
- compatible
|
- compatible
|
||||||
@ -72,7 +74,7 @@ examples:
|
|||||||
codec: codec@4c {
|
codec: codec@4c {
|
||||||
compatible = "ti,tas2562";
|
compatible = "ti,tas2562";
|
||||||
reg = <0x4c>;
|
reg = <0x4c>;
|
||||||
#sound-dai-cells = <1>;
|
#sound-dai-cells = <0>;
|
||||||
interrupt-parent = <&gpio1>;
|
interrupt-parent = <&gpio1>;
|
||||||
interrupts = <14>;
|
interrupts = <14>;
|
||||||
shutdown-gpios = <&gpio1 15 0>;
|
shutdown-gpios = <&gpio1 15 0>;
|
||||||
|
@ -57,7 +57,9 @@ properties:
|
|||||||
- 1 # Falling edge
|
- 1 # Falling edge
|
||||||
|
|
||||||
'#sound-dai-cells':
|
'#sound-dai-cells':
|
||||||
const: 1
|
# The codec has a single DAI, the #sound-dai-cells=<1>; case is left in for backward
|
||||||
|
# compatibility but is deprecated.
|
||||||
|
enum: [0, 1]
|
||||||
|
|
||||||
required:
|
required:
|
||||||
- compatible
|
- compatible
|
||||||
@ -74,7 +76,7 @@ examples:
|
|||||||
codec: codec@41 {
|
codec: codec@41 {
|
||||||
compatible = "ti,tas2770";
|
compatible = "ti,tas2770";
|
||||||
reg = <0x41>;
|
reg = <0x41>;
|
||||||
#sound-dai-cells = <1>;
|
#sound-dai-cells = <0>;
|
||||||
interrupt-parent = <&gpio1>;
|
interrupt-parent = <&gpio1>;
|
||||||
interrupts = <14>;
|
interrupts = <14>;
|
||||||
reset-gpio = <&gpio1 15 0>;
|
reset-gpio = <&gpio1 15 0>;
|
||||||
|
@ -50,7 +50,9 @@ properties:
|
|||||||
description: TDM TX voltage sense time slot.
|
description: TDM TX voltage sense time slot.
|
||||||
|
|
||||||
'#sound-dai-cells':
|
'#sound-dai-cells':
|
||||||
const: 1
|
# The codec has a single DAI, the #sound-dai-cells=<1>; case is left in for backward
|
||||||
|
# compatibility but is deprecated.
|
||||||
|
enum: [0, 1]
|
||||||
|
|
||||||
required:
|
required:
|
||||||
- compatible
|
- compatible
|
||||||
@ -67,7 +69,7 @@ examples:
|
|||||||
codec: codec@38 {
|
codec: codec@38 {
|
||||||
compatible = "ti,tas2764";
|
compatible = "ti,tas2764";
|
||||||
reg = <0x38>;
|
reg = <0x38>;
|
||||||
#sound-dai-cells = <1>;
|
#sound-dai-cells = <0>;
|
||||||
interrupt-parent = <&gpio1>;
|
interrupt-parent = <&gpio1>;
|
||||||
interrupts = <14>;
|
interrupts = <14>;
|
||||||
reset-gpios = <&gpio1 15 0>;
|
reset-gpios = <&gpio1 15 0>;
|
||||||
|
@ -8,7 +8,7 @@ Required properties:
|
|||||||
"ti,tlv320aic32x6" TLV320AIC3206, TLV320AIC3256
|
"ti,tlv320aic32x6" TLV320AIC3206, TLV320AIC3256
|
||||||
"ti,tas2505" TAS2505, TAS2521
|
"ti,tas2505" TAS2505, TAS2521
|
||||||
- reg: I2C slave address
|
- reg: I2C slave address
|
||||||
- supply-*: Required supply regulators are:
|
- *-supply: Required supply regulators are:
|
||||||
"iov" - digital IO power supply
|
"iov" - digital IO power supply
|
||||||
"ldoin" - LDO power supply
|
"ldoin" - LDO power supply
|
||||||
"dv" - Digital core power supply
|
"dv" - Digital core power supply
|
||||||
|
@ -64,7 +64,7 @@ properties:
|
|||||||
description:
|
description:
|
||||||
size of memory intended as internal memory for endpoints
|
size of memory intended as internal memory for endpoints
|
||||||
buffers expressed in KB
|
buffers expressed in KB
|
||||||
$ref: /schemas/types.yaml#/definitions/uint32
|
$ref: /schemas/types.yaml#/definitions/uint16
|
||||||
|
|
||||||
cdns,phyrst-a-enable:
|
cdns,phyrst-a-enable:
|
||||||
description: Enable resetting of PHY if Rx fail is detected
|
description: Enable resetting of PHY if Rx fail is detected
|
||||||
|
@ -287,7 +287,7 @@ properties:
|
|||||||
description:
|
description:
|
||||||
High-Speed PHY interface selection between UTMI+ and ULPI when the
|
High-Speed PHY interface selection between UTMI+ and ULPI when the
|
||||||
DWC_USB3_HSPHY_INTERFACE has value 3.
|
DWC_USB3_HSPHY_INTERFACE has value 3.
|
||||||
$ref: /schemas/types.yaml#/definitions/uint8
|
$ref: /schemas/types.yaml#/definitions/string
|
||||||
enum: [utmi, ulpi]
|
enum: [utmi, ulpi]
|
||||||
|
|
||||||
snps,quirk-frame-length-adjustment:
|
snps,quirk-frame-length-adjustment:
|
||||||
|
@ -72,7 +72,6 @@ Documentation for filesystem implementations.
|
|||||||
befs
|
befs
|
||||||
bfs
|
bfs
|
||||||
btrfs
|
btrfs
|
||||||
cifs/index
|
|
||||||
ceph
|
ceph
|
||||||
coda
|
coda
|
||||||
configfs
|
configfs
|
||||||
@ -111,6 +110,7 @@ Documentation for filesystem implementations.
|
|||||||
ramfs-rootfs-initramfs
|
ramfs-rootfs-initramfs
|
||||||
relay
|
relay
|
||||||
romfs
|
romfs
|
||||||
|
smb/index
|
||||||
spufs/index
|
spufs/index
|
||||||
squashfs
|
squashfs
|
||||||
sysfs
|
sysfs
|
||||||
|
@ -6,8 +6,7 @@ Ramfs, rootfs and initramfs
|
|||||||
|
|
||||||
October 17, 2005
|
October 17, 2005
|
||||||
|
|
||||||
Rob Landley <rob@landley.net>
|
:Author: Rob Landley <rob@landley.net>
|
||||||
=============================
|
|
||||||
|
|
||||||
What is ramfs?
|
What is ramfs?
|
||||||
--------------
|
--------------
|
||||||
|
@ -147,6 +147,7 @@ replicas continue to be exactly same.
|
|||||||
|
|
||||||
|
|
||||||
3) Setting mount states
|
3) Setting mount states
|
||||||
|
-----------------------
|
||||||
|
|
||||||
The mount command (util-linux package) can be used to set mount
|
The mount command (util-linux package) can be used to set mount
|
||||||
states::
|
states::
|
||||||
@ -612,6 +613,7 @@ replicas continue to be exactly same.
|
|||||||
|
|
||||||
|
|
||||||
6) Quiz
|
6) Quiz
|
||||||
|
-------
|
||||||
|
|
||||||
A. What is the result of the following command sequence?
|
A. What is the result of the following command sequence?
|
||||||
|
|
||||||
@ -673,6 +675,7 @@ replicas continue to be exactly same.
|
|||||||
/mnt/1/test be?
|
/mnt/1/test be?
|
||||||
|
|
||||||
7) FAQ
|
7) FAQ
|
||||||
|
------
|
||||||
|
|
||||||
Q1. Why is bind mount needed? How is it different from symbolic links?
|
Q1. Why is bind mount needed? How is it different from symbolic links?
|
||||||
symbolic links can get stale if the destination mount gets
|
symbolic links can get stale if the destination mount gets
|
||||||
@ -841,6 +844,7 @@ replicas continue to be exactly same.
|
|||||||
tmp usr tmp usr tmp usr
|
tmp usr tmp usr tmp usr
|
||||||
|
|
||||||
8) Implementation
|
8) Implementation
|
||||||
|
-----------------
|
||||||
|
|
||||||
8A) Datastructure
|
8A) Datastructure
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ the root file system via SMB protocol.
|
|||||||
Enables the kernel to mount the root file system via SMB that are
|
Enables the kernel to mount the root file system via SMB that are
|
||||||
located in the <server-ip> and <share> specified in this option.
|
located in the <server-ip> and <share> specified in this option.
|
||||||
|
|
||||||
The default mount options are set in fs/cifs/cifsroot.c.
|
The default mount options are set in fs/smb/client/cifsroot.c.
|
||||||
|
|
||||||
server-ip
|
server-ip
|
||||||
IPv4 address of the server.
|
IPv4 address of the server.
|
@ -1,7 +1,7 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
====
|
====
|
||||||
fpga
|
FPGA
|
||||||
====
|
====
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
=======
|
=======
|
||||||
locking
|
Locking
|
||||||
=======
|
=======
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
|
@ -52,3 +52,22 @@ Build kernel with:
|
|||||||
|
|
||||||
Optionally, build kernel with PAGE_TABLE_CHECK_ENFORCED in order to have page
|
Optionally, build kernel with PAGE_TABLE_CHECK_ENFORCED in order to have page
|
||||||
table support without extra kernel parameter.
|
table support without extra kernel parameter.
|
||||||
|
|
||||||
|
Implementation notes
|
||||||
|
====================
|
||||||
|
|
||||||
|
We specifically decided not to use VMA information in order to avoid relying on
|
||||||
|
MM states (except for limited "struct page" info). The page table check is a
|
||||||
|
separate from Linux-MM state machine that verifies that the user accessible
|
||||||
|
pages are not falsely shared.
|
||||||
|
|
||||||
|
PAGE_TABLE_CHECK depends on EXCLUSIVE_SYSTEM_RAM. The reason is that without
|
||||||
|
EXCLUSIVE_SYSTEM_RAM, users are allowed to map arbitrary physical memory
|
||||||
|
regions into the userspace via /dev/mem. At the same time, pages may change
|
||||||
|
their properties (e.g., from anonymous pages to named pages) while they are
|
||||||
|
still being mapped in the userspace, leading to "corruption" detected by the
|
||||||
|
page table check.
|
||||||
|
|
||||||
|
Even with EXCLUSIVE_SYSTEM_RAM, I/O pages may be still allowed to be mapped via
|
||||||
|
/dev/mem. However, these pages are always considered as named pages, so they
|
||||||
|
won't break the logic used in the page table check.
|
||||||
|
@ -60,22 +60,6 @@ attribute-sets:
|
|||||||
type: nest
|
type: nest
|
||||||
nested-attributes: bitset-bits
|
nested-attributes: bitset-bits
|
||||||
|
|
||||||
-
|
|
||||||
name: u64-array
|
|
||||||
attributes:
|
|
||||||
-
|
|
||||||
name: u64
|
|
||||||
type: nest
|
|
||||||
multi-attr: true
|
|
||||||
nested-attributes: u64
|
|
||||||
-
|
|
||||||
name: s32-array
|
|
||||||
attributes:
|
|
||||||
-
|
|
||||||
name: s32
|
|
||||||
type: nest
|
|
||||||
multi-attr: true
|
|
||||||
nested-attributes: s32
|
|
||||||
-
|
-
|
||||||
name: string
|
name: string
|
||||||
attributes:
|
attributes:
|
||||||
@ -705,16 +689,16 @@ attribute-sets:
|
|||||||
type: u8
|
type: u8
|
||||||
-
|
-
|
||||||
name: corrected
|
name: corrected
|
||||||
type: nest
|
type: binary
|
||||||
nested-attributes: u64-array
|
sub-type: u64
|
||||||
-
|
-
|
||||||
name: uncorr
|
name: uncorr
|
||||||
type: nest
|
type: binary
|
||||||
nested-attributes: u64-array
|
sub-type: u64
|
||||||
-
|
-
|
||||||
name: corr-bits
|
name: corr-bits
|
||||||
type: nest
|
type: binary
|
||||||
nested-attributes: u64-array
|
sub-type: u64
|
||||||
-
|
-
|
||||||
name: fec
|
name: fec
|
||||||
attributes:
|
attributes:
|
||||||
@ -827,8 +811,8 @@ attribute-sets:
|
|||||||
type: u32
|
type: u32
|
||||||
-
|
-
|
||||||
name: index
|
name: index
|
||||||
type: nest
|
type: binary
|
||||||
nested-attributes: s32-array
|
sub-type: s32
|
||||||
-
|
-
|
||||||
name: module
|
name: module
|
||||||
attributes:
|
attributes:
|
||||||
|
@ -68,6 +68,9 @@ attribute-sets:
|
|||||||
type: nest
|
type: nest
|
||||||
nested-attributes: x509
|
nested-attributes: x509
|
||||||
multi-attr: true
|
multi-attr: true
|
||||||
|
-
|
||||||
|
name: peername
|
||||||
|
type: string
|
||||||
-
|
-
|
||||||
name: done
|
name: done
|
||||||
attributes:
|
attributes:
|
||||||
@ -105,6 +108,7 @@ operations:
|
|||||||
- auth-mode
|
- auth-mode
|
||||||
- peer-identity
|
- peer-identity
|
||||||
- certificate
|
- certificate
|
||||||
|
- peername
|
||||||
-
|
-
|
||||||
name: done
|
name: done
|
||||||
doc: Handler reports handshake completion
|
doc: Handler reports handshake completion
|
||||||
|
@ -40,6 +40,7 @@ flow_steering_mode: Device flow steering mode
|
|||||||
---------------------------------------------
|
---------------------------------------------
|
||||||
The flow steering mode parameter controls the flow steering mode of the driver.
|
The flow steering mode parameter controls the flow steering mode of the driver.
|
||||||
Two modes are supported:
|
Two modes are supported:
|
||||||
|
|
||||||
1. 'dmfs' - Device managed flow steering.
|
1. 'dmfs' - Device managed flow steering.
|
||||||
2. 'smfs' - Software/Driver managed flow steering.
|
2. 'smfs' - Software/Driver managed flow steering.
|
||||||
|
|
||||||
@ -99,6 +100,7 @@ between representors and stacked devices.
|
|||||||
By default metadata is enabled on the supported devices in E-switch.
|
By default metadata is enabled on the supported devices in E-switch.
|
||||||
Metadata is applicable only for E-switch in switchdev mode and
|
Metadata is applicable only for E-switch in switchdev mode and
|
||||||
users may disable it when NONE of the below use cases will be in use:
|
users may disable it when NONE of the below use cases will be in use:
|
||||||
|
|
||||||
1. HCA is in Dual/multi-port RoCE mode.
|
1. HCA is in Dual/multi-port RoCE mode.
|
||||||
2. VF/SF representor bonding (Usually used for Live migration)
|
2. VF/SF representor bonding (Usually used for Live migration)
|
||||||
3. Stacked devices
|
3. Stacked devices
|
||||||
@ -180,7 +182,8 @@ User commands examples:
|
|||||||
|
|
||||||
$ devlink health diagnose pci/0000:82:00.0 reporter tx
|
$ devlink health diagnose pci/0000:82:00.0 reporter tx
|
||||||
|
|
||||||
NOTE: This command has valid output only when interface is up, otherwise the command has empty output.
|
.. note::
|
||||||
|
This command has valid output only when interface is up, otherwise the command has empty output.
|
||||||
|
|
||||||
- Show number of tx errors indicated, number of recover flows ended successfully,
|
- Show number of tx errors indicated, number of recover flows ended successfully,
|
||||||
is autorecover enabled and graceful period from last recover::
|
is autorecover enabled and graceful period from last recover::
|
||||||
@ -232,8 +235,9 @@ User commands examples:
|
|||||||
|
|
||||||
$ devlink health dump show pci/0000:82:00.0 reporter fw
|
$ 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,
|
.. note::
|
||||||
running it on other PF or any VF will return "Operation not permitted".
|
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
|
fw fatal reporter
|
||||||
-----------------
|
-----------------
|
||||||
@ -256,7 +260,8 @@ User commands examples:
|
|||||||
|
|
||||||
$ devlink health dump show pci/0000:82:00.1 reporter fw_fatal
|
$ devlink health dump show pci/0000:82:00.1 reporter fw_fatal
|
||||||
|
|
||||||
NOTE: This command can run only on PF.
|
.. note::
|
||||||
|
This command can run only on PF.
|
||||||
|
|
||||||
vnic reporter
|
vnic reporter
|
||||||
-------------
|
-------------
|
||||||
@ -265,28 +270,37 @@ It is responsible for querying the vnic diagnostic counters from fw and displayi
|
|||||||
them in realtime.
|
them in realtime.
|
||||||
|
|
||||||
Description of the vnic counters:
|
Description of the vnic counters:
|
||||||
total_q_under_processor_handle: number of queues in an error state due to
|
|
||||||
an async error or errored command.
|
- total_q_under_processor_handle
|
||||||
send_queue_priority_update_flow: number of QP/SQ priority/SL update
|
number of queues in an error state due to
|
||||||
events.
|
an async error or errored command.
|
||||||
cq_overrun: number of times CQ entered an error state due to an
|
- send_queue_priority_update_flow
|
||||||
overflow.
|
number of QP/SQ priority/SL update events.
|
||||||
async_eq_overrun: number of times an EQ mapped to async events was
|
- cq_overrun
|
||||||
overrun.
|
number of times CQ entered an error state due to an overflow.
|
||||||
comp_eq_overrun: number of times an EQ mapped to completion events was
|
- async_eq_overrun
|
||||||
overrun.
|
number of times an EQ mapped to async events was overrun.
|
||||||
quota_exceeded_command: number of commands issued and failed due to quota
|
comp_eq_overrun number of times an EQ mapped to completion events was
|
||||||
exceeded.
|
overrun.
|
||||||
invalid_command: number of commands issued and failed dues to any reason
|
- quota_exceeded_command
|
||||||
other than quota exceeded.
|
number of commands issued and failed due to quota exceeded.
|
||||||
nic_receive_steering_discard: number of packets that completed RX flow
|
- invalid_command
|
||||||
steering but were discarded due to a mismatch in flow table.
|
number of commands issued and failed dues to any reason other than quota
|
||||||
|
exceeded.
|
||||||
|
- nic_receive_steering_discard
|
||||||
|
number of packets that completed RX flow
|
||||||
|
steering but were discarded due to a mismatch in flow table.
|
||||||
|
|
||||||
User commands examples:
|
User commands examples:
|
||||||
- Diagnose PF/VF vnic counters
|
|
||||||
|
- Diagnose PF/VF vnic counters::
|
||||||
|
|
||||||
$ devlink health diagnose pci/0000:82:00.1 reporter vnic
|
$ devlink health diagnose pci/0000:82:00.1 reporter vnic
|
||||||
|
|
||||||
- Diagnose representor vnic counters (performed by supplying devlink port of the
|
- Diagnose representor vnic counters (performed by supplying devlink port of the
|
||||||
representor, which can be obtained via devlink port command)
|
representor, which can be obtained via devlink port command)::
|
||||||
|
|
||||||
$ devlink health diagnose pci/0000:82:00.1/65537 reporter vnic
|
$ devlink health diagnose pci/0000:82:00.1/65537 reporter vnic
|
||||||
|
|
||||||
NOTE: This command can run over all interfaces such as PF/VF and representor ports.
|
.. note::
|
||||||
|
This command can run over all interfaces such as PF/VF and representor ports.
|
||||||
|
@ -53,6 +53,7 @@ fills in a structure that contains the parameters of the request:
|
|||||||
struct socket *ta_sock;
|
struct socket *ta_sock;
|
||||||
tls_done_func_t ta_done;
|
tls_done_func_t ta_done;
|
||||||
void *ta_data;
|
void *ta_data;
|
||||||
|
const char *ta_peername;
|
||||||
unsigned int ta_timeout_ms;
|
unsigned int ta_timeout_ms;
|
||||||
key_serial_t ta_keyring;
|
key_serial_t ta_keyring;
|
||||||
key_serial_t ta_my_cert;
|
key_serial_t ta_my_cert;
|
||||||
@ -71,6 +72,10 @@ instantiated a struct file in sock->file.
|
|||||||
has completed. Further explanation of this function is in the "Handshake
|
has completed. Further explanation of this function is in the "Handshake
|
||||||
Completion" sesction below.
|
Completion" sesction below.
|
||||||
|
|
||||||
|
The consumer can provide a NUL-terminated hostname in the @ta_peername
|
||||||
|
field that is sent as part of ClientHello. If no peername is provided,
|
||||||
|
the DNS hostname associated with the server's IP address is used instead.
|
||||||
|
|
||||||
The consumer can fill in the @ta_timeout_ms field to force the servicing
|
The consumer can fill in the @ta_timeout_ms field to force the servicing
|
||||||
handshake agent to exit after a number of milliseconds. This enables the
|
handshake agent to exit after a number of milliseconds. This enables the
|
||||||
socket to be fully closed once both the kernel and the handshake agent
|
socket to be fully closed once both the kernel and the handshake agent
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
======
|
======
|
||||||
pcmcia
|
PCMCIA
|
||||||
======
|
======
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
|
@ -127,13 +127,32 @@ the value of ``Message-ID`` to the URL above.
|
|||||||
Updating patch status
|
Updating patch status
|
||||||
~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
It may be tempting to help the maintainers and update the state of your
|
Contributors and reviewers do not have the permissions to update patch
|
||||||
own patches when you post a new version or spot a bug. Please **do not**
|
state directly in patchwork. Patchwork doesn't expose much information
|
||||||
do that.
|
about the history of the state of patches, therefore having multiple
|
||||||
Interfering with the patch status on patchwork will only cause confusion. Leave
|
people update the state leads to confusion.
|
||||||
it to the maintainer to figure out what is the most recent and current
|
|
||||||
version that should be applied. If there is any doubt, the maintainer
|
Instead of delegating patchwork permissions netdev uses a simple mail
|
||||||
will reply and ask what should be done.
|
bot which looks for special commands/lines within the emails sent to
|
||||||
|
the mailing list. For example to mark a series as Changes Requested
|
||||||
|
one needs to send the following line anywhere in the email thread::
|
||||||
|
|
||||||
|
pw-bot: changes-requested
|
||||||
|
|
||||||
|
As a result the bot will set the entire series to Changes Requested.
|
||||||
|
This may be useful when author discovers a bug in their own series
|
||||||
|
and wants to prevent it from getting applied.
|
||||||
|
|
||||||
|
The use of the bot is entirely optional, if in doubt ignore its existence
|
||||||
|
completely. Maintainers will classify and update the state of the patches
|
||||||
|
themselves. No email should ever be sent to the list with the main purpose
|
||||||
|
of communicating with the bot, the bot commands should be seen as metadata.
|
||||||
|
|
||||||
|
The use of the bot is restricted to authors of the patches (the ``From:``
|
||||||
|
header on patch submission and command must match!), maintainers themselves
|
||||||
|
and a handful of senior reviewers. Bot records its activity here:
|
||||||
|
|
||||||
|
https://patchwork.hopto.org/pw-bot.html
|
||||||
|
|
||||||
Review timelines
|
Review timelines
|
||||||
~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~
|
||||||
|
@ -551,7 +551,6 @@ These are the steps:
|
|||||||
* IOMMU_SUPPORT
|
* IOMMU_SUPPORT
|
||||||
* S390
|
* S390
|
||||||
* ZCRYPT
|
* ZCRYPT
|
||||||
* S390_AP_IOMMU
|
|
||||||
* VFIO
|
* VFIO
|
||||||
* KVM
|
* KVM
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
=================================
|
=================================
|
||||||
brief tutorial on CRC computation
|
Brief tutorial on CRC computation
|
||||||
=================================
|
=================================
|
||||||
|
|
||||||
A CRC is a long-division remainder. You add the CRC to the message,
|
A CRC is a long-division remainder. You add the CRC to the message,
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
======
|
======
|
||||||
timers
|
Timers
|
||||||
======
|
======
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
|
@ -35,7 +35,7 @@ Documentation written by Tom Zanussi
|
|||||||
in place of an explicit value field - this is simply a count of
|
in place of an explicit value field - this is simply a count of
|
||||||
event hits. If 'values' isn't specified, an implicit 'hitcount'
|
event hits. If 'values' isn't specified, an implicit 'hitcount'
|
||||||
value will be automatically created and used as the only value.
|
value will be automatically created and used as the only value.
|
||||||
Keys can be any field, or the special string 'stacktrace', which
|
Keys can be any field, or the special string 'common_stacktrace', which
|
||||||
will use the event's kernel stacktrace as the key. The keywords
|
will use the event's kernel stacktrace as the key. The keywords
|
||||||
'keys' or 'key' can be used to specify keys, and the keywords
|
'keys' or 'key' can be used to specify keys, and the keywords
|
||||||
'values', 'vals', or 'val' can be used to specify values. Compound
|
'values', 'vals', or 'val' can be used to specify values. Compound
|
||||||
@ -54,7 +54,7 @@ Documentation written by Tom Zanussi
|
|||||||
'compatible' if the fields named in the trigger share the same
|
'compatible' if the fields named in the trigger share the same
|
||||||
number and type of fields and those fields also have the same names.
|
number and type of fields and those fields also have the same names.
|
||||||
Note that any two events always share the compatible 'hitcount' and
|
Note that any two events always share the compatible 'hitcount' and
|
||||||
'stacktrace' fields and can therefore be combined using those
|
'common_stacktrace' fields and can therefore be combined using those
|
||||||
fields, however pointless that may be.
|
fields, however pointless that may be.
|
||||||
|
|
||||||
'hist' triggers add a 'hist' file to each event's subdirectory.
|
'hist' triggers add a 'hist' file to each event's subdirectory.
|
||||||
@ -547,9 +547,9 @@ Extended error information
|
|||||||
the hist trigger display symbolic call_sites, we can have the hist
|
the hist trigger display symbolic call_sites, we can have the hist
|
||||||
trigger additionally display the complete set of kernel stack traces
|
trigger additionally display the complete set of kernel stack traces
|
||||||
that led to each call_site. To do that, we simply use the special
|
that led to each call_site. To do that, we simply use the special
|
||||||
value 'stacktrace' for the key parameter::
|
value 'common_stacktrace' for the key parameter::
|
||||||
|
|
||||||
# echo 'hist:keys=stacktrace:values=bytes_req,bytes_alloc:sort=bytes_alloc' > \
|
# echo 'hist:keys=common_stacktrace:values=bytes_req,bytes_alloc:sort=bytes_alloc' > \
|
||||||
/sys/kernel/tracing/events/kmem/kmalloc/trigger
|
/sys/kernel/tracing/events/kmem/kmalloc/trigger
|
||||||
|
|
||||||
The above trigger will use the kernel stack trace in effect when an
|
The above trigger will use the kernel stack trace in effect when an
|
||||||
@ -561,9 +561,9 @@ Extended error information
|
|||||||
every callpath to a kmalloc for a kernel compile)::
|
every callpath to a kmalloc for a kernel compile)::
|
||||||
|
|
||||||
# cat /sys/kernel/tracing/events/kmem/kmalloc/hist
|
# cat /sys/kernel/tracing/events/kmem/kmalloc/hist
|
||||||
# trigger info: hist:keys=stacktrace:vals=bytes_req,bytes_alloc:sort=bytes_alloc:size=2048 [active]
|
# trigger info: hist:keys=common_stacktrace:vals=bytes_req,bytes_alloc:sort=bytes_alloc:size=2048 [active]
|
||||||
|
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__kmalloc_track_caller+0x10b/0x1a0
|
__kmalloc_track_caller+0x10b/0x1a0
|
||||||
kmemdup+0x20/0x50
|
kmemdup+0x20/0x50
|
||||||
hidraw_report_event+0x8a/0x120 [hid]
|
hidraw_report_event+0x8a/0x120 [hid]
|
||||||
@ -581,7 +581,7 @@ Extended error information
|
|||||||
cpu_startup_entry+0x315/0x3e0
|
cpu_startup_entry+0x315/0x3e0
|
||||||
rest_init+0x7c/0x80
|
rest_init+0x7c/0x80
|
||||||
} hitcount: 3 bytes_req: 21 bytes_alloc: 24
|
} hitcount: 3 bytes_req: 21 bytes_alloc: 24
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__kmalloc_track_caller+0x10b/0x1a0
|
__kmalloc_track_caller+0x10b/0x1a0
|
||||||
kmemdup+0x20/0x50
|
kmemdup+0x20/0x50
|
||||||
hidraw_report_event+0x8a/0x120 [hid]
|
hidraw_report_event+0x8a/0x120 [hid]
|
||||||
@ -596,7 +596,7 @@ Extended error information
|
|||||||
do_IRQ+0x5a/0xf0
|
do_IRQ+0x5a/0xf0
|
||||||
ret_from_intr+0x0/0x30
|
ret_from_intr+0x0/0x30
|
||||||
} hitcount: 3 bytes_req: 21 bytes_alloc: 24
|
} hitcount: 3 bytes_req: 21 bytes_alloc: 24
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
kmem_cache_alloc_trace+0xeb/0x150
|
kmem_cache_alloc_trace+0xeb/0x150
|
||||||
aa_alloc_task_context+0x27/0x40
|
aa_alloc_task_context+0x27/0x40
|
||||||
apparmor_cred_prepare+0x1f/0x50
|
apparmor_cred_prepare+0x1f/0x50
|
||||||
@ -608,7 +608,7 @@ Extended error information
|
|||||||
.
|
.
|
||||||
.
|
.
|
||||||
.
|
.
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__kmalloc+0x11b/0x1b0
|
__kmalloc+0x11b/0x1b0
|
||||||
i915_gem_execbuffer2+0x6c/0x2c0 [i915]
|
i915_gem_execbuffer2+0x6c/0x2c0 [i915]
|
||||||
drm_ioctl+0x349/0x670 [drm]
|
drm_ioctl+0x349/0x670 [drm]
|
||||||
@ -616,7 +616,7 @@ Extended error information
|
|||||||
SyS_ioctl+0x81/0xa0
|
SyS_ioctl+0x81/0xa0
|
||||||
system_call_fastpath+0x12/0x6a
|
system_call_fastpath+0x12/0x6a
|
||||||
} hitcount: 17726 bytes_req: 13944120 bytes_alloc: 19593808
|
} hitcount: 17726 bytes_req: 13944120 bytes_alloc: 19593808
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__kmalloc+0x11b/0x1b0
|
__kmalloc+0x11b/0x1b0
|
||||||
load_elf_phdrs+0x76/0xa0
|
load_elf_phdrs+0x76/0xa0
|
||||||
load_elf_binary+0x102/0x1650
|
load_elf_binary+0x102/0x1650
|
||||||
@ -625,7 +625,7 @@ Extended error information
|
|||||||
SyS_execve+0x3a/0x50
|
SyS_execve+0x3a/0x50
|
||||||
return_from_execve+0x0/0x23
|
return_from_execve+0x0/0x23
|
||||||
} hitcount: 33348 bytes_req: 17152128 bytes_alloc: 20226048
|
} hitcount: 33348 bytes_req: 17152128 bytes_alloc: 20226048
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
kmem_cache_alloc_trace+0xeb/0x150
|
kmem_cache_alloc_trace+0xeb/0x150
|
||||||
apparmor_file_alloc_security+0x27/0x40
|
apparmor_file_alloc_security+0x27/0x40
|
||||||
security_file_alloc+0x16/0x20
|
security_file_alloc+0x16/0x20
|
||||||
@ -636,7 +636,7 @@ Extended error information
|
|||||||
SyS_open+0x1e/0x20
|
SyS_open+0x1e/0x20
|
||||||
system_call_fastpath+0x12/0x6a
|
system_call_fastpath+0x12/0x6a
|
||||||
} hitcount: 4766422 bytes_req: 9532844 bytes_alloc: 38131376
|
} hitcount: 4766422 bytes_req: 9532844 bytes_alloc: 38131376
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__kmalloc+0x11b/0x1b0
|
__kmalloc+0x11b/0x1b0
|
||||||
seq_buf_alloc+0x1b/0x50
|
seq_buf_alloc+0x1b/0x50
|
||||||
seq_read+0x2cc/0x370
|
seq_read+0x2cc/0x370
|
||||||
@ -1026,7 +1026,7 @@ Extended error information
|
|||||||
First we set up an initially paused stacktrace trigger on the
|
First we set up an initially paused stacktrace trigger on the
|
||||||
netif_receive_skb event::
|
netif_receive_skb event::
|
||||||
|
|
||||||
# echo 'hist:key=stacktrace:vals=len:pause' > \
|
# echo 'hist:key=common_stacktrace:vals=len:pause' > \
|
||||||
/sys/kernel/tracing/events/net/netif_receive_skb/trigger
|
/sys/kernel/tracing/events/net/netif_receive_skb/trigger
|
||||||
|
|
||||||
Next, we set up an 'enable_hist' trigger on the sched_process_exec
|
Next, we set up an 'enable_hist' trigger on the sched_process_exec
|
||||||
@ -1060,9 +1060,9 @@ Extended error information
|
|||||||
$ wget https://www.kernel.org/pub/linux/kernel/v3.x/patch-3.19.xz
|
$ wget https://www.kernel.org/pub/linux/kernel/v3.x/patch-3.19.xz
|
||||||
|
|
||||||
# cat /sys/kernel/tracing/events/net/netif_receive_skb/hist
|
# cat /sys/kernel/tracing/events/net/netif_receive_skb/hist
|
||||||
# trigger info: hist:keys=stacktrace:vals=len:sort=hitcount:size=2048 [paused]
|
# trigger info: hist:keys=common_stacktrace:vals=len:sort=hitcount:size=2048 [paused]
|
||||||
|
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__netif_receive_skb_core+0x46d/0x990
|
__netif_receive_skb_core+0x46d/0x990
|
||||||
__netif_receive_skb+0x18/0x60
|
__netif_receive_skb+0x18/0x60
|
||||||
netif_receive_skb_internal+0x23/0x90
|
netif_receive_skb_internal+0x23/0x90
|
||||||
@ -1079,7 +1079,7 @@ Extended error information
|
|||||||
kthread+0xd2/0xf0
|
kthread+0xd2/0xf0
|
||||||
ret_from_fork+0x42/0x70
|
ret_from_fork+0x42/0x70
|
||||||
} hitcount: 85 len: 28884
|
} hitcount: 85 len: 28884
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__netif_receive_skb_core+0x46d/0x990
|
__netif_receive_skb_core+0x46d/0x990
|
||||||
__netif_receive_skb+0x18/0x60
|
__netif_receive_skb+0x18/0x60
|
||||||
netif_receive_skb_internal+0x23/0x90
|
netif_receive_skb_internal+0x23/0x90
|
||||||
@ -1097,7 +1097,7 @@ Extended error information
|
|||||||
irq_thread+0x11f/0x150
|
irq_thread+0x11f/0x150
|
||||||
kthread+0xd2/0xf0
|
kthread+0xd2/0xf0
|
||||||
} hitcount: 98 len: 664329
|
} hitcount: 98 len: 664329
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__netif_receive_skb_core+0x46d/0x990
|
__netif_receive_skb_core+0x46d/0x990
|
||||||
__netif_receive_skb+0x18/0x60
|
__netif_receive_skb+0x18/0x60
|
||||||
process_backlog+0xa8/0x150
|
process_backlog+0xa8/0x150
|
||||||
@ -1115,7 +1115,7 @@ Extended error information
|
|||||||
inet_sendmsg+0x64/0xa0
|
inet_sendmsg+0x64/0xa0
|
||||||
sock_sendmsg+0x3d/0x50
|
sock_sendmsg+0x3d/0x50
|
||||||
} hitcount: 115 len: 13030
|
} hitcount: 115 len: 13030
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
__netif_receive_skb_core+0x46d/0x990
|
__netif_receive_skb_core+0x46d/0x990
|
||||||
__netif_receive_skb+0x18/0x60
|
__netif_receive_skb+0x18/0x60
|
||||||
netif_receive_skb_internal+0x23/0x90
|
netif_receive_skb_internal+0x23/0x90
|
||||||
@ -1142,14 +1142,14 @@ Extended error information
|
|||||||
into the histogram. In order to avoid having to set everything up
|
into the histogram. In order to avoid having to set everything up
|
||||||
again, we can just clear the histogram first::
|
again, we can just clear the histogram first::
|
||||||
|
|
||||||
# echo 'hist:key=stacktrace:vals=len:clear' >> \
|
# echo 'hist:key=common_stacktrace:vals=len:clear' >> \
|
||||||
/sys/kernel/tracing/events/net/netif_receive_skb/trigger
|
/sys/kernel/tracing/events/net/netif_receive_skb/trigger
|
||||||
|
|
||||||
Just to verify that it is in fact cleared, here's what we now see in
|
Just to verify that it is in fact cleared, here's what we now see in
|
||||||
the hist file::
|
the hist file::
|
||||||
|
|
||||||
# cat /sys/kernel/tracing/events/net/netif_receive_skb/hist
|
# cat /sys/kernel/tracing/events/net/netif_receive_skb/hist
|
||||||
# trigger info: hist:keys=stacktrace:vals=len:sort=hitcount:size=2048 [paused]
|
# trigger info: hist:keys=common_stacktrace:vals=len:sort=hitcount:size=2048 [paused]
|
||||||
|
|
||||||
Totals:
|
Totals:
|
||||||
Hits: 0
|
Hits: 0
|
||||||
@ -1485,12 +1485,12 @@ Extended error information
|
|||||||
|
|
||||||
And here's an example that shows how to combine histogram data from
|
And here's an example that shows how to combine histogram data from
|
||||||
any two events even if they don't share any 'compatible' fields
|
any two events even if they don't share any 'compatible' fields
|
||||||
other than 'hitcount' and 'stacktrace'. These commands create a
|
other than 'hitcount' and 'common_stacktrace'. These commands create a
|
||||||
couple of triggers named 'bar' using those fields::
|
couple of triggers named 'bar' using those fields::
|
||||||
|
|
||||||
# echo 'hist:name=bar:key=stacktrace:val=hitcount' > \
|
# echo 'hist:name=bar:key=common_stacktrace:val=hitcount' > \
|
||||||
/sys/kernel/tracing/events/sched/sched_process_fork/trigger
|
/sys/kernel/tracing/events/sched/sched_process_fork/trigger
|
||||||
# echo 'hist:name=bar:key=stacktrace:val=hitcount' > \
|
# echo 'hist:name=bar:key=common_stacktrace:val=hitcount' > \
|
||||||
/sys/kernel/tracing/events/net/netif_rx/trigger
|
/sys/kernel/tracing/events/net/netif_rx/trigger
|
||||||
|
|
||||||
And displaying the output of either shows some interesting if
|
And displaying the output of either shows some interesting if
|
||||||
@ -1501,16 +1501,16 @@ Extended error information
|
|||||||
|
|
||||||
# event histogram
|
# event histogram
|
||||||
#
|
#
|
||||||
# trigger info: hist:name=bar:keys=stacktrace:vals=hitcount:sort=hitcount:size=2048 [active]
|
# trigger info: hist:name=bar:keys=common_stacktrace:vals=hitcount:sort=hitcount:size=2048 [active]
|
||||||
#
|
#
|
||||||
|
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
kernel_clone+0x18e/0x330
|
kernel_clone+0x18e/0x330
|
||||||
kernel_thread+0x29/0x30
|
kernel_thread+0x29/0x30
|
||||||
kthreadd+0x154/0x1b0
|
kthreadd+0x154/0x1b0
|
||||||
ret_from_fork+0x3f/0x70
|
ret_from_fork+0x3f/0x70
|
||||||
} hitcount: 1
|
} hitcount: 1
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
netif_rx_internal+0xb2/0xd0
|
netif_rx_internal+0xb2/0xd0
|
||||||
netif_rx_ni+0x20/0x70
|
netif_rx_ni+0x20/0x70
|
||||||
dev_loopback_xmit+0xaa/0xd0
|
dev_loopback_xmit+0xaa/0xd0
|
||||||
@ -1528,7 +1528,7 @@ Extended error information
|
|||||||
call_cpuidle+0x3b/0x60
|
call_cpuidle+0x3b/0x60
|
||||||
cpu_startup_entry+0x22d/0x310
|
cpu_startup_entry+0x22d/0x310
|
||||||
} hitcount: 1
|
} hitcount: 1
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
netif_rx_internal+0xb2/0xd0
|
netif_rx_internal+0xb2/0xd0
|
||||||
netif_rx_ni+0x20/0x70
|
netif_rx_ni+0x20/0x70
|
||||||
dev_loopback_xmit+0xaa/0xd0
|
dev_loopback_xmit+0xaa/0xd0
|
||||||
@ -1543,7 +1543,7 @@ Extended error information
|
|||||||
SyS_sendto+0xe/0x10
|
SyS_sendto+0xe/0x10
|
||||||
entry_SYSCALL_64_fastpath+0x12/0x6a
|
entry_SYSCALL_64_fastpath+0x12/0x6a
|
||||||
} hitcount: 2
|
} hitcount: 2
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
netif_rx_internal+0xb2/0xd0
|
netif_rx_internal+0xb2/0xd0
|
||||||
netif_rx+0x1c/0x60
|
netif_rx+0x1c/0x60
|
||||||
loopback_xmit+0x6c/0xb0
|
loopback_xmit+0x6c/0xb0
|
||||||
@ -1561,7 +1561,7 @@ Extended error information
|
|||||||
sock_sendmsg+0x38/0x50
|
sock_sendmsg+0x38/0x50
|
||||||
___sys_sendmsg+0x14e/0x270
|
___sys_sendmsg+0x14e/0x270
|
||||||
} hitcount: 76
|
} hitcount: 76
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
netif_rx_internal+0xb2/0xd0
|
netif_rx_internal+0xb2/0xd0
|
||||||
netif_rx+0x1c/0x60
|
netif_rx+0x1c/0x60
|
||||||
loopback_xmit+0x6c/0xb0
|
loopback_xmit+0x6c/0xb0
|
||||||
@ -1579,7 +1579,7 @@ Extended error information
|
|||||||
sock_sendmsg+0x38/0x50
|
sock_sendmsg+0x38/0x50
|
||||||
___sys_sendmsg+0x269/0x270
|
___sys_sendmsg+0x269/0x270
|
||||||
} hitcount: 77
|
} hitcount: 77
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
netif_rx_internal+0xb2/0xd0
|
netif_rx_internal+0xb2/0xd0
|
||||||
netif_rx+0x1c/0x60
|
netif_rx+0x1c/0x60
|
||||||
loopback_xmit+0x6c/0xb0
|
loopback_xmit+0x6c/0xb0
|
||||||
@ -1597,7 +1597,7 @@ Extended error information
|
|||||||
sock_sendmsg+0x38/0x50
|
sock_sendmsg+0x38/0x50
|
||||||
SYSC_sendto+0xef/0x170
|
SYSC_sendto+0xef/0x170
|
||||||
} hitcount: 88
|
} hitcount: 88
|
||||||
{ stacktrace:
|
{ common_stacktrace:
|
||||||
kernel_clone+0x18e/0x330
|
kernel_clone+0x18e/0x330
|
||||||
SyS_clone+0x19/0x20
|
SyS_clone+0x19/0x20
|
||||||
entry_SYSCALL_64_fastpath+0x12/0x6a
|
entry_SYSCALL_64_fastpath+0x12/0x6a
|
||||||
@ -1949,7 +1949,7 @@ uninterruptible state::
|
|||||||
|
|
||||||
# cd /sys/kernel/tracing
|
# cd /sys/kernel/tracing
|
||||||
# echo 's:block_lat pid_t pid; u64 delta; unsigned long[] stack;' > dynamic_events
|
# echo 's:block_lat pid_t pid; u64 delta; unsigned long[] stack;' > dynamic_events
|
||||||
# echo 'hist:keys=next_pid:ts=common_timestamp.usecs,st=stacktrace if prev_state == 2' >> events/sched/sched_switch/trigger
|
# echo 'hist:keys=next_pid:ts=common_timestamp.usecs,st=common_stacktrace if prev_state == 2' >> events/sched/sched_switch/trigger
|
||||||
# echo 'hist:keys=prev_pid:delta=common_timestamp.usecs-$ts,s=$st:onmax($delta).trace(block_lat,prev_pid,$delta,$s)' >> events/sched/sched_switch/trigger
|
# echo 'hist:keys=prev_pid:delta=common_timestamp.usecs-$ts,s=$st:onmax($delta).trace(block_lat,prev_pid,$delta,$s)' >> events/sched/sched_switch/trigger
|
||||||
# echo 1 > events/synthetic/block_lat/enable
|
# echo 1 > events/synthetic/block_lat/enable
|
||||||
# cat trace
|
# cat trace
|
||||||
|
@ -363,7 +363,7 @@ Code Seq# Include File Comments
|
|||||||
0xCC 00-0F drivers/misc/ibmvmc.h pseries VMC driver
|
0xCC 00-0F drivers/misc/ibmvmc.h pseries VMC driver
|
||||||
0xCD 01 linux/reiserfs_fs.h
|
0xCD 01 linux/reiserfs_fs.h
|
||||||
0xCE 01-02 uapi/linux/cxl_mem.h Compute Express Link Memory Devices
|
0xCE 01-02 uapi/linux/cxl_mem.h Compute Express Link Memory Devices
|
||||||
0xCF 02 fs/cifs/ioctl.c
|
0xCF 02 fs/smb/client/cifs_ioctl.h
|
||||||
0xDB 00-0F drivers/char/mwave/mwavepub.h
|
0xDB 00-0F drivers/char/mwave/mwavepub.h
|
||||||
0xDD 00-3F ZFCP device driver see drivers/s390/scsi/
|
0xDD 00-3F ZFCP device driver see drivers/s390/scsi/
|
||||||
<mailto:aherrman@de.ibm.com>
|
<mailto:aherrman@de.ibm.com>
|
||||||
|
62
MAINTAINERS
62
MAINTAINERS
@ -956,7 +956,8 @@ F: Documentation/networking/device_drivers/ethernet/amazon/ena.rst
|
|||||||
F: drivers/net/ethernet/amazon/
|
F: drivers/net/ethernet/amazon/
|
||||||
|
|
||||||
AMAZON RDMA EFA DRIVER
|
AMAZON RDMA EFA DRIVER
|
||||||
M: Gal Pressman <galpress@amazon.com>
|
M: Michael Margolin <mrgolin@amazon.com>
|
||||||
|
R: Gal Pressman <gal.pressman@linux.dev>
|
||||||
R: Yossi Leybovich <sleybo@amazon.com>
|
R: Yossi Leybovich <sleybo@amazon.com>
|
||||||
L: linux-rdma@vger.kernel.org
|
L: linux-rdma@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -1600,7 +1601,7 @@ F: drivers/media/i2c/ar0521.c
|
|||||||
|
|
||||||
ARASAN NAND CONTROLLER DRIVER
|
ARASAN NAND CONTROLLER DRIVER
|
||||||
M: Miquel Raynal <miquel.raynal@bootlin.com>
|
M: Miquel Raynal <miquel.raynal@bootlin.com>
|
||||||
M: Naga Sureshkumar Relli <nagasure@xilinx.com>
|
R: Michal Simek <michal.simek@amd.com>
|
||||||
L: linux-mtd@lists.infradead.org
|
L: linux-mtd@lists.infradead.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/devicetree/bindings/mtd/arasan,nand-controller.yaml
|
F: Documentation/devicetree/bindings/mtd/arasan,nand-controller.yaml
|
||||||
@ -1677,10 +1678,7 @@ F: drivers/power/reset/arm-versatile-reboot.c
|
|||||||
F: drivers/soc/versatile/
|
F: drivers/soc/versatile/
|
||||||
|
|
||||||
ARM KOMEDA DRM-KMS DRIVER
|
ARM KOMEDA DRM-KMS DRIVER
|
||||||
M: James (Qian) Wang <james.qian.wang@arm.com>
|
|
||||||
M: Liviu Dudau <liviu.dudau@arm.com>
|
M: Liviu Dudau <liviu.dudau@arm.com>
|
||||||
M: Mihail Atanassov <mihail.atanassov@arm.com>
|
|
||||||
L: Mali DP Maintainers <malidp@foss.arm.com>
|
|
||||||
S: Supported
|
S: Supported
|
||||||
T: git git://anongit.freedesktop.org/drm/drm-misc
|
T: git git://anongit.freedesktop.org/drm/drm-misc
|
||||||
F: Documentation/devicetree/bindings/display/arm,komeda.yaml
|
F: Documentation/devicetree/bindings/display/arm,komeda.yaml
|
||||||
@ -1701,8 +1699,6 @@ F: include/uapi/drm/panfrost_drm.h
|
|||||||
|
|
||||||
ARM MALI-DP DRM DRIVER
|
ARM MALI-DP DRM DRIVER
|
||||||
M: Liviu Dudau <liviu.dudau@arm.com>
|
M: Liviu Dudau <liviu.dudau@arm.com>
|
||||||
M: Brian Starkey <brian.starkey@arm.com>
|
|
||||||
L: Mali DP Maintainers <malidp@foss.arm.com>
|
|
||||||
S: Supported
|
S: Supported
|
||||||
T: git git://anongit.freedesktop.org/drm/drm-misc
|
T: git git://anongit.freedesktop.org/drm/drm-misc
|
||||||
F: Documentation/devicetree/bindings/display/arm,malidp.yaml
|
F: Documentation/devicetree/bindings/display/arm,malidp.yaml
|
||||||
@ -1768,7 +1764,7 @@ F: include/linux/amba/mmci.h
|
|||||||
|
|
||||||
ARM PRIMECELL PL35X NAND CONTROLLER DRIVER
|
ARM PRIMECELL PL35X NAND CONTROLLER DRIVER
|
||||||
M: Miquel Raynal <miquel.raynal@bootlin.com>
|
M: Miquel Raynal <miquel.raynal@bootlin.com>
|
||||||
M: Naga Sureshkumar Relli <nagasure@xilinx.com>
|
R: Michal Simek <michal.simek@amd.com>
|
||||||
L: linux-mtd@lists.infradead.org
|
L: linux-mtd@lists.infradead.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/devicetree/bindings/mtd/arm,pl353-nand-r2p1.yaml
|
F: Documentation/devicetree/bindings/mtd/arm,pl353-nand-r2p1.yaml
|
||||||
@ -1776,7 +1772,7 @@ F: drivers/mtd/nand/raw/pl35x-nand-controller.c
|
|||||||
|
|
||||||
ARM PRIMECELL PL35X SMC DRIVER
|
ARM PRIMECELL PL35X SMC DRIVER
|
||||||
M: Miquel Raynal <miquel.raynal@bootlin.com>
|
M: Miquel Raynal <miquel.raynal@bootlin.com>
|
||||||
M: Naga Sureshkumar Relli <nagasure@xilinx.com>
|
R: Michal Simek <michal.simek@amd.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/memory-controllers/arm,pl35x-smc.yaml
|
F: Documentation/devicetree/bindings/memory-controllers/arm,pl35x-smc.yaml
|
||||||
@ -2434,6 +2430,15 @@ X: drivers/net/wireless/atmel/
|
|||||||
N: at91
|
N: at91
|
||||||
N: atmel
|
N: atmel
|
||||||
|
|
||||||
|
ARM/MICROCHIP (ARM64) SoC support
|
||||||
|
M: Conor Dooley <conor@kernel.org>
|
||||||
|
M: Nicolas Ferre <nicolas.ferre@microchip.com>
|
||||||
|
M: Claudiu Beznea <claudiu.beznea@microchip.com>
|
||||||
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
|
S: Supported
|
||||||
|
T: git https://git.kernel.org/pub/scm/linux/kernel/git/at91/linux.git
|
||||||
|
F: arch/arm64/boot/dts/microchip/
|
||||||
|
|
||||||
ARM/Microchip Sparx5 SoC support
|
ARM/Microchip Sparx5 SoC support
|
||||||
M: Lars Povlsen <lars.povlsen@microchip.com>
|
M: Lars Povlsen <lars.povlsen@microchip.com>
|
||||||
M: Steen Hegelund <Steen.Hegelund@microchip.com>
|
M: Steen Hegelund <Steen.Hegelund@microchip.com>
|
||||||
@ -2441,8 +2446,7 @@ M: Daniel Machon <daniel.machon@microchip.com>
|
|||||||
M: UNGLinuxDriver@microchip.com
|
M: UNGLinuxDriver@microchip.com
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Supported
|
S: Supported
|
||||||
T: git git://github.com/microchip-ung/linux-upstream.git
|
F: arch/arm64/boot/dts/microchip/sparx*
|
||||||
F: arch/arm64/boot/dts/microchip/
|
|
||||||
F: drivers/net/ethernet/microchip/vcap/
|
F: drivers/net/ethernet/microchip/vcap/
|
||||||
F: drivers/pinctrl/pinctrl-microchip-sgpio.c
|
F: drivers/pinctrl/pinctrl-microchip-sgpio.c
|
||||||
N: sparx5
|
N: sparx5
|
||||||
@ -3541,7 +3545,7 @@ F: Documentation/filesystems/befs.rst
|
|||||||
F: fs/befs/
|
F: fs/befs/
|
||||||
|
|
||||||
BFQ I/O SCHEDULER
|
BFQ I/O SCHEDULER
|
||||||
M: Paolo Valente <paolo.valente@linaro.org>
|
M: Paolo Valente <paolo.valente@unimore.it>
|
||||||
M: Jens Axboe <axboe@kernel.dk>
|
M: Jens Axboe <axboe@kernel.dk>
|
||||||
L: linux-block@vger.kernel.org
|
L: linux-block@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
@ -4914,7 +4918,6 @@ F: drivers/media/cec/i2c/ch7322.c
|
|||||||
CIRRUS LOGIC AUDIO CODEC DRIVERS
|
CIRRUS LOGIC AUDIO CODEC DRIVERS
|
||||||
M: James Schulman <james.schulman@cirrus.com>
|
M: James Schulman <james.schulman@cirrus.com>
|
||||||
M: David Rhodes <david.rhodes@cirrus.com>
|
M: David Rhodes <david.rhodes@cirrus.com>
|
||||||
M: Lucas Tanure <tanureal@opensource.cirrus.com>
|
|
||||||
M: Richard Fitzgerald <rf@opensource.cirrus.com>
|
M: Richard Fitzgerald <rf@opensource.cirrus.com>
|
||||||
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
||||||
L: patches@opensource.cirrus.com
|
L: patches@opensource.cirrus.com
|
||||||
@ -5136,7 +5139,7 @@ X: drivers/clk/clkdev.c
|
|||||||
|
|
||||||
COMMON INTERNET FILE SYSTEM CLIENT (CIFS and SMB3)
|
COMMON INTERNET FILE SYSTEM CLIENT (CIFS and SMB3)
|
||||||
M: Steve French <sfrench@samba.org>
|
M: Steve French <sfrench@samba.org>
|
||||||
R: Paulo Alcantara <pc@cjr.nz> (DFS, global name space)
|
R: Paulo Alcantara <pc@manguebit.com> (DFS, global name space)
|
||||||
R: Ronnie Sahlberg <lsahlber@redhat.com> (directory leases, sparse files)
|
R: Ronnie Sahlberg <lsahlber@redhat.com> (directory leases, sparse files)
|
||||||
R: Shyam Prasad N <sprasad@microsoft.com> (multichannel)
|
R: Shyam Prasad N <sprasad@microsoft.com> (multichannel)
|
||||||
R: Tom Talpey <tom@talpey.com> (RDMA, smbdirect)
|
R: Tom Talpey <tom@talpey.com> (RDMA, smbdirect)
|
||||||
@ -5146,8 +5149,8 @@ S: Supported
|
|||||||
W: https://wiki.samba.org/index.php/LinuxCIFS
|
W: https://wiki.samba.org/index.php/LinuxCIFS
|
||||||
T: git git://git.samba.org/sfrench/cifs-2.6.git
|
T: git git://git.samba.org/sfrench/cifs-2.6.git
|
||||||
F: Documentation/admin-guide/cifs/
|
F: Documentation/admin-guide/cifs/
|
||||||
F: fs/cifs/
|
F: fs/smb/client/
|
||||||
F: fs/smbfs_common/
|
F: fs/smb/common/
|
||||||
F: include/uapi/linux/cifs
|
F: include/uapi/linux/cifs
|
||||||
|
|
||||||
COMPACTPCI HOTPLUG CORE
|
COMPACTPCI HOTPLUG CORE
|
||||||
@ -6012,7 +6015,7 @@ W: http://www.dialog-semiconductor.com/products
|
|||||||
F: Documentation/devicetree/bindings/input/da90??-onkey.txt
|
F: Documentation/devicetree/bindings/input/da90??-onkey.txt
|
||||||
F: Documentation/devicetree/bindings/input/dlg,da72??.txt
|
F: Documentation/devicetree/bindings/input/dlg,da72??.txt
|
||||||
F: Documentation/devicetree/bindings/mfd/da90*.txt
|
F: Documentation/devicetree/bindings/mfd/da90*.txt
|
||||||
F: Documentation/devicetree/bindings/mfd/da90*.yaml
|
F: Documentation/devicetree/bindings/mfd/dlg,da90*.yaml
|
||||||
F: Documentation/devicetree/bindings/regulator/da92*.txt
|
F: Documentation/devicetree/bindings/regulator/da92*.txt
|
||||||
F: Documentation/devicetree/bindings/regulator/dlg,da9*.yaml
|
F: Documentation/devicetree/bindings/regulator/dlg,da9*.yaml
|
||||||
F: Documentation/devicetree/bindings/regulator/slg51000.txt
|
F: Documentation/devicetree/bindings/regulator/slg51000.txt
|
||||||
@ -6211,6 +6214,7 @@ X: Documentation/devicetree/
|
|||||||
X: Documentation/driver-api/media/
|
X: Documentation/driver-api/media/
|
||||||
X: Documentation/firmware-guide/acpi/
|
X: Documentation/firmware-guide/acpi/
|
||||||
X: Documentation/i2c/
|
X: Documentation/i2c/
|
||||||
|
X: Documentation/netlink/
|
||||||
X: Documentation/power/
|
X: Documentation/power/
|
||||||
X: Documentation/spi/
|
X: Documentation/spi/
|
||||||
X: Documentation/userspace-api/media/
|
X: Documentation/userspace-api/media/
|
||||||
@ -8158,6 +8162,7 @@ F: include/linux/spi/spi-fsl-dspi.h
|
|||||||
|
|
||||||
FREESCALE ENETC ETHERNET DRIVERS
|
FREESCALE ENETC ETHERNET DRIVERS
|
||||||
M: Claudiu Manoil <claudiu.manoil@nxp.com>
|
M: Claudiu Manoil <claudiu.manoil@nxp.com>
|
||||||
|
M: Vladimir Oltean <vladimir.oltean@nxp.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/net/ethernet/freescale/enetc/
|
F: drivers/net/ethernet/freescale/enetc/
|
||||||
@ -9339,7 +9344,7 @@ F: include/linux/hisi_acc_qm.h
|
|||||||
|
|
||||||
HISILICON ROCE DRIVER
|
HISILICON ROCE DRIVER
|
||||||
M: Haoyue Xu <xuhaoyue1@hisilicon.com>
|
M: Haoyue Xu <xuhaoyue1@hisilicon.com>
|
||||||
M: Wenpeng Liang <liangwenpeng@huawei.com>
|
M: Junxian Huang <huangjunxian6@hisilicon.com>
|
||||||
L: linux-rdma@vger.kernel.org
|
L: linux-rdma@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/devicetree/bindings/infiniband/hisilicon-hns-roce.txt
|
F: Documentation/devicetree/bindings/infiniband/hisilicon-hns-roce.txt
|
||||||
@ -10110,7 +10115,7 @@ S: Maintained
|
|||||||
F: Documentation/process/kernel-docs.rst
|
F: Documentation/process/kernel-docs.rst
|
||||||
|
|
||||||
INDUSTRY PACK SUBSYSTEM (IPACK)
|
INDUSTRY PACK SUBSYSTEM (IPACK)
|
||||||
M: Samuel Iglesias Gonsalvez <siglesias@igalia.com>
|
M: Vaibhav Gupta <vaibhavgupta40@gmail.com>
|
||||||
M: Jens Taprogge <jens.taprogge@taprogge.org>
|
M: Jens Taprogge <jens.taprogge@taprogge.org>
|
||||||
M: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
M: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
||||||
L: industrypack-devel@lists.sourceforge.net
|
L: industrypack-devel@lists.sourceforge.net
|
||||||
@ -11305,9 +11310,9 @@ R: Tom Talpey <tom@talpey.com>
|
|||||||
L: linux-cifs@vger.kernel.org
|
L: linux-cifs@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
T: git git://git.samba.org/ksmbd.git
|
T: git git://git.samba.org/ksmbd.git
|
||||||
F: Documentation/filesystems/cifs/ksmbd.rst
|
F: Documentation/filesystems/smb/ksmbd.rst
|
||||||
F: fs/ksmbd/
|
F: fs/smb/common/
|
||||||
F: fs/smbfs_common/
|
F: fs/smb/server/
|
||||||
|
|
||||||
KERNEL UNIT TESTING FRAMEWORK (KUnit)
|
KERNEL UNIT TESTING FRAMEWORK (KUnit)
|
||||||
M: Brendan Higgins <brendanhiggins@google.com>
|
M: Brendan Higgins <brendanhiggins@google.com>
|
||||||
@ -13832,7 +13837,7 @@ F: drivers/tty/serial/8250/8250_pci1xxxx.c
|
|||||||
|
|
||||||
MICROCHIP POLARFIRE FPGA DRIVERS
|
MICROCHIP POLARFIRE FPGA DRIVERS
|
||||||
M: Conor Dooley <conor.dooley@microchip.com>
|
M: Conor Dooley <conor.dooley@microchip.com>
|
||||||
R: Ivan Bornyakov <i.bornyakov@metrotek.ru>
|
R: Vladimir Georgiev <v.georgiev@metrotek.ru>
|
||||||
L: linux-fpga@vger.kernel.org
|
L: linux-fpga@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/devicetree/bindings/fpga/microchip,mpf-spi-fpga-mgr.yaml
|
F: Documentation/devicetree/bindings/fpga/microchip,mpf-spi-fpga-mgr.yaml
|
||||||
@ -14566,6 +14571,7 @@ T: git git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next.git
|
|||||||
F: Documentation/devicetree/bindings/net/
|
F: Documentation/devicetree/bindings/net/
|
||||||
F: drivers/connector/
|
F: drivers/connector/
|
||||||
F: drivers/net/
|
F: drivers/net/
|
||||||
|
X: drivers/net/wireless/
|
||||||
F: include/dt-bindings/net/
|
F: include/dt-bindings/net/
|
||||||
F: include/linux/etherdevice.h
|
F: include/linux/etherdevice.h
|
||||||
F: include/linux/fcdevice.h
|
F: include/linux/fcdevice.h
|
||||||
@ -14615,6 +14621,7 @@ B: mailto:netdev@vger.kernel.org
|
|||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net.git
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next.git
|
||||||
F: Documentation/core-api/netlink.rst
|
F: Documentation/core-api/netlink.rst
|
||||||
|
F: Documentation/netlink/
|
||||||
F: Documentation/networking/
|
F: Documentation/networking/
|
||||||
F: Documentation/process/maintainer-netdev.rst
|
F: Documentation/process/maintainer-netdev.rst
|
||||||
F: Documentation/userspace-api/netlink/
|
F: Documentation/userspace-api/netlink/
|
||||||
@ -14629,6 +14636,7 @@ F: include/uapi/linux/netdevice.h
|
|||||||
F: lib/net_utils.c
|
F: lib/net_utils.c
|
||||||
F: lib/random32.c
|
F: lib/random32.c
|
||||||
F: net/
|
F: net/
|
||||||
|
X: net/bluetooth/
|
||||||
F: tools/net/
|
F: tools/net/
|
||||||
F: tools/testing/selftests/net/
|
F: tools/testing/selftests/net/
|
||||||
|
|
||||||
@ -14928,6 +14936,7 @@ F: drivers/ntb/hw/intel/
|
|||||||
|
|
||||||
NTFS FILESYSTEM
|
NTFS FILESYSTEM
|
||||||
M: Anton Altaparmakov <anton@tuxera.com>
|
M: Anton Altaparmakov <anton@tuxera.com>
|
||||||
|
R: Namjae Jeon <linkinjeon@kernel.org>
|
||||||
L: linux-ntfs-dev@lists.sourceforge.net
|
L: linux-ntfs-dev@lists.sourceforge.net
|
||||||
S: Supported
|
S: Supported
|
||||||
W: http://www.tuxera.com/
|
W: http://www.tuxera.com/
|
||||||
@ -18583,10 +18592,9 @@ F: Documentation/admin-guide/LSM/SafeSetID.rst
|
|||||||
F: security/safesetid/
|
F: security/safesetid/
|
||||||
|
|
||||||
SAMSUNG AUDIO (ASoC) DRIVERS
|
SAMSUNG AUDIO (ASoC) DRIVERS
|
||||||
M: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
|
|
||||||
M: Sylwester Nawrocki <s.nawrocki@samsung.com>
|
M: Sylwester Nawrocki <s.nawrocki@samsung.com>
|
||||||
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
||||||
S: Supported
|
S: Maintained
|
||||||
B: mailto:linux-samsung-soc@vger.kernel.org
|
B: mailto:linux-samsung-soc@vger.kernel.org
|
||||||
F: Documentation/devicetree/bindings/sound/samsung*
|
F: Documentation/devicetree/bindings/sound/samsung*
|
||||||
F: sound/soc/samsung/
|
F: sound/soc/samsung/
|
||||||
@ -18714,7 +18722,6 @@ F: include/dt-bindings/clock/samsung,*.h
|
|||||||
F: include/linux/clk/samsung.h
|
F: include/linux/clk/samsung.h
|
||||||
|
|
||||||
SAMSUNG SPI DRIVERS
|
SAMSUNG SPI DRIVERS
|
||||||
M: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
|
|
||||||
M: Andi Shyti <andi.shyti@kernel.org>
|
M: Andi Shyti <andi.shyti@kernel.org>
|
||||||
L: linux-spi@vger.kernel.org
|
L: linux-spi@vger.kernel.org
|
||||||
L: linux-samsung-soc@vger.kernel.org
|
L: linux-samsung-soc@vger.kernel.org
|
||||||
@ -18850,12 +18857,11 @@ F: drivers/target/
|
|||||||
F: include/target/
|
F: include/target/
|
||||||
|
|
||||||
SCTP PROTOCOL
|
SCTP PROTOCOL
|
||||||
M: Neil Horman <nhorman@tuxdriver.com>
|
|
||||||
M: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
|
M: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
|
||||||
M: Xin Long <lucien.xin@gmail.com>
|
M: Xin Long <lucien.xin@gmail.com>
|
||||||
L: linux-sctp@vger.kernel.org
|
L: linux-sctp@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
W: http://lksctp.sourceforge.net
|
W: https://github.com/sctp/lksctp-tools/wiki
|
||||||
F: Documentation/networking/sctp.rst
|
F: Documentation/networking/sctp.rst
|
||||||
F: include/linux/sctp.h
|
F: include/linux/sctp.h
|
||||||
F: include/net/sctp/
|
F: include/net/sctp/
|
||||||
|
2
Makefile
2
Makefile
@ -2,7 +2,7 @@
|
|||||||
VERSION = 6
|
VERSION = 6
|
||||||
PATCHLEVEL = 4
|
PATCHLEVEL = 4
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc2
|
EXTRAVERSION = -rc5
|
||||||
NAME = Hurr durr I'ma ninja sloth
|
NAME = Hurr durr I'ma ninja sloth
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -209,6 +209,7 @@ &pcie {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_pcie>;
|
pinctrl-0 = <&pinctrl_pcie>;
|
||||||
reset-gpio = <&gpio6 7 GPIO_ACTIVE_LOW>;
|
reset-gpio = <&gpio6 7 GPIO_ACTIVE_LOW>;
|
||||||
|
vpcie-supply = <®_pcie>;
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include <dt-bindings/input/input.h>
|
#include <dt-bindings/input/input.h>
|
||||||
#include <dt-bindings/leds/common.h>
|
#include <dt-bindings/leds/common.h>
|
||||||
#include <dt-bindings/pwm/pwm.h>
|
#include <dt-bindings/pwm/pwm.h>
|
||||||
|
#include <dt-bindings/regulator/dlg,da9063-regulator.h>
|
||||||
#include "imx6ull.dtsi"
|
#include "imx6ull.dtsi"
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
@ -84,16 +85,20 @@ onkey {
|
|||||||
|
|
||||||
regulators {
|
regulators {
|
||||||
vdd_soc_in_1v4: buck1 {
|
vdd_soc_in_1v4: buck1 {
|
||||||
|
regulator-allowed-modes = <DA9063_BUCK_MODE_SLEEP>; /* PFM */
|
||||||
regulator-always-on;
|
regulator-always-on;
|
||||||
regulator-boot-on;
|
regulator-boot-on;
|
||||||
|
regulator-initial-mode = <DA9063_BUCK_MODE_SLEEP>;
|
||||||
regulator-max-microvolt = <1400000>;
|
regulator-max-microvolt = <1400000>;
|
||||||
regulator-min-microvolt = <1400000>;
|
regulator-min-microvolt = <1400000>;
|
||||||
regulator-name = "vdd_soc_in_1v4";
|
regulator-name = "vdd_soc_in_1v4";
|
||||||
};
|
};
|
||||||
|
|
||||||
vcc_3v3: buck2 {
|
vcc_3v3: buck2 {
|
||||||
|
regulator-allowed-modes = <DA9063_BUCK_MODE_SYNC>; /* PWM */
|
||||||
regulator-always-on;
|
regulator-always-on;
|
||||||
regulator-boot-on;
|
regulator-boot-on;
|
||||||
|
regulator-initial-mode = <DA9063_BUCK_MODE_SYNC>;
|
||||||
regulator-max-microvolt = <3300000>;
|
regulator-max-microvolt = <3300000>;
|
||||||
regulator-min-microvolt = <3300000>;
|
regulator-min-microvolt = <3300000>;
|
||||||
regulator-name = "vcc_3v3";
|
regulator-name = "vcc_3v3";
|
||||||
@ -106,8 +111,10 @@ vcc_3v3: buck2 {
|
|||||||
* the voltage is set to 1.5V.
|
* the voltage is set to 1.5V.
|
||||||
*/
|
*/
|
||||||
vcc_ddr_1v35: buck3 {
|
vcc_ddr_1v35: buck3 {
|
||||||
|
regulator-allowed-modes = <DA9063_BUCK_MODE_SYNC>; /* PWM */
|
||||||
regulator-always-on;
|
regulator-always-on;
|
||||||
regulator-boot-on;
|
regulator-boot-on;
|
||||||
|
regulator-initial-mode = <DA9063_BUCK_MODE_SYNC>;
|
||||||
regulator-max-microvolt = <1500000>;
|
regulator-max-microvolt = <1500000>;
|
||||||
regulator-min-microvolt = <1500000>;
|
regulator-min-microvolt = <1500000>;
|
||||||
regulator-name = "vcc_ddr_1v35";
|
regulator-name = "vcc_ddr_1v35";
|
||||||
|
@ -387,6 +387,7 @@ can2: can@40006800 {
|
|||||||
interrupt-names = "tx", "rx0", "rx1", "sce";
|
interrupt-names = "tx", "rx0", "rx1", "sce";
|
||||||
resets = <&rcc STM32F4_APB1_RESET(CAN2)>;
|
resets = <&rcc STM32F4_APB1_RESET(CAN2)>;
|
||||||
clocks = <&rcc 0 STM32F4_APB1_CLOCK(CAN2)>;
|
clocks = <&rcc 0 STM32F4_APB1_CLOCK(CAN2)>;
|
||||||
|
st,can-secondary;
|
||||||
st,gcan = <&gcan>;
|
st,gcan = <&gcan>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
@ -283,6 +283,88 @@ pins2 {
|
|||||||
slew-rate = <2>;
|
slew-rate = <2>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
can1_pins_a: can1-0 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('A', 12, AF9)>; /* CAN1_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('A', 11, AF9)>; /* CAN1_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can1_pins_b: can1-1 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 9, AF9)>; /* CAN1_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 8, AF9)>; /* CAN1_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can1_pins_c: can1-2 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('D', 1, AF9)>; /* CAN1_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('D', 0, AF9)>; /* CAN1_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can1_pins_d: can1-3 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('H', 13, AF9)>; /* CAN1_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('H', 14, AF9)>; /* CAN1_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can2_pins_a: can2-0 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 6, AF9)>; /* CAN2_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 5, AF9)>; /* CAN2_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can2_pins_b: can2-1 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 13, AF9)>; /* CAN2_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 12, AF9)>; /* CAN2_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can3_pins_a: can3-0 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('A', 15, AF11)>; /* CAN3_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('A', 8, AF11)>; /* CAN3_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
can3_pins_b: can3-1 {
|
||||||
|
pins1 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 4, AF11)>; /* CAN3_TX */
|
||||||
|
};
|
||||||
|
pins2 {
|
||||||
|
pinmux = <STM32_PINMUX('B', 3, AF11)>; /* CAN3_RX */
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -132,6 +132,7 @@ L2: cache-controller@2c0f0000 {
|
|||||||
reg = <0x2c0f0000 0x1000>;
|
reg = <0x2c0f0000 0x1000>;
|
||||||
interrupts = <0 84 4>;
|
interrupts = <0 84 4>;
|
||||||
cache-level = <2>;
|
cache-level = <2>;
|
||||||
|
cache-unified;
|
||||||
};
|
};
|
||||||
|
|
||||||
pmu {
|
pmu {
|
||||||
|
@ -92,7 +92,7 @@
|
|||||||
|
|
||||||
#define RETURN_READ_PMEVCNTRN(n) \
|
#define RETURN_READ_PMEVCNTRN(n) \
|
||||||
return read_sysreg(PMEVCNTR##n)
|
return read_sysreg(PMEVCNTR##n)
|
||||||
static unsigned long read_pmevcntrn(int n)
|
static inline unsigned long read_pmevcntrn(int n)
|
||||||
{
|
{
|
||||||
PMEVN_SWITCH(n, RETURN_READ_PMEVCNTRN);
|
PMEVN_SWITCH(n, RETURN_READ_PMEVCNTRN);
|
||||||
return 0;
|
return 0;
|
||||||
@ -100,14 +100,14 @@ static unsigned long read_pmevcntrn(int n)
|
|||||||
|
|
||||||
#define WRITE_PMEVCNTRN(n) \
|
#define WRITE_PMEVCNTRN(n) \
|
||||||
write_sysreg(val, PMEVCNTR##n)
|
write_sysreg(val, PMEVCNTR##n)
|
||||||
static void write_pmevcntrn(int n, unsigned long val)
|
static inline void write_pmevcntrn(int n, unsigned long val)
|
||||||
{
|
{
|
||||||
PMEVN_SWITCH(n, WRITE_PMEVCNTRN);
|
PMEVN_SWITCH(n, WRITE_PMEVCNTRN);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define WRITE_PMEVTYPERN(n) \
|
#define WRITE_PMEVTYPERN(n) \
|
||||||
write_sysreg(val, PMEVTYPER##n)
|
write_sysreg(val, PMEVTYPER##n)
|
||||||
static void write_pmevtypern(int n, unsigned long val)
|
static inline void write_pmevtypern(int n, unsigned long val)
|
||||||
{
|
{
|
||||||
PMEVN_SWITCH(n, WRITE_PMEVTYPERN);
|
PMEVN_SWITCH(n, WRITE_PMEVTYPERN);
|
||||||
}
|
}
|
||||||
|
@ -59,6 +59,7 @@ cpu3: cpu@3 {
|
|||||||
L2_0: l2-cache0 {
|
L2_0: l2-cache0 {
|
||||||
compatible = "cache";
|
compatible = "cache";
|
||||||
cache-level = <2>;
|
cache-level = <2>;
|
||||||
|
cache-unified;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -72,6 +72,7 @@ cpu@3 {
|
|||||||
L2_0: l2-cache0 {
|
L2_0: l2-cache0 {
|
||||||
compatible = "cache";
|
compatible = "cache";
|
||||||
cache-level = <2>;
|
cache-level = <2>;
|
||||||
|
cache-unified;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -58,6 +58,7 @@ cpu@1 {
|
|||||||
L2_0: l2-cache0 {
|
L2_0: l2-cache0 {
|
||||||
compatible = "cache";
|
compatible = "cache";
|
||||||
cache-level = <2>;
|
cache-level = <2>;
|
||||||
|
cache-unified;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -171,6 +171,7 @@ usbotg3_cdns3: usb@5b120000 {
|
|||||||
interrupt-names = "host", "peripheral", "otg", "wakeup";
|
interrupt-names = "host", "peripheral", "otg", "wakeup";
|
||||||
phys = <&usb3_phy>;
|
phys = <&usb3_phy>;
|
||||||
phy-names = "cdns3,usb3-phy";
|
phy-names = "cdns3,usb3-phy";
|
||||||
|
cdns,on-chip-buff-size = /bits/ 16 <18>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -98,11 +98,17 @@ mdio {
|
|||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
|
|
||||||
ethphy: ethernet-phy@4 {
|
ethphy: ethernet-phy@4 { /* AR8033 or ADIN1300 */
|
||||||
compatible = "ethernet-phy-ieee802.3-c22";
|
compatible = "ethernet-phy-ieee802.3-c22";
|
||||||
reg = <4>;
|
reg = <4>;
|
||||||
reset-gpios = <&gpio1 9 GPIO_ACTIVE_LOW>;
|
reset-gpios = <&gpio1 9 GPIO_ACTIVE_LOW>;
|
||||||
reset-assert-us = <10000>;
|
reset-assert-us = <10000>;
|
||||||
|
/*
|
||||||
|
* Deassert delay:
|
||||||
|
* ADIN1300 requires 5ms.
|
||||||
|
* AR8033 requires 1ms.
|
||||||
|
*/
|
||||||
|
reset-deassert-us = <20000>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -1069,13 +1069,6 @@ lcdif: lcdif@32e00000 {
|
|||||||
<&clk IMX8MN_CLK_DISP_APB_ROOT>,
|
<&clk IMX8MN_CLK_DISP_APB_ROOT>,
|
||||||
<&clk IMX8MN_CLK_DISP_AXI_ROOT>;
|
<&clk IMX8MN_CLK_DISP_AXI_ROOT>;
|
||||||
clock-names = "pix", "axi", "disp_axi";
|
clock-names = "pix", "axi", "disp_axi";
|
||||||
assigned-clocks = <&clk IMX8MN_CLK_DISP_PIXEL_ROOT>,
|
|
||||||
<&clk IMX8MN_CLK_DISP_AXI>,
|
|
||||||
<&clk IMX8MN_CLK_DISP_APB>;
|
|
||||||
assigned-clock-parents = <&clk IMX8MN_CLK_DISP_PIXEL>,
|
|
||||||
<&clk IMX8MN_SYS_PLL2_1000M>,
|
|
||||||
<&clk IMX8MN_SYS_PLL1_800M>;
|
|
||||||
assigned-clock-rates = <594000000>, <500000000>, <200000000>;
|
|
||||||
interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
power-domains = <&disp_blk_ctrl IMX8MN_DISPBLK_PD_LCDIF>;
|
power-domains = <&disp_blk_ctrl IMX8MN_DISPBLK_PD_LCDIF>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
@ -1093,12 +1086,6 @@ mipi_dsi: dsi@32e10000 {
|
|||||||
clocks = <&clk IMX8MN_CLK_DSI_CORE>,
|
clocks = <&clk IMX8MN_CLK_DSI_CORE>,
|
||||||
<&clk IMX8MN_CLK_DSI_PHY_REF>;
|
<&clk IMX8MN_CLK_DSI_PHY_REF>;
|
||||||
clock-names = "bus_clk", "sclk_mipi";
|
clock-names = "bus_clk", "sclk_mipi";
|
||||||
assigned-clocks = <&clk IMX8MN_CLK_DSI_CORE>,
|
|
||||||
<&clk IMX8MN_CLK_DSI_PHY_REF>;
|
|
||||||
assigned-clock-parents = <&clk IMX8MN_SYS_PLL1_266M>,
|
|
||||||
<&clk IMX8MN_CLK_24M>;
|
|
||||||
assigned-clock-rates = <266000000>, <24000000>;
|
|
||||||
samsung,pll-clock-frequency = <24000000>;
|
|
||||||
interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
power-domains = <&disp_blk_ctrl IMX8MN_DISPBLK_PD_MIPI_DSI>;
|
power-domains = <&disp_blk_ctrl IMX8MN_DISPBLK_PD_MIPI_DSI>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
@ -1142,6 +1129,21 @@ disp_blk_ctrl: blk-ctrl@32e28000 {
|
|||||||
"lcdif-axi", "lcdif-apb", "lcdif-pix",
|
"lcdif-axi", "lcdif-apb", "lcdif-pix",
|
||||||
"dsi-pclk", "dsi-ref",
|
"dsi-pclk", "dsi-ref",
|
||||||
"csi-aclk", "csi-pclk";
|
"csi-aclk", "csi-pclk";
|
||||||
|
assigned-clocks = <&clk IMX8MN_CLK_DSI_CORE>,
|
||||||
|
<&clk IMX8MN_CLK_DSI_PHY_REF>,
|
||||||
|
<&clk IMX8MN_CLK_DISP_PIXEL>,
|
||||||
|
<&clk IMX8MN_CLK_DISP_AXI>,
|
||||||
|
<&clk IMX8MN_CLK_DISP_APB>;
|
||||||
|
assigned-clock-parents = <&clk IMX8MN_SYS_PLL1_266M>,
|
||||||
|
<&clk IMX8MN_CLK_24M>,
|
||||||
|
<&clk IMX8MN_VIDEO_PLL1_OUT>,
|
||||||
|
<&clk IMX8MN_SYS_PLL2_1000M>,
|
||||||
|
<&clk IMX8MN_SYS_PLL1_800M>;
|
||||||
|
assigned-clock-rates = <266000000>,
|
||||||
|
<24000000>,
|
||||||
|
<594000000>,
|
||||||
|
<500000000>,
|
||||||
|
<200000000>;
|
||||||
#power-domain-cells = <1>;
|
#power-domain-cells = <1>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1211,13 +1211,6 @@ lcdif1: display-controller@32e80000 {
|
|||||||
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
||||||
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
||||||
clock-names = "pix", "axi", "disp_axi";
|
clock-names = "pix", "axi", "disp_axi";
|
||||||
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_DISP1_PIX_ROOT>,
|
|
||||||
<&clk IMX8MP_CLK_MEDIA_AXI>,
|
|
||||||
<&clk IMX8MP_CLK_MEDIA_APB>;
|
|
||||||
assigned-clock-parents = <&clk IMX8MP_CLK_MEDIA_DISP1_PIX>,
|
|
||||||
<&clk IMX8MP_SYS_PLL2_1000M>,
|
|
||||||
<&clk IMX8MP_SYS_PLL1_800M>;
|
|
||||||
assigned-clock-rates = <594000000>, <500000000>, <200000000>;
|
|
||||||
interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_LCDIF_1>;
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_LCDIF_1>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
@ -1237,11 +1230,6 @@ lcdif2: display-controller@32e90000 {
|
|||||||
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
||||||
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
||||||
clock-names = "pix", "axi", "disp_axi";
|
clock-names = "pix", "axi", "disp_axi";
|
||||||
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_DISP2_PIX>,
|
|
||||||
<&clk IMX8MP_VIDEO_PLL1>;
|
|
||||||
assigned-clock-parents = <&clk IMX8MP_VIDEO_PLL1_OUT>,
|
|
||||||
<&clk IMX8MP_VIDEO_PLL1_REF_SEL>;
|
|
||||||
assigned-clock-rates = <0>, <1039500000>;
|
|
||||||
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_LCDIF_2>;
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_LCDIF_2>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
||||||
@ -1296,11 +1284,16 @@ media_blk_ctrl: blk-ctrl@32ec0000 {
|
|||||||
"disp1", "disp2", "isp", "phy";
|
"disp1", "disp2", "isp", "phy";
|
||||||
|
|
||||||
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_AXI>,
|
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_AXI>,
|
||||||
<&clk IMX8MP_CLK_MEDIA_APB>;
|
<&clk IMX8MP_CLK_MEDIA_APB>,
|
||||||
|
<&clk IMX8MP_CLK_MEDIA_DISP1_PIX>,
|
||||||
|
<&clk IMX8MP_CLK_MEDIA_DISP2_PIX>,
|
||||||
|
<&clk IMX8MP_VIDEO_PLL1>;
|
||||||
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_1000M>,
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_1000M>,
|
||||||
<&clk IMX8MP_SYS_PLL1_800M>;
|
<&clk IMX8MP_SYS_PLL1_800M>,
|
||||||
assigned-clock-rates = <500000000>, <200000000>;
|
<&clk IMX8MP_VIDEO_PLL1_OUT>,
|
||||||
|
<&clk IMX8MP_VIDEO_PLL1_OUT>;
|
||||||
|
assigned-clock-rates = <500000000>, <200000000>,
|
||||||
|
<0>, <0>, <1039500000>;
|
||||||
#power-domain-cells = <1>;
|
#power-domain-cells = <1>;
|
||||||
|
|
||||||
lvds_bridge: bridge@5c {
|
lvds_bridge: bridge@5c {
|
||||||
|
@ -33,6 +33,12 @@ rtc_i2c: rtc@68 {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&iomuxc {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&pinctrl_ext_io0>, <&pinctrl_hog0>, <&pinctrl_hog1>,
|
||||||
|
<&pinctrl_lpspi2_cs2>;
|
||||||
|
};
|
||||||
|
|
||||||
/* Colibri SPI */
|
/* Colibri SPI */
|
||||||
&lpspi2 {
|
&lpspi2 {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -48,8 +48,7 @@ pinctrl_gpio_iris: gpioirisgrp {
|
|||||||
<IMX8QXP_SAI0_TXFS_LSIO_GPIO0_IO28 0x20>, /* SODIMM 101 */
|
<IMX8QXP_SAI0_TXFS_LSIO_GPIO0_IO28 0x20>, /* SODIMM 101 */
|
||||||
<IMX8QXP_SAI0_RXD_LSIO_GPIO0_IO27 0x20>, /* SODIMM 97 */
|
<IMX8QXP_SAI0_RXD_LSIO_GPIO0_IO27 0x20>, /* SODIMM 97 */
|
||||||
<IMX8QXP_ENET0_RGMII_RXC_LSIO_GPIO5_IO03 0x06000020>, /* SODIMM 85 */
|
<IMX8QXP_ENET0_RGMII_RXC_LSIO_GPIO5_IO03 0x06000020>, /* SODIMM 85 */
|
||||||
<IMX8QXP_SAI0_TXC_LSIO_GPIO0_IO26 0x20>, /* SODIMM 79 */
|
<IMX8QXP_SAI0_TXC_LSIO_GPIO0_IO26 0x20>; /* SODIMM 79 */
|
||||||
<IMX8QXP_QSPI0A_DATA1_LSIO_GPIO3_IO10 0x06700041>; /* SODIMM 45 */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
pinctrl_uart1_forceoff: uart1forceoffgrp {
|
pinctrl_uart1_forceoff: uart1forceoffgrp {
|
||||||
|
@ -363,10 +363,6 @@ &usdhc2 {
|
|||||||
/* TODO VPU Encoder/Decoder */
|
/* TODO VPU Encoder/Decoder */
|
||||||
|
|
||||||
&iomuxc {
|
&iomuxc {
|
||||||
pinctrl-names = "default";
|
|
||||||
pinctrl-0 = <&pinctrl_ext_io0>, <&pinctrl_hog0>, <&pinctrl_hog1>,
|
|
||||||
<&pinctrl_hog2>, <&pinctrl_lpspi2_cs2>;
|
|
||||||
|
|
||||||
/* On-module touch pen-down interrupt */
|
/* On-module touch pen-down interrupt */
|
||||||
pinctrl_ad7879_int: ad7879intgrp {
|
pinctrl_ad7879_int: ad7879intgrp {
|
||||||
fsl,pins = <IMX8QXP_MIPI_CSI0_I2C0_SCL_LSIO_GPIO3_IO05 0x21>;
|
fsl,pins = <IMX8QXP_MIPI_CSI0_I2C0_SCL_LSIO_GPIO3_IO05 0x21>;
|
||||||
@ -499,8 +495,7 @@ pinctrl_hog0: hog0grp {
|
|||||||
};
|
};
|
||||||
|
|
||||||
pinctrl_hog1: hog1grp {
|
pinctrl_hog1: hog1grp {
|
||||||
fsl,pins = <IMX8QXP_CSI_MCLK_LSIO_GPIO3_IO01 0x20>, /* SODIMM 75 */
|
fsl,pins = <IMX8QXP_QSPI0A_SCLK_LSIO_GPIO3_IO16 0x20>; /* SODIMM 93 */
|
||||||
<IMX8QXP_QSPI0A_SCLK_LSIO_GPIO3_IO16 0x20>; /* SODIMM 93 */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
pinctrl_hog2: hog2grp {
|
pinctrl_hog2: hog2grp {
|
||||||
@ -774,3 +769,10 @@ pinctrl_wifi: wifigrp {
|
|||||||
fsl,pins = <IMX8QXP_SCU_BOOT_MODE3_SCU_DSC_RTC_CLOCK_OUTPUT_32K 0x20>;
|
fsl,pins = <IMX8QXP_SCU_BOOT_MODE3_SCU_DSC_RTC_CLOCK_OUTPUT_32K 0x20>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Delete peripherals which are not present on SOC, but are defined in imx8-ss-*.dtsi */
|
||||||
|
|
||||||
|
/delete-node/ &adc1;
|
||||||
|
/delete-node/ &adc1_lpcg;
|
||||||
|
/delete-node/ &dsp;
|
||||||
|
/delete-node/ &dsp_lpcg;
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#define RETURN_READ_PMEVCNTRN(n) \
|
#define RETURN_READ_PMEVCNTRN(n) \
|
||||||
return read_sysreg(pmevcntr##n##_el0)
|
return read_sysreg(pmevcntr##n##_el0)
|
||||||
static unsigned long read_pmevcntrn(int n)
|
static inline unsigned long read_pmevcntrn(int n)
|
||||||
{
|
{
|
||||||
PMEVN_SWITCH(n, RETURN_READ_PMEVCNTRN);
|
PMEVN_SWITCH(n, RETURN_READ_PMEVCNTRN);
|
||||||
return 0;
|
return 0;
|
||||||
@ -21,14 +21,14 @@ static unsigned long read_pmevcntrn(int n)
|
|||||||
|
|
||||||
#define WRITE_PMEVCNTRN(n) \
|
#define WRITE_PMEVCNTRN(n) \
|
||||||
write_sysreg(val, pmevcntr##n##_el0)
|
write_sysreg(val, pmevcntr##n##_el0)
|
||||||
static void write_pmevcntrn(int n, unsigned long val)
|
static inline void write_pmevcntrn(int n, unsigned long val)
|
||||||
{
|
{
|
||||||
PMEVN_SWITCH(n, WRITE_PMEVCNTRN);
|
PMEVN_SWITCH(n, WRITE_PMEVCNTRN);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define WRITE_PMEVTYPERN(n) \
|
#define WRITE_PMEVTYPERN(n) \
|
||||||
write_sysreg(val, pmevtyper##n##_el0)
|
write_sysreg(val, pmevtyper##n##_el0)
|
||||||
static void write_pmevtypern(int n, unsigned long val)
|
static inline void write_pmevtypern(int n, unsigned long val)
|
||||||
{
|
{
|
||||||
PMEVN_SWITCH(n, WRITE_PMEVTYPERN);
|
PMEVN_SWITCH(n, WRITE_PMEVTYPERN);
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,10 @@
|
|||||||
#define APPLE_CPU_PART_M1_FIRESTORM_MAX 0x029
|
#define APPLE_CPU_PART_M1_FIRESTORM_MAX 0x029
|
||||||
#define APPLE_CPU_PART_M2_BLIZZARD 0x032
|
#define APPLE_CPU_PART_M2_BLIZZARD 0x032
|
||||||
#define APPLE_CPU_PART_M2_AVALANCHE 0x033
|
#define APPLE_CPU_PART_M2_AVALANCHE 0x033
|
||||||
|
#define APPLE_CPU_PART_M2_BLIZZARD_PRO 0x034
|
||||||
|
#define APPLE_CPU_PART_M2_AVALANCHE_PRO 0x035
|
||||||
|
#define APPLE_CPU_PART_M2_BLIZZARD_MAX 0x038
|
||||||
|
#define APPLE_CPU_PART_M2_AVALANCHE_MAX 0x039
|
||||||
|
|
||||||
#define AMPERE_CPU_PART_AMPERE1 0xAC3
|
#define AMPERE_CPU_PART_AMPERE1 0xAC3
|
||||||
|
|
||||||
@ -181,6 +185,10 @@
|
|||||||
#define MIDR_APPLE_M1_FIRESTORM_MAX MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M1_FIRESTORM_MAX)
|
#define MIDR_APPLE_M1_FIRESTORM_MAX MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M1_FIRESTORM_MAX)
|
||||||
#define MIDR_APPLE_M2_BLIZZARD MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_BLIZZARD)
|
#define MIDR_APPLE_M2_BLIZZARD MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_BLIZZARD)
|
||||||
#define MIDR_APPLE_M2_AVALANCHE MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_AVALANCHE)
|
#define MIDR_APPLE_M2_AVALANCHE MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_AVALANCHE)
|
||||||
|
#define MIDR_APPLE_M2_BLIZZARD_PRO MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_BLIZZARD_PRO)
|
||||||
|
#define MIDR_APPLE_M2_AVALANCHE_PRO MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_AVALANCHE_PRO)
|
||||||
|
#define MIDR_APPLE_M2_BLIZZARD_MAX MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_BLIZZARD_MAX)
|
||||||
|
#define MIDR_APPLE_M2_AVALANCHE_MAX MIDR_CPU_MODEL(ARM_CPU_IMP_APPLE, APPLE_CPU_PART_M2_AVALANCHE_MAX)
|
||||||
#define MIDR_AMPERE1 MIDR_CPU_MODEL(ARM_CPU_IMP_AMPERE, AMPERE_CPU_PART_AMPERE1)
|
#define MIDR_AMPERE1 MIDR_CPU_MODEL(ARM_CPU_IMP_AMPERE, AMPERE_CPU_PART_AMPERE1)
|
||||||
|
|
||||||
/* Fujitsu Erratum 010001 affects A64FX 1.0 and 1.1, (v0r0 and v1r0) */
|
/* Fujitsu Erratum 010001 affects A64FX 1.0 and 1.1, (v0r0 and v1r0) */
|
||||||
|
@ -209,6 +209,7 @@ struct kvm_pgtable_visit_ctx {
|
|||||||
kvm_pte_t old;
|
kvm_pte_t old;
|
||||||
void *arg;
|
void *arg;
|
||||||
struct kvm_pgtable_mm_ops *mm_ops;
|
struct kvm_pgtable_mm_ops *mm_ops;
|
||||||
|
u64 start;
|
||||||
u64 addr;
|
u64 addr;
|
||||||
u64 end;
|
u64 end;
|
||||||
u32 level;
|
u32 level;
|
||||||
@ -631,9 +632,9 @@ int kvm_pgtable_stage2_flush(struct kvm_pgtable *pgt, u64 addr, u64 size);
|
|||||||
*
|
*
|
||||||
* The walker will walk the page-table entries corresponding to the input
|
* The walker will walk the page-table entries corresponding to the input
|
||||||
* address range specified, visiting entries according to the walker flags.
|
* address range specified, visiting entries according to the walker flags.
|
||||||
* Invalid entries are treated as leaf entries. Leaf entries are reloaded
|
* Invalid entries are treated as leaf entries. The visited page table entry is
|
||||||
* after invoking the walker callback, allowing the walker to descend into
|
* reloaded after invoking the walker callback, allowing the walker to descend
|
||||||
* a newly installed table.
|
* into a newly installed table.
|
||||||
*
|
*
|
||||||
* Returning a negative error code from the walker callback function will
|
* Returning a negative error code from the walker callback function will
|
||||||
* terminate the walk immediately with the same error code.
|
* terminate the walk immediately with the same error code.
|
||||||
|
@ -115,8 +115,14 @@
|
|||||||
#define SB_BARRIER_INSN __SYS_BARRIER_INSN(0, 7, 31)
|
#define SB_BARRIER_INSN __SYS_BARRIER_INSN(0, 7, 31)
|
||||||
|
|
||||||
#define SYS_DC_ISW sys_insn(1, 0, 7, 6, 2)
|
#define SYS_DC_ISW sys_insn(1, 0, 7, 6, 2)
|
||||||
|
#define SYS_DC_IGSW sys_insn(1, 0, 7, 6, 4)
|
||||||
|
#define SYS_DC_IGDSW sys_insn(1, 0, 7, 6, 6)
|
||||||
#define SYS_DC_CSW sys_insn(1, 0, 7, 10, 2)
|
#define SYS_DC_CSW sys_insn(1, 0, 7, 10, 2)
|
||||||
|
#define SYS_DC_CGSW sys_insn(1, 0, 7, 10, 4)
|
||||||
|
#define SYS_DC_CGDSW sys_insn(1, 0, 7, 10, 6)
|
||||||
#define SYS_DC_CISW sys_insn(1, 0, 7, 14, 2)
|
#define SYS_DC_CISW sys_insn(1, 0, 7, 14, 2)
|
||||||
|
#define SYS_DC_CIGSW sys_insn(1, 0, 7, 14, 4)
|
||||||
|
#define SYS_DC_CIGDSW sys_insn(1, 0, 7, 14, 6)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Automatically generated definitions for system registers, the
|
* Automatically generated definitions for system registers, the
|
||||||
|
@ -66,13 +66,10 @@ void mte_sync_tags(pte_t old_pte, pte_t pte)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
/* if PG_mte_tagged is set, tags have already been initialised */
|
/* if PG_mte_tagged is set, tags have already been initialised */
|
||||||
for (i = 0; i < nr_pages; i++, page++) {
|
for (i = 0; i < nr_pages; i++, page++)
|
||||||
if (!page_mte_tagged(page)) {
|
if (!page_mte_tagged(page))
|
||||||
mte_sync_page_tags(page, old_pte, check_swap,
|
mte_sync_page_tags(page, old_pte, check_swap,
|
||||||
pte_is_tagged);
|
pte_is_tagged);
|
||||||
set_page_mte_tagged(page);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ensure the tags are visible before the PTE is set */
|
/* ensure the tags are visible before the PTE is set */
|
||||||
smp_wmb();
|
smp_wmb();
|
||||||
|
@ -288,7 +288,7 @@ static int aarch32_alloc_kuser_vdso_page(void)
|
|||||||
|
|
||||||
memcpy((void *)(vdso_page + 0x1000 - kuser_sz), __kuser_helper_start,
|
memcpy((void *)(vdso_page + 0x1000 - kuser_sz), __kuser_helper_start,
|
||||||
kuser_sz);
|
kuser_sz);
|
||||||
aarch32_vectors_page = virt_to_page(vdso_page);
|
aarch32_vectors_page = virt_to_page((void *)vdso_page);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -81,26 +81,34 @@ void kvm_arch_vcpu_load_fp(struct kvm_vcpu *vcpu)
|
|||||||
|
|
||||||
fpsimd_kvm_prepare();
|
fpsimd_kvm_prepare();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We will check TIF_FOREIGN_FPSTATE just before entering the
|
||||||
|
* guest in kvm_arch_vcpu_ctxflush_fp() and override this to
|
||||||
|
* FP_STATE_FREE if the flag set.
|
||||||
|
*/
|
||||||
vcpu->arch.fp_state = FP_STATE_HOST_OWNED;
|
vcpu->arch.fp_state = FP_STATE_HOST_OWNED;
|
||||||
|
|
||||||
vcpu_clear_flag(vcpu, HOST_SVE_ENABLED);
|
vcpu_clear_flag(vcpu, HOST_SVE_ENABLED);
|
||||||
if (read_sysreg(cpacr_el1) & CPACR_EL1_ZEN_EL0EN)
|
if (read_sysreg(cpacr_el1) & CPACR_EL1_ZEN_EL0EN)
|
||||||
vcpu_set_flag(vcpu, HOST_SVE_ENABLED);
|
vcpu_set_flag(vcpu, HOST_SVE_ENABLED);
|
||||||
|
|
||||||
/*
|
|
||||||
* We don't currently support SME guests but if we leave
|
|
||||||
* things in streaming mode then when the guest starts running
|
|
||||||
* FPSIMD or SVE code it may generate SME traps so as a
|
|
||||||
* special case if we are in streaming mode we force the host
|
|
||||||
* state to be saved now and exit streaming mode so that we
|
|
||||||
* don't have to handle any SME traps for valid guest
|
|
||||||
* operations. Do this for ZA as well for now for simplicity.
|
|
||||||
*/
|
|
||||||
if (system_supports_sme()) {
|
if (system_supports_sme()) {
|
||||||
vcpu_clear_flag(vcpu, HOST_SME_ENABLED);
|
vcpu_clear_flag(vcpu, HOST_SME_ENABLED);
|
||||||
if (read_sysreg(cpacr_el1) & CPACR_EL1_SMEN_EL0EN)
|
if (read_sysreg(cpacr_el1) & CPACR_EL1_SMEN_EL0EN)
|
||||||
vcpu_set_flag(vcpu, HOST_SME_ENABLED);
|
vcpu_set_flag(vcpu, HOST_SME_ENABLED);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If PSTATE.SM is enabled then save any pending FP
|
||||||
|
* state and disable PSTATE.SM. If we leave PSTATE.SM
|
||||||
|
* enabled and the guest does not enable SME via
|
||||||
|
* CPACR_EL1.SMEN then operations that should be valid
|
||||||
|
* may generate SME traps from EL1 to EL1 which we
|
||||||
|
* can't intercept and which would confuse the guest.
|
||||||
|
*
|
||||||
|
* Do the same for PSTATE.ZA in the case where there
|
||||||
|
* is state in the registers which has not already
|
||||||
|
* been saved, this is very unlikely to happen.
|
||||||
|
*/
|
||||||
if (read_sysreg_s(SYS_SVCR) & (SVCR_SM_MASK | SVCR_ZA_MASK)) {
|
if (read_sysreg_s(SYS_SVCR) & (SVCR_SM_MASK | SVCR_ZA_MASK)) {
|
||||||
vcpu->arch.fp_state = FP_STATE_FREE;
|
vcpu->arch.fp_state = FP_STATE_FREE;
|
||||||
fpsimd_save_and_flush_cpu_state();
|
fpsimd_save_and_flush_cpu_state();
|
||||||
|
@ -177,9 +177,17 @@ static bool kvm_hyp_handle_fpsimd(struct kvm_vcpu *vcpu, u64 *exit_code)
|
|||||||
sve_guest = vcpu_has_sve(vcpu);
|
sve_guest = vcpu_has_sve(vcpu);
|
||||||
esr_ec = kvm_vcpu_trap_get_class(vcpu);
|
esr_ec = kvm_vcpu_trap_get_class(vcpu);
|
||||||
|
|
||||||
/* Don't handle SVE traps for non-SVE vcpus here: */
|
/* Only handle traps the vCPU can support here: */
|
||||||
if (!sve_guest && esr_ec != ESR_ELx_EC_FP_ASIMD)
|
switch (esr_ec) {
|
||||||
|
case ESR_ELx_EC_FP_ASIMD:
|
||||||
|
break;
|
||||||
|
case ESR_ELx_EC_SVE:
|
||||||
|
if (!sve_guest)
|
||||||
|
return false;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/* Valid trap. Switch the context: */
|
/* Valid trap. Switch the context: */
|
||||||
|
|
||||||
@ -404,17 +412,21 @@ static bool kvm_hyp_handle_cp15_32(struct kvm_vcpu *vcpu, u64 *exit_code)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool kvm_hyp_handle_iabt_low(struct kvm_vcpu *vcpu, u64 *exit_code)
|
static bool kvm_hyp_handle_memory_fault(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
{
|
{
|
||||||
if (!__populate_fault_info(vcpu))
|
if (!__populate_fault_info(vcpu))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
static bool kvm_hyp_handle_iabt_low(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
|
__alias(kvm_hyp_handle_memory_fault);
|
||||||
|
static bool kvm_hyp_handle_watchpt_low(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
|
__alias(kvm_hyp_handle_memory_fault);
|
||||||
|
|
||||||
static bool kvm_hyp_handle_dabt_low(struct kvm_vcpu *vcpu, u64 *exit_code)
|
static bool kvm_hyp_handle_dabt_low(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
{
|
{
|
||||||
if (!__populate_fault_info(vcpu))
|
if (kvm_hyp_handle_memory_fault(vcpu, exit_code))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (static_branch_unlikely(&vgic_v2_cpuif_trap)) {
|
if (static_branch_unlikely(&vgic_v2_cpuif_trap)) {
|
||||||
|
@ -575,7 +575,7 @@ struct pkvm_mem_donation {
|
|||||||
|
|
||||||
struct check_walk_data {
|
struct check_walk_data {
|
||||||
enum pkvm_page_state desired;
|
enum pkvm_page_state desired;
|
||||||
enum pkvm_page_state (*get_page_state)(kvm_pte_t pte);
|
enum pkvm_page_state (*get_page_state)(kvm_pte_t pte, u64 addr);
|
||||||
};
|
};
|
||||||
|
|
||||||
static int __check_page_state_visitor(const struct kvm_pgtable_visit_ctx *ctx,
|
static int __check_page_state_visitor(const struct kvm_pgtable_visit_ctx *ctx,
|
||||||
@ -583,10 +583,7 @@ static int __check_page_state_visitor(const struct kvm_pgtable_visit_ctx *ctx,
|
|||||||
{
|
{
|
||||||
struct check_walk_data *d = ctx->arg;
|
struct check_walk_data *d = ctx->arg;
|
||||||
|
|
||||||
if (kvm_pte_valid(ctx->old) && !addr_is_allowed_memory(kvm_pte_to_phys(ctx->old)))
|
return d->get_page_state(ctx->old, ctx->addr) == d->desired ? 0 : -EPERM;
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
return d->get_page_state(ctx->old) == d->desired ? 0 : -EPERM;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int check_page_state_range(struct kvm_pgtable *pgt, u64 addr, u64 size,
|
static int check_page_state_range(struct kvm_pgtable *pgt, u64 addr, u64 size,
|
||||||
@ -601,8 +598,11 @@ static int check_page_state_range(struct kvm_pgtable *pgt, u64 addr, u64 size,
|
|||||||
return kvm_pgtable_walk(pgt, addr, size, &walker);
|
return kvm_pgtable_walk(pgt, addr, size, &walker);
|
||||||
}
|
}
|
||||||
|
|
||||||
static enum pkvm_page_state host_get_page_state(kvm_pte_t pte)
|
static enum pkvm_page_state host_get_page_state(kvm_pte_t pte, u64 addr)
|
||||||
{
|
{
|
||||||
|
if (!addr_is_allowed_memory(addr))
|
||||||
|
return PKVM_NOPAGE;
|
||||||
|
|
||||||
if (!kvm_pte_valid(pte) && pte)
|
if (!kvm_pte_valid(pte) && pte)
|
||||||
return PKVM_NOPAGE;
|
return PKVM_NOPAGE;
|
||||||
|
|
||||||
@ -709,7 +709,7 @@ static int host_complete_donation(u64 addr, const struct pkvm_mem_transition *tx
|
|||||||
return host_stage2_set_owner_locked(addr, size, host_id);
|
return host_stage2_set_owner_locked(addr, size, host_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static enum pkvm_page_state hyp_get_page_state(kvm_pte_t pte)
|
static enum pkvm_page_state hyp_get_page_state(kvm_pte_t pte, u64 addr)
|
||||||
{
|
{
|
||||||
if (!kvm_pte_valid(pte))
|
if (!kvm_pte_valid(pte))
|
||||||
return PKVM_NOPAGE;
|
return PKVM_NOPAGE;
|
||||||
|
@ -186,6 +186,7 @@ static const exit_handler_fn hyp_exit_handlers[] = {
|
|||||||
[ESR_ELx_EC_FP_ASIMD] = kvm_hyp_handle_fpsimd,
|
[ESR_ELx_EC_FP_ASIMD] = kvm_hyp_handle_fpsimd,
|
||||||
[ESR_ELx_EC_IABT_LOW] = kvm_hyp_handle_iabt_low,
|
[ESR_ELx_EC_IABT_LOW] = kvm_hyp_handle_iabt_low,
|
||||||
[ESR_ELx_EC_DABT_LOW] = kvm_hyp_handle_dabt_low,
|
[ESR_ELx_EC_DABT_LOW] = kvm_hyp_handle_dabt_low,
|
||||||
|
[ESR_ELx_EC_WATCHPT_LOW] = kvm_hyp_handle_watchpt_low,
|
||||||
[ESR_ELx_EC_PAC] = kvm_hyp_handle_ptrauth,
|
[ESR_ELx_EC_PAC] = kvm_hyp_handle_ptrauth,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -196,6 +197,7 @@ static const exit_handler_fn pvm_exit_handlers[] = {
|
|||||||
[ESR_ELx_EC_FP_ASIMD] = kvm_hyp_handle_fpsimd,
|
[ESR_ELx_EC_FP_ASIMD] = kvm_hyp_handle_fpsimd,
|
||||||
[ESR_ELx_EC_IABT_LOW] = kvm_hyp_handle_iabt_low,
|
[ESR_ELx_EC_IABT_LOW] = kvm_hyp_handle_iabt_low,
|
||||||
[ESR_ELx_EC_DABT_LOW] = kvm_hyp_handle_dabt_low,
|
[ESR_ELx_EC_DABT_LOW] = kvm_hyp_handle_dabt_low,
|
||||||
|
[ESR_ELx_EC_WATCHPT_LOW] = kvm_hyp_handle_watchpt_low,
|
||||||
[ESR_ELx_EC_PAC] = kvm_hyp_handle_ptrauth,
|
[ESR_ELx_EC_PAC] = kvm_hyp_handle_ptrauth,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -58,8 +58,9 @@
|
|||||||
struct kvm_pgtable_walk_data {
|
struct kvm_pgtable_walk_data {
|
||||||
struct kvm_pgtable_walker *walker;
|
struct kvm_pgtable_walker *walker;
|
||||||
|
|
||||||
|
const u64 start;
|
||||||
u64 addr;
|
u64 addr;
|
||||||
u64 end;
|
const u64 end;
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool kvm_phys_is_valid(u64 phys)
|
static bool kvm_phys_is_valid(u64 phys)
|
||||||
@ -201,20 +202,33 @@ static inline int __kvm_pgtable_visit(struct kvm_pgtable_walk_data *data,
|
|||||||
.old = READ_ONCE(*ptep),
|
.old = READ_ONCE(*ptep),
|
||||||
.arg = data->walker->arg,
|
.arg = data->walker->arg,
|
||||||
.mm_ops = mm_ops,
|
.mm_ops = mm_ops,
|
||||||
|
.start = data->start,
|
||||||
.addr = data->addr,
|
.addr = data->addr,
|
||||||
.end = data->end,
|
.end = data->end,
|
||||||
.level = level,
|
.level = level,
|
||||||
.flags = flags,
|
.flags = flags,
|
||||||
};
|
};
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
bool reload = false;
|
||||||
kvm_pteref_t childp;
|
kvm_pteref_t childp;
|
||||||
bool table = kvm_pte_table(ctx.old, level);
|
bool table = kvm_pte_table(ctx.old, level);
|
||||||
|
|
||||||
if (table && (ctx.flags & KVM_PGTABLE_WALK_TABLE_PRE))
|
if (table && (ctx.flags & KVM_PGTABLE_WALK_TABLE_PRE)) {
|
||||||
ret = kvm_pgtable_visitor_cb(data, &ctx, KVM_PGTABLE_WALK_TABLE_PRE);
|
ret = kvm_pgtable_visitor_cb(data, &ctx, KVM_PGTABLE_WALK_TABLE_PRE);
|
||||||
|
reload = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (!table && (ctx.flags & KVM_PGTABLE_WALK_LEAF)) {
|
if (!table && (ctx.flags & KVM_PGTABLE_WALK_LEAF)) {
|
||||||
ret = kvm_pgtable_visitor_cb(data, &ctx, KVM_PGTABLE_WALK_LEAF);
|
ret = kvm_pgtable_visitor_cb(data, &ctx, KVM_PGTABLE_WALK_LEAF);
|
||||||
|
reload = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Reload the page table after invoking the walker callback for leaf
|
||||||
|
* entries or after pre-order traversal, to allow the walker to descend
|
||||||
|
* into a newly installed or replaced table.
|
||||||
|
*/
|
||||||
|
if (reload) {
|
||||||
ctx.old = READ_ONCE(*ptep);
|
ctx.old = READ_ONCE(*ptep);
|
||||||
table = kvm_pte_table(ctx.old, level);
|
table = kvm_pte_table(ctx.old, level);
|
||||||
}
|
}
|
||||||
@ -293,6 +307,7 @@ int kvm_pgtable_walk(struct kvm_pgtable *pgt, u64 addr, u64 size,
|
|||||||
struct kvm_pgtable_walker *walker)
|
struct kvm_pgtable_walker *walker)
|
||||||
{
|
{
|
||||||
struct kvm_pgtable_walk_data walk_data = {
|
struct kvm_pgtable_walk_data walk_data = {
|
||||||
|
.start = ALIGN_DOWN(addr, PAGE_SIZE),
|
||||||
.addr = ALIGN_DOWN(addr, PAGE_SIZE),
|
.addr = ALIGN_DOWN(addr, PAGE_SIZE),
|
||||||
.end = PAGE_ALIGN(walk_data.addr + size),
|
.end = PAGE_ALIGN(walk_data.addr + size),
|
||||||
.walker = walker,
|
.walker = walker,
|
||||||
@ -349,7 +364,7 @@ int kvm_pgtable_get_leaf(struct kvm_pgtable *pgt, u64 addr,
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct hyp_map_data {
|
struct hyp_map_data {
|
||||||
u64 phys;
|
const u64 phys;
|
||||||
kvm_pte_t attr;
|
kvm_pte_t attr;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -407,13 +422,12 @@ enum kvm_pgtable_prot kvm_pgtable_hyp_pte_prot(kvm_pte_t pte)
|
|||||||
static bool hyp_map_walker_try_leaf(const struct kvm_pgtable_visit_ctx *ctx,
|
static bool hyp_map_walker_try_leaf(const struct kvm_pgtable_visit_ctx *ctx,
|
||||||
struct hyp_map_data *data)
|
struct hyp_map_data *data)
|
||||||
{
|
{
|
||||||
|
u64 phys = data->phys + (ctx->addr - ctx->start);
|
||||||
kvm_pte_t new;
|
kvm_pte_t new;
|
||||||
u64 granule = kvm_granule_size(ctx->level), phys = data->phys;
|
|
||||||
|
|
||||||
if (!kvm_block_mapping_supported(ctx, phys))
|
if (!kvm_block_mapping_supported(ctx, phys))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
data->phys += granule;
|
|
||||||
new = kvm_init_valid_leaf_pte(phys, data->attr, ctx->level);
|
new = kvm_init_valid_leaf_pte(phys, data->attr, ctx->level);
|
||||||
if (ctx->old == new)
|
if (ctx->old == new)
|
||||||
return true;
|
return true;
|
||||||
@ -576,7 +590,7 @@ void kvm_pgtable_hyp_destroy(struct kvm_pgtable *pgt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct stage2_map_data {
|
struct stage2_map_data {
|
||||||
u64 phys;
|
const u64 phys;
|
||||||
kvm_pte_t attr;
|
kvm_pte_t attr;
|
||||||
u8 owner_id;
|
u8 owner_id;
|
||||||
|
|
||||||
@ -794,20 +808,43 @@ static bool stage2_pte_executable(kvm_pte_t pte)
|
|||||||
return !(pte & KVM_PTE_LEAF_ATTR_HI_S2_XN);
|
return !(pte & KVM_PTE_LEAF_ATTR_HI_S2_XN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static u64 stage2_map_walker_phys_addr(const struct kvm_pgtable_visit_ctx *ctx,
|
||||||
|
const struct stage2_map_data *data)
|
||||||
|
{
|
||||||
|
u64 phys = data->phys;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Stage-2 walks to update ownership data are communicated to the map
|
||||||
|
* walker using an invalid PA. Avoid offsetting an already invalid PA,
|
||||||
|
* which could overflow and make the address valid again.
|
||||||
|
*/
|
||||||
|
if (!kvm_phys_is_valid(phys))
|
||||||
|
return phys;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Otherwise, work out the correct PA based on how far the walk has
|
||||||
|
* gotten.
|
||||||
|
*/
|
||||||
|
return phys + (ctx->addr - ctx->start);
|
||||||
|
}
|
||||||
|
|
||||||
static bool stage2_leaf_mapping_allowed(const struct kvm_pgtable_visit_ctx *ctx,
|
static bool stage2_leaf_mapping_allowed(const struct kvm_pgtable_visit_ctx *ctx,
|
||||||
struct stage2_map_data *data)
|
struct stage2_map_data *data)
|
||||||
{
|
{
|
||||||
|
u64 phys = stage2_map_walker_phys_addr(ctx, data);
|
||||||
|
|
||||||
if (data->force_pte && (ctx->level < (KVM_PGTABLE_MAX_LEVELS - 1)))
|
if (data->force_pte && (ctx->level < (KVM_PGTABLE_MAX_LEVELS - 1)))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return kvm_block_mapping_supported(ctx, data->phys);
|
return kvm_block_mapping_supported(ctx, phys);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int stage2_map_walker_try_leaf(const struct kvm_pgtable_visit_ctx *ctx,
|
static int stage2_map_walker_try_leaf(const struct kvm_pgtable_visit_ctx *ctx,
|
||||||
struct stage2_map_data *data)
|
struct stage2_map_data *data)
|
||||||
{
|
{
|
||||||
kvm_pte_t new;
|
kvm_pte_t new;
|
||||||
u64 granule = kvm_granule_size(ctx->level), phys = data->phys;
|
u64 phys = stage2_map_walker_phys_addr(ctx, data);
|
||||||
|
u64 granule = kvm_granule_size(ctx->level);
|
||||||
struct kvm_pgtable *pgt = data->mmu->pgt;
|
struct kvm_pgtable *pgt = data->mmu->pgt;
|
||||||
struct kvm_pgtable_mm_ops *mm_ops = ctx->mm_ops;
|
struct kvm_pgtable_mm_ops *mm_ops = ctx->mm_ops;
|
||||||
|
|
||||||
@ -841,8 +878,6 @@ static int stage2_map_walker_try_leaf(const struct kvm_pgtable_visit_ctx *ctx,
|
|||||||
|
|
||||||
stage2_make_pte(ctx, new);
|
stage2_make_pte(ctx, new);
|
||||||
|
|
||||||
if (kvm_phys_is_valid(phys))
|
|
||||||
data->phys += granule;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1297,4 +1332,7 @@ void kvm_pgtable_stage2_free_removed(struct kvm_pgtable_mm_ops *mm_ops, void *pg
|
|||||||
};
|
};
|
||||||
|
|
||||||
WARN_ON(__kvm_pgtable_walk(&data, mm_ops, ptep, level + 1));
|
WARN_ON(__kvm_pgtable_walk(&data, mm_ops, ptep, level + 1));
|
||||||
|
|
||||||
|
WARN_ON(mm_ops->page_count(pgtable) != 1);
|
||||||
|
mm_ops->put_page(pgtable);
|
||||||
}
|
}
|
||||||
|
@ -110,6 +110,7 @@ static const exit_handler_fn hyp_exit_handlers[] = {
|
|||||||
[ESR_ELx_EC_FP_ASIMD] = kvm_hyp_handle_fpsimd,
|
[ESR_ELx_EC_FP_ASIMD] = kvm_hyp_handle_fpsimd,
|
||||||
[ESR_ELx_EC_IABT_LOW] = kvm_hyp_handle_iabt_low,
|
[ESR_ELx_EC_IABT_LOW] = kvm_hyp_handle_iabt_low,
|
||||||
[ESR_ELx_EC_DABT_LOW] = kvm_hyp_handle_dabt_low,
|
[ESR_ELx_EC_DABT_LOW] = kvm_hyp_handle_dabt_low,
|
||||||
|
[ESR_ELx_EC_WATCHPT_LOW] = kvm_hyp_handle_watchpt_low,
|
||||||
[ESR_ELx_EC_PAC] = kvm_hyp_handle_ptrauth,
|
[ESR_ELx_EC_PAC] = kvm_hyp_handle_ptrauth,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -204,7 +204,7 @@ void kvm_inject_size_fault(struct kvm_vcpu *vcpu)
|
|||||||
* Size Fault at level 0, as if exceeding PARange.
|
* Size Fault at level 0, as if exceeding PARange.
|
||||||
*
|
*
|
||||||
* Non-LPAE guests will only get the external abort, as there
|
* Non-LPAE guests will only get the external abort, as there
|
||||||
* is no way to to describe the ASF.
|
* is no way to describe the ASF.
|
||||||
*/
|
*/
|
||||||
if (vcpu_el1_is_32bit(vcpu) &&
|
if (vcpu_el1_is_32bit(vcpu) &&
|
||||||
!(vcpu_read_sys_reg(vcpu, TCR_EL1) & TTBCR_EAE))
|
!(vcpu_read_sys_reg(vcpu, TCR_EL1) & TTBCR_EAE))
|
||||||
|
@ -694,45 +694,23 @@ void kvm_host_pmu_init(struct arm_pmu *pmu)
|
|||||||
|
|
||||||
static struct arm_pmu *kvm_pmu_probe_armpmu(void)
|
static struct arm_pmu *kvm_pmu_probe_armpmu(void)
|
||||||
{
|
{
|
||||||
struct perf_event_attr attr = { };
|
struct arm_pmu *tmp, *pmu = NULL;
|
||||||
struct perf_event *event;
|
struct arm_pmu_entry *entry;
|
||||||
struct arm_pmu *pmu = NULL;
|
int cpu;
|
||||||
|
|
||||||
/*
|
mutex_lock(&arm_pmus_lock);
|
||||||
* Create a dummy event that only counts user cycles. As we'll never
|
|
||||||
* leave this function with the event being live, it will never
|
|
||||||
* count anything. But it allows us to probe some of the PMU
|
|
||||||
* details. Yes, this is terrible.
|
|
||||||
*/
|
|
||||||
attr.type = PERF_TYPE_RAW;
|
|
||||||
attr.size = sizeof(attr);
|
|
||||||
attr.pinned = 1;
|
|
||||||
attr.disabled = 0;
|
|
||||||
attr.exclude_user = 0;
|
|
||||||
attr.exclude_kernel = 1;
|
|
||||||
attr.exclude_hv = 1;
|
|
||||||
attr.exclude_host = 1;
|
|
||||||
attr.config = ARMV8_PMUV3_PERFCTR_CPU_CYCLES;
|
|
||||||
attr.sample_period = GENMASK(63, 0);
|
|
||||||
|
|
||||||
event = perf_event_create_kernel_counter(&attr, -1, current,
|
cpu = smp_processor_id();
|
||||||
kvm_pmu_perf_overflow, &attr);
|
list_for_each_entry(entry, &arm_pmus, entry) {
|
||||||
|
tmp = entry->arm_pmu;
|
||||||
|
|
||||||
if (IS_ERR(event)) {
|
if (cpumask_test_cpu(cpu, &tmp->supported_cpus)) {
|
||||||
pr_err_once("kvm: pmu event creation failed %ld\n",
|
pmu = tmp;
|
||||||
PTR_ERR(event));
|
break;
|
||||||
return NULL;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event->pmu) {
|
mutex_unlock(&arm_pmus_lock);
|
||||||
pmu = to_arm_pmu(event->pmu);
|
|
||||||
if (pmu->pmuver == ID_AA64DFR0_EL1_PMUVer_NI ||
|
|
||||||
pmu->pmuver == ID_AA64DFR0_EL1_PMUVer_IMP_DEF)
|
|
||||||
pmu = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
perf_event_disable(event);
|
|
||||||
perf_event_release_kernel(event);
|
|
||||||
|
|
||||||
return pmu;
|
return pmu;
|
||||||
}
|
}
|
||||||
@ -912,7 +890,17 @@ int kvm_arm_pmu_v3_set_attr(struct kvm_vcpu *vcpu, struct kvm_device_attr *attr)
|
|||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
|
|
||||||
if (!kvm->arch.arm_pmu) {
|
if (!kvm->arch.arm_pmu) {
|
||||||
/* No PMU set, get the default one */
|
/*
|
||||||
|
* No PMU set, get the default one.
|
||||||
|
*
|
||||||
|
* The observant among you will notice that the supported_cpus
|
||||||
|
* mask does not get updated for the default PMU even though it
|
||||||
|
* is quite possible the selected instance supports only a
|
||||||
|
* subset of cores in the system. This is intentional, and
|
||||||
|
* upholds the preexisting behavior on heterogeneous systems
|
||||||
|
* where vCPUs can be scheduled on any core but the guest
|
||||||
|
* counters could stop working.
|
||||||
|
*/
|
||||||
kvm->arch.arm_pmu = kvm_pmu_probe_armpmu();
|
kvm->arch.arm_pmu = kvm_pmu_probe_armpmu();
|
||||||
if (!kvm->arch.arm_pmu)
|
if (!kvm->arch.arm_pmu)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
@ -211,6 +211,19 @@ static bool access_dcsw(struct kvm_vcpu *vcpu,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool access_dcgsw(struct kvm_vcpu *vcpu,
|
||||||
|
struct sys_reg_params *p,
|
||||||
|
const struct sys_reg_desc *r)
|
||||||
|
{
|
||||||
|
if (!kvm_has_mte(vcpu->kvm)) {
|
||||||
|
kvm_inject_undefined(vcpu);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Treat MTE S/W ops as we treat the classic ones: with contempt */
|
||||||
|
return access_dcsw(vcpu, p, r);
|
||||||
|
}
|
||||||
|
|
||||||
static void get_access_mask(const struct sys_reg_desc *r, u64 *mask, u64 *shift)
|
static void get_access_mask(const struct sys_reg_desc *r, u64 *mask, u64 *shift)
|
||||||
{
|
{
|
||||||
switch (r->aarch32_map) {
|
switch (r->aarch32_map) {
|
||||||
@ -1756,8 +1769,14 @@ static bool access_spsr(struct kvm_vcpu *vcpu,
|
|||||||
*/
|
*/
|
||||||
static const struct sys_reg_desc sys_reg_descs[] = {
|
static const struct sys_reg_desc sys_reg_descs[] = {
|
||||||
{ SYS_DESC(SYS_DC_ISW), access_dcsw },
|
{ SYS_DESC(SYS_DC_ISW), access_dcsw },
|
||||||
|
{ SYS_DESC(SYS_DC_IGSW), access_dcgsw },
|
||||||
|
{ SYS_DESC(SYS_DC_IGDSW), access_dcgsw },
|
||||||
{ SYS_DESC(SYS_DC_CSW), access_dcsw },
|
{ SYS_DESC(SYS_DC_CSW), access_dcsw },
|
||||||
|
{ SYS_DESC(SYS_DC_CGSW), access_dcgsw },
|
||||||
|
{ SYS_DESC(SYS_DC_CGDSW), access_dcgsw },
|
||||||
{ SYS_DESC(SYS_DC_CISW), access_dcsw },
|
{ SYS_DESC(SYS_DC_CISW), access_dcsw },
|
||||||
|
{ SYS_DESC(SYS_DC_CIGSW), access_dcgsw },
|
||||||
|
{ SYS_DESC(SYS_DC_CIGDSW), access_dcgsw },
|
||||||
|
|
||||||
DBG_BCR_BVR_WCR_WVR_EL1(0),
|
DBG_BCR_BVR_WCR_WVR_EL1(0),
|
||||||
DBG_BCR_BVR_WCR_WVR_EL1(1),
|
DBG_BCR_BVR_WCR_WVR_EL1(1),
|
||||||
|
@ -235,9 +235,9 @@ int kvm_vgic_vcpu_init(struct kvm_vcpu *vcpu)
|
|||||||
* KVM io device for the redistributor that belongs to this VCPU.
|
* KVM io device for the redistributor that belongs to this VCPU.
|
||||||
*/
|
*/
|
||||||
if (dist->vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3) {
|
if (dist->vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3) {
|
||||||
mutex_lock(&vcpu->kvm->arch.config_lock);
|
mutex_lock(&vcpu->kvm->slots_lock);
|
||||||
ret = vgic_register_redist_iodev(vcpu);
|
ret = vgic_register_redist_iodev(vcpu);
|
||||||
mutex_unlock(&vcpu->kvm->arch.config_lock);
|
mutex_unlock(&vcpu->kvm->slots_lock);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -406,7 +406,7 @@ void kvm_vgic_destroy(struct kvm *kvm)
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* vgic_lazy_init: Lazy init is only allowed if the GIC exposed to the guest
|
* vgic_lazy_init: Lazy init is only allowed if the GIC exposed to the guest
|
||||||
* is a GICv2. A GICv3 must be explicitly initialized by the guest using the
|
* is a GICv2. A GICv3 must be explicitly initialized by userspace using the
|
||||||
* KVM_DEV_ARM_VGIC_GRP_CTRL KVM_DEVICE group.
|
* KVM_DEV_ARM_VGIC_GRP_CTRL KVM_DEVICE group.
|
||||||
* @kvm: kvm struct pointer
|
* @kvm: kvm struct pointer
|
||||||
*/
|
*/
|
||||||
@ -446,11 +446,13 @@ int vgic_lazy_init(struct kvm *kvm)
|
|||||||
int kvm_vgic_map_resources(struct kvm *kvm)
|
int kvm_vgic_map_resources(struct kvm *kvm)
|
||||||
{
|
{
|
||||||
struct vgic_dist *dist = &kvm->arch.vgic;
|
struct vgic_dist *dist = &kvm->arch.vgic;
|
||||||
|
gpa_t dist_base;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (likely(vgic_ready(kvm)))
|
if (likely(vgic_ready(kvm)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
mutex_lock(&kvm->slots_lock);
|
||||||
mutex_lock(&kvm->arch.config_lock);
|
mutex_lock(&kvm->arch.config_lock);
|
||||||
if (vgic_ready(kvm))
|
if (vgic_ready(kvm))
|
||||||
goto out;
|
goto out;
|
||||||
@ -463,13 +465,26 @@ int kvm_vgic_map_resources(struct kvm *kvm)
|
|||||||
else
|
else
|
||||||
ret = vgic_v3_map_resources(kvm);
|
ret = vgic_v3_map_resources(kvm);
|
||||||
|
|
||||||
if (ret)
|
if (ret) {
|
||||||
__kvm_vgic_destroy(kvm);
|
__kvm_vgic_destroy(kvm);
|
||||||
else
|
goto out;
|
||||||
dist->ready = true;
|
}
|
||||||
|
dist->ready = true;
|
||||||
|
dist_base = dist->vgic_dist_base;
|
||||||
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
|
|
||||||
|
ret = vgic_register_dist_iodev(kvm, dist_base,
|
||||||
|
kvm_vgic_global_state.type);
|
||||||
|
if (ret) {
|
||||||
|
kvm_err("Unable to register VGIC dist MMIO regions\n");
|
||||||
|
kvm_vgic_destroy(kvm);
|
||||||
|
}
|
||||||
|
mutex_unlock(&kvm->slots_lock);
|
||||||
|
return ret;
|
||||||
|
|
||||||
out:
|
out:
|
||||||
mutex_unlock(&kvm->arch.config_lock);
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
|
mutex_unlock(&kvm->slots_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1936,6 +1936,7 @@ void vgic_lpi_translation_cache_destroy(struct kvm *kvm)
|
|||||||
|
|
||||||
static int vgic_its_create(struct kvm_device *dev, u32 type)
|
static int vgic_its_create(struct kvm_device *dev, u32 type)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
struct vgic_its *its;
|
struct vgic_its *its;
|
||||||
|
|
||||||
if (type != KVM_DEV_TYPE_ARM_VGIC_ITS)
|
if (type != KVM_DEV_TYPE_ARM_VGIC_ITS)
|
||||||
@ -1945,9 +1946,12 @@ static int vgic_its_create(struct kvm_device *dev, u32 type)
|
|||||||
if (!its)
|
if (!its)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
|
mutex_lock(&dev->kvm->arch.config_lock);
|
||||||
|
|
||||||
if (vgic_initialized(dev->kvm)) {
|
if (vgic_initialized(dev->kvm)) {
|
||||||
int ret = vgic_v4_init(dev->kvm);
|
ret = vgic_v4_init(dev->kvm);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
|
mutex_unlock(&dev->kvm->arch.config_lock);
|
||||||
kfree(its);
|
kfree(its);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1960,12 +1964,10 @@ static int vgic_its_create(struct kvm_device *dev, u32 type)
|
|||||||
|
|
||||||
/* Yep, even more trickery for lock ordering... */
|
/* Yep, even more trickery for lock ordering... */
|
||||||
#ifdef CONFIG_LOCKDEP
|
#ifdef CONFIG_LOCKDEP
|
||||||
mutex_lock(&dev->kvm->arch.config_lock);
|
|
||||||
mutex_lock(&its->cmd_lock);
|
mutex_lock(&its->cmd_lock);
|
||||||
mutex_lock(&its->its_lock);
|
mutex_lock(&its->its_lock);
|
||||||
mutex_unlock(&its->its_lock);
|
mutex_unlock(&its->its_lock);
|
||||||
mutex_unlock(&its->cmd_lock);
|
mutex_unlock(&its->cmd_lock);
|
||||||
mutex_unlock(&dev->kvm->arch.config_lock);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
its->vgic_its_base = VGIC_ADDR_UNDEF;
|
its->vgic_its_base = VGIC_ADDR_UNDEF;
|
||||||
@ -1986,7 +1988,11 @@ static int vgic_its_create(struct kvm_device *dev, u32 type)
|
|||||||
|
|
||||||
dev->private = its;
|
dev->private = its;
|
||||||
|
|
||||||
return vgic_its_set_abi(its, NR_ITS_ABIS - 1);
|
ret = vgic_its_set_abi(its, NR_ITS_ABIS - 1);
|
||||||
|
|
||||||
|
mutex_unlock(&dev->kvm->arch.config_lock);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vgic_its_destroy(struct kvm_device *kvm_dev)
|
static void vgic_its_destroy(struct kvm_device *kvm_dev)
|
||||||
|
@ -102,7 +102,11 @@ static int kvm_vgic_addr(struct kvm *kvm, struct kvm_device_attr *attr, bool wri
|
|||||||
if (get_user(addr, uaddr))
|
if (get_user(addr, uaddr))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
|
||||||
mutex_lock(&kvm->arch.config_lock);
|
/*
|
||||||
|
* Since we can't hold config_lock while registering the redistributor
|
||||||
|
* iodevs, take the slots_lock immediately.
|
||||||
|
*/
|
||||||
|
mutex_lock(&kvm->slots_lock);
|
||||||
switch (attr->attr) {
|
switch (attr->attr) {
|
||||||
case KVM_VGIC_V2_ADDR_TYPE_DIST:
|
case KVM_VGIC_V2_ADDR_TYPE_DIST:
|
||||||
r = vgic_check_type(kvm, KVM_DEV_TYPE_ARM_VGIC_V2);
|
r = vgic_check_type(kvm, KVM_DEV_TYPE_ARM_VGIC_V2);
|
||||||
@ -182,6 +186,7 @@ static int kvm_vgic_addr(struct kvm *kvm, struct kvm_device_attr *attr, bool wri
|
|||||||
if (r)
|
if (r)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
mutex_lock(&kvm->arch.config_lock);
|
||||||
if (write) {
|
if (write) {
|
||||||
r = vgic_check_iorange(kvm, *addr_ptr, addr, alignment, size);
|
r = vgic_check_iorange(kvm, *addr_ptr, addr, alignment, size);
|
||||||
if (!r)
|
if (!r)
|
||||||
@ -189,9 +194,10 @@ static int kvm_vgic_addr(struct kvm *kvm, struct kvm_device_attr *attr, bool wri
|
|||||||
} else {
|
} else {
|
||||||
addr = *addr_ptr;
|
addr = *addr_ptr;
|
||||||
}
|
}
|
||||||
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
mutex_unlock(&kvm->arch.config_lock);
|
mutex_unlock(&kvm->slots_lock);
|
||||||
|
|
||||||
if (!r && !write)
|
if (!r && !write)
|
||||||
r = put_user(addr, uaddr);
|
r = put_user(addr, uaddr);
|
||||||
|
@ -769,10 +769,13 @@ int vgic_register_redist_iodev(struct kvm_vcpu *vcpu)
|
|||||||
struct vgic_io_device *rd_dev = &vcpu->arch.vgic_cpu.rd_iodev;
|
struct vgic_io_device *rd_dev = &vcpu->arch.vgic_cpu.rd_iodev;
|
||||||
struct vgic_redist_region *rdreg;
|
struct vgic_redist_region *rdreg;
|
||||||
gpa_t rd_base;
|
gpa_t rd_base;
|
||||||
int ret;
|
int ret = 0;
|
||||||
|
|
||||||
|
lockdep_assert_held(&kvm->slots_lock);
|
||||||
|
mutex_lock(&kvm->arch.config_lock);
|
||||||
|
|
||||||
if (!IS_VGIC_ADDR_UNDEF(vgic_cpu->rd_iodev.base_addr))
|
if (!IS_VGIC_ADDR_UNDEF(vgic_cpu->rd_iodev.base_addr))
|
||||||
return 0;
|
goto out_unlock;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We may be creating VCPUs before having set the base address for the
|
* We may be creating VCPUs before having set the base address for the
|
||||||
@ -782,10 +785,12 @@ int vgic_register_redist_iodev(struct kvm_vcpu *vcpu)
|
|||||||
*/
|
*/
|
||||||
rdreg = vgic_v3_rdist_free_slot(&vgic->rd_regions);
|
rdreg = vgic_v3_rdist_free_slot(&vgic->rd_regions);
|
||||||
if (!rdreg)
|
if (!rdreg)
|
||||||
return 0;
|
goto out_unlock;
|
||||||
|
|
||||||
if (!vgic_v3_check_base(kvm))
|
if (!vgic_v3_check_base(kvm)) {
|
||||||
return -EINVAL;
|
ret = -EINVAL;
|
||||||
|
goto out_unlock;
|
||||||
|
}
|
||||||
|
|
||||||
vgic_cpu->rdreg = rdreg;
|
vgic_cpu->rdreg = rdreg;
|
||||||
vgic_cpu->rdreg_index = rdreg->free_index;
|
vgic_cpu->rdreg_index = rdreg->free_index;
|
||||||
@ -799,16 +804,20 @@ int vgic_register_redist_iodev(struct kvm_vcpu *vcpu)
|
|||||||
rd_dev->nr_regions = ARRAY_SIZE(vgic_v3_rd_registers);
|
rd_dev->nr_regions = ARRAY_SIZE(vgic_v3_rd_registers);
|
||||||
rd_dev->redist_vcpu = vcpu;
|
rd_dev->redist_vcpu = vcpu;
|
||||||
|
|
||||||
mutex_lock(&kvm->slots_lock);
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
|
|
||||||
ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, rd_base,
|
ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, rd_base,
|
||||||
2 * SZ_64K, &rd_dev->dev);
|
2 * SZ_64K, &rd_dev->dev);
|
||||||
mutex_unlock(&kvm->slots_lock);
|
|
||||||
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
/* Protected by slots_lock */
|
||||||
rdreg->free_index++;
|
rdreg->free_index++;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
out_unlock:
|
||||||
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vgic_unregister_redist_iodev(struct kvm_vcpu *vcpu)
|
static void vgic_unregister_redist_iodev(struct kvm_vcpu *vcpu)
|
||||||
@ -834,12 +843,10 @@ static int vgic_register_all_redist_iodevs(struct kvm *kvm)
|
|||||||
/* The current c failed, so iterate over the previous ones. */
|
/* The current c failed, so iterate over the previous ones. */
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
mutex_lock(&kvm->slots_lock);
|
|
||||||
for (i = 0; i < c; i++) {
|
for (i = 0; i < c; i++) {
|
||||||
vcpu = kvm_get_vcpu(kvm, i);
|
vcpu = kvm_get_vcpu(kvm, i);
|
||||||
vgic_unregister_redist_iodev(vcpu);
|
vgic_unregister_redist_iodev(vcpu);
|
||||||
}
|
}
|
||||||
mutex_unlock(&kvm->slots_lock);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@ -938,7 +945,9 @@ int vgic_v3_set_redist_base(struct kvm *kvm, u32 index, u64 addr, u32 count)
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
mutex_lock(&kvm->arch.config_lock);
|
||||||
ret = vgic_v3_alloc_redist_region(kvm, index, addr, count);
|
ret = vgic_v3_alloc_redist_region(kvm, index, addr, count);
|
||||||
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -950,8 +959,10 @@ int vgic_v3_set_redist_base(struct kvm *kvm, u32 index, u64 addr, u32 count)
|
|||||||
if (ret) {
|
if (ret) {
|
||||||
struct vgic_redist_region *rdreg;
|
struct vgic_redist_region *rdreg;
|
||||||
|
|
||||||
|
mutex_lock(&kvm->arch.config_lock);
|
||||||
rdreg = vgic_v3_rdist_region_from_index(kvm, index);
|
rdreg = vgic_v3_rdist_region_from_index(kvm, index);
|
||||||
vgic_v3_free_redist_region(rdreg);
|
vgic_v3_free_redist_region(rdreg);
|
||||||
|
mutex_unlock(&kvm->arch.config_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1096,7 +1096,6 @@ int vgic_register_dist_iodev(struct kvm *kvm, gpa_t dist_base_address,
|
|||||||
enum vgic_type type)
|
enum vgic_type type)
|
||||||
{
|
{
|
||||||
struct vgic_io_device *io_device = &kvm->arch.vgic.dist_iodev;
|
struct vgic_io_device *io_device = &kvm->arch.vgic.dist_iodev;
|
||||||
int ret = 0;
|
|
||||||
unsigned int len;
|
unsigned int len;
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
@ -1114,10 +1113,6 @@ int vgic_register_dist_iodev(struct kvm *kvm, gpa_t dist_base_address,
|
|||||||
io_device->iodev_type = IODEV_DIST;
|
io_device->iodev_type = IODEV_DIST;
|
||||||
io_device->redist_vcpu = NULL;
|
io_device->redist_vcpu = NULL;
|
||||||
|
|
||||||
mutex_lock(&kvm->slots_lock);
|
return kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, dist_base_address,
|
||||||
ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, dist_base_address,
|
len, &io_device->dev);
|
||||||
len, &io_device->dev);
|
|
||||||
mutex_unlock(&kvm->slots_lock);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
@ -312,12 +312,6 @@ int vgic_v2_map_resources(struct kvm *kvm)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = vgic_register_dist_iodev(kvm, dist->vgic_dist_base, VGIC_V2);
|
|
||||||
if (ret) {
|
|
||||||
kvm_err("Unable to register VGIC MMIO regions\n");
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!static_branch_unlikely(&vgic_v2_cpuif_trap)) {
|
if (!static_branch_unlikely(&vgic_v2_cpuif_trap)) {
|
||||||
ret = kvm_phys_addr_ioremap(kvm, dist->vgic_cpu_base,
|
ret = kvm_phys_addr_ioremap(kvm, dist->vgic_cpu_base,
|
||||||
kvm_vgic_global_state.vcpu_base,
|
kvm_vgic_global_state.vcpu_base,
|
||||||
|
@ -539,7 +539,6 @@ int vgic_v3_map_resources(struct kvm *kvm)
|
|||||||
{
|
{
|
||||||
struct vgic_dist *dist = &kvm->arch.vgic;
|
struct vgic_dist *dist = &kvm->arch.vgic;
|
||||||
struct kvm_vcpu *vcpu;
|
struct kvm_vcpu *vcpu;
|
||||||
int ret = 0;
|
|
||||||
unsigned long c;
|
unsigned long c;
|
||||||
|
|
||||||
kvm_for_each_vcpu(c, vcpu, kvm) {
|
kvm_for_each_vcpu(c, vcpu, kvm) {
|
||||||
@ -569,12 +568,6 @@ int vgic_v3_map_resources(struct kvm *kvm)
|
|||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = vgic_register_dist_iodev(kvm, dist->vgic_dist_base, VGIC_V3);
|
|
||||||
if (ret) {
|
|
||||||
kvm_err("Unable to register VGICv3 dist MMIO regions\n");
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (kvm_vgic_global_state.has_gicv4_1)
|
if (kvm_vgic_global_state.has_gicv4_1)
|
||||||
vgic_v4_configure_vsgis(kvm);
|
vgic_v4_configure_vsgis(kvm);
|
||||||
|
|
||||||
@ -616,6 +609,10 @@ static const struct midr_range broken_seis[] = {
|
|||||||
MIDR_ALL_VERSIONS(MIDR_APPLE_M1_FIRESTORM_MAX),
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M1_FIRESTORM_MAX),
|
||||||
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_BLIZZARD),
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_BLIZZARD),
|
||||||
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_AVALANCHE),
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_AVALANCHE),
|
||||||
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_BLIZZARD_PRO),
|
||||||
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_AVALANCHE_PRO),
|
||||||
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_BLIZZARD_MAX),
|
||||||
|
MIDR_ALL_VERSIONS(MIDR_APPLE_M2_AVALANCHE_MAX),
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -184,13 +184,14 @@ static void vgic_v4_disable_vsgis(struct kvm_vcpu *vcpu)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Must be called with the kvm lock held */
|
|
||||||
void vgic_v4_configure_vsgis(struct kvm *kvm)
|
void vgic_v4_configure_vsgis(struct kvm *kvm)
|
||||||
{
|
{
|
||||||
struct vgic_dist *dist = &kvm->arch.vgic;
|
struct vgic_dist *dist = &kvm->arch.vgic;
|
||||||
struct kvm_vcpu *vcpu;
|
struct kvm_vcpu *vcpu;
|
||||||
unsigned long i;
|
unsigned long i;
|
||||||
|
|
||||||
|
lockdep_assert_held(&kvm->arch.config_lock);
|
||||||
|
|
||||||
kvm_arm_halt_guest(kvm);
|
kvm_arm_halt_guest(kvm);
|
||||||
|
|
||||||
kvm_for_each_vcpu(i, vcpu, kvm) {
|
kvm_for_each_vcpu(i, vcpu, kvm) {
|
||||||
|
@ -47,7 +47,7 @@ static void flush_context(void)
|
|||||||
int cpu;
|
int cpu;
|
||||||
u64 vmid;
|
u64 vmid;
|
||||||
|
|
||||||
bitmap_clear(vmid_map, 0, NUM_USER_VMIDS);
|
bitmap_zero(vmid_map, NUM_USER_VMIDS);
|
||||||
|
|
||||||
for_each_possible_cpu(cpu) {
|
for_each_possible_cpu(cpu) {
|
||||||
vmid = atomic64_xchg_relaxed(&per_cpu(active_vmids, cpu), 0);
|
vmid = atomic64_xchg_relaxed(&per_cpu(active_vmids, cpu), 0);
|
||||||
@ -182,8 +182,7 @@ int __init kvm_arm_vmid_alloc_init(void)
|
|||||||
*/
|
*/
|
||||||
WARN_ON(NUM_USER_VMIDS - 1 <= num_possible_cpus());
|
WARN_ON(NUM_USER_VMIDS - 1 <= num_possible_cpus());
|
||||||
atomic64_set(&vmid_generation, VMID_FIRST_VERSION);
|
atomic64_set(&vmid_generation, VMID_FIRST_VERSION);
|
||||||
vmid_map = kcalloc(BITS_TO_LONGS(NUM_USER_VMIDS),
|
vmid_map = bitmap_zalloc(NUM_USER_VMIDS, GFP_KERNEL);
|
||||||
sizeof(*vmid_map), GFP_KERNEL);
|
|
||||||
if (!vmid_map)
|
if (!vmid_map)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
@ -192,5 +191,5 @@ int __init kvm_arm_vmid_alloc_init(void)
|
|||||||
|
|
||||||
void __init kvm_arm_vmid_alloc_free(void)
|
void __init kvm_arm_vmid_alloc_free(void)
|
||||||
{
|
{
|
||||||
kfree(vmid_map);
|
bitmap_free(vmid_map);
|
||||||
}
|
}
|
||||||
|
@ -21,9 +21,10 @@ void copy_highpage(struct page *to, struct page *from)
|
|||||||
|
|
||||||
copy_page(kto, kfrom);
|
copy_page(kto, kfrom);
|
||||||
|
|
||||||
|
if (kasan_hw_tags_enabled())
|
||||||
|
page_kasan_tag_reset(to);
|
||||||
|
|
||||||
if (system_supports_mte() && page_mte_tagged(from)) {
|
if (system_supports_mte() && page_mte_tagged(from)) {
|
||||||
if (kasan_hw_tags_enabled())
|
|
||||||
page_kasan_tag_reset(to);
|
|
||||||
/* It's a new page, shouldn't have been tagged yet */
|
/* It's a new page, shouldn't have been tagged yet */
|
||||||
WARN_ON_ONCE(!try_page_mte_tagging(to));
|
WARN_ON_ONCE(!try_page_mte_tagging(to));
|
||||||
mte_copy_page_tags(kto, kfrom);
|
mte_copy_page_tags(kto, kfrom);
|
||||||
|
@ -480,8 +480,8 @@ static void do_bad_area(unsigned long far, unsigned long esr,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define VM_FAULT_BADMAP 0x010000
|
#define VM_FAULT_BADMAP ((__force vm_fault_t)0x010000)
|
||||||
#define VM_FAULT_BADACCESS 0x020000
|
#define VM_FAULT_BADACCESS ((__force vm_fault_t)0x020000)
|
||||||
|
|
||||||
static vm_fault_t __do_page_fault(struct mm_struct *mm, unsigned long addr,
|
static vm_fault_t __do_page_fault(struct mm_struct *mm, unsigned long addr,
|
||||||
unsigned int mm_flags, unsigned long vm_flags,
|
unsigned int mm_flags, unsigned long vm_flags,
|
||||||
|
@ -858,11 +858,17 @@ static inline int rt_setup_ucontext(struct ucontext __user *uc, struct pt_regs *
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline void __user *
|
static inline void __user *
|
||||||
get_sigframe(struct ksignal *ksig, size_t frame_size)
|
get_sigframe(struct ksignal *ksig, struct pt_regs *tregs, size_t frame_size)
|
||||||
{
|
{
|
||||||
unsigned long usp = sigsp(rdusp(), ksig);
|
unsigned long usp = sigsp(rdusp(), ksig);
|
||||||
|
unsigned long gap = 0;
|
||||||
|
|
||||||
return (void __user *)((usp - frame_size) & -8UL);
|
if (CPU_IS_020_OR_030 && tregs->format == 0xb) {
|
||||||
|
/* USP is unreliable so use worst-case value */
|
||||||
|
gap = 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (void __user *)((usp - gap - frame_size) & -8UL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int setup_frame(struct ksignal *ksig, sigset_t *set,
|
static int setup_frame(struct ksignal *ksig, sigset_t *set,
|
||||||
@ -880,7 +886,7 @@ static int setup_frame(struct ksignal *ksig, sigset_t *set,
|
|||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
frame = get_sigframe(ksig, sizeof(*frame) + fsize);
|
frame = get_sigframe(ksig, tregs, sizeof(*frame) + fsize);
|
||||||
|
|
||||||
if (fsize)
|
if (fsize)
|
||||||
err |= copy_to_user (frame + 1, regs + 1, fsize);
|
err |= copy_to_user (frame + 1, regs + 1, fsize);
|
||||||
@ -952,7 +958,7 @@ static int setup_rt_frame(struct ksignal *ksig, sigset_t *set,
|
|||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
frame = get_sigframe(ksig, sizeof(*frame));
|
frame = get_sigframe(ksig, tregs, sizeof(*frame));
|
||||||
|
|
||||||
if (fsize)
|
if (fsize)
|
||||||
err |= copy_to_user (&frame->uc.uc_extra, regs + 1, fsize);
|
err |= copy_to_user (&frame->uc.uc_extra, regs + 1, fsize);
|
||||||
|
@ -79,6 +79,7 @@ config MIPS
|
|||||||
select HAVE_LD_DEAD_CODE_DATA_ELIMINATION
|
select HAVE_LD_DEAD_CODE_DATA_ELIMINATION
|
||||||
select HAVE_MOD_ARCH_SPECIFIC
|
select HAVE_MOD_ARCH_SPECIFIC
|
||||||
select HAVE_NMI
|
select HAVE_NMI
|
||||||
|
select HAVE_PATA_PLATFORM
|
||||||
select HAVE_PERF_EVENTS
|
select HAVE_PERF_EVENTS
|
||||||
select HAVE_PERF_REGS
|
select HAVE_PERF_REGS
|
||||||
select HAVE_PERF_USER_STACK_DUMP
|
select HAVE_PERF_USER_STACK_DUMP
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <linux/dma-map-ops.h> /* for dma_default_coherent */
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
@ -623,17 +624,18 @@ u32 au1xxx_dbdma_put_source(u32 chanid, dma_addr_t buf, int nbytes, u32 flags)
|
|||||||
dp->dscr_cmd0 &= ~DSCR_CMD0_IE;
|
dp->dscr_cmd0 &= ~DSCR_CMD0_IE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* There is an errata on the Au1200/Au1550 parts that could result
|
* There is an erratum on certain Au1200/Au1550 revisions that could
|
||||||
* in "stale" data being DMA'ed. It has to do with the snoop logic on
|
* result in "stale" data being DMA'ed. It has to do with the snoop
|
||||||
* the cache eviction buffer. DMA_NONCOHERENT is on by default for
|
* logic on the cache eviction buffer. dma_default_coherent is set
|
||||||
* these parts. If it is fixed in the future, these dma_cache_inv will
|
* to false on these parts.
|
||||||
* just be nothing more than empty macros. See io.h.
|
|
||||||
*/
|
*/
|
||||||
dma_cache_wback_inv((unsigned long)buf, nbytes);
|
if (!dma_default_coherent)
|
||||||
|
dma_cache_wback_inv(KSEG0ADDR(buf), nbytes);
|
||||||
dp->dscr_cmd0 |= DSCR_CMD0_V; /* Let it rip */
|
dp->dscr_cmd0 |= DSCR_CMD0_V; /* Let it rip */
|
||||||
wmb(); /* drain writebuffer */
|
wmb(); /* drain writebuffer */
|
||||||
dma_cache_wback_inv((unsigned long)dp, sizeof(*dp));
|
dma_cache_wback_inv((unsigned long)dp, sizeof(*dp));
|
||||||
ctp->chan_ptr->ddma_dbell = 0;
|
ctp->chan_ptr->ddma_dbell = 0;
|
||||||
|
wmb(); /* force doorbell write out to dma engine */
|
||||||
|
|
||||||
/* Get next descriptor pointer. */
|
/* Get next descriptor pointer. */
|
||||||
ctp->put_ptr = phys_to_virt(DSCR_GET_NXTPTR(dp->dscr_nxtptr));
|
ctp->put_ptr = phys_to_virt(DSCR_GET_NXTPTR(dp->dscr_nxtptr));
|
||||||
@ -685,17 +687,18 @@ u32 au1xxx_dbdma_put_dest(u32 chanid, dma_addr_t buf, int nbytes, u32 flags)
|
|||||||
dp->dscr_source1, dp->dscr_dest0, dp->dscr_dest1);
|
dp->dscr_source1, dp->dscr_dest0, dp->dscr_dest1);
|
||||||
#endif
|
#endif
|
||||||
/*
|
/*
|
||||||
* There is an errata on the Au1200/Au1550 parts that could result in
|
* There is an erratum on certain Au1200/Au1550 revisions that could
|
||||||
* "stale" data being DMA'ed. It has to do with the snoop logic on the
|
* result in "stale" data being DMA'ed. It has to do with the snoop
|
||||||
* cache eviction buffer. DMA_NONCOHERENT is on by default for these
|
* logic on the cache eviction buffer. dma_default_coherent is set
|
||||||
* parts. If it is fixed in the future, these dma_cache_inv will just
|
* to false on these parts.
|
||||||
* be nothing more than empty macros. See io.h.
|
|
||||||
*/
|
*/
|
||||||
dma_cache_inv((unsigned long)buf, nbytes);
|
if (!dma_default_coherent)
|
||||||
|
dma_cache_inv(KSEG0ADDR(buf), nbytes);
|
||||||
dp->dscr_cmd0 |= DSCR_CMD0_V; /* Let it rip */
|
dp->dscr_cmd0 |= DSCR_CMD0_V; /* Let it rip */
|
||||||
wmb(); /* drain writebuffer */
|
wmb(); /* drain writebuffer */
|
||||||
dma_cache_wback_inv((unsigned long)dp, sizeof(*dp));
|
dma_cache_wback_inv((unsigned long)dp, sizeof(*dp));
|
||||||
ctp->chan_ptr->ddma_dbell = 0;
|
ctp->chan_ptr->ddma_dbell = 0;
|
||||||
|
wmb(); /* force doorbell write out to dma engine */
|
||||||
|
|
||||||
/* Get next descriptor pointer. */
|
/* Get next descriptor pointer. */
|
||||||
ctp->put_ptr = phys_to_virt(DSCR_GET_NXTPTR(dp->dscr_nxtptr));
|
ctp->put_ptr = phys_to_virt(DSCR_GET_NXTPTR(dp->dscr_nxtptr));
|
||||||
|
@ -1502,6 +1502,10 @@ static inline void cpu_probe_alchemy(struct cpuinfo_mips *c, unsigned int cpu)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case PRID_IMP_NETLOGIC_AU13XX:
|
||||||
|
c->cputype = CPU_ALCHEMY;
|
||||||
|
__cpu_name[cpu] = "Au1300";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1863,6 +1867,7 @@ void cpu_probe(void)
|
|||||||
cpu_probe_mips(c, cpu);
|
cpu_probe_mips(c, cpu);
|
||||||
break;
|
break;
|
||||||
case PRID_COMP_ALCHEMY:
|
case PRID_COMP_ALCHEMY:
|
||||||
|
case PRID_COMP_NETLOGIC:
|
||||||
cpu_probe_alchemy(c, cpu);
|
cpu_probe_alchemy(c, cpu);
|
||||||
break;
|
break;
|
||||||
case PRID_COMP_SIBYTE:
|
case PRID_COMP_SIBYTE:
|
||||||
|
@ -158,10 +158,6 @@ static unsigned long __init init_initrd(void)
|
|||||||
pr_err("initrd start must be page aligned\n");
|
pr_err("initrd start must be page aligned\n");
|
||||||
goto disable;
|
goto disable;
|
||||||
}
|
}
|
||||||
if (initrd_start < PAGE_OFFSET) {
|
|
||||||
pr_err("initrd start < PAGE_OFFSET\n");
|
|
||||||
goto disable;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Sanitize initrd addresses. For example firmware
|
* Sanitize initrd addresses. For example firmware
|
||||||
@ -174,6 +170,11 @@ static unsigned long __init init_initrd(void)
|
|||||||
initrd_end = (unsigned long)__va(end);
|
initrd_end = (unsigned long)__va(end);
|
||||||
initrd_start = (unsigned long)__va(__pa(initrd_start));
|
initrd_start = (unsigned long)__va(__pa(initrd_start));
|
||||||
|
|
||||||
|
if (initrd_start < PAGE_OFFSET) {
|
||||||
|
pr_err("initrd start < PAGE_OFFSET\n");
|
||||||
|
goto disable;
|
||||||
|
}
|
||||||
|
|
||||||
ROOT_DEV = Root_RAM0;
|
ROOT_DEV = Root_RAM0;
|
||||||
return PFN_UP(end);
|
return PFN_UP(end);
|
||||||
disable:
|
disable:
|
||||||
|
@ -130,6 +130,10 @@ config PM
|
|||||||
config STACKTRACE_SUPPORT
|
config STACKTRACE_SUPPORT
|
||||||
def_bool y
|
def_bool y
|
||||||
|
|
||||||
|
config LOCKDEP_SUPPORT
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config ISA_DMA_API
|
config ISA_DMA_API
|
||||||
bool
|
bool
|
||||||
|
|
||||||
|
@ -1 +1,12 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
#
|
||||||
|
config LIGHTWEIGHT_SPINLOCK_CHECK
|
||||||
|
bool "Enable lightweight spinlock checks"
|
||||||
|
depends on SMP && !DEBUG_SPINLOCK
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
Add checks with low performance impact to the spinlock functions
|
||||||
|
to catch memory overwrites at runtime. For more advanced
|
||||||
|
spinlock debugging you should choose the DEBUG_SPINLOCK option
|
||||||
|
which will detect unitialized spinlocks too.
|
||||||
|
If unsure say Y here.
|
||||||
|
@ -48,6 +48,10 @@ void flush_dcache_page(struct page *page);
|
|||||||
|
|
||||||
#define flush_dcache_mmap_lock(mapping) xa_lock_irq(&mapping->i_pages)
|
#define flush_dcache_mmap_lock(mapping) xa_lock_irq(&mapping->i_pages)
|
||||||
#define flush_dcache_mmap_unlock(mapping) xa_unlock_irq(&mapping->i_pages)
|
#define flush_dcache_mmap_unlock(mapping) xa_unlock_irq(&mapping->i_pages)
|
||||||
|
#define flush_dcache_mmap_lock_irqsave(mapping, flags) \
|
||||||
|
xa_lock_irqsave(&mapping->i_pages, flags)
|
||||||
|
#define flush_dcache_mmap_unlock_irqrestore(mapping, flags) \
|
||||||
|
xa_unlock_irqrestore(&mapping->i_pages, flags)
|
||||||
|
|
||||||
#define flush_icache_page(vma,page) do { \
|
#define flush_icache_page(vma,page) do { \
|
||||||
flush_kernel_dcache_page_addr(page_address(page)); \
|
flush_kernel_dcache_page_addr(page_address(page)); \
|
||||||
|
@ -7,10 +7,26 @@
|
|||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
#include <asm/spinlock_types.h>
|
#include <asm/spinlock_types.h>
|
||||||
|
|
||||||
|
#define SPINLOCK_BREAK_INSN 0x0000c006 /* break 6,6 */
|
||||||
|
|
||||||
|
static inline void arch_spin_val_check(int lock_val)
|
||||||
|
{
|
||||||
|
if (IS_ENABLED(CONFIG_LIGHTWEIGHT_SPINLOCK_CHECK))
|
||||||
|
asm volatile( "andcm,= %0,%1,%%r0\n"
|
||||||
|
".word %2\n"
|
||||||
|
: : "r" (lock_val), "r" (__ARCH_SPIN_LOCK_UNLOCKED_VAL),
|
||||||
|
"i" (SPINLOCK_BREAK_INSN));
|
||||||
|
}
|
||||||
|
|
||||||
static inline int arch_spin_is_locked(arch_spinlock_t *x)
|
static inline int arch_spin_is_locked(arch_spinlock_t *x)
|
||||||
{
|
{
|
||||||
volatile unsigned int *a = __ldcw_align(x);
|
volatile unsigned int *a;
|
||||||
return READ_ONCE(*a) == 0;
|
int lock_val;
|
||||||
|
|
||||||
|
a = __ldcw_align(x);
|
||||||
|
lock_val = READ_ONCE(*a);
|
||||||
|
arch_spin_val_check(lock_val);
|
||||||
|
return (lock_val == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void arch_spin_lock(arch_spinlock_t *x)
|
static inline void arch_spin_lock(arch_spinlock_t *x)
|
||||||
@ -18,9 +34,18 @@ static inline void arch_spin_lock(arch_spinlock_t *x)
|
|||||||
volatile unsigned int *a;
|
volatile unsigned int *a;
|
||||||
|
|
||||||
a = __ldcw_align(x);
|
a = __ldcw_align(x);
|
||||||
while (__ldcw(a) == 0)
|
do {
|
||||||
|
int lock_val_old;
|
||||||
|
|
||||||
|
lock_val_old = __ldcw(a);
|
||||||
|
arch_spin_val_check(lock_val_old);
|
||||||
|
if (lock_val_old)
|
||||||
|
return; /* got lock */
|
||||||
|
|
||||||
|
/* wait until we should try to get lock again */
|
||||||
while (*a == 0)
|
while (*a == 0)
|
||||||
continue;
|
continue;
|
||||||
|
} while (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void arch_spin_unlock(arch_spinlock_t *x)
|
static inline void arch_spin_unlock(arch_spinlock_t *x)
|
||||||
@ -29,15 +54,19 @@ static inline void arch_spin_unlock(arch_spinlock_t *x)
|
|||||||
|
|
||||||
a = __ldcw_align(x);
|
a = __ldcw_align(x);
|
||||||
/* Release with ordered store. */
|
/* Release with ordered store. */
|
||||||
__asm__ __volatile__("stw,ma %0,0(%1)" : : "r"(1), "r"(a) : "memory");
|
__asm__ __volatile__("stw,ma %0,0(%1)"
|
||||||
|
: : "r"(__ARCH_SPIN_LOCK_UNLOCKED_VAL), "r"(a) : "memory");
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int arch_spin_trylock(arch_spinlock_t *x)
|
static inline int arch_spin_trylock(arch_spinlock_t *x)
|
||||||
{
|
{
|
||||||
volatile unsigned int *a;
|
volatile unsigned int *a;
|
||||||
|
int lock_val;
|
||||||
|
|
||||||
a = __ldcw_align(x);
|
a = __ldcw_align(x);
|
||||||
return __ldcw(a) != 0;
|
lock_val = __ldcw(a);
|
||||||
|
arch_spin_val_check(lock_val);
|
||||||
|
return lock_val != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -2,13 +2,17 @@
|
|||||||
#ifndef __ASM_SPINLOCK_TYPES_H
|
#ifndef __ASM_SPINLOCK_TYPES_H
|
||||||
#define __ASM_SPINLOCK_TYPES_H
|
#define __ASM_SPINLOCK_TYPES_H
|
||||||
|
|
||||||
|
#define __ARCH_SPIN_LOCK_UNLOCKED_VAL 0x1a46
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
#ifdef CONFIG_PA20
|
#ifdef CONFIG_PA20
|
||||||
volatile unsigned int slock;
|
volatile unsigned int slock;
|
||||||
# define __ARCH_SPIN_LOCK_UNLOCKED { 1 }
|
# define __ARCH_SPIN_LOCK_UNLOCKED { __ARCH_SPIN_LOCK_UNLOCKED_VAL }
|
||||||
#else
|
#else
|
||||||
volatile unsigned int lock[4];
|
volatile unsigned int lock[4];
|
||||||
# define __ARCH_SPIN_LOCK_UNLOCKED { { 1, 1, 1, 1 } }
|
# define __ARCH_SPIN_LOCK_UNLOCKED \
|
||||||
|
{ { __ARCH_SPIN_LOCK_UNLOCKED_VAL, __ARCH_SPIN_LOCK_UNLOCKED_VAL, \
|
||||||
|
__ARCH_SPIN_LOCK_UNLOCKED_VAL, __ARCH_SPIN_LOCK_UNLOCKED_VAL } }
|
||||||
#endif
|
#endif
|
||||||
} arch_spinlock_t;
|
} arch_spinlock_t;
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ void __init_or_module apply_alternatives(struct alt_instr *start,
|
|||||||
{
|
{
|
||||||
struct alt_instr *entry;
|
struct alt_instr *entry;
|
||||||
int index = 0, applied = 0;
|
int index = 0, applied = 0;
|
||||||
int num_cpus = num_online_cpus();
|
int num_cpus = num_present_cpus();
|
||||||
u16 cond_check;
|
u16 cond_check;
|
||||||
|
|
||||||
cond_check = ALT_COND_ALWAYS |
|
cond_check = ALT_COND_ALWAYS |
|
||||||
|
@ -399,6 +399,7 @@ void flush_dcache_page(struct page *page)
|
|||||||
unsigned long offset;
|
unsigned long offset;
|
||||||
unsigned long addr, old_addr = 0;
|
unsigned long addr, old_addr = 0;
|
||||||
unsigned long count = 0;
|
unsigned long count = 0;
|
||||||
|
unsigned long flags;
|
||||||
pgoff_t pgoff;
|
pgoff_t pgoff;
|
||||||
|
|
||||||
if (mapping && !mapping_mapped(mapping)) {
|
if (mapping && !mapping_mapped(mapping)) {
|
||||||
@ -420,7 +421,7 @@ void flush_dcache_page(struct page *page)
|
|||||||
* to flush one address here for them all to become coherent
|
* to flush one address here for them all to become coherent
|
||||||
* on machines that support equivalent aliasing
|
* on machines that support equivalent aliasing
|
||||||
*/
|
*/
|
||||||
flush_dcache_mmap_lock(mapping);
|
flush_dcache_mmap_lock_irqsave(mapping, flags);
|
||||||
vma_interval_tree_foreach(mpnt, &mapping->i_mmap, pgoff, pgoff) {
|
vma_interval_tree_foreach(mpnt, &mapping->i_mmap, pgoff, pgoff) {
|
||||||
offset = (pgoff - mpnt->vm_pgoff) << PAGE_SHIFT;
|
offset = (pgoff - mpnt->vm_pgoff) << PAGE_SHIFT;
|
||||||
addr = mpnt->vm_start + offset;
|
addr = mpnt->vm_start + offset;
|
||||||
@ -460,7 +461,7 @@ void flush_dcache_page(struct page *page)
|
|||||||
}
|
}
|
||||||
WARN_ON(++count == 4096);
|
WARN_ON(++count == 4096);
|
||||||
}
|
}
|
||||||
flush_dcache_mmap_unlock(mapping);
|
flush_dcache_mmap_unlock_irqrestore(mapping, flags);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(flush_dcache_page);
|
EXPORT_SYMBOL(flush_dcache_page);
|
||||||
|
|
||||||
|
@ -446,11 +446,27 @@ void arch_dma_free(struct device *dev, size_t size, void *vaddr,
|
|||||||
void arch_sync_dma_for_device(phys_addr_t paddr, size_t size,
|
void arch_sync_dma_for_device(phys_addr_t paddr, size_t size,
|
||||||
enum dma_data_direction dir)
|
enum dma_data_direction dir)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
|
* fdc: The data cache line is written back to memory, if and only if
|
||||||
|
* it is dirty, and then invalidated from the data cache.
|
||||||
|
*/
|
||||||
flush_kernel_dcache_range((unsigned long)phys_to_virt(paddr), size);
|
flush_kernel_dcache_range((unsigned long)phys_to_virt(paddr), size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void arch_sync_dma_for_cpu(phys_addr_t paddr, size_t size,
|
void arch_sync_dma_for_cpu(phys_addr_t paddr, size_t size,
|
||||||
enum dma_data_direction dir)
|
enum dma_data_direction dir)
|
||||||
{
|
{
|
||||||
flush_kernel_dcache_range((unsigned long)phys_to_virt(paddr), size);
|
unsigned long addr = (unsigned long) phys_to_virt(paddr);
|
||||||
|
|
||||||
|
switch (dir) {
|
||||||
|
case DMA_TO_DEVICE:
|
||||||
|
case DMA_BIDIRECTIONAL:
|
||||||
|
flush_kernel_dcache_range(addr, size);
|
||||||
|
return;
|
||||||
|
case DMA_FROM_DEVICE:
|
||||||
|
purge_kernel_dcache_range_asm(addr, addr + size);
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
BUG();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -122,13 +122,18 @@ void machine_power_off(void)
|
|||||||
/* It seems we have no way to power the system off via
|
/* It seems we have no way to power the system off via
|
||||||
* software. The user has to press the button himself. */
|
* software. The user has to press the button himself. */
|
||||||
|
|
||||||
printk(KERN_EMERG "System shut down completed.\n"
|
printk("Power off or press RETURN to reboot.\n");
|
||||||
"Please power this system off now.");
|
|
||||||
|
|
||||||
/* prevent soft lockup/stalled CPU messages for endless loop. */
|
/* prevent soft lockup/stalled CPU messages for endless loop. */
|
||||||
rcu_sysrq_start();
|
rcu_sysrq_start();
|
||||||
lockup_detector_soft_poweroff();
|
lockup_detector_soft_poweroff();
|
||||||
for (;;);
|
while (1) {
|
||||||
|
/* reboot if user presses RETURN key */
|
||||||
|
if (pdc_iodc_getc() == 13) {
|
||||||
|
printk("Rebooting...\n");
|
||||||
|
machine_restart(NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void (*pm_power_off)(void);
|
void (*pm_power_off)(void);
|
||||||
|
@ -47,6 +47,10 @@
|
|||||||
#include <linux/kgdb.h>
|
#include <linux/kgdb.h>
|
||||||
#include <linux/kprobes.h>
|
#include <linux/kprobes.h>
|
||||||
|
|
||||||
|
#if defined(CONFIG_LIGHTWEIGHT_SPINLOCK_CHECK)
|
||||||
|
#include <asm/spinlock.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "../math-emu/math-emu.h" /* for handle_fpe() */
|
#include "../math-emu/math-emu.h" /* for handle_fpe() */
|
||||||
|
|
||||||
static void parisc_show_stack(struct task_struct *task,
|
static void parisc_show_stack(struct task_struct *task,
|
||||||
@ -291,24 +295,30 @@ static void handle_break(struct pt_regs *regs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_KPROBES
|
#ifdef CONFIG_KPROBES
|
||||||
if (unlikely(iir == PARISC_KPROBES_BREAK_INSN)) {
|
if (unlikely(iir == PARISC_KPROBES_BREAK_INSN && !user_mode(regs))) {
|
||||||
parisc_kprobe_break_handler(regs);
|
parisc_kprobe_break_handler(regs);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (unlikely(iir == PARISC_KPROBES_BREAK_INSN2)) {
|
if (unlikely(iir == PARISC_KPROBES_BREAK_INSN2 && !user_mode(regs))) {
|
||||||
parisc_kprobe_ss_handler(regs);
|
parisc_kprobe_ss_handler(regs);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_KGDB
|
#ifdef CONFIG_KGDB
|
||||||
if (unlikely(iir == PARISC_KGDB_COMPILED_BREAK_INSN ||
|
if (unlikely((iir == PARISC_KGDB_COMPILED_BREAK_INSN ||
|
||||||
iir == PARISC_KGDB_BREAK_INSN)) {
|
iir == PARISC_KGDB_BREAK_INSN)) && !user_mode(regs)) {
|
||||||
kgdb_handle_exception(9, SIGTRAP, 0, regs);
|
kgdb_handle_exception(9, SIGTRAP, 0, regs);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LIGHTWEIGHT_SPINLOCK_CHECK
|
||||||
|
if ((iir == SPINLOCK_BREAK_INSN) && !user_mode(regs)) {
|
||||||
|
die_if_kernel("Spinlock was trashed", regs, 1);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (unlikely(iir != GDB_BREAK_INSN))
|
if (unlikely(iir != GDB_BREAK_INSN))
|
||||||
parisc_printk_ratelimited(0, regs,
|
parisc_printk_ratelimited(0, regs,
|
||||||
KERN_DEBUG "break %d,%d: pid=%d command='%s'\n",
|
KERN_DEBUG "break %d,%d: pid=%d command='%s'\n",
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user