mirror of
https://github.com/torvalds/linux.git
synced 2024-11-27 06:31:52 +00:00
Linux 5.16-rc5
-----BEGIN PGP SIGNATURE-----
iQFSBAABCAA8FiEEq68RxlopcLEwq+PEeb4+QwBBGIYFAmG2fU0eHHRvcnZhbGRz
QGxpbnV4LWZvdW5kYXRpb24ub3JnAAoJEHm+PkMAQRiGC7EH/3R7Rt+OD8Wn8Ss3
w8V+dBxVwa2u2oMTyUHPxaeOXZ7bi38XlUdLFPOK/76bGwO0a5TmYZqsWdRbGyT0
HfcYjHsQ0lbJXk/nh2oM47oJxJXVpThIHXJEk0FZ0Y5t+DYjIYlNHzqZymUyhLem
St74zgWcyT+MXuqY34vB827FJDUnOxhhhi85tObeunaSPAomy9aiYidSC1ARREnz
iz2VUntP/QnRnKVvL2nUZNzcz1xL5vfCRSKsRGRSv3qW1Y/1M71ylt6JVmSftWq+
VmMdFxFhdrb1OK/1ct/930Un/UP2NG9EJsWxote2XYlnVSZHzDqH7lUhbqgdCcLz
1m2tVNY=
=7wRd
-----END PGP SIGNATURE-----
Merge v5.16-rc5 into drm-next
Thomas Zimmermann requested a fixes backmerge, specifically also for
96c5f82ef0
("drm/vc4: fix error code in vc4_create_object()")
Just a bunch of adjacent changes conflicts, even the big pile of them
in vc4.
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
commit
99b03ca651
2
.mailmap
2
.mailmap
@ -126,6 +126,8 @@ Greg Kroah-Hartman <gregkh@suse.de>
|
|||||||
Greg Kroah-Hartman <greg@kroah.com>
|
Greg Kroah-Hartman <greg@kroah.com>
|
||||||
Greg Kurz <groug@kaod.org> <gkurz@linux.vnet.ibm.com>
|
Greg Kurz <groug@kaod.org> <gkurz@linux.vnet.ibm.com>
|
||||||
Gregory CLEMENT <gregory.clement@bootlin.com> <gregory.clement@free-electrons.com>
|
Gregory CLEMENT <gregory.clement@bootlin.com> <gregory.clement@free-electrons.com>
|
||||||
|
Guo Ren <guoren@kernel.org> <guoren@linux.alibaba.com>
|
||||||
|
Guo Ren <guoren@kernel.org> <ren_guo@c-sky.com>
|
||||||
Gustavo Padovan <gustavo@las.ic.unicamp.br>
|
Gustavo Padovan <gustavo@las.ic.unicamp.br>
|
||||||
Gustavo Padovan <padovan@profusion.mobi>
|
Gustavo Padovan <padovan@profusion.mobi>
|
||||||
Hanjun Guo <guohanjun@huawei.com> <hanjun.guo@linaro.org>
|
Hanjun Guo <guohanjun@huawei.com> <hanjun.guo@linaro.org>
|
||||||
|
@ -25,6 +25,6 @@ Sub graphs of DRBD's state transitions
|
|||||||
:alt: disk-states-8.dot
|
:alt: disk-states-8.dot
|
||||||
:align: center
|
:align: center
|
||||||
|
|
||||||
.. kernel-figure:: node-states-8.dot
|
.. kernel-figure:: peer-states-8.dot
|
||||||
:alt: node-states-8.dot
|
:alt: peer-states-8.dot
|
||||||
:align: center
|
:align: center
|
||||||
|
@ -1,8 +1,3 @@
|
|||||||
digraph node_states {
|
|
||||||
Secondary -> Primary [ label = "ioctl_set_state()" ]
|
|
||||||
Primary -> Secondary [ label = "ioctl_set_state()" ]
|
|
||||||
}
|
|
||||||
|
|
||||||
digraph peer_states {
|
digraph peer_states {
|
||||||
Secondary -> Primary [ label = "recv state packet" ]
|
Secondary -> Primary [ label = "recv state packet" ]
|
||||||
Primary -> Secondary [ label = "recv state packet" ]
|
Primary -> Secondary [ label = "recv state packet" ]
|
@ -53,11 +53,10 @@ The number of bits that the PAC occupies in a pointer is 55 minus the
|
|||||||
virtual address size configured by the kernel. For example, with a
|
virtual address size configured by the kernel. For example, with a
|
||||||
virtual address size of 48, the PAC is 7 bits wide.
|
virtual address size of 48, the PAC is 7 bits wide.
|
||||||
|
|
||||||
Recent versions of GCC can compile code with APIAKey-based return
|
When ARM64_PTR_AUTH_KERNEL is selected, the kernel will be compiled
|
||||||
address protection when passed the -msign-return-address option. This
|
with HINT space pointer authentication instructions protecting
|
||||||
uses instructions in the HINT space (unless -march=armv8.3-a or higher
|
function returns. Kernels built with this option will work on hardware
|
||||||
is also passed), and such code can run on systems without the pointer
|
with or without pointer authentication support.
|
||||||
authentication extension.
|
|
||||||
|
|
||||||
In addition to exec(), keys can also be reinitialized to random values
|
In addition to exec(), keys can also be reinitialized to random values
|
||||||
using the PR_PAC_RESET_KEYS prctl. A bitmask of PR_PAC_APIAKEY,
|
using the PR_PAC_RESET_KEYS prctl. A bitmask of PR_PAC_APIAKEY,
|
||||||
|
@ -249,11 +249,16 @@ except ImportError:
|
|||||||
|
|
||||||
html_static_path = ['sphinx-static']
|
html_static_path = ['sphinx-static']
|
||||||
|
|
||||||
html_context = {
|
html_css_files = [
|
||||||
'css_files': [
|
'theme_overrides.css',
|
||||||
'_static/theme_overrides.css',
|
]
|
||||||
],
|
|
||||||
}
|
if major <= 1 and minor < 8:
|
||||||
|
html_context = {
|
||||||
|
'css_files': [
|
||||||
|
'_static/theme_overrides.css',
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
||||||
# Add any extra paths that contain custom files (such as robots.txt or
|
# Add any extra paths that contain custom files (such as robots.txt or
|
||||||
# .htaccess) here, relative to this directory. These files are copied
|
# .htaccess) here, relative to this directory. These files are copied
|
||||||
|
@ -73,12 +73,12 @@ CPUFREQ_POSTCHANGE.
|
|||||||
The third argument is a struct cpufreq_freqs with the following
|
The third argument is a struct cpufreq_freqs with the following
|
||||||
values:
|
values:
|
||||||
|
|
||||||
===== ===========================
|
====== ======================================
|
||||||
cpu number of the affected CPU
|
policy a pointer to the struct cpufreq_policy
|
||||||
old old frequency
|
old old frequency
|
||||||
new new frequency
|
new new frequency
|
||||||
flags flags of the cpufreq driver
|
flags flags of the cpufreq driver
|
||||||
===== ===========================
|
====== ======================================
|
||||||
|
|
||||||
3. CPUFreq Table Generation with Operating Performance Point (OPP)
|
3. CPUFreq Table Generation with Operating Performance Point (OPP)
|
||||||
==================================================================
|
==================================================================
|
||||||
|
@ -17,9 +17,10 @@ properties:
|
|||||||
oneOf:
|
oneOf:
|
||||||
- enum:
|
- enum:
|
||||||
- fsl,imx7ulp-lpi2c
|
- fsl,imx7ulp-lpi2c
|
||||||
- fsl,imx8qm-lpi2c
|
|
||||||
- items:
|
- items:
|
||||||
- const: fsl,imx8qxp-lpi2c
|
- enum:
|
||||||
|
- fsl,imx8qxp-lpi2c
|
||||||
|
- fsl,imx8qm-lpi2c
|
||||||
- const: fsl,imx7ulp-lpi2c
|
- const: fsl,imx7ulp-lpi2c
|
||||||
|
|
||||||
reg:
|
reg:
|
||||||
|
@ -136,7 +136,7 @@ examples:
|
|||||||
samsung,syscon-phandle = <&pmu_system_controller>;
|
samsung,syscon-phandle = <&pmu_system_controller>;
|
||||||
|
|
||||||
/* NTC thermistor is a hwmon device */
|
/* NTC thermistor is a hwmon device */
|
||||||
ncp15wb473 {
|
thermistor {
|
||||||
compatible = "murata,ncp15wb473";
|
compatible = "murata,ncp15wb473";
|
||||||
pullup-uv = <1800000>;
|
pullup-uv = <1800000>;
|
||||||
pullup-ohm = <47000>;
|
pullup-ohm = <47000>;
|
||||||
|
@ -142,7 +142,7 @@ examples:
|
|||||||
down {
|
down {
|
||||||
label = "GPIO Key DOWN";
|
label = "GPIO Key DOWN";
|
||||||
linux,code = <108>;
|
linux,code = <108>;
|
||||||
interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>;
|
interrupts = <1 IRQ_TYPE_EDGE_FALLING>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -79,6 +79,8 @@ properties:
|
|||||||
|
|
||||||
properties:
|
properties:
|
||||||
data-lanes:
|
data-lanes:
|
||||||
|
description:
|
||||||
|
Note that 'fsl,imx7-mipi-csi2' only supports up to 2 data lines.
|
||||||
items:
|
items:
|
||||||
minItems: 1
|
minItems: 1
|
||||||
maxItems: 4
|
maxItems: 4
|
||||||
@ -91,18 +93,6 @@ properties:
|
|||||||
required:
|
required:
|
||||||
- data-lanes
|
- data-lanes
|
||||||
|
|
||||||
allOf:
|
|
||||||
- if:
|
|
||||||
properties:
|
|
||||||
compatible:
|
|
||||||
contains:
|
|
||||||
const: fsl,imx7-mipi-csi2
|
|
||||||
then:
|
|
||||||
properties:
|
|
||||||
data-lanes:
|
|
||||||
items:
|
|
||||||
maxItems: 2
|
|
||||||
|
|
||||||
port@1:
|
port@1:
|
||||||
$ref: /schemas/graph.yaml#/properties/port
|
$ref: /schemas/graph.yaml#/properties/port
|
||||||
description:
|
description:
|
||||||
|
@ -91,6 +91,14 @@ properties:
|
|||||||
compensate for the board being designed with the lanes
|
compensate for the board being designed with the lanes
|
||||||
swapped.
|
swapped.
|
||||||
|
|
||||||
|
enet-phy-lane-no-swap:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/flag
|
||||||
|
description:
|
||||||
|
If set, indicates that PHY will disable swap of the
|
||||||
|
TX/RX lanes. This property allows the PHY to work correcly after
|
||||||
|
e.g. wrong bootstrap configuration caused by issues in PCB
|
||||||
|
layout design.
|
||||||
|
|
||||||
eee-broken-100tx:
|
eee-broken-100tx:
|
||||||
$ref: /schemas/types.yaml#/definitions/flag
|
$ref: /schemas/types.yaml#/definitions/flag
|
||||||
description:
|
description:
|
||||||
|
@ -29,7 +29,7 @@ properties:
|
|||||||
- PHY_TYPE_PCIE
|
- PHY_TYPE_PCIE
|
||||||
- PHY_TYPE_SATA
|
- PHY_TYPE_SATA
|
||||||
- PHY_TYPE_SGMII
|
- PHY_TYPE_SGMII
|
||||||
- PHY_TYPE_USB
|
- PHY_TYPE_USB3
|
||||||
- description: The PHY instance
|
- description: The PHY instance
|
||||||
minimum: 0
|
minimum: 0
|
||||||
maximum: 1 # for DP, SATA or USB
|
maximum: 1 # for DP, SATA or USB
|
||||||
|
@ -105,7 +105,7 @@ examples:
|
|||||||
reg = <0x65>;
|
reg = <0x65>;
|
||||||
interrupt-parent = <&gpio1>;
|
interrupt-parent = <&gpio1>;
|
||||||
interrupts = <16 IRQ_TYPE_EDGE_FALLING>;
|
interrupts = <16 IRQ_TYPE_EDGE_FALLING>;
|
||||||
ti,watchdog-timer = <0>;
|
ti,watchdog-timeout-ms = <0>;
|
||||||
ti,sc-ocp-limit-microamp = <2000000>;
|
ti,sc-ocp-limit-microamp = <2000000>;
|
||||||
ti,sc-ovp-limit-microvolt = <17800000>;
|
ti,sc-ovp-limit-microvolt = <17800000>;
|
||||||
monitored-battery = <&bat>;
|
monitored-battery = <&bat>;
|
||||||
|
@ -19,6 +19,9 @@ properties:
|
|||||||
clocks:
|
clocks:
|
||||||
maxItems: 1
|
maxItems: 1
|
||||||
|
|
||||||
|
interrupts:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
"#sound-dai-cells":
|
"#sound-dai-cells":
|
||||||
const: 0
|
const: 0
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@ properties:
|
|||||||
- rockchip,rk3328-spi
|
- rockchip,rk3328-spi
|
||||||
- rockchip,rk3368-spi
|
- rockchip,rk3368-spi
|
||||||
- rockchip,rk3399-spi
|
- rockchip,rk3399-spi
|
||||||
|
- rockchip,rk3568-spi
|
||||||
- rockchip,rv1126-spi
|
- rockchip,rv1126-spi
|
||||||
- const: rockchip,rk3066-spi
|
- const: rockchip,rk3066-spi
|
||||||
|
|
||||||
|
@ -50,11 +50,11 @@ ksmbd.mountd (user space daemon)
|
|||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
ksmbd.mountd is userspace process to, transfer user account and password that
|
ksmbd.mountd is userspace process to, transfer user account and password that
|
||||||
are registered using ksmbd.adduser(part of utils for user space). Further it
|
are registered using ksmbd.adduser (part of utils for user space). Further it
|
||||||
allows sharing information parameters that parsed from smb.conf to ksmbd in
|
allows sharing information parameters that parsed from smb.conf to ksmbd in
|
||||||
kernel. For the execution part it has a daemon which is continuously running
|
kernel. For the execution part it has a daemon which is continuously running
|
||||||
and connected to the kernel interface using netlink socket, it waits for the
|
and connected to the kernel interface using netlink socket, it waits for the
|
||||||
requests(dcerpc and share/user info). It handles RPC calls (at a minimum few
|
requests (dcerpc and share/user info). It handles RPC calls (at a minimum few
|
||||||
dozen) that are most important for file server from NetShareEnum and
|
dozen) that are most important for file server from NetShareEnum and
|
||||||
NetServerGetInfo. Complete DCE/RPC response is prepared from the user space
|
NetServerGetInfo. Complete DCE/RPC response is prepared from the user space
|
||||||
and passed over to the associated kernel thread for the client.
|
and passed over to the associated kernel thread for the client.
|
||||||
@ -154,11 +154,11 @@ Each layer
|
|||||||
1. Enable all component prints
|
1. Enable all component prints
|
||||||
# sudo ksmbd.control -d "all"
|
# sudo ksmbd.control -d "all"
|
||||||
|
|
||||||
2. Enable one of components(smb, auth, vfs, oplock, ipc, conn, rdma)
|
2. Enable one of components (smb, auth, vfs, oplock, ipc, conn, rdma)
|
||||||
# sudo ksmbd.control -d "smb"
|
# sudo ksmbd.control -d "smb"
|
||||||
|
|
||||||
3. Show what prints are enable.
|
3. Show what prints are enabled.
|
||||||
# cat/sys/class/ksmbd-control/debug
|
# cat /sys/class/ksmbd-control/debug
|
||||||
[smb] auth vfs oplock ipc conn [rdma]
|
[smb] auth vfs oplock ipc conn [rdma]
|
||||||
|
|
||||||
4. Disable prints:
|
4. Disable prints:
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
.. SPDX-License-Identifier: GPL-2.0
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
=================================
|
=================================
|
||||||
NETWORK FILESYSTEM HELPER LIBRARY
|
Network Filesystem Helper Library
|
||||||
=================================
|
=================================
|
||||||
|
|
||||||
.. Contents:
|
.. Contents:
|
||||||
@ -37,22 +37,22 @@ into a common call framework.
|
|||||||
|
|
||||||
The following services are provided:
|
The following services are provided:
|
||||||
|
|
||||||
* Handles transparent huge pages (THPs).
|
* Handle folios that span multiple pages.
|
||||||
|
|
||||||
* Insulates the netfs from VM interface changes.
|
* Insulate the netfs from VM interface changes.
|
||||||
|
|
||||||
* Allows the netfs to arbitrarily split reads up into pieces, even ones that
|
* Allow the netfs to arbitrarily split reads up into pieces, even ones that
|
||||||
don't match page sizes or page alignments and that may cross pages.
|
don't match folio sizes or folio alignments and that may cross folios.
|
||||||
|
|
||||||
* Allows the netfs to expand a readahead request in both directions to meet
|
* Allow the netfs to expand a readahead request in both directions to meet its
|
||||||
its needs.
|
needs.
|
||||||
|
|
||||||
* Allows the netfs to partially fulfil a read, which will then be resubmitted.
|
* Allow the netfs to partially fulfil a read, which will then be resubmitted.
|
||||||
|
|
||||||
* Handles local caching, allowing cached data and server-read data to be
|
* Handle local caching, allowing cached data and server-read data to be
|
||||||
interleaved for a single request.
|
interleaved for a single request.
|
||||||
|
|
||||||
* Handles clearing of bufferage that aren't on the server.
|
* Handle clearing of bufferage that aren't on the server.
|
||||||
|
|
||||||
* Handle retrying of reads that failed, switching reads from the cache to the
|
* Handle retrying of reads that failed, switching reads from the cache to the
|
||||||
server as necessary.
|
server as necessary.
|
||||||
@ -70,22 +70,22 @@ Read Helper Functions
|
|||||||
|
|
||||||
Three read helpers are provided::
|
Three read helpers are provided::
|
||||||
|
|
||||||
* void netfs_readahead(struct readahead_control *ractl,
|
void netfs_readahead(struct readahead_control *ractl,
|
||||||
const struct netfs_read_request_ops *ops,
|
const struct netfs_read_request_ops *ops,
|
||||||
void *netfs_priv);``
|
void *netfs_priv);
|
||||||
* int netfs_readpage(struct file *file,
|
int netfs_readpage(struct file *file,
|
||||||
struct page *page,
|
struct folio *folio,
|
||||||
const struct netfs_read_request_ops *ops,
|
const struct netfs_read_request_ops *ops,
|
||||||
void *netfs_priv);
|
void *netfs_priv);
|
||||||
* int netfs_write_begin(struct file *file,
|
int netfs_write_begin(struct file *file,
|
||||||
struct address_space *mapping,
|
struct address_space *mapping,
|
||||||
loff_t pos,
|
loff_t pos,
|
||||||
unsigned int len,
|
unsigned int len,
|
||||||
unsigned int flags,
|
unsigned int flags,
|
||||||
struct page **_page,
|
struct folio **_folio,
|
||||||
void **_fsdata,
|
void **_fsdata,
|
||||||
const struct netfs_read_request_ops *ops,
|
const struct netfs_read_request_ops *ops,
|
||||||
void *netfs_priv);
|
void *netfs_priv);
|
||||||
|
|
||||||
Each corresponds to a VM operation, with the addition of a couple of parameters
|
Each corresponds to a VM operation, with the addition of a couple of parameters
|
||||||
for the use of the read helpers:
|
for the use of the read helpers:
|
||||||
@ -103,8 +103,8 @@ Both of these values will be stored into the read request structure.
|
|||||||
For ->readahead() and ->readpage(), the network filesystem should just jump
|
For ->readahead() and ->readpage(), the network filesystem should just jump
|
||||||
into the corresponding read helper; whereas for ->write_begin(), it may be a
|
into the corresponding read helper; whereas for ->write_begin(), it may be a
|
||||||
little more complicated as the network filesystem might want to flush
|
little more complicated as the network filesystem might want to flush
|
||||||
conflicting writes or track dirty data and needs to put the acquired page if an
|
conflicting writes or track dirty data and needs to put the acquired folio if
|
||||||
error occurs after calling the helper.
|
an error occurs after calling the helper.
|
||||||
|
|
||||||
The helpers manage the read request, calling back into the network filesystem
|
The helpers manage the read request, calling back into the network filesystem
|
||||||
through the suppplied table of operations. Waits will be performed as
|
through the suppplied table of operations. Waits will be performed as
|
||||||
@ -253,7 +253,7 @@ through which it can issue requests and negotiate::
|
|||||||
void (*issue_op)(struct netfs_read_subrequest *subreq);
|
void (*issue_op)(struct netfs_read_subrequest *subreq);
|
||||||
bool (*is_still_valid)(struct netfs_read_request *rreq);
|
bool (*is_still_valid)(struct netfs_read_request *rreq);
|
||||||
int (*check_write_begin)(struct file *file, loff_t pos, unsigned len,
|
int (*check_write_begin)(struct file *file, loff_t pos, unsigned len,
|
||||||
struct page *page, void **_fsdata);
|
struct folio *folio, void **_fsdata);
|
||||||
void (*done)(struct netfs_read_request *rreq);
|
void (*done)(struct netfs_read_request *rreq);
|
||||||
void (*cleanup)(struct address_space *mapping, void *netfs_priv);
|
void (*cleanup)(struct address_space *mapping, void *netfs_priv);
|
||||||
};
|
};
|
||||||
@ -313,13 +313,14 @@ The operations are as follows:
|
|||||||
|
|
||||||
There is no return value; the netfs_subreq_terminated() function should be
|
There is no return value; the netfs_subreq_terminated() function should be
|
||||||
called to indicate whether or not the operation succeeded and how much data
|
called to indicate whether or not the operation succeeded and how much data
|
||||||
it transferred. The filesystem also should not deal with setting pages
|
it transferred. The filesystem also should not deal with setting folios
|
||||||
uptodate, unlocking them or dropping their refs - the helpers need to deal
|
uptodate, unlocking them or dropping their refs - the helpers need to deal
|
||||||
with this as they have to coordinate with copying to the local cache.
|
with this as they have to coordinate with copying to the local cache.
|
||||||
|
|
||||||
Note that the helpers have the pages locked, but not pinned. It is possible
|
Note that the helpers have the folios locked, but not pinned. It is
|
||||||
to use the ITER_XARRAY iov iterator to refer to the range of the inode that
|
possible to use the ITER_XARRAY iov iterator to refer to the range of the
|
||||||
is being operated upon without the need to allocate large bvec tables.
|
inode that is being operated upon without the need to allocate large bvec
|
||||||
|
tables.
|
||||||
|
|
||||||
* ``is_still_valid()``
|
* ``is_still_valid()``
|
||||||
|
|
||||||
@ -330,15 +331,15 @@ The operations are as follows:
|
|||||||
* ``check_write_begin()``
|
* ``check_write_begin()``
|
||||||
|
|
||||||
[Optional] This is called from the netfs_write_begin() helper once it has
|
[Optional] This is called from the netfs_write_begin() helper once it has
|
||||||
allocated/grabbed the page to be modified to allow the filesystem to flush
|
allocated/grabbed the folio to be modified to allow the filesystem to flush
|
||||||
conflicting state before allowing it to be modified.
|
conflicting state before allowing it to be modified.
|
||||||
|
|
||||||
It should return 0 if everything is now fine, -EAGAIN if the page should be
|
It should return 0 if everything is now fine, -EAGAIN if the folio should be
|
||||||
regrabbed and any other error code to abort the operation.
|
regrabbed and any other error code to abort the operation.
|
||||||
|
|
||||||
* ``done``
|
* ``done``
|
||||||
|
|
||||||
[Optional] This is called after the pages in the request have all been
|
[Optional] This is called after the folios in the request have all been
|
||||||
unlocked (and marked uptodate if applicable).
|
unlocked (and marked uptodate if applicable).
|
||||||
|
|
||||||
* ``cleanup``
|
* ``cleanup``
|
||||||
@ -390,7 +391,7 @@ The read helpers work by the following general procedure:
|
|||||||
* If NETFS_SREQ_CLEAR_TAIL was set, a short read will be cleared to the
|
* If NETFS_SREQ_CLEAR_TAIL was set, a short read will be cleared to the
|
||||||
end of the slice instead of reissuing.
|
end of the slice instead of reissuing.
|
||||||
|
|
||||||
* Once the data is read, the pages that have been fully read/cleared:
|
* Once the data is read, the folios that have been fully read/cleared:
|
||||||
|
|
||||||
* Will be marked uptodate.
|
* Will be marked uptodate.
|
||||||
|
|
||||||
@ -398,11 +399,11 @@ The read helpers work by the following general procedure:
|
|||||||
|
|
||||||
* Unlocked
|
* Unlocked
|
||||||
|
|
||||||
* Any pages that need writing to the cache will then have DIO writes issued.
|
* Any folios that need writing to the cache will then have DIO writes issued.
|
||||||
|
|
||||||
* Synchronous operations will wait for reading to be complete.
|
* Synchronous operations will wait for reading to be complete.
|
||||||
|
|
||||||
* Writes to the cache will proceed asynchronously and the pages will have the
|
* Writes to the cache will proceed asynchronously and the folios will have the
|
||||||
PG_fscache mark removed when that completes.
|
PG_fscache mark removed when that completes.
|
||||||
|
|
||||||
* The request structures will be cleaned up when everything has completed.
|
* The request structures will be cleaned up when everything has completed.
|
||||||
@ -452,6 +453,9 @@ operation table looks like the following::
|
|||||||
netfs_io_terminated_t term_func,
|
netfs_io_terminated_t term_func,
|
||||||
void *term_func_priv);
|
void *term_func_priv);
|
||||||
|
|
||||||
|
int (*prepare_write)(struct netfs_cache_resources *cres,
|
||||||
|
loff_t *_start, size_t *_len, loff_t i_size);
|
||||||
|
|
||||||
int (*write)(struct netfs_cache_resources *cres,
|
int (*write)(struct netfs_cache_resources *cres,
|
||||||
loff_t start_pos,
|
loff_t start_pos,
|
||||||
struct iov_iter *iter,
|
struct iov_iter *iter,
|
||||||
@ -509,6 +513,14 @@ The methods defined in the table are:
|
|||||||
indicating whether the termination is definitely happening in the caller's
|
indicating whether the termination is definitely happening in the caller's
|
||||||
context.
|
context.
|
||||||
|
|
||||||
|
* ``prepare_write()``
|
||||||
|
|
||||||
|
[Required] Called to adjust a write to the cache and check that there is
|
||||||
|
sufficient space in the cache. The start and length values indicate the
|
||||||
|
size of the write that netfslib is proposing, and this can be adjusted by
|
||||||
|
the cache to respect DIO boundaries. The file size is passed for
|
||||||
|
information.
|
||||||
|
|
||||||
* ``write()``
|
* ``write()``
|
||||||
|
|
||||||
[Required] Called to write to the cache. The start file offset is given
|
[Required] Called to write to the cache. The start file offset is given
|
||||||
@ -525,4 +537,9 @@ not the read request structure as they could be used in other situations where
|
|||||||
there isn't a read request structure as well, such as writing dirty data to the
|
there isn't a read request structure as well, such as writing dirty data to the
|
||||||
cache.
|
cache.
|
||||||
|
|
||||||
|
|
||||||
|
API Function Reference
|
||||||
|
======================
|
||||||
|
|
||||||
.. kernel-doc:: include/linux/netfs.h
|
.. kernel-doc:: include/linux/netfs.h
|
||||||
|
.. kernel-doc:: fs/netfs/read_helper.c
|
||||||
|
@ -36,6 +36,8 @@ Key to symbols
|
|||||||
|
|
||||||
=============== =============================================================
|
=============== =============================================================
|
||||||
S Start condition
|
S Start condition
|
||||||
|
Sr Repeated start condition, used to switch from write to
|
||||||
|
read mode.
|
||||||
P Stop condition
|
P Stop condition
|
||||||
Rd/Wr (1 bit) Read/Write bit. Rd equals 1, Wr equals 0.
|
Rd/Wr (1 bit) Read/Write bit. Rd equals 1, Wr equals 0.
|
||||||
A, NA (1 bit) Acknowledge (ACK) and Not Acknowledge (NACK) bit
|
A, NA (1 bit) Acknowledge (ACK) and Not Acknowledge (NACK) bit
|
||||||
@ -100,7 +102,7 @@ Implemented by i2c_smbus_read_byte_data()
|
|||||||
This reads a single byte from a device, from a designated register.
|
This reads a single byte from a device, from a designated register.
|
||||||
The register is specified through the Comm byte::
|
The register is specified through the Comm byte::
|
||||||
|
|
||||||
S Addr Wr [A] Comm [A] S Addr Rd [A] [Data] NA P
|
S Addr Wr [A] Comm [A] Sr Addr Rd [A] [Data] NA P
|
||||||
|
|
||||||
Functionality flag: I2C_FUNC_SMBUS_READ_BYTE_DATA
|
Functionality flag: I2C_FUNC_SMBUS_READ_BYTE_DATA
|
||||||
|
|
||||||
@ -114,7 +116,7 @@ This operation is very like Read Byte; again, data is read from a
|
|||||||
device, from a designated register that is specified through the Comm
|
device, from a designated register that is specified through the Comm
|
||||||
byte. But this time, the data is a complete word (16 bits)::
|
byte. But this time, the data is a complete word (16 bits)::
|
||||||
|
|
||||||
S Addr Wr [A] Comm [A] S Addr Rd [A] [DataLow] A [DataHigh] NA P
|
S Addr Wr [A] Comm [A] Sr Addr Rd [A] [DataLow] A [DataHigh] NA P
|
||||||
|
|
||||||
Functionality flag: I2C_FUNC_SMBUS_READ_WORD_DATA
|
Functionality flag: I2C_FUNC_SMBUS_READ_WORD_DATA
|
||||||
|
|
||||||
@ -164,7 +166,7 @@ This command selects a device register (through the Comm byte), sends
|
|||||||
16 bits of data to it, and reads 16 bits of data in return::
|
16 bits of data to it, and reads 16 bits of data in return::
|
||||||
|
|
||||||
S Addr Wr [A] Comm [A] DataLow [A] DataHigh [A]
|
S Addr Wr [A] Comm [A] DataLow [A] DataHigh [A]
|
||||||
S Addr Rd [A] [DataLow] A [DataHigh] NA P
|
Sr Addr Rd [A] [DataLow] A [DataHigh] NA P
|
||||||
|
|
||||||
Functionality flag: I2C_FUNC_SMBUS_PROC_CALL
|
Functionality flag: I2C_FUNC_SMBUS_PROC_CALL
|
||||||
|
|
||||||
@ -181,7 +183,7 @@ of data is specified by the device in the Count byte.
|
|||||||
::
|
::
|
||||||
|
|
||||||
S Addr Wr [A] Comm [A]
|
S Addr Wr [A] Comm [A]
|
||||||
S Addr Rd [A] [Count] A [Data] A [Data] A ... A [Data] NA P
|
Sr Addr Rd [A] [Count] A [Data] A [Data] A ... A [Data] NA P
|
||||||
|
|
||||||
Functionality flag: I2C_FUNC_SMBUS_READ_BLOCK_DATA
|
Functionality flag: I2C_FUNC_SMBUS_READ_BLOCK_DATA
|
||||||
|
|
||||||
@ -212,7 +214,7 @@ This command selects a device register (through the Comm byte), sends
|
|||||||
1 to 31 bytes of data to it, and reads 1 to 31 bytes of data in return::
|
1 to 31 bytes of data to it, and reads 1 to 31 bytes of data in return::
|
||||||
|
|
||||||
S Addr Wr [A] Comm [A] Count [A] Data [A] ...
|
S Addr Wr [A] Comm [A] Count [A] Data [A] ...
|
||||||
S Addr Rd [A] [Count] A [Data] ... A P
|
Sr Addr Rd [A] [Count] A [Data] ... A P
|
||||||
|
|
||||||
Functionality flag: I2C_FUNC_SMBUS_BLOCK_PROC_CALL
|
Functionality flag: I2C_FUNC_SMBUS_BLOCK_PROC_CALL
|
||||||
|
|
||||||
@ -300,7 +302,7 @@ This command reads a block of bytes from a device, from a
|
|||||||
designated register that is specified through the Comm byte::
|
designated register that is specified through the Comm byte::
|
||||||
|
|
||||||
S Addr Wr [A] Comm [A]
|
S Addr Wr [A] Comm [A]
|
||||||
S Addr Rd [A] [Data] A [Data] A ... A [Data] NA P
|
Sr Addr Rd [A] [Data] A [Data] A ... A [Data] NA P
|
||||||
|
|
||||||
Functionality flag: I2C_FUNC_SMBUS_READ_I2C_BLOCK
|
Functionality flag: I2C_FUNC_SMBUS_READ_I2C_BLOCK
|
||||||
|
|
||||||
|
@ -439,11 +439,9 @@ preemption. The following substitution works on both kernels::
|
|||||||
spin_lock(&p->lock);
|
spin_lock(&p->lock);
|
||||||
p->count += this_cpu_read(var2);
|
p->count += this_cpu_read(var2);
|
||||||
|
|
||||||
On a non-PREEMPT_RT kernel migrate_disable() maps to preempt_disable()
|
|
||||||
which makes the above code fully equivalent. On a PREEMPT_RT kernel
|
|
||||||
migrate_disable() ensures that the task is pinned on the current CPU which
|
migrate_disable() ensures that the task is pinned on the current CPU which
|
||||||
in turn guarantees that the per-CPU access to var1 and var2 are staying on
|
in turn guarantees that the per-CPU access to var1 and var2 are staying on
|
||||||
the same CPU.
|
the same CPU while the task remains preemptible.
|
||||||
|
|
||||||
The migrate_disable() substitution is not valid for the following
|
The migrate_disable() substitution is not valid for the following
|
||||||
scenario::
|
scenario::
|
||||||
@ -456,9 +454,8 @@ scenario::
|
|||||||
p = this_cpu_ptr(&var1);
|
p = this_cpu_ptr(&var1);
|
||||||
p->val = func2();
|
p->val = func2();
|
||||||
|
|
||||||
While correct on a non-PREEMPT_RT kernel, this breaks on PREEMPT_RT because
|
This breaks because migrate_disable() does not protect against reentrancy from
|
||||||
here migrate_disable() does not protect against reentrancy from a
|
a preempting task. A correct substitution for this case is::
|
||||||
preempting task. A correct substitution for this case is::
|
|
||||||
|
|
||||||
func()
|
func()
|
||||||
{
|
{
|
||||||
|
@ -37,8 +37,7 @@ conn_reuse_mode - INTEGER
|
|||||||
|
|
||||||
0: disable any special handling on port reuse. The new
|
0: disable any special handling on port reuse. The new
|
||||||
connection will be delivered to the same real server that was
|
connection will be delivered to the same real server that was
|
||||||
servicing the previous connection. This will effectively
|
servicing the previous connection.
|
||||||
disable expire_nodest_conn.
|
|
||||||
|
|
||||||
bit 1: enable rescheduling of new connections when it is safe.
|
bit 1: enable rescheduling of new connections when it is safe.
|
||||||
That is, whenever expire_nodest_conn and for TCP sockets, when
|
That is, whenever expire_nodest_conn and for TCP sockets, when
|
||||||
|
@ -486,8 +486,8 @@ of packets.
|
|||||||
Drivers are free to use a more permissive configuration than the requested
|
Drivers are free to use a more permissive configuration than the requested
|
||||||
configuration. It is expected that drivers should only implement directly the
|
configuration. It is expected that drivers should only implement directly the
|
||||||
most generic mode that can be supported. For example if the hardware can
|
most generic mode that can be supported. For example if the hardware can
|
||||||
support HWTSTAMP_FILTER_V2_EVENT, then it should generally always upscale
|
support HWTSTAMP_FILTER_PTP_V2_EVENT, then it should generally always upscale
|
||||||
HWTSTAMP_FILTER_V2_L2_SYNC_MESSAGE, and so forth, as HWTSTAMP_FILTER_V2_EVENT
|
HWTSTAMP_FILTER_PTP_V2_L2_SYNC, and so forth, as HWTSTAMP_FILTER_PTP_V2_EVENT
|
||||||
is more generic (and more useful to applications).
|
is more generic (and more useful to applications).
|
||||||
|
|
||||||
A driver which supports hardware time stamping shall update the struct
|
A driver which supports hardware time stamping shall update the struct
|
||||||
|
@ -35,6 +35,7 @@ GNU make 3.81 make --version
|
|||||||
binutils 2.23 ld -v
|
binutils 2.23 ld -v
|
||||||
flex 2.5.35 flex --version
|
flex 2.5.35 flex --version
|
||||||
bison 2.0 bison --version
|
bison 2.0 bison --version
|
||||||
|
pahole 1.16 pahole --version
|
||||||
util-linux 2.10o fdformat --version
|
util-linux 2.10o fdformat --version
|
||||||
kmod 13 depmod -V
|
kmod 13 depmod -V
|
||||||
e2fsprogs 1.41.4 e2fsck -V
|
e2fsprogs 1.41.4 e2fsck -V
|
||||||
@ -108,6 +109,16 @@ Bison
|
|||||||
Since Linux 4.16, the build system generates parsers
|
Since Linux 4.16, the build system generates parsers
|
||||||
during build. This requires bison 2.0 or later.
|
during build. This requires bison 2.0 or later.
|
||||||
|
|
||||||
|
pahole:
|
||||||
|
-------
|
||||||
|
|
||||||
|
Since Linux 5.2, if CONFIG_DEBUG_INFO_BTF is selected, the build system
|
||||||
|
generates BTF (BPF Type Format) from DWARF in vmlinux, a bit later from kernel
|
||||||
|
modules as well. This requires pahole v1.16 or later.
|
||||||
|
|
||||||
|
It is found in the 'dwarves' or 'pahole' distro packages or from
|
||||||
|
https://fedorapeople.org/~acme/dwarves/.
|
||||||
|
|
||||||
Perl
|
Perl
|
||||||
----
|
----
|
||||||
|
|
||||||
|
@ -14,7 +14,8 @@ works, see Documentation/process/development-process.rst. Also, read
|
|||||||
Documentation/process/submit-checklist.rst
|
Documentation/process/submit-checklist.rst
|
||||||
for a list of items to check before submitting code. If you are submitting
|
for a list of items to check before submitting code. If you are submitting
|
||||||
a driver, also read Documentation/process/submitting-drivers.rst; for device
|
a driver, also read Documentation/process/submitting-drivers.rst; for device
|
||||||
tree binding patches, read Documentation/process/submitting-patches.rst.
|
tree binding patches, read
|
||||||
|
Documentation/devicetree/bindings/submitting-patches.rst.
|
||||||
|
|
||||||
This documentation assumes that you're using ``git`` to prepare your patches.
|
This documentation assumes that you're using ``git`` to prepare your patches.
|
||||||
If you're unfamiliar with ``git``, you would be well-advised to learn how to
|
If you're unfamiliar with ``git``, you would be well-advised to learn how to
|
||||||
|
48
MAINTAINERS
48
MAINTAINERS
@ -2264,6 +2264,15 @@ L: linux-iio@vger.kernel.org
|
|||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/counter/microchip-tcb-capture.c
|
F: drivers/counter/microchip-tcb-capture.c
|
||||||
|
|
||||||
|
ARM/MILBEAUT ARCHITECTURE
|
||||||
|
M: Taichi Sugaya <sugaya.taichi@socionext.com>
|
||||||
|
M: Takao Orito <orito.takao@socionext.com>
|
||||||
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
|
S: Maintained
|
||||||
|
F: arch/arm/boot/dts/milbeaut*
|
||||||
|
F: arch/arm/mach-milbeaut/
|
||||||
|
N: milbeaut
|
||||||
|
|
||||||
ARM/MIOA701 MACHINE SUPPORT
|
ARM/MIOA701 MACHINE SUPPORT
|
||||||
M: Robert Jarzmik <robert.jarzmik@free.fr>
|
M: Robert Jarzmik <robert.jarzmik@free.fr>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
@ -2730,10 +2739,11 @@ S: Maintained
|
|||||||
F: drivers/memory/*emif*
|
F: drivers/memory/*emif*
|
||||||
|
|
||||||
ARM/TEXAS INSTRUMENT KEYSTONE ARCHITECTURE
|
ARM/TEXAS INSTRUMENT KEYSTONE ARCHITECTURE
|
||||||
|
M: Nishanth Menon <nm@ti.com>
|
||||||
M: Santosh Shilimkar <ssantosh@kernel.org>
|
M: Santosh Shilimkar <ssantosh@kernel.org>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/ssantosh/linux-keystone.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/ti/linux.git
|
||||||
F: arch/arm/boot/dts/keystone-*
|
F: arch/arm/boot/dts/keystone-*
|
||||||
F: arch/arm/mach-keystone/
|
F: arch/arm/mach-keystone/
|
||||||
|
|
||||||
@ -3571,13 +3581,14 @@ L: netdev@vger.kernel.org
|
|||||||
S: Supported
|
S: Supported
|
||||||
F: drivers/net/ethernet/broadcom/b44.*
|
F: drivers/net/ethernet/broadcom/b44.*
|
||||||
|
|
||||||
BROADCOM B53 ETHERNET SWITCH DRIVER
|
BROADCOM B53/SF2 ETHERNET SWITCH DRIVER
|
||||||
M: Florian Fainelli <f.fainelli@gmail.com>
|
M: Florian Fainelli <f.fainelli@gmail.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
L: openwrt-devel@lists.openwrt.org (subscribers-only)
|
L: openwrt-devel@lists.openwrt.org (subscribers-only)
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/devicetree/bindings/net/dsa/brcm,b53.yaml
|
F: Documentation/devicetree/bindings/net/dsa/brcm,b53.yaml
|
||||||
F: drivers/net/dsa/b53/*
|
F: drivers/net/dsa/b53/*
|
||||||
|
F: drivers/net/dsa/bcm_sf2*
|
||||||
F: include/linux/dsa/brcm.h
|
F: include/linux/dsa/brcm.h
|
||||||
F: include/linux/platform_data/b53.h
|
F: include/linux/platform_data/b53.h
|
||||||
|
|
||||||
@ -9335,7 +9346,6 @@ S: Maintained
|
|||||||
F: drivers/iio/pressure/dps310.c
|
F: drivers/iio/pressure/dps310.c
|
||||||
|
|
||||||
INFINIBAND SUBSYSTEM
|
INFINIBAND SUBSYSTEM
|
||||||
M: Doug Ledford <dledford@redhat.com>
|
|
||||||
M: Jason Gunthorpe <jgg@nvidia.com>
|
M: Jason Gunthorpe <jgg@nvidia.com>
|
||||||
L: linux-rdma@vger.kernel.org
|
L: linux-rdma@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -10287,9 +10297,9 @@ F: lib/Kconfig.kcsan
|
|||||||
F: scripts/Makefile.kcsan
|
F: scripts/Makefile.kcsan
|
||||||
|
|
||||||
KDUMP
|
KDUMP
|
||||||
M: Dave Young <dyoung@redhat.com>
|
|
||||||
M: Baoquan He <bhe@redhat.com>
|
M: Baoquan He <bhe@redhat.com>
|
||||||
R: Vivek Goyal <vgoyal@redhat.com>
|
R: Vivek Goyal <vgoyal@redhat.com>
|
||||||
|
R: Dave Young <dyoung@redhat.com>
|
||||||
L: kexec@lists.infradead.org
|
L: kexec@lists.infradead.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
W: http://lse.sourceforge.net/kdump/
|
W: http://lse.sourceforge.net/kdump/
|
||||||
@ -12187,8 +12197,8 @@ F: drivers/net/ethernet/mellanox/mlx5/core/fpga/*
|
|||||||
F: include/linux/mlx5/mlx5_ifc_fpga.h
|
F: include/linux/mlx5/mlx5_ifc_fpga.h
|
||||||
|
|
||||||
MELLANOX ETHERNET SWITCH DRIVERS
|
MELLANOX ETHERNET SWITCH DRIVERS
|
||||||
M: Jiri Pirko <jiri@nvidia.com>
|
|
||||||
M: Ido Schimmel <idosch@nvidia.com>
|
M: Ido Schimmel <idosch@nvidia.com>
|
||||||
|
M: Petr Machata <petrm@nvidia.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
W: http://www.mellanox.com
|
W: http://www.mellanox.com
|
||||||
@ -15778,6 +15788,15 @@ S: Maintained
|
|||||||
F: Documentation/devicetree/bindings/net/qcom,ethqos.txt
|
F: Documentation/devicetree/bindings/net/qcom,ethqos.txt
|
||||||
F: drivers/net/ethernet/stmicro/stmmac/dwmac-qcom-ethqos.c
|
F: drivers/net/ethernet/stmicro/stmmac/dwmac-qcom-ethqos.c
|
||||||
|
|
||||||
|
QUALCOMM FASTRPC DRIVER
|
||||||
|
M: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
|
||||||
|
M: Amol Maheshwari <amahesh@qti.qualcomm.com>
|
||||||
|
L: linux-arm-msm@vger.kernel.org
|
||||||
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/misc/qcom,fastrpc.txt
|
||||||
|
F: drivers/misc/fastrpc.c
|
||||||
|
F: include/uapi/misc/fastrpc.h
|
||||||
|
|
||||||
QUALCOMM GENERIC INTERFACE I2C DRIVER
|
QUALCOMM GENERIC INTERFACE I2C DRIVER
|
||||||
M: Akash Asthana <akashast@codeaurora.org>
|
M: Akash Asthana <akashast@codeaurora.org>
|
||||||
M: Mukesh Savaliya <msavaliy@codeaurora.org>
|
M: Mukesh Savaliya <msavaliy@codeaurora.org>
|
||||||
@ -15986,6 +16005,7 @@ F: arch/mips/generic/board-ranchu.c
|
|||||||
|
|
||||||
RANDOM NUMBER DRIVER
|
RANDOM NUMBER DRIVER
|
||||||
M: "Theodore Ts'o" <tytso@mit.edu>
|
M: "Theodore Ts'o" <tytso@mit.edu>
|
||||||
|
M: Jason A. Donenfeld <Jason@zx2c4.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/char/random.c
|
F: drivers/char/random.c
|
||||||
|
|
||||||
@ -16508,6 +16528,12 @@ T: git git://linuxtv.org/media_tree.git
|
|||||||
F: Documentation/devicetree/bindings/media/allwinner,sun8i-a83t-de2-rotate.yaml
|
F: Documentation/devicetree/bindings/media/allwinner,sun8i-a83t-de2-rotate.yaml
|
||||||
F: drivers/media/platform/sunxi/sun8i-rotate/
|
F: drivers/media/platform/sunxi/sun8i-rotate/
|
||||||
|
|
||||||
|
RPMSG TTY DRIVER
|
||||||
|
M: Arnaud Pouliquen <arnaud.pouliquen@foss.st.com>
|
||||||
|
L: linux-remoteproc@vger.kernel.org
|
||||||
|
S: Maintained
|
||||||
|
F: drivers/tty/rpmsg_tty.c
|
||||||
|
|
||||||
RTL2830 MEDIA DRIVER
|
RTL2830 MEDIA DRIVER
|
||||||
M: Antti Palosaari <crope@iki.fi>
|
M: Antti Palosaari <crope@iki.fi>
|
||||||
L: linux-media@vger.kernel.org
|
L: linux-media@vger.kernel.org
|
||||||
@ -16629,8 +16655,8 @@ W: http://www.ibm.com/developerworks/linux/linux390/
|
|||||||
F: drivers/iommu/s390-iommu.c
|
F: drivers/iommu/s390-iommu.c
|
||||||
|
|
||||||
S390 IUCV NETWORK LAYER
|
S390 IUCV NETWORK LAYER
|
||||||
M: Julian Wiedmann <jwi@linux.ibm.com>
|
M: Alexandra Winter <wintera@linux.ibm.com>
|
||||||
M: Karsten Graul <kgraul@linux.ibm.com>
|
M: Wenjia Zhang <wenjia@linux.ibm.com>
|
||||||
L: linux-s390@vger.kernel.org
|
L: linux-s390@vger.kernel.org
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -16640,8 +16666,8 @@ F: include/net/iucv/
|
|||||||
F: net/iucv/
|
F: net/iucv/
|
||||||
|
|
||||||
S390 NETWORK DRIVERS
|
S390 NETWORK DRIVERS
|
||||||
M: Julian Wiedmann <jwi@linux.ibm.com>
|
M: Alexandra Winter <wintera@linux.ibm.com>
|
||||||
M: Karsten Graul <kgraul@linux.ibm.com>
|
M: Wenjia Zhang <wenjia@linux.ibm.com>
|
||||||
L: linux-s390@vger.kernel.org
|
L: linux-s390@vger.kernel.org
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -18501,6 +18527,7 @@ F: include/uapi/linux/pkt_sched.h
|
|||||||
F: include/uapi/linux/tc_act/
|
F: include/uapi/linux/tc_act/
|
||||||
F: include/uapi/linux/tc_ematch/
|
F: include/uapi/linux/tc_ematch/
|
||||||
F: net/sched/
|
F: net/sched/
|
||||||
|
F: tools/testing/selftests/tc-testing
|
||||||
|
|
||||||
TC90522 MEDIA DRIVER
|
TC90522 MEDIA DRIVER
|
||||||
M: Akihiro Tsukada <tskd08@gmail.com>
|
M: Akihiro Tsukada <tskd08@gmail.com>
|
||||||
@ -19049,11 +19076,12 @@ F: drivers/mmc/host/tifm_sd.c
|
|||||||
F: include/linux/tifm.h
|
F: include/linux/tifm.h
|
||||||
|
|
||||||
TI KEYSTONE MULTICORE NAVIGATOR DRIVERS
|
TI KEYSTONE MULTICORE NAVIGATOR DRIVERS
|
||||||
|
M: Nishanth Menon <nm@ti.com>
|
||||||
M: Santosh Shilimkar <ssantosh@kernel.org>
|
M: Santosh Shilimkar <ssantosh@kernel.org>
|
||||||
L: linux-kernel@vger.kernel.org
|
L: linux-kernel@vger.kernel.org
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/ssantosh/linux-keystone.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/ti/linux.git
|
||||||
F: drivers/soc/ti/*
|
F: drivers/soc/ti/*
|
||||||
|
|
||||||
TI LM49xxx FAMILY ASoC CODEC DRIVERS
|
TI LM49xxx FAMILY ASoC CODEC DRIVERS
|
||||||
|
16
Makefile
16
Makefile
@ -2,8 +2,8 @@
|
|||||||
VERSION = 5
|
VERSION = 5
|
||||||
PATCHLEVEL = 16
|
PATCHLEVEL = 16
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc2
|
EXTRAVERSION = -rc5
|
||||||
NAME = Trick or Treat
|
NAME = Gobble Gobble
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
# To see a list of typical targets execute "make help"
|
# To see a list of typical targets execute "make help"
|
||||||
@ -789,7 +789,7 @@ stackp-flags-$(CONFIG_STACKPROTECTOR_STRONG) := -fstack-protector-strong
|
|||||||
KBUILD_CFLAGS += $(stackp-flags-y)
|
KBUILD_CFLAGS += $(stackp-flags-y)
|
||||||
|
|
||||||
KBUILD_CFLAGS-$(CONFIG_WERROR) += -Werror
|
KBUILD_CFLAGS-$(CONFIG_WERROR) += -Werror
|
||||||
KBUILD_CFLAGS += $(KBUILD_CFLAGS-y) $(CONFIG_CC_IMPLICIT_FALLTHROUGH)
|
KBUILD_CFLAGS += $(KBUILD_CFLAGS-y) $(CONFIG_CC_IMPLICIT_FALLTHROUGH:"%"=%)
|
||||||
|
|
||||||
ifdef CONFIG_CC_IS_CLANG
|
ifdef CONFIG_CC_IS_CLANG
|
||||||
KBUILD_CPPFLAGS += -Qunused-arguments
|
KBUILD_CPPFLAGS += -Qunused-arguments
|
||||||
@ -1374,17 +1374,17 @@ endif
|
|||||||
|
|
||||||
ifneq ($(dtstree),)
|
ifneq ($(dtstree),)
|
||||||
|
|
||||||
%.dtb: dt_binding_check include/config/kernel.release scripts_dtc
|
%.dtb: include/config/kernel.release scripts_dtc
|
||||||
$(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@ $(dtstree)/$*.dt.yaml
|
$(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@
|
||||||
|
|
||||||
%.dtbo: dt_binding_check include/config/kernel.release scripts_dtc
|
%.dtbo: include/config/kernel.release scripts_dtc
|
||||||
$(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@ $(dtstree)/$*.dt.yaml
|
$(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@
|
||||||
|
|
||||||
PHONY += dtbs dtbs_install dtbs_check
|
PHONY += dtbs dtbs_install dtbs_check
|
||||||
dtbs: include/config/kernel.release scripts_dtc
|
dtbs: include/config/kernel.release scripts_dtc
|
||||||
$(Q)$(MAKE) $(build)=$(dtstree)
|
$(Q)$(MAKE) $(build)=$(dtstree)
|
||||||
|
|
||||||
ifneq ($(filter dtbs_check %.dtb %.dtbo, $(MAKECMDGOALS)),)
|
ifneq ($(filter dtbs_check, $(MAKECMDGOALS)),)
|
||||||
export CHECK_DTBS=y
|
export CHECK_DTBS=y
|
||||||
dtbs: dt_binding_check
|
dtbs: dt_binding_check
|
||||||
endif
|
endif
|
||||||
|
10
arch/Kconfig
10
arch/Kconfig
@ -991,6 +991,16 @@ config HAVE_ARCH_COMPAT_MMAP_BASES
|
|||||||
and vice-versa 32-bit applications to call 64-bit mmap().
|
and vice-versa 32-bit applications to call 64-bit mmap().
|
||||||
Required for applications doing different bitness syscalls.
|
Required for applications doing different bitness syscalls.
|
||||||
|
|
||||||
|
config PAGE_SIZE_LESS_THAN_64KB
|
||||||
|
def_bool y
|
||||||
|
depends on !ARM64_64K_PAGES
|
||||||
|
depends on !IA64_PAGE_SIZE_64KB
|
||||||
|
depends on !PAGE_SIZE_64KB
|
||||||
|
depends on !PARISC_PAGE_SIZE_64KB
|
||||||
|
depends on !PPC_64K_PAGES
|
||||||
|
depends on !PPC_256K_PAGES
|
||||||
|
depends on !PAGE_SIZE_256KB
|
||||||
|
|
||||||
# This allows to use a set of generic functions to determine mmap base
|
# This allows to use a set of generic functions to determine mmap base
|
||||||
# address by giving priority to top-down scheme only if the process
|
# address by giving priority to top-down scheme only if the process
|
||||||
# is not in legacy mode (compat task, unlimited stack size or
|
# is not in legacy mode (compat task, unlimited stack size or
|
||||||
|
@ -488,3 +488,4 @@
|
|||||||
556 common landlock_restrict_self sys_landlock_restrict_self
|
556 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 557 reserved for memfd_secret
|
# 557 reserved for memfd_secret
|
||||||
558 common process_mrelease sys_process_mrelease
|
558 common process_mrelease sys_process_mrelease
|
||||||
|
559 common futex_waitv sys_futex_waitv
|
||||||
|
@ -36,7 +36,6 @@ void __flush_dcache_page(phys_addr_t paddr, unsigned long vaddr);
|
|||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
|
|
||||||
void flush_dcache_page(struct page *page);
|
void flush_dcache_page(struct page *page);
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
|
|
||||||
void dma_cache_wback_inv(phys_addr_t start, unsigned long sz);
|
void dma_cache_wback_inv(phys_addr_t start, unsigned long sz);
|
||||||
void dma_cache_inv(phys_addr_t start, unsigned long sz);
|
void dma_cache_inv(phys_addr_t start, unsigned long sz);
|
||||||
|
@ -506,11 +506,17 @@
|
|||||||
#address-cells = <3>;
|
#address-cells = <3>;
|
||||||
#interrupt-cells = <1>;
|
#interrupt-cells = <1>;
|
||||||
#size-cells = <2>;
|
#size-cells = <2>;
|
||||||
interrupts = <GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>,
|
interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
|
||||||
<GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>;
|
<GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
interrupt-names = "pcie", "msi";
|
interrupt-names = "pcie", "msi";
|
||||||
interrupt-map-mask = <0x0 0x0 0x0 0x7>;
|
interrupt-map-mask = <0x0 0x0 0x0 0x7>;
|
||||||
interrupt-map = <0 0 0 1 &gicv2 GIC_SPI 143
|
interrupt-map = <0 0 0 1 &gicv2 GIC_SPI 143
|
||||||
|
IRQ_TYPE_LEVEL_HIGH>,
|
||||||
|
<0 0 0 2 &gicv2 GIC_SPI 144
|
||||||
|
IRQ_TYPE_LEVEL_HIGH>,
|
||||||
|
<0 0 0 3 &gicv2 GIC_SPI 145
|
||||||
|
IRQ_TYPE_LEVEL_HIGH>,
|
||||||
|
<0 0 0 4 &gicv2 GIC_SPI 146
|
||||||
IRQ_TYPE_LEVEL_HIGH>;
|
IRQ_TYPE_LEVEL_HIGH>;
|
||||||
msi-controller;
|
msi-controller;
|
||||||
msi-parent = <&pcie0>;
|
msi-parent = <&pcie0>;
|
||||||
|
@ -242,6 +242,8 @@
|
|||||||
|
|
||||||
gpio-controller;
|
gpio-controller;
|
||||||
#gpio-cells = <2>;
|
#gpio-cells = <2>;
|
||||||
|
interrupt-controller;
|
||||||
|
#interrupt-cells = <2>;
|
||||||
};
|
};
|
||||||
|
|
||||||
pcie0: pcie@12000 {
|
pcie0: pcie@12000 {
|
||||||
@ -408,7 +410,7 @@
|
|||||||
i2c0: i2c@18009000 {
|
i2c0: i2c@18009000 {
|
||||||
compatible = "brcm,iproc-i2c";
|
compatible = "brcm,iproc-i2c";
|
||||||
reg = <0x18009000 0x50>;
|
reg = <0x18009000 0x50>;
|
||||||
interrupts = <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
clock-frequency = <100000>;
|
clock-frequency = <100000>;
|
||||||
|
@ -290,7 +290,6 @@ extern void flush_cache_page(struct vm_area_struct *vma, unsigned long user_addr
|
|||||||
*/
|
*/
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
extern void flush_dcache_page(struct page *);
|
extern void flush_dcache_page(struct page *);
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
|
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_KERNEL_VMAP_RANGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_KERNEL_VMAP_RANGE 1
|
||||||
static inline void flush_kernel_vmap_range(void *addr, int size)
|
static inline void flush_kernel_vmap_range(void *addr, int size)
|
||||||
|
@ -33,7 +33,7 @@ extern void __iomem *sdr_ctl_base_addr;
|
|||||||
u32 socfpga_sdram_self_refresh(u32 sdr_base);
|
u32 socfpga_sdram_self_refresh(u32 sdr_base);
|
||||||
extern unsigned int socfpga_sdram_self_refresh_sz;
|
extern unsigned int socfpga_sdram_self_refresh_sz;
|
||||||
|
|
||||||
extern char secondary_trampoline, secondary_trampoline_end;
|
extern char secondary_trampoline[], secondary_trampoline_end[];
|
||||||
|
|
||||||
extern unsigned long socfpga_cpu1start_addr;
|
extern unsigned long socfpga_cpu1start_addr;
|
||||||
|
|
||||||
|
@ -20,14 +20,14 @@
|
|||||||
|
|
||||||
static int socfpga_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
static int socfpga_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
||||||
{
|
{
|
||||||
int trampoline_size = &secondary_trampoline_end - &secondary_trampoline;
|
int trampoline_size = secondary_trampoline_end - secondary_trampoline;
|
||||||
|
|
||||||
if (socfpga_cpu1start_addr) {
|
if (socfpga_cpu1start_addr) {
|
||||||
/* This will put CPU #1 into reset. */
|
/* This will put CPU #1 into reset. */
|
||||||
writel(RSTMGR_MPUMODRST_CPU1,
|
writel(RSTMGR_MPUMODRST_CPU1,
|
||||||
rst_manager_base_addr + SOCFPGA_RSTMGR_MODMPURST);
|
rst_manager_base_addr + SOCFPGA_RSTMGR_MODMPURST);
|
||||||
|
|
||||||
memcpy(phys_to_virt(0), &secondary_trampoline, trampoline_size);
|
memcpy(phys_to_virt(0), secondary_trampoline, trampoline_size);
|
||||||
|
|
||||||
writel(__pa_symbol(secondary_startup),
|
writel(__pa_symbol(secondary_startup),
|
||||||
sys_manager_base_addr + (socfpga_cpu1start_addr & 0x000000ff));
|
sys_manager_base_addr + (socfpga_cpu1start_addr & 0x000000ff));
|
||||||
@ -45,12 +45,12 @@ static int socfpga_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
|||||||
|
|
||||||
static int socfpga_a10_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
static int socfpga_a10_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
||||||
{
|
{
|
||||||
int trampoline_size = &secondary_trampoline_end - &secondary_trampoline;
|
int trampoline_size = secondary_trampoline_end - secondary_trampoline;
|
||||||
|
|
||||||
if (socfpga_cpu1start_addr) {
|
if (socfpga_cpu1start_addr) {
|
||||||
writel(RSTMGR_MPUMODRST_CPU1, rst_manager_base_addr +
|
writel(RSTMGR_MPUMODRST_CPU1, rst_manager_base_addr +
|
||||||
SOCFPGA_A10_RSTMGR_MODMPURST);
|
SOCFPGA_A10_RSTMGR_MODMPURST);
|
||||||
memcpy(phys_to_virt(0), &secondary_trampoline, trampoline_size);
|
memcpy(phys_to_virt(0), secondary_trampoline, trampoline_size);
|
||||||
|
|
||||||
writel(__pa_symbol(secondary_startup),
|
writel(__pa_symbol(secondary_startup),
|
||||||
sys_manager_base_addr + (socfpga_cpu1start_addr & 0x00000fff));
|
sys_manager_base_addr + (socfpga_cpu1start_addr & 0x00000fff));
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
* Copyright The Asahi Linux Contributors
|
* Copyright The Asahi Linux Contributors
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <dt-bindings/gpio/gpio.h>
|
||||||
#include <dt-bindings/interrupt-controller/apple-aic.h>
|
#include <dt-bindings/interrupt-controller/apple-aic.h>
|
||||||
#include <dt-bindings/interrupt-controller/irq.h>
|
#include <dt-bindings/interrupt-controller/irq.h>
|
||||||
#include <dt-bindings/pinctrl/apple.h>
|
#include <dt-bindings/pinctrl/apple.h>
|
||||||
@ -281,7 +282,7 @@
|
|||||||
port00: pci@0,0 {
|
port00: pci@0,0 {
|
||||||
device_type = "pci";
|
device_type = "pci";
|
||||||
reg = <0x0 0x0 0x0 0x0 0x0>;
|
reg = <0x0 0x0 0x0 0x0 0x0>;
|
||||||
reset-gpios = <&pinctrl_ap 152 0>;
|
reset-gpios = <&pinctrl_ap 152 GPIO_ACTIVE_LOW>;
|
||||||
max-link-speed = <2>;
|
max-link-speed = <2>;
|
||||||
|
|
||||||
#address-cells = <3>;
|
#address-cells = <3>;
|
||||||
@ -301,7 +302,7 @@
|
|||||||
port01: pci@1,0 {
|
port01: pci@1,0 {
|
||||||
device_type = "pci";
|
device_type = "pci";
|
||||||
reg = <0x800 0x0 0x0 0x0 0x0>;
|
reg = <0x800 0x0 0x0 0x0 0x0>;
|
||||||
reset-gpios = <&pinctrl_ap 153 0>;
|
reset-gpios = <&pinctrl_ap 153 GPIO_ACTIVE_LOW>;
|
||||||
max-link-speed = <2>;
|
max-link-speed = <2>;
|
||||||
|
|
||||||
#address-cells = <3>;
|
#address-cells = <3>;
|
||||||
@ -321,7 +322,7 @@
|
|||||||
port02: pci@2,0 {
|
port02: pci@2,0 {
|
||||||
device_type = "pci";
|
device_type = "pci";
|
||||||
reg = <0x1000 0x0 0x0 0x0 0x0>;
|
reg = <0x1000 0x0 0x0 0x0 0x0>;
|
||||||
reset-gpios = <&pinctrl_ap 33 0>;
|
reset-gpios = <&pinctrl_ap 33 GPIO_ACTIVE_LOW>;
|
||||||
max-link-speed = <1>;
|
max-link-speed = <1>;
|
||||||
|
|
||||||
#address-cells = <3>;
|
#address-cells = <3>;
|
||||||
|
@ -296,8 +296,7 @@
|
|||||||
pinctrl-0 = <&ufs_rst_n &ufs_refclk_out>;
|
pinctrl-0 = <&ufs_rst_n &ufs_refclk_out>;
|
||||||
phys = <&ufs_0_phy>;
|
phys = <&ufs_0_phy>;
|
||||||
phy-names = "ufs-phy";
|
phy-names = "ufs-phy";
|
||||||
samsung,sysreg = <&syscon_fsys2>;
|
samsung,sysreg = <&syscon_fsys2 0x710>;
|
||||||
samsung,ufs-shareability-reg-offset = <0x710>;
|
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -12,6 +12,17 @@
|
|||||||
|
|
||||||
#define HAVE_FUNCTION_GRAPH_FP_TEST
|
#define HAVE_FUNCTION_GRAPH_FP_TEST
|
||||||
|
|
||||||
|
/*
|
||||||
|
* HAVE_FUNCTION_GRAPH_RET_ADDR_PTR means that the architecture can provide a
|
||||||
|
* "return address pointer" which can be used to uniquely identify a return
|
||||||
|
* address which has been overwritten.
|
||||||
|
*
|
||||||
|
* On arm64 we use the address of the caller's frame record, which remains the
|
||||||
|
* same for the lifetime of the instrumented function, unlike the return
|
||||||
|
* address in the LR.
|
||||||
|
*/
|
||||||
|
#define HAVE_FUNCTION_GRAPH_RET_ADDR_PTR
|
||||||
|
|
||||||
#ifdef CONFIG_DYNAMIC_FTRACE_WITH_REGS
|
#ifdef CONFIG_DYNAMIC_FTRACE_WITH_REGS
|
||||||
#define ARCH_SUPPORTS_FTRACE_OPS 1
|
#define ARCH_SUPPORTS_FTRACE_OPS 1
|
||||||
#else
|
#else
|
||||||
|
@ -91,7 +91,7 @@
|
|||||||
#define HCR_HOST_VHE_FLAGS (HCR_RW | HCR_TGE | HCR_E2H)
|
#define HCR_HOST_VHE_FLAGS (HCR_RW | HCR_TGE | HCR_E2H)
|
||||||
|
|
||||||
/* TCR_EL2 Registers bits */
|
/* TCR_EL2 Registers bits */
|
||||||
#define TCR_EL2_RES1 ((1 << 31) | (1 << 23))
|
#define TCR_EL2_RES1 ((1U << 31) | (1 << 23))
|
||||||
#define TCR_EL2_TBI (1 << 20)
|
#define TCR_EL2_TBI (1 << 20)
|
||||||
#define TCR_EL2_PS_SHIFT 16
|
#define TCR_EL2_PS_SHIFT 16
|
||||||
#define TCR_EL2_PS_MASK (7 << TCR_EL2_PS_SHIFT)
|
#define TCR_EL2_PS_MASK (7 << TCR_EL2_PS_SHIFT)
|
||||||
@ -276,7 +276,7 @@
|
|||||||
#define CPTR_EL2_TFP_SHIFT 10
|
#define CPTR_EL2_TFP_SHIFT 10
|
||||||
|
|
||||||
/* Hyp Coprocessor Trap Register */
|
/* Hyp Coprocessor Trap Register */
|
||||||
#define CPTR_EL2_TCPAC (1 << 31)
|
#define CPTR_EL2_TCPAC (1U << 31)
|
||||||
#define CPTR_EL2_TAM (1 << 30)
|
#define CPTR_EL2_TAM (1 << 30)
|
||||||
#define CPTR_EL2_TTA (1 << 20)
|
#define CPTR_EL2_TTA (1 << 20)
|
||||||
#define CPTR_EL2_TFP (1 << CPTR_EL2_TFP_SHIFT)
|
#define CPTR_EL2_TFP (1 << CPTR_EL2_TFP_SHIFT)
|
||||||
|
@ -76,7 +76,7 @@ static inline void __pmd_populate(pmd_t *pmdp, phys_addr_t ptep,
|
|||||||
static inline void
|
static inline void
|
||||||
pmd_populate_kernel(struct mm_struct *mm, pmd_t *pmdp, pte_t *ptep)
|
pmd_populate_kernel(struct mm_struct *mm, pmd_t *pmdp, pte_t *ptep)
|
||||||
{
|
{
|
||||||
VM_BUG_ON(mm != &init_mm);
|
VM_BUG_ON(mm && mm != &init_mm);
|
||||||
__pmd_populate(pmdp, __pa(ptep), PMD_TYPE_TABLE | PMD_TABLE_UXN);
|
__pmd_populate(pmdp, __pa(ptep), PMD_TYPE_TABLE | PMD_TABLE_UXN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,9 +47,6 @@ struct stack_info {
|
|||||||
* @prev_type: The type of stack this frame record was on, or a synthetic
|
* @prev_type: The type of stack this frame record was on, or a synthetic
|
||||||
* value of STACK_TYPE_UNKNOWN. This is used to detect a
|
* value of STACK_TYPE_UNKNOWN. This is used to detect a
|
||||||
* transition from one stack to another.
|
* transition from one stack to another.
|
||||||
*
|
|
||||||
* @graph: When FUNCTION_GRAPH_TRACER is selected, holds the index of a
|
|
||||||
* replacement lr value in the ftrace graph stack.
|
|
||||||
*/
|
*/
|
||||||
struct stackframe {
|
struct stackframe {
|
||||||
unsigned long fp;
|
unsigned long fp;
|
||||||
@ -57,9 +54,6 @@ struct stackframe {
|
|||||||
DECLARE_BITMAP(stacks_done, __NR_STACK_TYPES);
|
DECLARE_BITMAP(stacks_done, __NR_STACK_TYPES);
|
||||||
unsigned long prev_fp;
|
unsigned long prev_fp;
|
||||||
enum stack_type prev_type;
|
enum stack_type prev_type;
|
||||||
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
||||||
int graph;
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_KRETPROBES
|
#ifdef CONFIG_KRETPROBES
|
||||||
struct llist_node *kr_cur;
|
struct llist_node *kr_cur;
|
||||||
#endif
|
#endif
|
||||||
|
@ -281,12 +281,22 @@ do { \
|
|||||||
(x) = (__force __typeof__(*(ptr)))__gu_val; \
|
(x) = (__force __typeof__(*(ptr)))__gu_val; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We must not call into the scheduler between uaccess_ttbr0_enable() and
|
||||||
|
* uaccess_ttbr0_disable(). As `x` and `ptr` could contain blocking functions,
|
||||||
|
* we must evaluate these outside of the critical section.
|
||||||
|
*/
|
||||||
#define __raw_get_user(x, ptr, err) \
|
#define __raw_get_user(x, ptr, err) \
|
||||||
do { \
|
do { \
|
||||||
|
__typeof__(*(ptr)) __user *__rgu_ptr = (ptr); \
|
||||||
|
__typeof__(x) __rgu_val; \
|
||||||
__chk_user_ptr(ptr); \
|
__chk_user_ptr(ptr); \
|
||||||
|
\
|
||||||
uaccess_ttbr0_enable(); \
|
uaccess_ttbr0_enable(); \
|
||||||
__raw_get_mem("ldtr", x, ptr, err); \
|
__raw_get_mem("ldtr", __rgu_val, __rgu_ptr, err); \
|
||||||
uaccess_ttbr0_disable(); \
|
uaccess_ttbr0_disable(); \
|
||||||
|
\
|
||||||
|
(x) = __rgu_val; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define __get_user_error(x, ptr, err) \
|
#define __get_user_error(x, ptr, err) \
|
||||||
@ -310,14 +320,22 @@ do { \
|
|||||||
|
|
||||||
#define get_user __get_user
|
#define get_user __get_user
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We must not call into the scheduler between __uaccess_enable_tco_async() and
|
||||||
|
* __uaccess_disable_tco_async(). As `dst` and `src` may contain blocking
|
||||||
|
* functions, we must evaluate these outside of the critical section.
|
||||||
|
*/
|
||||||
#define __get_kernel_nofault(dst, src, type, err_label) \
|
#define __get_kernel_nofault(dst, src, type, err_label) \
|
||||||
do { \
|
do { \
|
||||||
|
__typeof__(dst) __gkn_dst = (dst); \
|
||||||
|
__typeof__(src) __gkn_src = (src); \
|
||||||
int __gkn_err = 0; \
|
int __gkn_err = 0; \
|
||||||
\
|
\
|
||||||
__uaccess_enable_tco_async(); \
|
__uaccess_enable_tco_async(); \
|
||||||
__raw_get_mem("ldr", *((type *)(dst)), \
|
__raw_get_mem("ldr", *((type *)(__gkn_dst)), \
|
||||||
(__force type *)(src), __gkn_err); \
|
(__force type *)(__gkn_src), __gkn_err); \
|
||||||
__uaccess_disable_tco_async(); \
|
__uaccess_disable_tco_async(); \
|
||||||
|
\
|
||||||
if (unlikely(__gkn_err)) \
|
if (unlikely(__gkn_err)) \
|
||||||
goto err_label; \
|
goto err_label; \
|
||||||
} while (0)
|
} while (0)
|
||||||
@ -351,11 +369,19 @@ do { \
|
|||||||
} \
|
} \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We must not call into the scheduler between uaccess_ttbr0_enable() and
|
||||||
|
* uaccess_ttbr0_disable(). As `x` and `ptr` could contain blocking functions,
|
||||||
|
* we must evaluate these outside of the critical section.
|
||||||
|
*/
|
||||||
#define __raw_put_user(x, ptr, err) \
|
#define __raw_put_user(x, ptr, err) \
|
||||||
do { \
|
do { \
|
||||||
__chk_user_ptr(ptr); \
|
__typeof__(*(ptr)) __user *__rpu_ptr = (ptr); \
|
||||||
|
__typeof__(*(ptr)) __rpu_val = (x); \
|
||||||
|
__chk_user_ptr(__rpu_ptr); \
|
||||||
|
\
|
||||||
uaccess_ttbr0_enable(); \
|
uaccess_ttbr0_enable(); \
|
||||||
__raw_put_mem("sttr", x, ptr, err); \
|
__raw_put_mem("sttr", __rpu_val, __rpu_ptr, err); \
|
||||||
uaccess_ttbr0_disable(); \
|
uaccess_ttbr0_disable(); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
@ -380,14 +406,22 @@ do { \
|
|||||||
|
|
||||||
#define put_user __put_user
|
#define put_user __put_user
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We must not call into the scheduler between __uaccess_enable_tco_async() and
|
||||||
|
* __uaccess_disable_tco_async(). As `dst` and `src` may contain blocking
|
||||||
|
* functions, we must evaluate these outside of the critical section.
|
||||||
|
*/
|
||||||
#define __put_kernel_nofault(dst, src, type, err_label) \
|
#define __put_kernel_nofault(dst, src, type, err_label) \
|
||||||
do { \
|
do { \
|
||||||
|
__typeof__(dst) __pkn_dst = (dst); \
|
||||||
|
__typeof__(src) __pkn_src = (src); \
|
||||||
int __pkn_err = 0; \
|
int __pkn_err = 0; \
|
||||||
\
|
\
|
||||||
__uaccess_enable_tco_async(); \
|
__uaccess_enable_tco_async(); \
|
||||||
__raw_put_mem("str", *((type *)(src)), \
|
__raw_put_mem("str", *((type *)(__pkn_src)), \
|
||||||
(__force type *)(dst), __pkn_err); \
|
(__force type *)(__pkn_dst), __pkn_err); \
|
||||||
__uaccess_disable_tco_async(); \
|
__uaccess_disable_tco_async(); \
|
||||||
|
\
|
||||||
if (unlikely(__pkn_err)) \
|
if (unlikely(__pkn_err)) \
|
||||||
goto err_label; \
|
goto err_label; \
|
||||||
} while(0)
|
} while(0)
|
||||||
|
@ -77,11 +77,17 @@
|
|||||||
.endm
|
.endm
|
||||||
|
|
||||||
SYM_CODE_START(ftrace_regs_caller)
|
SYM_CODE_START(ftrace_regs_caller)
|
||||||
|
#ifdef BTI_C
|
||||||
|
BTI_C
|
||||||
|
#endif
|
||||||
ftrace_regs_entry 1
|
ftrace_regs_entry 1
|
||||||
b ftrace_common
|
b ftrace_common
|
||||||
SYM_CODE_END(ftrace_regs_caller)
|
SYM_CODE_END(ftrace_regs_caller)
|
||||||
|
|
||||||
SYM_CODE_START(ftrace_caller)
|
SYM_CODE_START(ftrace_caller)
|
||||||
|
#ifdef BTI_C
|
||||||
|
BTI_C
|
||||||
|
#endif
|
||||||
ftrace_regs_entry 0
|
ftrace_regs_entry 0
|
||||||
b ftrace_common
|
b ftrace_common
|
||||||
SYM_CODE_END(ftrace_caller)
|
SYM_CODE_END(ftrace_caller)
|
||||||
|
@ -244,8 +244,6 @@ void arch_ftrace_update_code(int command)
|
|||||||
* on the way back to parent. For this purpose, this function is called
|
* on the way back to parent. For this purpose, this function is called
|
||||||
* in _mcount() or ftrace_caller() to replace return address (*parent) on
|
* in _mcount() or ftrace_caller() to replace return address (*parent) on
|
||||||
* the call stack to return_to_handler.
|
* the call stack to return_to_handler.
|
||||||
*
|
|
||||||
* Note that @frame_pointer is used only for sanity check later.
|
|
||||||
*/
|
*/
|
||||||
void prepare_ftrace_return(unsigned long self_addr, unsigned long *parent,
|
void prepare_ftrace_return(unsigned long self_addr, unsigned long *parent,
|
||||||
unsigned long frame_pointer)
|
unsigned long frame_pointer)
|
||||||
@ -263,8 +261,10 @@ void prepare_ftrace_return(unsigned long self_addr, unsigned long *parent,
|
|||||||
*/
|
*/
|
||||||
old = *parent;
|
old = *parent;
|
||||||
|
|
||||||
if (!function_graph_enter(old, self_addr, frame_pointer, NULL))
|
if (!function_graph_enter(old, self_addr, frame_pointer,
|
||||||
|
(void *)frame_pointer)) {
|
||||||
*parent = return_hooker;
|
*parent = return_hooker;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_DYNAMIC_FTRACE
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
||||||
|
@ -147,7 +147,7 @@ int machine_kexec_post_load(struct kimage *kimage)
|
|||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
kimage->arch.ttbr1 = __pa(trans_pgd);
|
kimage->arch.ttbr1 = __pa(trans_pgd);
|
||||||
kimage->arch.zero_page = __pa(empty_zero_page);
|
kimage->arch.zero_page = __pa_symbol(empty_zero_page);
|
||||||
|
|
||||||
reloc_size = __relocate_new_kernel_end - __relocate_new_kernel_start;
|
reloc_size = __relocate_new_kernel_end - __relocate_new_kernel_start;
|
||||||
memcpy(reloc_code, __relocate_new_kernel_start, reloc_size);
|
memcpy(reloc_code, __relocate_new_kernel_start, reloc_size);
|
||||||
|
@ -38,9 +38,6 @@ void start_backtrace(struct stackframe *frame, unsigned long fp,
|
|||||||
{
|
{
|
||||||
frame->fp = fp;
|
frame->fp = fp;
|
||||||
frame->pc = pc;
|
frame->pc = pc;
|
||||||
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
||||||
frame->graph = 0;
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_KRETPROBES
|
#ifdef CONFIG_KRETPROBES
|
||||||
frame->kr_cur = NULL;
|
frame->kr_cur = NULL;
|
||||||
#endif
|
#endif
|
||||||
@ -116,20 +113,23 @@ int notrace unwind_frame(struct task_struct *tsk, struct stackframe *frame)
|
|||||||
frame->prev_fp = fp;
|
frame->prev_fp = fp;
|
||||||
frame->prev_type = info.type;
|
frame->prev_type = info.type;
|
||||||
|
|
||||||
|
frame->pc = ptrauth_strip_insn_pac(frame->pc);
|
||||||
|
|
||||||
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
||||||
if (tsk->ret_stack &&
|
if (tsk->ret_stack &&
|
||||||
(ptrauth_strip_insn_pac(frame->pc) == (unsigned long)return_to_handler)) {
|
(frame->pc == (unsigned long)return_to_handler)) {
|
||||||
struct ftrace_ret_stack *ret_stack;
|
unsigned long orig_pc;
|
||||||
/*
|
/*
|
||||||
* This is a case where function graph tracer has
|
* This is a case where function graph tracer has
|
||||||
* modified a return address (LR) in a stack frame
|
* modified a return address (LR) in a stack frame
|
||||||
* to hook a function return.
|
* to hook a function return.
|
||||||
* So replace it to an original value.
|
* So replace it to an original value.
|
||||||
*/
|
*/
|
||||||
ret_stack = ftrace_graph_get_ret_stack(tsk, frame->graph++);
|
orig_pc = ftrace_graph_ret_addr(tsk, NULL, frame->pc,
|
||||||
if (WARN_ON_ONCE(!ret_stack))
|
(void *)frame->fp);
|
||||||
|
if (WARN_ON_ONCE(frame->pc == orig_pc))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
frame->pc = ret_stack->ret;
|
frame->pc = orig_pc;
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
|
#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
|
||||||
#ifdef CONFIG_KRETPROBES
|
#ifdef CONFIG_KRETPROBES
|
||||||
@ -137,8 +137,6 @@ int notrace unwind_frame(struct task_struct *tsk, struct stackframe *frame)
|
|||||||
frame->pc = kretprobe_find_ret_addr(tsk, (void *)frame->fp, &frame->kr_cur);
|
frame->pc = kretprobe_find_ret_addr(tsk, (void *)frame->fp, &frame->kr_cur);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
frame->pc = ptrauth_strip_insn_pac(frame->pc);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
NOKPROBE_SYMBOL(unwind_frame);
|
NOKPROBE_SYMBOL(unwind_frame);
|
||||||
|
@ -403,6 +403,8 @@ typedef bool (*exit_handler_fn)(struct kvm_vcpu *, u64 *);
|
|||||||
|
|
||||||
static const exit_handler_fn *kvm_get_exit_handler_array(struct kvm_vcpu *vcpu);
|
static const exit_handler_fn *kvm_get_exit_handler_array(struct kvm_vcpu *vcpu);
|
||||||
|
|
||||||
|
static void early_exit_filter(struct kvm_vcpu *vcpu, u64 *exit_code);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Allow the hypervisor to handle the exit with an exit handler if it has one.
|
* Allow the hypervisor to handle the exit with an exit handler if it has one.
|
||||||
*
|
*
|
||||||
@ -429,6 +431,18 @@ static inline bool kvm_hyp_handle_exit(struct kvm_vcpu *vcpu, u64 *exit_code)
|
|||||||
*/
|
*/
|
||||||
static inline bool fixup_guest_exit(struct kvm_vcpu *vcpu, u64 *exit_code)
|
static inline bool fixup_guest_exit(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
|
* Save PSTATE early so that we can evaluate the vcpu mode
|
||||||
|
* early on.
|
||||||
|
*/
|
||||||
|
vcpu->arch.ctxt.regs.pstate = read_sysreg_el2(SYS_SPSR);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check whether we want to repaint the state one way or
|
||||||
|
* another.
|
||||||
|
*/
|
||||||
|
early_exit_filter(vcpu, exit_code);
|
||||||
|
|
||||||
if (ARM_EXCEPTION_CODE(*exit_code) != ARM_EXCEPTION_IRQ)
|
if (ARM_EXCEPTION_CODE(*exit_code) != ARM_EXCEPTION_IRQ)
|
||||||
vcpu->arch.fault.esr_el2 = read_sysreg_el2(SYS_ESR);
|
vcpu->arch.fault.esr_el2 = read_sysreg_el2(SYS_ESR);
|
||||||
|
|
||||||
|
@ -70,7 +70,12 @@ static inline void __sysreg_save_el1_state(struct kvm_cpu_context *ctxt)
|
|||||||
static inline void __sysreg_save_el2_return_state(struct kvm_cpu_context *ctxt)
|
static inline void __sysreg_save_el2_return_state(struct kvm_cpu_context *ctxt)
|
||||||
{
|
{
|
||||||
ctxt->regs.pc = read_sysreg_el2(SYS_ELR);
|
ctxt->regs.pc = read_sysreg_el2(SYS_ELR);
|
||||||
ctxt->regs.pstate = read_sysreg_el2(SYS_SPSR);
|
/*
|
||||||
|
* Guest PSTATE gets saved at guest fixup time in all
|
||||||
|
* cases. We still need to handle the nVHE host side here.
|
||||||
|
*/
|
||||||
|
if (!has_vhe() && ctxt->__hyp_running_vcpu)
|
||||||
|
ctxt->regs.pstate = read_sysreg_el2(SYS_SPSR);
|
||||||
|
|
||||||
if (cpus_have_final_cap(ARM64_HAS_RAS_EXTN))
|
if (cpus_have_final_cap(ARM64_HAS_RAS_EXTN))
|
||||||
ctxt_sys_reg(ctxt, DISR_EL1) = read_sysreg_s(SYS_VDISR_EL2);
|
ctxt_sys_reg(ctxt, DISR_EL1) = read_sysreg_s(SYS_VDISR_EL2);
|
||||||
|
@ -233,7 +233,7 @@ static const exit_handler_fn *kvm_get_exit_handler_array(struct kvm_vcpu *vcpu)
|
|||||||
* Returns false if the guest ran in AArch32 when it shouldn't have, and
|
* Returns false if the guest ran in AArch32 when it shouldn't have, and
|
||||||
* thus should exit to the host, or true if a the guest run loop can continue.
|
* thus should exit to the host, or true if a the guest run loop can continue.
|
||||||
*/
|
*/
|
||||||
static bool handle_aarch32_guest(struct kvm_vcpu *vcpu, u64 *exit_code)
|
static void early_exit_filter(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
{
|
{
|
||||||
struct kvm *kvm = kern_hyp_va(vcpu->kvm);
|
struct kvm *kvm = kern_hyp_va(vcpu->kvm);
|
||||||
|
|
||||||
@ -248,10 +248,7 @@ static bool handle_aarch32_guest(struct kvm_vcpu *vcpu, u64 *exit_code)
|
|||||||
vcpu->arch.target = -1;
|
vcpu->arch.target = -1;
|
||||||
*exit_code &= BIT(ARM_EXIT_WITH_SERROR_BIT);
|
*exit_code &= BIT(ARM_EXIT_WITH_SERROR_BIT);
|
||||||
*exit_code |= ARM_EXCEPTION_IL;
|
*exit_code |= ARM_EXCEPTION_IL;
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Switch to the guest for legacy non-VHE systems */
|
/* Switch to the guest for legacy non-VHE systems */
|
||||||
@ -316,9 +313,6 @@ int __kvm_vcpu_run(struct kvm_vcpu *vcpu)
|
|||||||
/* Jump in the fire! */
|
/* Jump in the fire! */
|
||||||
exit_code = __guest_enter(vcpu);
|
exit_code = __guest_enter(vcpu);
|
||||||
|
|
||||||
if (unlikely(!handle_aarch32_guest(vcpu, &exit_code)))
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* And we're baaack! */
|
/* And we're baaack! */
|
||||||
} while (fixup_guest_exit(vcpu, &exit_code));
|
} while (fixup_guest_exit(vcpu, &exit_code));
|
||||||
|
|
||||||
|
@ -112,6 +112,10 @@ static const exit_handler_fn *kvm_get_exit_handler_array(struct kvm_vcpu *vcpu)
|
|||||||
return hyp_exit_handlers;
|
return hyp_exit_handlers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void early_exit_filter(struct kvm_vcpu *vcpu, u64 *exit_code)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
/* Switch to the guest for VHE systems running in EL2 */
|
/* Switch to the guest for VHE systems running in EL2 */
|
||||||
static int __kvm_vcpu_run_vhe(struct kvm_vcpu *vcpu)
|
static int __kvm_vcpu_run_vhe(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
|
@ -209,7 +209,7 @@ asmlinkage void do_trap_illinsn(struct pt_regs *regs)
|
|||||||
|
|
||||||
asmlinkage void do_trap_fpe(struct pt_regs *regs)
|
asmlinkage void do_trap_fpe(struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_CPU_HAS_FP
|
#ifdef CONFIG_CPU_HAS_FPU
|
||||||
return fpu_fpe(regs);
|
return fpu_fpe(regs);
|
||||||
#else
|
#else
|
||||||
do_trap_error(regs, SIGILL, ILL_ILLOPC, regs->pc,
|
do_trap_error(regs, SIGILL, ILL_ILLOPC, regs->pc,
|
||||||
@ -219,7 +219,7 @@ asmlinkage void do_trap_fpe(struct pt_regs *regs)
|
|||||||
|
|
||||||
asmlinkage void do_trap_priv(struct pt_regs *regs)
|
asmlinkage void do_trap_priv(struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_CPU_HAS_FP
|
#ifdef CONFIG_CPU_HAS_FPU
|
||||||
if (user_mode(regs) && fpu_libc_helper(regs))
|
if (user_mode(regs) && fpu_libc_helper(regs))
|
||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
|
@ -369,3 +369,4 @@
|
|||||||
446 common landlock_restrict_self sys_landlock_restrict_self
|
446 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 447 reserved for memfd_secret
|
# 447 reserved for memfd_secret
|
||||||
448 common process_mrelease sys_process_mrelease
|
448 common process_mrelease sys_process_mrelease
|
||||||
|
449 common futex_waitv sys_futex_waitv
|
||||||
|
@ -250,7 +250,6 @@ static inline void __flush_page_to_ram(void *vaddr)
|
|||||||
|
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
#define flush_dcache_page(page) __flush_page_to_ram(page_address(page))
|
#define flush_dcache_page(page) __flush_page_to_ram(page_address(page))
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
#define flush_dcache_mmap_lock(mapping) do { } while (0)
|
#define flush_dcache_mmap_lock(mapping) do { } while (0)
|
||||||
#define flush_dcache_mmap_unlock(mapping) do { } while (0)
|
#define flush_dcache_mmap_unlock(mapping) do { } while (0)
|
||||||
#define flush_icache_page(vma, page) __flush_page_to_ram(page_address(page))
|
#define flush_icache_page(vma, page) __flush_page_to_ram(page_address(page))
|
||||||
|
@ -448,3 +448,4 @@
|
|||||||
446 common landlock_restrict_self sys_landlock_restrict_self
|
446 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 447 reserved for memfd_secret
|
# 447 reserved for memfd_secret
|
||||||
448 common process_mrelease sys_process_mrelease
|
448 common process_mrelease sys_process_mrelease
|
||||||
|
449 common futex_waitv sys_futex_waitv
|
||||||
|
@ -454,3 +454,4 @@
|
|||||||
446 common landlock_restrict_self sys_landlock_restrict_self
|
446 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 447 reserved for memfd_secret
|
# 447 reserved for memfd_secret
|
||||||
448 common process_mrelease sys_process_mrelease
|
448 common process_mrelease sys_process_mrelease
|
||||||
|
449 common futex_waitv sys_futex_waitv
|
||||||
|
@ -3097,7 +3097,7 @@ config STACKTRACE_SUPPORT
|
|||||||
config PGTABLE_LEVELS
|
config PGTABLE_LEVELS
|
||||||
int
|
int
|
||||||
default 4 if PAGE_SIZE_4KB && MIPS_VA_BITS_48
|
default 4 if PAGE_SIZE_4KB && MIPS_VA_BITS_48
|
||||||
default 3 if 64BIT && !PAGE_SIZE_64KB
|
default 3 if 64BIT && (!PAGE_SIZE_64KB || MIPS_VA_BITS_48)
|
||||||
default 2
|
default 2
|
||||||
|
|
||||||
config MIPS_AUTO_PFN_OFFSET
|
config MIPS_AUTO_PFN_OFFSET
|
||||||
|
@ -52,7 +52,7 @@ endif
|
|||||||
|
|
||||||
vmlinuzobjs-$(CONFIG_KERNEL_XZ) += $(obj)/ashldi3.o
|
vmlinuzobjs-$(CONFIG_KERNEL_XZ) += $(obj)/ashldi3.o
|
||||||
|
|
||||||
vmlinuzobjs-$(CONFIG_KERNEL_ZSTD) += $(obj)/bswapdi.o
|
vmlinuzobjs-$(CONFIG_KERNEL_ZSTD) += $(obj)/bswapdi.o $(obj)/ashldi3.o
|
||||||
|
|
||||||
targets := $(notdir $(vmlinuzobjs-y))
|
targets := $(notdir $(vmlinuzobjs-y))
|
||||||
|
|
||||||
|
@ -61,8 +61,6 @@ static inline void flush_dcache_page(struct page *page)
|
|||||||
SetPageDcacheDirty(page);
|
SetPageDcacheDirty(page);
|
||||||
}
|
}
|
||||||
|
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
|
|
||||||
#define flush_dcache_mmap_lock(mapping) do { } while (0)
|
#define flush_dcache_mmap_lock(mapping) do { } while (0)
|
||||||
#define flush_dcache_mmap_unlock(mapping) do { } while (0)
|
#define flush_dcache_mmap_unlock(mapping) do { } while (0)
|
||||||
|
|
||||||
|
@ -1734,8 +1734,6 @@ static inline void decode_cpucfg(struct cpuinfo_mips *c)
|
|||||||
|
|
||||||
static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu)
|
static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu)
|
||||||
{
|
{
|
||||||
decode_configs(c);
|
|
||||||
|
|
||||||
/* All Loongson processors covered here define ExcCode 16 as GSExc. */
|
/* All Loongson processors covered here define ExcCode 16 as GSExc. */
|
||||||
c->options |= MIPS_CPU_GSEXCEX;
|
c->options |= MIPS_CPU_GSEXCEX;
|
||||||
|
|
||||||
@ -1796,6 +1794,8 @@ static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu)
|
|||||||
panic("Unknown Loongson Processor ID!");
|
panic("Unknown Loongson Processor ID!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
decode_configs(c);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu) { }
|
static inline void cpu_probe_loongson(struct cpuinfo_mips *c, unsigned int cpu) { }
|
||||||
|
@ -185,7 +185,7 @@ static int show_cpuinfo(struct seq_file *m, void *v)
|
|||||||
seq_puts(m, " tx39_cache");
|
seq_puts(m, " tx39_cache");
|
||||||
if (cpu_has_octeon_cache)
|
if (cpu_has_octeon_cache)
|
||||||
seq_puts(m, " octeon_cache");
|
seq_puts(m, " octeon_cache");
|
||||||
if (cpu_has_fpu)
|
if (raw_cpu_has_fpu)
|
||||||
seq_puts(m, " fpu");
|
seq_puts(m, " fpu");
|
||||||
if (cpu_has_32fpr)
|
if (cpu_has_32fpr)
|
||||||
seq_puts(m, " 32fpr");
|
seq_puts(m, " 32fpr");
|
||||||
|
@ -98,7 +98,7 @@ do { \
|
|||||||
#define emit(...) __emit(__VA_ARGS__)
|
#define emit(...) __emit(__VA_ARGS__)
|
||||||
|
|
||||||
/* Workaround for R10000 ll/sc errata */
|
/* Workaround for R10000 ll/sc errata */
|
||||||
#ifdef CONFIG_WAR_R10000
|
#ifdef CONFIG_WAR_R10000_LLSC
|
||||||
#define LLSC_beqz beqzl
|
#define LLSC_beqz beqzl
|
||||||
#else
|
#else
|
||||||
#define LLSC_beqz beqz
|
#define LLSC_beqz beqz
|
||||||
|
@ -27,7 +27,6 @@ void flush_cache_vunmap(unsigned long start, unsigned long end);
|
|||||||
|
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
void flush_dcache_page(struct page *page);
|
void flush_dcache_page(struct page *page);
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
void copy_to_user_page(struct vm_area_struct *vma, struct page *page,
|
void copy_to_user_page(struct vm_area_struct *vma, struct page *page,
|
||||||
unsigned long vaddr, void *dst, void *src, int len);
|
unsigned long vaddr, void *dst, void *src, int len);
|
||||||
void copy_from_user_page(struct vm_area_struct *vma, struct page *page,
|
void copy_from_user_page(struct vm_area_struct *vma, struct page *page,
|
||||||
|
@ -29,7 +29,6 @@ extern void flush_cache_page(struct vm_area_struct *vma, unsigned long vmaddr,
|
|||||||
unsigned long pfn);
|
unsigned long pfn);
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
void flush_dcache_page(struct page *page);
|
void flush_dcache_page(struct page *page);
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
|
|
||||||
extern void flush_icache_range(unsigned long start, unsigned long end);
|
extern void flush_icache_range(unsigned long start, unsigned long end);
|
||||||
extern void flush_icache_page(struct vm_area_struct *vma, struct page *page);
|
extern void flush_icache_page(struct vm_area_struct *vma, struct page *page);
|
||||||
|
@ -15,7 +15,12 @@
|
|||||||
# Mike Shaver, Helge Deller and Martin K. Petersen
|
# Mike Shaver, Helge Deller and Martin K. Petersen
|
||||||
#
|
#
|
||||||
|
|
||||||
|
ifdef CONFIG_PARISC_SELF_EXTRACT
|
||||||
|
boot := arch/parisc/boot
|
||||||
|
KBUILD_IMAGE := $(boot)/bzImage
|
||||||
|
else
|
||||||
KBUILD_IMAGE := vmlinuz
|
KBUILD_IMAGE := vmlinuz
|
||||||
|
endif
|
||||||
|
|
||||||
NM = sh $(srctree)/arch/parisc/nm
|
NM = sh $(srctree)/arch/parisc/nm
|
||||||
CHECKFLAGS += -D__hppa__=1
|
CHECKFLAGS += -D__hppa__=1
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
CONFIG_LOCALVERSION="-64bit"
|
CONFIG_LOCALVERSION="-64bit"
|
||||||
# CONFIG_LOCALVERSION_AUTO is not set
|
# CONFIG_LOCALVERSION_AUTO is not set
|
||||||
|
CONFIG_KERNEL_LZ4=y
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_POSIX_MQUEUE=y
|
CONFIG_POSIX_MQUEUE=y
|
||||||
|
CONFIG_AUDIT=y
|
||||||
CONFIG_BSD_PROCESS_ACCT=y
|
CONFIG_BSD_PROCESS_ACCT=y
|
||||||
CONFIG_BSD_PROCESS_ACCT_V3=y
|
CONFIG_BSD_PROCESS_ACCT_V3=y
|
||||||
CONFIG_TASKSTATS=y
|
CONFIG_TASKSTATS=y
|
||||||
@ -35,6 +37,7 @@ CONFIG_MODVERSIONS=y
|
|||||||
CONFIG_BLK_DEV_INTEGRITY=y
|
CONFIG_BLK_DEV_INTEGRITY=y
|
||||||
CONFIG_BINFMT_MISC=m
|
CONFIG_BINFMT_MISC=m
|
||||||
# CONFIG_COMPACTION is not set
|
# CONFIG_COMPACTION is not set
|
||||||
|
CONFIG_MEMORY_FAILURE=y
|
||||||
CONFIG_NET=y
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
@ -65,12 +68,15 @@ CONFIG_SCSI_ISCSI_ATTRS=y
|
|||||||
CONFIG_SCSI_SRP_ATTRS=y
|
CONFIG_SCSI_SRP_ATTRS=y
|
||||||
CONFIG_ISCSI_BOOT_SYSFS=y
|
CONFIG_ISCSI_BOOT_SYSFS=y
|
||||||
CONFIG_SCSI_MPT2SAS=y
|
CONFIG_SCSI_MPT2SAS=y
|
||||||
CONFIG_SCSI_LASI700=m
|
CONFIG_SCSI_LASI700=y
|
||||||
CONFIG_SCSI_SYM53C8XX_2=y
|
CONFIG_SCSI_SYM53C8XX_2=y
|
||||||
CONFIG_SCSI_ZALON=y
|
CONFIG_SCSI_ZALON=y
|
||||||
CONFIG_SCSI_QLA_ISCSI=m
|
CONFIG_SCSI_QLA_ISCSI=m
|
||||||
CONFIG_SCSI_DH=y
|
CONFIG_SCSI_DH=y
|
||||||
CONFIG_ATA=y
|
CONFIG_ATA=y
|
||||||
|
CONFIG_SATA_SIL=y
|
||||||
|
CONFIG_SATA_SIS=y
|
||||||
|
CONFIG_SATA_VIA=y
|
||||||
CONFIG_PATA_NS87415=y
|
CONFIG_PATA_NS87415=y
|
||||||
CONFIG_PATA_SIL680=y
|
CONFIG_PATA_SIL680=y
|
||||||
CONFIG_ATA_GENERIC=y
|
CONFIG_ATA_GENERIC=y
|
||||||
@ -79,6 +85,7 @@ CONFIG_MD_LINEAR=m
|
|||||||
CONFIG_BLK_DEV_DM=m
|
CONFIG_BLK_DEV_DM=m
|
||||||
CONFIG_DM_RAID=m
|
CONFIG_DM_RAID=m
|
||||||
CONFIG_DM_UEVENT=y
|
CONFIG_DM_UEVENT=y
|
||||||
|
CONFIG_DM_AUDIT=y
|
||||||
CONFIG_FUSION=y
|
CONFIG_FUSION=y
|
||||||
CONFIG_FUSION_SPI=y
|
CONFIG_FUSION_SPI=y
|
||||||
CONFIG_FUSION_SAS=y
|
CONFIG_FUSION_SAS=y
|
||||||
@ -196,10 +203,15 @@ CONFIG_FB_MATROX_G=y
|
|||||||
CONFIG_FB_MATROX_I2C=y
|
CONFIG_FB_MATROX_I2C=y
|
||||||
CONFIG_FB_MATROX_MAVEN=y
|
CONFIG_FB_MATROX_MAVEN=y
|
||||||
CONFIG_FB_RADEON=y
|
CONFIG_FB_RADEON=y
|
||||||
|
CONFIG_LOGO=y
|
||||||
|
# CONFIG_LOGO_LINUX_CLUT224 is not set
|
||||||
CONFIG_HIDRAW=y
|
CONFIG_HIDRAW=y
|
||||||
CONFIG_HID_PID=y
|
CONFIG_HID_PID=y
|
||||||
CONFIG_USB_HIDDEV=y
|
CONFIG_USB_HIDDEV=y
|
||||||
CONFIG_USB=y
|
CONFIG_USB=y
|
||||||
|
CONFIG_USB_EHCI_HCD=y
|
||||||
|
CONFIG_USB_OHCI_HCD=y
|
||||||
|
CONFIG_USB_OHCI_HCD_PLATFORM=y
|
||||||
CONFIG_UIO=y
|
CONFIG_UIO=y
|
||||||
CONFIG_UIO_PDRV_GENIRQ=m
|
CONFIG_UIO_PDRV_GENIRQ=m
|
||||||
CONFIG_UIO_AEC=m
|
CONFIG_UIO_AEC=m
|
||||||
|
@ -147,6 +147,17 @@
|
|||||||
extrd,u \r, 63-(\sa), 64-(\sa), \t
|
extrd,u \r, 63-(\sa), 64-(\sa), \t
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
/* Extract unsigned for 32- and 64-bit
|
||||||
|
* The extru instruction leaves the most significant 32 bits of the
|
||||||
|
* target register in an undefined state on PA 2.0 systems. */
|
||||||
|
.macro extru_safe r, p, len, t
|
||||||
|
#ifdef CONFIG_64BIT
|
||||||
|
extrd,u \r, 32+(\p), \len, \t
|
||||||
|
#else
|
||||||
|
extru \r, \p, \len, \t
|
||||||
|
#endif
|
||||||
|
.endm
|
||||||
|
|
||||||
/* load 32-bit 'value' into 'reg' compensating for the ldil
|
/* load 32-bit 'value' into 'reg' compensating for the ldil
|
||||||
* sign-extension when running in wide mode.
|
* sign-extension when running in wide mode.
|
||||||
* WARNING!! neither 'value' nor 'reg' can be expressions
|
* WARNING!! neither 'value' nor 'reg' can be expressions
|
||||||
|
@ -50,7 +50,6 @@ void invalidate_kernel_vmap_range(void *vaddr, int size);
|
|||||||
|
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
void flush_dcache_page(struct page *page);
|
void flush_dcache_page(struct page *page);
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
|
|
||||||
#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)
|
||||||
|
@ -39,6 +39,7 @@ verify "$3"
|
|||||||
if [ -n "${INSTALLKERNEL}" ]; then
|
if [ -n "${INSTALLKERNEL}" ]; then
|
||||||
if [ -x ~/bin/${INSTALLKERNEL} ]; then exec ~/bin/${INSTALLKERNEL} "$@"; fi
|
if [ -x ~/bin/${INSTALLKERNEL} ]; then exec ~/bin/${INSTALLKERNEL} "$@"; fi
|
||||||
if [ -x /sbin/${INSTALLKERNEL} ]; then exec /sbin/${INSTALLKERNEL} "$@"; fi
|
if [ -x /sbin/${INSTALLKERNEL} ]; then exec /sbin/${INSTALLKERNEL} "$@"; fi
|
||||||
|
if [ -x /usr/sbin/${INSTALLKERNEL} ]; then exec /usr/sbin/${INSTALLKERNEL} "$@"; fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Default install
|
# Default install
|
||||||
|
@ -366,17 +366,9 @@
|
|||||||
*/
|
*/
|
||||||
.macro L2_ptep pmd,pte,index,va,fault
|
.macro L2_ptep pmd,pte,index,va,fault
|
||||||
#if CONFIG_PGTABLE_LEVELS == 3
|
#if CONFIG_PGTABLE_LEVELS == 3
|
||||||
extru \va,31-ASM_PMD_SHIFT,ASM_BITS_PER_PMD,\index
|
extru_safe \va,31-ASM_PMD_SHIFT,ASM_BITS_PER_PMD,\index
|
||||||
#else
|
#else
|
||||||
# if defined(CONFIG_64BIT)
|
extru_safe \va,31-ASM_PGDIR_SHIFT,ASM_BITS_PER_PGD,\index
|
||||||
extrd,u \va,63-ASM_PGDIR_SHIFT,ASM_BITS_PER_PGD,\index
|
|
||||||
#else
|
|
||||||
# if PAGE_SIZE > 4096
|
|
||||||
extru \va,31-ASM_PGDIR_SHIFT,32-ASM_PGDIR_SHIFT,\index
|
|
||||||
# else
|
|
||||||
extru \va,31-ASM_PGDIR_SHIFT,ASM_BITS_PER_PGD,\index
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#endif
|
#endif
|
||||||
dep %r0,31,PAGE_SHIFT,\pmd /* clear offset */
|
dep %r0,31,PAGE_SHIFT,\pmd /* clear offset */
|
||||||
#if CONFIG_PGTABLE_LEVELS < 3
|
#if CONFIG_PGTABLE_LEVELS < 3
|
||||||
@ -386,7 +378,7 @@
|
|||||||
bb,>=,n \pmd,_PxD_PRESENT_BIT,\fault
|
bb,>=,n \pmd,_PxD_PRESENT_BIT,\fault
|
||||||
dep %r0,31,PxD_FLAG_SHIFT,\pmd /* clear flags */
|
dep %r0,31,PxD_FLAG_SHIFT,\pmd /* clear flags */
|
||||||
SHLREG \pmd,PxD_VALUE_SHIFT,\pmd
|
SHLREG \pmd,PxD_VALUE_SHIFT,\pmd
|
||||||
extru \va,31-PAGE_SHIFT,ASM_BITS_PER_PTE,\index
|
extru_safe \va,31-PAGE_SHIFT,ASM_BITS_PER_PTE,\index
|
||||||
dep %r0,31,PAGE_SHIFT,\pmd /* clear offset */
|
dep %r0,31,PAGE_SHIFT,\pmd /* clear offset */
|
||||||
shladd \index,BITS_PER_PTE_ENTRY,\pmd,\pmd /* pmd is now pte */
|
shladd \index,BITS_PER_PTE_ENTRY,\pmd,\pmd /* pmd is now pte */
|
||||||
.endm
|
.endm
|
||||||
|
@ -566,7 +566,7 @@ lws_compare_and_swap:
|
|||||||
ldo R%lws_lock_start(%r20), %r28
|
ldo R%lws_lock_start(%r20), %r28
|
||||||
|
|
||||||
/* Extract eight bits from r26 and hash lock (Bits 3-11) */
|
/* Extract eight bits from r26 and hash lock (Bits 3-11) */
|
||||||
extru %r26, 28, 8, %r20
|
extru_safe %r26, 28, 8, %r20
|
||||||
|
|
||||||
/* Find lock to use, the hash is either one of 0 to
|
/* Find lock to use, the hash is either one of 0 to
|
||||||
15, multiplied by 16 (keep it 16-byte aligned)
|
15, multiplied by 16 (keep it 16-byte aligned)
|
||||||
@ -751,7 +751,7 @@ cas2_lock_start:
|
|||||||
ldo R%lws_lock_start(%r20), %r28
|
ldo R%lws_lock_start(%r20), %r28
|
||||||
|
|
||||||
/* Extract eight bits from r26 and hash lock (Bits 3-11) */
|
/* Extract eight bits from r26 and hash lock (Bits 3-11) */
|
||||||
extru %r26, 28, 8, %r20
|
extru_safe %r26, 28, 8, %r20
|
||||||
|
|
||||||
/* Find lock to use, the hash is either one of 0 to
|
/* Find lock to use, the hash is either one of 0 to
|
||||||
15, multiplied by 16 (keep it 16-byte aligned)
|
15, multiplied by 16 (keep it 16-byte aligned)
|
||||||
|
@ -249,30 +249,16 @@ void __init time_init(void)
|
|||||||
static int __init init_cr16_clocksource(void)
|
static int __init init_cr16_clocksource(void)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* The cr16 interval timers are not syncronized across CPUs on
|
* The cr16 interval timers are not syncronized across CPUs, even if
|
||||||
* different sockets, so mark them unstable and lower rating on
|
* they share the same socket.
|
||||||
* multi-socket SMP systems.
|
|
||||||
*/
|
*/
|
||||||
if (num_online_cpus() > 1 && !running_on_qemu) {
|
if (num_online_cpus() > 1 && !running_on_qemu) {
|
||||||
int cpu;
|
/* mark sched_clock unstable */
|
||||||
unsigned long cpu0_loc;
|
clear_sched_clock_stable();
|
||||||
cpu0_loc = per_cpu(cpu_data, 0).cpu_loc;
|
|
||||||
|
|
||||||
for_each_online_cpu(cpu) {
|
clocksource_cr16.name = "cr16_unstable";
|
||||||
if (cpu == 0)
|
clocksource_cr16.flags = CLOCK_SOURCE_UNSTABLE;
|
||||||
continue;
|
clocksource_cr16.rating = 0;
|
||||||
if ((cpu0_loc != 0) &&
|
|
||||||
(cpu0_loc == per_cpu(cpu_data, cpu).cpu_loc))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
/* mark sched_clock unstable */
|
|
||||||
clear_sched_clock_stable();
|
|
||||||
|
|
||||||
clocksource_cr16.name = "cr16_unstable";
|
|
||||||
clocksource_cr16.flags = CLOCK_SOURCE_UNSTABLE;
|
|
||||||
clocksource_cr16.rating = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* register at clocksource framework */
|
/* register at clocksource framework */
|
||||||
|
@ -57,8 +57,6 @@ SECTIONS
|
|||||||
{
|
{
|
||||||
. = KERNEL_BINARY_TEXT_START;
|
. = KERNEL_BINARY_TEXT_START;
|
||||||
|
|
||||||
_stext = .; /* start of kernel text, includes init code & data */
|
|
||||||
|
|
||||||
__init_begin = .;
|
__init_begin = .;
|
||||||
HEAD_TEXT_SECTION
|
HEAD_TEXT_SECTION
|
||||||
MLONGCALL_DISCARD(INIT_TEXT_SECTION(8))
|
MLONGCALL_DISCARD(INIT_TEXT_SECTION(8))
|
||||||
@ -82,6 +80,7 @@ SECTIONS
|
|||||||
/* freed after init ends here */
|
/* freed after init ends here */
|
||||||
|
|
||||||
_text = .; /* Text and read-only data */
|
_text = .; /* Text and read-only data */
|
||||||
|
_stext = .;
|
||||||
MLONGCALL_KEEP(INIT_TEXT_SECTION(8))
|
MLONGCALL_KEEP(INIT_TEXT_SECTION(8))
|
||||||
.text ALIGN(PAGE_SIZE) : {
|
.text ALIGN(PAGE_SIZE) : {
|
||||||
TEXT_TEXT
|
TEXT_TEXT
|
||||||
|
@ -202,11 +202,11 @@ vmap_stack_overflow:
|
|||||||
mfspr r1, SPRN_SPRG_THREAD
|
mfspr r1, SPRN_SPRG_THREAD
|
||||||
lwz r1, TASK_CPU - THREAD(r1)
|
lwz r1, TASK_CPU - THREAD(r1)
|
||||||
slwi r1, r1, 3
|
slwi r1, r1, 3
|
||||||
addis r1, r1, emergency_ctx@ha
|
addis r1, r1, emergency_ctx-PAGE_OFFSET@ha
|
||||||
#else
|
#else
|
||||||
lis r1, emergency_ctx@ha
|
lis r1, emergency_ctx-PAGE_OFFSET@ha
|
||||||
#endif
|
#endif
|
||||||
lwz r1, emergency_ctx@l(r1)
|
lwz r1, emergency_ctx-PAGE_OFFSET@l(r1)
|
||||||
addi r1, r1, THREAD_SIZE - INT_FRAME_SIZE
|
addi r1, r1, THREAD_SIZE - INT_FRAME_SIZE
|
||||||
EXCEPTION_PROLOG_2 0 vmap_stack_overflow
|
EXCEPTION_PROLOG_2 0 vmap_stack_overflow
|
||||||
prepare_transfer_to_handler
|
prepare_transfer_to_handler
|
||||||
|
@ -528,3 +528,4 @@
|
|||||||
446 common landlock_restrict_self sys_landlock_restrict_self
|
446 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 447 reserved for memfd_secret
|
# 447 reserved for memfd_secret
|
||||||
448 common process_mrelease sys_process_mrelease
|
448 common process_mrelease sys_process_mrelease
|
||||||
|
449 common futex_waitv sys_futex_waitv
|
||||||
|
@ -695,6 +695,7 @@ static void flush_guest_tlb(struct kvm *kvm)
|
|||||||
"r" (0) : "memory");
|
"r" (0) : "memory");
|
||||||
}
|
}
|
||||||
asm volatile("ptesync": : :"memory");
|
asm volatile("ptesync": : :"memory");
|
||||||
|
// POWER9 congruence-class TLBIEL leaves ERAT. Flush it now.
|
||||||
asm volatile(PPC_RADIX_INVALIDATE_ERAT_GUEST : : :"memory");
|
asm volatile(PPC_RADIX_INVALIDATE_ERAT_GUEST : : :"memory");
|
||||||
} else {
|
} else {
|
||||||
for (set = 0; set < kvm->arch.tlb_sets; ++set) {
|
for (set = 0; set < kvm->arch.tlb_sets; ++set) {
|
||||||
@ -705,7 +706,9 @@ static void flush_guest_tlb(struct kvm *kvm)
|
|||||||
rb += PPC_BIT(51); /* increment set number */
|
rb += PPC_BIT(51); /* increment set number */
|
||||||
}
|
}
|
||||||
asm volatile("ptesync": : :"memory");
|
asm volatile("ptesync": : :"memory");
|
||||||
asm volatile(PPC_ISA_3_0_INVALIDATE_ERAT : : :"memory");
|
// POWER9 congruence-class TLBIEL leaves ERAT. Flush it now.
|
||||||
|
if (cpu_has_feature(CPU_FTR_ARCH_300))
|
||||||
|
asm volatile(PPC_ISA_3_0_INVALIDATE_ERAT : : :"memory");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,14 +12,12 @@
|
|||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/kvm.h>
|
#include <linux/kvm.h>
|
||||||
#include <linux/kvm_types.h>
|
#include <linux/kvm_types.h>
|
||||||
|
#include <asm/csr.h>
|
||||||
#include <asm/kvm_vcpu_fp.h>
|
#include <asm/kvm_vcpu_fp.h>
|
||||||
#include <asm/kvm_vcpu_timer.h>
|
#include <asm/kvm_vcpu_timer.h>
|
||||||
|
|
||||||
#ifdef CONFIG_64BIT
|
#define KVM_MAX_VCPUS \
|
||||||
#define KVM_MAX_VCPUS (1U << 16)
|
((HGATP_VMID_MASK >> HGATP_VMID_SHIFT) + 1)
|
||||||
#else
|
|
||||||
#define KVM_MAX_VCPUS (1U << 9)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define KVM_HALT_POLL_NS_DEFAULT 500000
|
#define KVM_HALT_POLL_NS_DEFAULT 500000
|
||||||
|
|
||||||
|
@ -453,6 +453,12 @@ void kvm_arch_flush_shadow_all(struct kvm *kvm)
|
|||||||
void kvm_arch_flush_shadow_memslot(struct kvm *kvm,
|
void kvm_arch_flush_shadow_memslot(struct kvm *kvm,
|
||||||
struct kvm_memory_slot *slot)
|
struct kvm_memory_slot *slot)
|
||||||
{
|
{
|
||||||
|
gpa_t gpa = slot->base_gfn << PAGE_SHIFT;
|
||||||
|
phys_addr_t size = slot->npages << PAGE_SHIFT;
|
||||||
|
|
||||||
|
spin_lock(&kvm->mmu_lock);
|
||||||
|
stage2_unmap_range(kvm, gpa, size, false);
|
||||||
|
spin_unlock(&kvm->mmu_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
void kvm_arch_commit_memory_region(struct kvm *kvm,
|
void kvm_arch_commit_memory_region(struct kvm *kvm,
|
||||||
|
@ -403,7 +403,6 @@ CONFIG_DEVTMPFS=y
|
|||||||
CONFIG_CONNECTOR=y
|
CONFIG_CONNECTOR=y
|
||||||
CONFIG_ZRAM=y
|
CONFIG_ZRAM=y
|
||||||
CONFIG_BLK_DEV_LOOP=m
|
CONFIG_BLK_DEV_LOOP=m
|
||||||
CONFIG_BLK_DEV_CRYPTOLOOP=m
|
|
||||||
CONFIG_BLK_DEV_DRBD=m
|
CONFIG_BLK_DEV_DRBD=m
|
||||||
CONFIG_BLK_DEV_NBD=m
|
CONFIG_BLK_DEV_NBD=m
|
||||||
CONFIG_BLK_DEV_RAM=y
|
CONFIG_BLK_DEV_RAM=y
|
||||||
@ -476,6 +475,7 @@ CONFIG_MACVLAN=m
|
|||||||
CONFIG_MACVTAP=m
|
CONFIG_MACVTAP=m
|
||||||
CONFIG_VXLAN=m
|
CONFIG_VXLAN=m
|
||||||
CONFIG_BAREUDP=m
|
CONFIG_BAREUDP=m
|
||||||
|
CONFIG_AMT=m
|
||||||
CONFIG_TUN=m
|
CONFIG_TUN=m
|
||||||
CONFIG_VETH=m
|
CONFIG_VETH=m
|
||||||
CONFIG_VIRTIO_NET=m
|
CONFIG_VIRTIO_NET=m
|
||||||
@ -489,6 +489,7 @@ CONFIG_NLMON=m
|
|||||||
# CONFIG_NET_VENDOR_AMD is not set
|
# CONFIG_NET_VENDOR_AMD is not set
|
||||||
# CONFIG_NET_VENDOR_AQUANTIA is not set
|
# CONFIG_NET_VENDOR_AQUANTIA is not set
|
||||||
# CONFIG_NET_VENDOR_ARC is not set
|
# CONFIG_NET_VENDOR_ARC is not set
|
||||||
|
# CONFIG_NET_VENDOR_ASIX is not set
|
||||||
# CONFIG_NET_VENDOR_ATHEROS is not set
|
# CONFIG_NET_VENDOR_ATHEROS is not set
|
||||||
# CONFIG_NET_VENDOR_BROADCOM is not set
|
# CONFIG_NET_VENDOR_BROADCOM is not set
|
||||||
# CONFIG_NET_VENDOR_BROCADE is not set
|
# CONFIG_NET_VENDOR_BROCADE is not set
|
||||||
@ -571,6 +572,7 @@ CONFIG_WATCHDOG=y
|
|||||||
CONFIG_WATCHDOG_NOWAYOUT=y
|
CONFIG_WATCHDOG_NOWAYOUT=y
|
||||||
CONFIG_SOFT_WATCHDOG=m
|
CONFIG_SOFT_WATCHDOG=m
|
||||||
CONFIG_DIAG288_WATCHDOG=m
|
CONFIG_DIAG288_WATCHDOG=m
|
||||||
|
# CONFIG_DRM_DEBUG_MODESET_LOCK is not set
|
||||||
CONFIG_FB=y
|
CONFIG_FB=y
|
||||||
CONFIG_FRAMEBUFFER_CONSOLE=y
|
CONFIG_FRAMEBUFFER_CONSOLE=y
|
||||||
CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y
|
CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y
|
||||||
@ -775,12 +777,14 @@ CONFIG_CRC4=m
|
|||||||
CONFIG_CRC7=m
|
CONFIG_CRC7=m
|
||||||
CONFIG_CRC8=m
|
CONFIG_CRC8=m
|
||||||
CONFIG_RANDOM32_SELFTEST=y
|
CONFIG_RANDOM32_SELFTEST=y
|
||||||
|
CONFIG_XZ_DEC_MICROLZMA=y
|
||||||
CONFIG_DMA_CMA=y
|
CONFIG_DMA_CMA=y
|
||||||
CONFIG_CMA_SIZE_MBYTES=0
|
CONFIG_CMA_SIZE_MBYTES=0
|
||||||
CONFIG_PRINTK_TIME=y
|
CONFIG_PRINTK_TIME=y
|
||||||
CONFIG_DYNAMIC_DEBUG=y
|
CONFIG_DYNAMIC_DEBUG=y
|
||||||
CONFIG_DEBUG_INFO=y
|
CONFIG_DEBUG_INFO=y
|
||||||
CONFIG_DEBUG_INFO_DWARF4=y
|
CONFIG_DEBUG_INFO_DWARF4=y
|
||||||
|
CONFIG_DEBUG_INFO_BTF=y
|
||||||
CONFIG_GDB_SCRIPTS=y
|
CONFIG_GDB_SCRIPTS=y
|
||||||
CONFIG_HEADERS_INSTALL=y
|
CONFIG_HEADERS_INSTALL=y
|
||||||
CONFIG_DEBUG_SECTION_MISMATCH=y
|
CONFIG_DEBUG_SECTION_MISMATCH=y
|
||||||
@ -807,6 +811,7 @@ CONFIG_DEBUG_MEMORY_INIT=y
|
|||||||
CONFIG_MEMORY_NOTIFIER_ERROR_INJECT=m
|
CONFIG_MEMORY_NOTIFIER_ERROR_INJECT=m
|
||||||
CONFIG_DEBUG_PER_CPU_MAPS=y
|
CONFIG_DEBUG_PER_CPU_MAPS=y
|
||||||
CONFIG_KFENCE=y
|
CONFIG_KFENCE=y
|
||||||
|
CONFIG_KFENCE_STATIC_KEYS=y
|
||||||
CONFIG_DEBUG_SHIRQ=y
|
CONFIG_DEBUG_SHIRQ=y
|
||||||
CONFIG_PANIC_ON_OOPS=y
|
CONFIG_PANIC_ON_OOPS=y
|
||||||
CONFIG_DETECT_HUNG_TASK=y
|
CONFIG_DETECT_HUNG_TASK=y
|
||||||
@ -842,6 +847,7 @@ CONFIG_FTRACE_STARTUP_TEST=y
|
|||||||
CONFIG_SAMPLES=y
|
CONFIG_SAMPLES=y
|
||||||
CONFIG_SAMPLE_TRACE_PRINTK=m
|
CONFIG_SAMPLE_TRACE_PRINTK=m
|
||||||
CONFIG_SAMPLE_FTRACE_DIRECT=m
|
CONFIG_SAMPLE_FTRACE_DIRECT=m
|
||||||
|
CONFIG_SAMPLE_FTRACE_DIRECT_MULTI=m
|
||||||
CONFIG_DEBUG_ENTRY=y
|
CONFIG_DEBUG_ENTRY=y
|
||||||
CONFIG_CIO_INJECT=y
|
CONFIG_CIO_INJECT=y
|
||||||
CONFIG_KUNIT=m
|
CONFIG_KUNIT=m
|
||||||
@ -860,7 +866,7 @@ CONFIG_FAIL_FUNCTION=y
|
|||||||
CONFIG_FAULT_INJECTION_STACKTRACE_FILTER=y
|
CONFIG_FAULT_INJECTION_STACKTRACE_FILTER=y
|
||||||
CONFIG_LKDTM=m
|
CONFIG_LKDTM=m
|
||||||
CONFIG_TEST_MIN_HEAP=y
|
CONFIG_TEST_MIN_HEAP=y
|
||||||
CONFIG_KPROBES_SANITY_TEST=y
|
CONFIG_KPROBES_SANITY_TEST=m
|
||||||
CONFIG_RBTREE_TEST=y
|
CONFIG_RBTREE_TEST=y
|
||||||
CONFIG_INTERVAL_TREE_TEST=m
|
CONFIG_INTERVAL_TREE_TEST=m
|
||||||
CONFIG_PERCPU_TEST=m
|
CONFIG_PERCPU_TEST=m
|
||||||
|
@ -394,7 +394,6 @@ CONFIG_DEVTMPFS=y
|
|||||||
CONFIG_CONNECTOR=y
|
CONFIG_CONNECTOR=y
|
||||||
CONFIG_ZRAM=y
|
CONFIG_ZRAM=y
|
||||||
CONFIG_BLK_DEV_LOOP=m
|
CONFIG_BLK_DEV_LOOP=m
|
||||||
CONFIG_BLK_DEV_CRYPTOLOOP=m
|
|
||||||
CONFIG_BLK_DEV_DRBD=m
|
CONFIG_BLK_DEV_DRBD=m
|
||||||
CONFIG_BLK_DEV_NBD=m
|
CONFIG_BLK_DEV_NBD=m
|
||||||
CONFIG_BLK_DEV_RAM=y
|
CONFIG_BLK_DEV_RAM=y
|
||||||
@ -467,6 +466,7 @@ CONFIG_MACVLAN=m
|
|||||||
CONFIG_MACVTAP=m
|
CONFIG_MACVTAP=m
|
||||||
CONFIG_VXLAN=m
|
CONFIG_VXLAN=m
|
||||||
CONFIG_BAREUDP=m
|
CONFIG_BAREUDP=m
|
||||||
|
CONFIG_AMT=m
|
||||||
CONFIG_TUN=m
|
CONFIG_TUN=m
|
||||||
CONFIG_VETH=m
|
CONFIG_VETH=m
|
||||||
CONFIG_VIRTIO_NET=m
|
CONFIG_VIRTIO_NET=m
|
||||||
@ -480,6 +480,7 @@ CONFIG_NLMON=m
|
|||||||
# CONFIG_NET_VENDOR_AMD is not set
|
# CONFIG_NET_VENDOR_AMD is not set
|
||||||
# CONFIG_NET_VENDOR_AQUANTIA is not set
|
# CONFIG_NET_VENDOR_AQUANTIA is not set
|
||||||
# CONFIG_NET_VENDOR_ARC is not set
|
# CONFIG_NET_VENDOR_ARC is not set
|
||||||
|
# CONFIG_NET_VENDOR_ASIX is not set
|
||||||
# CONFIG_NET_VENDOR_ATHEROS is not set
|
# CONFIG_NET_VENDOR_ATHEROS is not set
|
||||||
# CONFIG_NET_VENDOR_BROADCOM is not set
|
# CONFIG_NET_VENDOR_BROADCOM is not set
|
||||||
# CONFIG_NET_VENDOR_BROCADE is not set
|
# CONFIG_NET_VENDOR_BROCADE is not set
|
||||||
@ -762,12 +763,14 @@ CONFIG_PRIME_NUMBERS=m
|
|||||||
CONFIG_CRC4=m
|
CONFIG_CRC4=m
|
||||||
CONFIG_CRC7=m
|
CONFIG_CRC7=m
|
||||||
CONFIG_CRC8=m
|
CONFIG_CRC8=m
|
||||||
|
CONFIG_XZ_DEC_MICROLZMA=y
|
||||||
CONFIG_DMA_CMA=y
|
CONFIG_DMA_CMA=y
|
||||||
CONFIG_CMA_SIZE_MBYTES=0
|
CONFIG_CMA_SIZE_MBYTES=0
|
||||||
CONFIG_PRINTK_TIME=y
|
CONFIG_PRINTK_TIME=y
|
||||||
CONFIG_DYNAMIC_DEBUG=y
|
CONFIG_DYNAMIC_DEBUG=y
|
||||||
CONFIG_DEBUG_INFO=y
|
CONFIG_DEBUG_INFO=y
|
||||||
CONFIG_DEBUG_INFO_DWARF4=y
|
CONFIG_DEBUG_INFO_DWARF4=y
|
||||||
|
CONFIG_DEBUG_INFO_BTF=y
|
||||||
CONFIG_GDB_SCRIPTS=y
|
CONFIG_GDB_SCRIPTS=y
|
||||||
CONFIG_DEBUG_SECTION_MISMATCH=y
|
CONFIG_DEBUG_SECTION_MISMATCH=y
|
||||||
CONFIG_MAGIC_SYSRQ=y
|
CONFIG_MAGIC_SYSRQ=y
|
||||||
@ -792,9 +795,11 @@ CONFIG_HIST_TRIGGERS=y
|
|||||||
CONFIG_SAMPLES=y
|
CONFIG_SAMPLES=y
|
||||||
CONFIG_SAMPLE_TRACE_PRINTK=m
|
CONFIG_SAMPLE_TRACE_PRINTK=m
|
||||||
CONFIG_SAMPLE_FTRACE_DIRECT=m
|
CONFIG_SAMPLE_FTRACE_DIRECT=m
|
||||||
|
CONFIG_SAMPLE_FTRACE_DIRECT_MULTI=m
|
||||||
CONFIG_KUNIT=m
|
CONFIG_KUNIT=m
|
||||||
CONFIG_KUNIT_DEBUGFS=y
|
CONFIG_KUNIT_DEBUGFS=y
|
||||||
CONFIG_LKDTM=m
|
CONFIG_LKDTM=m
|
||||||
|
CONFIG_KPROBES_SANITY_TEST=m
|
||||||
CONFIG_PERCPU_TEST=m
|
CONFIG_PERCPU_TEST=m
|
||||||
CONFIG_ATOMIC64_SELFTEST=y
|
CONFIG_ATOMIC64_SELFTEST=y
|
||||||
CONFIG_TEST_BPF=m
|
CONFIG_TEST_BPF=m
|
||||||
|
@ -65,9 +65,11 @@ CONFIG_ZFCP=y
|
|||||||
# CONFIG_NETWORK_FILESYSTEMS is not set
|
# CONFIG_NETWORK_FILESYSTEMS is not set
|
||||||
CONFIG_LSM="yama,loadpin,safesetid,integrity"
|
CONFIG_LSM="yama,loadpin,safesetid,integrity"
|
||||||
# CONFIG_ZLIB_DFLTCC is not set
|
# CONFIG_ZLIB_DFLTCC is not set
|
||||||
|
CONFIG_XZ_DEC_MICROLZMA=y
|
||||||
CONFIG_PRINTK_TIME=y
|
CONFIG_PRINTK_TIME=y
|
||||||
# CONFIG_SYMBOLIC_ERRNAME is not set
|
# CONFIG_SYMBOLIC_ERRNAME is not set
|
||||||
CONFIG_DEBUG_INFO=y
|
CONFIG_DEBUG_INFO=y
|
||||||
|
CONFIG_DEBUG_INFO_BTF=y
|
||||||
CONFIG_DEBUG_FS=y
|
CONFIG_DEBUG_FS=y
|
||||||
CONFIG_DEBUG_KERNEL=y
|
CONFIG_DEBUG_KERNEL=y
|
||||||
CONFIG_PANIC_ON_OOPS=y
|
CONFIG_PANIC_ON_OOPS=y
|
||||||
|
@ -14,12 +14,13 @@
|
|||||||
|
|
||||||
/* I/O Map */
|
/* I/O Map */
|
||||||
#define ZPCI_IOMAP_SHIFT 48
|
#define ZPCI_IOMAP_SHIFT 48
|
||||||
#define ZPCI_IOMAP_ADDR_BASE 0x8000000000000000UL
|
#define ZPCI_IOMAP_ADDR_SHIFT 62
|
||||||
|
#define ZPCI_IOMAP_ADDR_BASE (1UL << ZPCI_IOMAP_ADDR_SHIFT)
|
||||||
#define ZPCI_IOMAP_ADDR_OFF_MASK ((1UL << ZPCI_IOMAP_SHIFT) - 1)
|
#define ZPCI_IOMAP_ADDR_OFF_MASK ((1UL << ZPCI_IOMAP_SHIFT) - 1)
|
||||||
#define ZPCI_IOMAP_MAX_ENTRIES \
|
#define ZPCI_IOMAP_MAX_ENTRIES \
|
||||||
((ULONG_MAX - ZPCI_IOMAP_ADDR_BASE + 1) / (1UL << ZPCI_IOMAP_SHIFT))
|
(1UL << (ZPCI_IOMAP_ADDR_SHIFT - ZPCI_IOMAP_SHIFT))
|
||||||
#define ZPCI_IOMAP_ADDR_IDX_MASK \
|
#define ZPCI_IOMAP_ADDR_IDX_MASK \
|
||||||
(~ZPCI_IOMAP_ADDR_OFF_MASK - ZPCI_IOMAP_ADDR_BASE)
|
((ZPCI_IOMAP_ADDR_BASE - 1) & ~ZPCI_IOMAP_ADDR_OFF_MASK)
|
||||||
|
|
||||||
struct zpci_iomap_entry {
|
struct zpci_iomap_entry {
|
||||||
u32 fh;
|
u32 fh;
|
||||||
|
@ -173,10 +173,11 @@ static noinline int unwindme_func4(struct unwindme *u)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* trigger specification exception
|
* Trigger operation exception; use insn notation to bypass
|
||||||
|
* llvm's integrated assembler sanity checks.
|
||||||
*/
|
*/
|
||||||
asm volatile(
|
asm volatile(
|
||||||
" mvcl %%r1,%%r1\n"
|
" .insn e,0x0000\n" /* illegal opcode */
|
||||||
"0: nopr %%r7\n"
|
"0: nopr %%r7\n"
|
||||||
EX_TABLE(0b, 0b)
|
EX_TABLE(0b, 0b)
|
||||||
:);
|
:);
|
||||||
|
@ -43,7 +43,6 @@ extern void flush_cache_range(struct vm_area_struct *vma,
|
|||||||
unsigned long start, unsigned long end);
|
unsigned long start, unsigned long end);
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
|
||||||
void flush_dcache_page(struct page *page);
|
void flush_dcache_page(struct page *page);
|
||||||
void flush_dcache_folio(struct folio *folio);
|
|
||||||
extern void flush_icache_range(unsigned long start, unsigned long end);
|
extern void flush_icache_range(unsigned long start, unsigned long end);
|
||||||
#define flush_icache_user_range flush_icache_range
|
#define flush_icache_user_range flush_icache_range
|
||||||
extern void flush_icache_page(struct vm_area_struct *vma,
|
extern void flush_icache_page(struct vm_area_struct *vma,
|
||||||
|
@ -451,3 +451,4 @@
|
|||||||
446 common landlock_restrict_self sys_landlock_restrict_self
|
446 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 447 reserved for memfd_secret
|
# 447 reserved for memfd_secret
|
||||||
448 common process_mrelease sys_process_mrelease
|
448 common process_mrelease sys_process_mrelease
|
||||||
|
449 common futex_waitv sys_futex_waitv
|
||||||
|
@ -494,3 +494,4 @@
|
|||||||
446 common landlock_restrict_self sys_landlock_restrict_self
|
446 common landlock_restrict_self sys_landlock_restrict_self
|
||||||
# 447 reserved for memfd_secret
|
# 447 reserved for memfd_secret
|
||||||
448 common process_mrelease sys_process_mrelease
|
448 common process_mrelease sys_process_mrelease
|
||||||
|
449 common futex_waitv sys_futex_waitv
|
||||||
|
@ -1932,6 +1932,7 @@ config EFI
|
|||||||
depends on ACPI
|
depends on ACPI
|
||||||
select UCS2_STRING
|
select UCS2_STRING
|
||||||
select EFI_RUNTIME_WRAPPERS
|
select EFI_RUNTIME_WRAPPERS
|
||||||
|
select ARCH_USE_MEMREMAP_PROT
|
||||||
help
|
help
|
||||||
This enables the kernel to use EFI runtime services that are
|
This enables the kernel to use EFI runtime services that are
|
||||||
available (such as the EFI variable services).
|
available (such as the EFI variable services).
|
||||||
|
@ -574,6 +574,10 @@ SYM_INNER_LABEL(swapgs_restore_regs_and_return_to_usermode, SYM_L_GLOBAL)
|
|||||||
ud2
|
ud2
|
||||||
1:
|
1:
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef CONFIG_XEN_PV
|
||||||
|
ALTERNATIVE "", "jmp xenpv_restore_regs_and_return_to_usermode", X86_FEATURE_XENPV
|
||||||
|
#endif
|
||||||
|
|
||||||
POP_REGS pop_rdi=0
|
POP_REGS pop_rdi=0
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -890,6 +894,7 @@ SYM_CODE_START_LOCAL(paranoid_entry)
|
|||||||
.Lparanoid_entry_checkgs:
|
.Lparanoid_entry_checkgs:
|
||||||
/* EBX = 1 -> kernel GSBASE active, no restore required */
|
/* EBX = 1 -> kernel GSBASE active, no restore required */
|
||||||
movl $1, %ebx
|
movl $1, %ebx
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The kernel-enforced convention is a negative GSBASE indicates
|
* The kernel-enforced convention is a negative GSBASE indicates
|
||||||
* a kernel value. No SWAPGS needed on entry and exit.
|
* a kernel value. No SWAPGS needed on entry and exit.
|
||||||
@ -897,21 +902,14 @@ SYM_CODE_START_LOCAL(paranoid_entry)
|
|||||||
movl $MSR_GS_BASE, %ecx
|
movl $MSR_GS_BASE, %ecx
|
||||||
rdmsr
|
rdmsr
|
||||||
testl %edx, %edx
|
testl %edx, %edx
|
||||||
jns .Lparanoid_entry_swapgs
|
js .Lparanoid_kernel_gsbase
|
||||||
ret
|
|
||||||
|
|
||||||
.Lparanoid_entry_swapgs:
|
|
||||||
swapgs
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The above SAVE_AND_SWITCH_TO_KERNEL_CR3 macro doesn't do an
|
|
||||||
* unconditional CR3 write, even in the PTI case. So do an lfence
|
|
||||||
* to prevent GS speculation, regardless of whether PTI is enabled.
|
|
||||||
*/
|
|
||||||
FENCE_SWAPGS_KERNEL_ENTRY
|
|
||||||
|
|
||||||
/* EBX = 0 -> SWAPGS required on exit */
|
/* EBX = 0 -> SWAPGS required on exit */
|
||||||
xorl %ebx, %ebx
|
xorl %ebx, %ebx
|
||||||
|
swapgs
|
||||||
|
.Lparanoid_kernel_gsbase:
|
||||||
|
|
||||||
|
FENCE_SWAPGS_KERNEL_ENTRY
|
||||||
ret
|
ret
|
||||||
SYM_CODE_END(paranoid_entry)
|
SYM_CODE_END(paranoid_entry)
|
||||||
|
|
||||||
@ -993,11 +991,6 @@ SYM_CODE_START_LOCAL(error_entry)
|
|||||||
pushq %r12
|
pushq %r12
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.Lerror_entry_done_lfence:
|
|
||||||
FENCE_SWAPGS_KERNEL_ENTRY
|
|
||||||
.Lerror_entry_done:
|
|
||||||
ret
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* There are two places in the kernel that can potentially fault with
|
* There are two places in the kernel that can potentially fault with
|
||||||
* usergs. Handle them here. B stepping K8s sometimes report a
|
* usergs. Handle them here. B stepping K8s sometimes report a
|
||||||
@ -1020,8 +1013,14 @@ SYM_CODE_START_LOCAL(error_entry)
|
|||||||
* .Lgs_change's error handler with kernel gsbase.
|
* .Lgs_change's error handler with kernel gsbase.
|
||||||
*/
|
*/
|
||||||
SWAPGS
|
SWAPGS
|
||||||
FENCE_SWAPGS_USER_ENTRY
|
|
||||||
jmp .Lerror_entry_done
|
/*
|
||||||
|
* Issue an LFENCE to prevent GS speculation, regardless of whether it is a
|
||||||
|
* kernel or user gsbase.
|
||||||
|
*/
|
||||||
|
.Lerror_entry_done_lfence:
|
||||||
|
FENCE_SWAPGS_KERNEL_ENTRY
|
||||||
|
ret
|
||||||
|
|
||||||
.Lbstep_iret:
|
.Lbstep_iret:
|
||||||
/* Fix truncated RIP */
|
/* Fix truncated RIP */
|
||||||
|
@ -102,12 +102,6 @@ extern void switch_fpu_return(void);
|
|||||||
*/
|
*/
|
||||||
extern int cpu_has_xfeatures(u64 xfeatures_mask, const char **feature_name);
|
extern int cpu_has_xfeatures(u64 xfeatures_mask, const char **feature_name);
|
||||||
|
|
||||||
/*
|
|
||||||
* Tasks that are not using SVA have mm->pasid set to zero to note that they
|
|
||||||
* will not have the valid bit set in MSR_IA32_PASID while they are running.
|
|
||||||
*/
|
|
||||||
#define PASID_DISABLED 0
|
|
||||||
|
|
||||||
/* Trap handling */
|
/* Trap handling */
|
||||||
extern int fpu__exception_code(struct fpu *fpu, int trap_nr);
|
extern int fpu__exception_code(struct fpu *fpu, int trap_nr);
|
||||||
extern void fpu_sync_fpstate(struct fpu *fpu);
|
extern void fpu_sync_fpstate(struct fpu *fpu);
|
||||||
|
@ -108,7 +108,7 @@
|
|||||||
#define INTEL_FAM6_ALDERLAKE 0x97 /* Golden Cove / Gracemont */
|
#define INTEL_FAM6_ALDERLAKE 0x97 /* Golden Cove / Gracemont */
|
||||||
#define INTEL_FAM6_ALDERLAKE_L 0x9A /* Golden Cove / Gracemont */
|
#define INTEL_FAM6_ALDERLAKE_L 0x9A /* Golden Cove / Gracemont */
|
||||||
|
|
||||||
#define INTEL_FAM6_RAPTOR_LAKE 0xB7
|
#define INTEL_FAM6_RAPTORLAKE 0xB7
|
||||||
|
|
||||||
/* "Small Core" Processors (Atom) */
|
/* "Small Core" Processors (Atom) */
|
||||||
|
|
||||||
|
@ -97,7 +97,7 @@
|
|||||||
KVM_ARCH_REQ_FLAGS(25, KVM_REQUEST_WAIT | KVM_REQUEST_NO_WAKEUP)
|
KVM_ARCH_REQ_FLAGS(25, KVM_REQUEST_WAIT | KVM_REQUEST_NO_WAKEUP)
|
||||||
#define KVM_REQ_TLB_FLUSH_CURRENT KVM_ARCH_REQ(26)
|
#define KVM_REQ_TLB_FLUSH_CURRENT KVM_ARCH_REQ(26)
|
||||||
#define KVM_REQ_TLB_FLUSH_GUEST \
|
#define KVM_REQ_TLB_FLUSH_GUEST \
|
||||||
KVM_ARCH_REQ_FLAGS(27, KVM_REQUEST_NO_WAKEUP)
|
KVM_ARCH_REQ_FLAGS(27, KVM_REQUEST_WAIT | KVM_REQUEST_NO_WAKEUP)
|
||||||
#define KVM_REQ_APF_READY KVM_ARCH_REQ(28)
|
#define KVM_REQ_APF_READY KVM_ARCH_REQ(28)
|
||||||
#define KVM_REQ_MSR_FILTER_CHANGED KVM_ARCH_REQ(29)
|
#define KVM_REQ_MSR_FILTER_CHANGED KVM_ARCH_REQ(29)
|
||||||
#define KVM_REQ_UPDATE_CPU_DIRTY_LOGGING \
|
#define KVM_REQ_UPDATE_CPU_DIRTY_LOGGING \
|
||||||
@ -1036,6 +1036,7 @@ struct kvm_x86_msr_filter {
|
|||||||
#define APICV_INHIBIT_REASON_PIT_REINJ 4
|
#define APICV_INHIBIT_REASON_PIT_REINJ 4
|
||||||
#define APICV_INHIBIT_REASON_X2APIC 5
|
#define APICV_INHIBIT_REASON_X2APIC 5
|
||||||
#define APICV_INHIBIT_REASON_BLOCKIRQ 6
|
#define APICV_INHIBIT_REASON_BLOCKIRQ 6
|
||||||
|
#define APICV_INHIBIT_REASON_ABSENT 7
|
||||||
|
|
||||||
struct kvm_arch {
|
struct kvm_arch {
|
||||||
unsigned long n_used_mmu_pages;
|
unsigned long n_used_mmu_pages;
|
||||||
|
@ -73,4 +73,15 @@
|
|||||||
|
|
||||||
#define GHCB_RESP_CODE(v) ((v) & GHCB_MSR_INFO_MASK)
|
#define GHCB_RESP_CODE(v) ((v) & GHCB_MSR_INFO_MASK)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Error codes related to GHCB input that can be communicated back to the guest
|
||||||
|
* by setting the lower 32-bits of the GHCB SW_EXITINFO1 field to 2.
|
||||||
|
*/
|
||||||
|
#define GHCB_ERR_NOT_REGISTERED 1
|
||||||
|
#define GHCB_ERR_INVALID_USAGE 2
|
||||||
|
#define GHCB_ERR_INVALID_SCRATCH_AREA 3
|
||||||
|
#define GHCB_ERR_MISSING_INPUT 4
|
||||||
|
#define GHCB_ERR_INVALID_INPUT 5
|
||||||
|
#define GHCB_ERR_INVALID_EVENT 6
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -281,13 +281,13 @@ HYPERVISOR_callback_op(int cmd, void *arg)
|
|||||||
return _hypercall2(int, callback_op, cmd, arg);
|
return _hypercall2(int, callback_op, cmd, arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int
|
static __always_inline int
|
||||||
HYPERVISOR_set_debugreg(int reg, unsigned long value)
|
HYPERVISOR_set_debugreg(int reg, unsigned long value)
|
||||||
{
|
{
|
||||||
return _hypercall2(int, set_debugreg, reg, value);
|
return _hypercall2(int, set_debugreg, reg, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline unsigned long
|
static __always_inline unsigned long
|
||||||
HYPERVISOR_get_debugreg(int reg)
|
HYPERVISOR_get_debugreg(int reg)
|
||||||
{
|
{
|
||||||
return _hypercall1(unsigned long, get_debugreg, reg);
|
return _hypercall1(unsigned long, get_debugreg, reg);
|
||||||
|
@ -64,6 +64,7 @@ void xen_arch_unregister_cpu(int num);
|
|||||||
|
|
||||||
#ifdef CONFIG_PVH
|
#ifdef CONFIG_PVH
|
||||||
void __init xen_pvh_init(struct boot_params *boot_params);
|
void __init xen_pvh_init(struct boot_params *boot_params);
|
||||||
|
void __init mem_map_via_hcall(struct boot_params *boot_params_p);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* _ASM_X86_XEN_HYPERVISOR_H */
|
#endif /* _ASM_X86_XEN_HYPERVISOR_H */
|
||||||
|
@ -118,7 +118,7 @@ static inline bool save_xstate_epilog(void __user *buf, int ia32_frame,
|
|||||||
struct fpstate *fpstate)
|
struct fpstate *fpstate)
|
||||||
{
|
{
|
||||||
struct xregs_state __user *x = buf;
|
struct xregs_state __user *x = buf;
|
||||||
struct _fpx_sw_bytes sw_bytes;
|
struct _fpx_sw_bytes sw_bytes = {};
|
||||||
u32 xfeatures;
|
u32 xfeatures;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
|
@ -742,7 +742,7 @@ dump_kernel_offset(struct notifier_block *self, unsigned long v, void *p)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *prepare_command_line(void)
|
static char * __init prepare_command_line(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_CMDLINE_BOOL
|
#ifdef CONFIG_CMDLINE_BOOL
|
||||||
#ifdef CONFIG_CMDLINE_OVERRIDE
|
#ifdef CONFIG_CMDLINE_OVERRIDE
|
||||||
|
@ -294,11 +294,6 @@ static enum es_result vc_write_mem(struct es_em_ctxt *ctxt,
|
|||||||
char *dst, char *buf, size_t size)
|
char *dst, char *buf, size_t size)
|
||||||
{
|
{
|
||||||
unsigned long error_code = X86_PF_PROT | X86_PF_WRITE;
|
unsigned long error_code = X86_PF_PROT | X86_PF_WRITE;
|
||||||
char __user *target = (char __user *)dst;
|
|
||||||
u64 d8;
|
|
||||||
u32 d4;
|
|
||||||
u16 d2;
|
|
||||||
u8 d1;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This function uses __put_user() independent of whether kernel or user
|
* This function uses __put_user() independent of whether kernel or user
|
||||||
@ -320,26 +315,42 @@ static enum es_result vc_write_mem(struct es_em_ctxt *ctxt,
|
|||||||
* instructions here would cause infinite nesting.
|
* instructions here would cause infinite nesting.
|
||||||
*/
|
*/
|
||||||
switch (size) {
|
switch (size) {
|
||||||
case 1:
|
case 1: {
|
||||||
|
u8 d1;
|
||||||
|
u8 __user *target = (u8 __user *)dst;
|
||||||
|
|
||||||
memcpy(&d1, buf, 1);
|
memcpy(&d1, buf, 1);
|
||||||
if (__put_user(d1, target))
|
if (__put_user(d1, target))
|
||||||
goto fault;
|
goto fault;
|
||||||
break;
|
break;
|
||||||
case 2:
|
}
|
||||||
|
case 2: {
|
||||||
|
u16 d2;
|
||||||
|
u16 __user *target = (u16 __user *)dst;
|
||||||
|
|
||||||
memcpy(&d2, buf, 2);
|
memcpy(&d2, buf, 2);
|
||||||
if (__put_user(d2, target))
|
if (__put_user(d2, target))
|
||||||
goto fault;
|
goto fault;
|
||||||
break;
|
break;
|
||||||
case 4:
|
}
|
||||||
|
case 4: {
|
||||||
|
u32 d4;
|
||||||
|
u32 __user *target = (u32 __user *)dst;
|
||||||
|
|
||||||
memcpy(&d4, buf, 4);
|
memcpy(&d4, buf, 4);
|
||||||
if (__put_user(d4, target))
|
if (__put_user(d4, target))
|
||||||
goto fault;
|
goto fault;
|
||||||
break;
|
break;
|
||||||
case 8:
|
}
|
||||||
|
case 8: {
|
||||||
|
u64 d8;
|
||||||
|
u64 __user *target = (u64 __user *)dst;
|
||||||
|
|
||||||
memcpy(&d8, buf, 8);
|
memcpy(&d8, buf, 8);
|
||||||
if (__put_user(d8, target))
|
if (__put_user(d8, target))
|
||||||
goto fault;
|
goto fault;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
WARN_ONCE(1, "%s: Invalid size: %zu\n", __func__, size);
|
WARN_ONCE(1, "%s: Invalid size: %zu\n", __func__, size);
|
||||||
return ES_UNSUPPORTED;
|
return ES_UNSUPPORTED;
|
||||||
@ -362,11 +373,6 @@ static enum es_result vc_read_mem(struct es_em_ctxt *ctxt,
|
|||||||
char *src, char *buf, size_t size)
|
char *src, char *buf, size_t size)
|
||||||
{
|
{
|
||||||
unsigned long error_code = X86_PF_PROT;
|
unsigned long error_code = X86_PF_PROT;
|
||||||
char __user *s = (char __user *)src;
|
|
||||||
u64 d8;
|
|
||||||
u32 d4;
|
|
||||||
u16 d2;
|
|
||||||
u8 d1;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This function uses __get_user() independent of whether kernel or user
|
* This function uses __get_user() independent of whether kernel or user
|
||||||
@ -388,26 +394,41 @@ static enum es_result vc_read_mem(struct es_em_ctxt *ctxt,
|
|||||||
* instructions here would cause infinite nesting.
|
* instructions here would cause infinite nesting.
|
||||||
*/
|
*/
|
||||||
switch (size) {
|
switch (size) {
|
||||||
case 1:
|
case 1: {
|
||||||
|
u8 d1;
|
||||||
|
u8 __user *s = (u8 __user *)src;
|
||||||
|
|
||||||
if (__get_user(d1, s))
|
if (__get_user(d1, s))
|
||||||
goto fault;
|
goto fault;
|
||||||
memcpy(buf, &d1, 1);
|
memcpy(buf, &d1, 1);
|
||||||
break;
|
break;
|
||||||
case 2:
|
}
|
||||||
|
case 2: {
|
||||||
|
u16 d2;
|
||||||
|
u16 __user *s = (u16 __user *)src;
|
||||||
|
|
||||||
if (__get_user(d2, s))
|
if (__get_user(d2, s))
|
||||||
goto fault;
|
goto fault;
|
||||||
memcpy(buf, &d2, 2);
|
memcpy(buf, &d2, 2);
|
||||||
break;
|
break;
|
||||||
case 4:
|
}
|
||||||
|
case 4: {
|
||||||
|
u32 d4;
|
||||||
|
u32 __user *s = (u32 __user *)src;
|
||||||
|
|
||||||
if (__get_user(d4, s))
|
if (__get_user(d4, s))
|
||||||
goto fault;
|
goto fault;
|
||||||
memcpy(buf, &d4, 4);
|
memcpy(buf, &d4, 4);
|
||||||
break;
|
break;
|
||||||
case 8:
|
}
|
||||||
|
case 8: {
|
||||||
|
u64 d8;
|
||||||
|
u64 __user *s = (u64 __user *)src;
|
||||||
if (__get_user(d8, s))
|
if (__get_user(d8, s))
|
||||||
goto fault;
|
goto fault;
|
||||||
memcpy(buf, &d8, 8);
|
memcpy(buf, &d8, 8);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
WARN_ONCE(1, "%s: Invalid size: %zu\n", __func__, size);
|
WARN_ONCE(1, "%s: Invalid size: %zu\n", __func__, size);
|
||||||
return ES_UNSUPPORTED;
|
return ES_UNSUPPORTED;
|
||||||
|
@ -579,6 +579,17 @@ static struct sched_domain_topology_level x86_numa_in_package_topology[] = {
|
|||||||
{ NULL, },
|
{ NULL, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct sched_domain_topology_level x86_hybrid_topology[] = {
|
||||||
|
#ifdef CONFIG_SCHED_SMT
|
||||||
|
{ cpu_smt_mask, x86_smt_flags, SD_INIT_NAME(SMT) },
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_SCHED_MC
|
||||||
|
{ cpu_coregroup_mask, x86_core_flags, SD_INIT_NAME(MC) },
|
||||||
|
#endif
|
||||||
|
{ cpu_cpu_mask, SD_INIT_NAME(DIE) },
|
||||||
|
{ NULL, },
|
||||||
|
};
|
||||||
|
|
||||||
static struct sched_domain_topology_level x86_topology[] = {
|
static struct sched_domain_topology_level x86_topology[] = {
|
||||||
#ifdef CONFIG_SCHED_SMT
|
#ifdef CONFIG_SCHED_SMT
|
||||||
{ cpu_smt_mask, x86_smt_flags, SD_INIT_NAME(SMT) },
|
{ cpu_smt_mask, x86_smt_flags, SD_INIT_NAME(SMT) },
|
||||||
@ -1469,8 +1480,11 @@ void __init native_smp_cpus_done(unsigned int max_cpus)
|
|||||||
|
|
||||||
calculate_max_logical_packages();
|
calculate_max_logical_packages();
|
||||||
|
|
||||||
|
/* XXX for now assume numa-in-package and hybrid don't overlap */
|
||||||
if (x86_has_numa_in_package)
|
if (x86_has_numa_in_package)
|
||||||
set_sched_topology(x86_numa_in_package_topology);
|
set_sched_topology(x86_numa_in_package_topology);
|
||||||
|
if (cpu_feature_enabled(X86_FEATURE_HYBRID_CPU))
|
||||||
|
set_sched_topology(x86_hybrid_topology);
|
||||||
|
|
||||||
nmi_selftest();
|
nmi_selftest();
|
||||||
impress_friends();
|
impress_friends();
|
||||||
|
@ -1180,6 +1180,12 @@ void mark_tsc_unstable(char *reason)
|
|||||||
|
|
||||||
EXPORT_SYMBOL_GPL(mark_tsc_unstable);
|
EXPORT_SYMBOL_GPL(mark_tsc_unstable);
|
||||||
|
|
||||||
|
static void __init tsc_disable_clocksource_watchdog(void)
|
||||||
|
{
|
||||||
|
clocksource_tsc_early.flags &= ~CLOCK_SOURCE_MUST_VERIFY;
|
||||||
|
clocksource_tsc.flags &= ~CLOCK_SOURCE_MUST_VERIFY;
|
||||||
|
}
|
||||||
|
|
||||||
static void __init check_system_tsc_reliable(void)
|
static void __init check_system_tsc_reliable(void)
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_MGEODEGX1) || defined(CONFIG_MGEODE_LX) || defined(CONFIG_X86_GENERIC)
|
#if defined(CONFIG_MGEODEGX1) || defined(CONFIG_MGEODE_LX) || defined(CONFIG_X86_GENERIC)
|
||||||
@ -1196,6 +1202,23 @@ static void __init check_system_tsc_reliable(void)
|
|||||||
#endif
|
#endif
|
||||||
if (boot_cpu_has(X86_FEATURE_TSC_RELIABLE))
|
if (boot_cpu_has(X86_FEATURE_TSC_RELIABLE))
|
||||||
tsc_clocksource_reliable = 1;
|
tsc_clocksource_reliable = 1;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Disable the clocksource watchdog when the system has:
|
||||||
|
* - TSC running at constant frequency
|
||||||
|
* - TSC which does not stop in C-States
|
||||||
|
* - the TSC_ADJUST register which allows to detect even minimal
|
||||||
|
* modifications
|
||||||
|
* - not more than two sockets. As the number of sockets cannot be
|
||||||
|
* evaluated at the early boot stage where this has to be
|
||||||
|
* invoked, check the number of online memory nodes as a
|
||||||
|
* fallback solution which is an reasonable estimate.
|
||||||
|
*/
|
||||||
|
if (boot_cpu_has(X86_FEATURE_CONSTANT_TSC) &&
|
||||||
|
boot_cpu_has(X86_FEATURE_NONSTOP_TSC) &&
|
||||||
|
boot_cpu_has(X86_FEATURE_TSC_ADJUST) &&
|
||||||
|
nr_online_nodes <= 2)
|
||||||
|
tsc_disable_clocksource_watchdog();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1387,9 +1410,6 @@ static int __init init_tsc_clocksource(void)
|
|||||||
if (tsc_unstable)
|
if (tsc_unstable)
|
||||||
goto unreg;
|
goto unreg;
|
||||||
|
|
||||||
if (tsc_clocksource_reliable || no_tsc_watchdog)
|
|
||||||
clocksource_tsc.flags &= ~CLOCK_SOURCE_MUST_VERIFY;
|
|
||||||
|
|
||||||
if (boot_cpu_has(X86_FEATURE_NONSTOP_TSC_S3))
|
if (boot_cpu_has(X86_FEATURE_NONSTOP_TSC_S3))
|
||||||
clocksource_tsc.flags |= CLOCK_SOURCE_SUSPEND_NONSTOP;
|
clocksource_tsc.flags |= CLOCK_SOURCE_SUSPEND_NONSTOP;
|
||||||
|
|
||||||
@ -1527,7 +1547,7 @@ void __init tsc_init(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (tsc_clocksource_reliable || no_tsc_watchdog)
|
if (tsc_clocksource_reliable || no_tsc_watchdog)
|
||||||
clocksource_tsc_early.flags &= ~CLOCK_SOURCE_MUST_VERIFY;
|
tsc_disable_clocksource_watchdog();
|
||||||
|
|
||||||
clocksource_register_khz(&clocksource_tsc_early, tsc_khz);
|
clocksource_register_khz(&clocksource_tsc_early, tsc_khz);
|
||||||
detect_art();
|
detect_art();
|
||||||
|
@ -30,6 +30,7 @@ struct tsc_adjust {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static DEFINE_PER_CPU(struct tsc_adjust, tsc_adjust);
|
static DEFINE_PER_CPU(struct tsc_adjust, tsc_adjust);
|
||||||
|
static struct timer_list tsc_sync_check_timer;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* TSC's on different sockets may be reset asynchronously.
|
* TSC's on different sockets may be reset asynchronously.
|
||||||
@ -77,6 +78,46 @@ void tsc_verify_tsc_adjust(bool resume)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Normally the tsc_sync will be checked every time system enters idle
|
||||||
|
* state, but there is still caveat that a system won't enter idle,
|
||||||
|
* either because it's too busy or configured purposely to not enter
|
||||||
|
* idle.
|
||||||
|
*
|
||||||
|
* So setup a periodic timer (every 10 minutes) to make sure the check
|
||||||
|
* is always on.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define SYNC_CHECK_INTERVAL (HZ * 600)
|
||||||
|
|
||||||
|
static void tsc_sync_check_timer_fn(struct timer_list *unused)
|
||||||
|
{
|
||||||
|
int next_cpu;
|
||||||
|
|
||||||
|
tsc_verify_tsc_adjust(false);
|
||||||
|
|
||||||
|
/* Run the check for all onlined CPUs in turn */
|
||||||
|
next_cpu = cpumask_next(raw_smp_processor_id(), cpu_online_mask);
|
||||||
|
if (next_cpu >= nr_cpu_ids)
|
||||||
|
next_cpu = cpumask_first(cpu_online_mask);
|
||||||
|
|
||||||
|
tsc_sync_check_timer.expires += SYNC_CHECK_INTERVAL;
|
||||||
|
add_timer_on(&tsc_sync_check_timer, next_cpu);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int __init start_sync_check_timer(void)
|
||||||
|
{
|
||||||
|
if (!cpu_feature_enabled(X86_FEATURE_TSC_ADJUST) || tsc_clocksource_reliable)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
timer_setup(&tsc_sync_check_timer, tsc_sync_check_timer_fn, 0);
|
||||||
|
tsc_sync_check_timer.expires = jiffies + SYNC_CHECK_INTERVAL;
|
||||||
|
add_timer(&tsc_sync_check_timer);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
late_initcall(start_sync_check_timer);
|
||||||
|
|
||||||
static void tsc_sanitize_first_cpu(struct tsc_adjust *cur, s64 bootval,
|
static void tsc_sanitize_first_cpu(struct tsc_adjust *cur, s64 bootval,
|
||||||
unsigned int cpu, bool bootcpu)
|
unsigned int cpu, bool bootcpu)
|
||||||
{
|
{
|
||||||
|
@ -1922,11 +1922,13 @@ static u64 kvm_hv_send_ipi(struct kvm_vcpu *vcpu, struct kvm_hv_hcall *hc, bool
|
|||||||
|
|
||||||
all_cpus = send_ipi_ex.vp_set.format == HV_GENERIC_SET_ALL;
|
all_cpus = send_ipi_ex.vp_set.format == HV_GENERIC_SET_ALL;
|
||||||
|
|
||||||
|
if (all_cpus)
|
||||||
|
goto check_and_send_ipi;
|
||||||
|
|
||||||
if (!sparse_banks_len)
|
if (!sparse_banks_len)
|
||||||
goto ret_success;
|
goto ret_success;
|
||||||
|
|
||||||
if (!all_cpus &&
|
if (kvm_read_guest(kvm,
|
||||||
kvm_read_guest(kvm,
|
|
||||||
hc->ingpa + offsetof(struct hv_send_ipi_ex,
|
hc->ingpa + offsetof(struct hv_send_ipi_ex,
|
||||||
vp_set.bank_contents),
|
vp_set.bank_contents),
|
||||||
sparse_banks,
|
sparse_banks,
|
||||||
@ -1934,6 +1936,7 @@ static u64 kvm_hv_send_ipi(struct kvm_vcpu *vcpu, struct kvm_hv_hcall *hc, bool
|
|||||||
return HV_STATUS_INVALID_HYPERCALL_INPUT;
|
return HV_STATUS_INVALID_HYPERCALL_INPUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
check_and_send_ipi:
|
||||||
if ((vector < HV_IPI_LOW_VECTOR) || (vector > HV_IPI_HIGH_VECTOR))
|
if ((vector < HV_IPI_LOW_VECTOR) || (vector > HV_IPI_HIGH_VECTOR))
|
||||||
return HV_STATUS_INVALID_HYPERCALL_INPUT;
|
return HV_STATUS_INVALID_HYPERCALL_INPUT;
|
||||||
|
|
||||||
|
@ -81,7 +81,6 @@ struct kvm_ioapic {
|
|||||||
unsigned long irq_states[IOAPIC_NUM_PINS];
|
unsigned long irq_states[IOAPIC_NUM_PINS];
|
||||||
struct kvm_io_device dev;
|
struct kvm_io_device dev;
|
||||||
struct kvm *kvm;
|
struct kvm *kvm;
|
||||||
void (*ack_notifier)(void *opaque, int irq);
|
|
||||||
spinlock_t lock;
|
spinlock_t lock;
|
||||||
struct rtc_status rtc_status;
|
struct rtc_status rtc_status;
|
||||||
struct delayed_work eoi_inject;
|
struct delayed_work eoi_inject;
|
||||||
|
@ -56,7 +56,6 @@ struct kvm_pic {
|
|||||||
struct kvm_io_device dev_master;
|
struct kvm_io_device dev_master;
|
||||||
struct kvm_io_device dev_slave;
|
struct kvm_io_device dev_slave;
|
||||||
struct kvm_io_device dev_elcr;
|
struct kvm_io_device dev_elcr;
|
||||||
void (*ack_notifier)(void *opaque, int irq);
|
|
||||||
unsigned long irq_states[PIC_NUM_PINS];
|
unsigned long irq_states[PIC_NUM_PINS];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user