Merge git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net
drivers/net/usb/r8152.cbe53771c87
("r8152: add vendor/device ID pair for Microsoft Devkit")ec51fbd1b8
("r8152: add USB device driver for config selection") https://lore.kernel.org/all/20230113113339.658c4723@canb.auug.org.au/ Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
commit
a99da46ac0
1
.mailmap
1
.mailmap
@ -422,6 +422,7 @@ Tony Luck <tony.luck@intel.com>
|
|||||||
TripleX Chung <xxx.phy@gmail.com> <triplex@zh-kernel.org>
|
TripleX Chung <xxx.phy@gmail.com> <triplex@zh-kernel.org>
|
||||||
TripleX Chung <xxx.phy@gmail.com> <zhongyu@18mail.cn>
|
TripleX Chung <xxx.phy@gmail.com> <zhongyu@18mail.cn>
|
||||||
Tsuneo Yoshioka <Tsuneo.Yoshioka@f-secure.com>
|
Tsuneo Yoshioka <Tsuneo.Yoshioka@f-secure.com>
|
||||||
|
Tudor Ambarus <tudor.ambarus@linaro.org> <tudor.ambarus@microchip.com>
|
||||||
Tycho Andersen <tycho@tycho.pizza> <tycho@tycho.ws>
|
Tycho Andersen <tycho@tycho.pizza> <tycho@tycho.ws>
|
||||||
Tzung-Bi Shih <tzungbi@kernel.org> <tzungbi@google.com>
|
Tzung-Bi Shih <tzungbi@kernel.org> <tzungbi@google.com>
|
||||||
Uwe Kleine-König <ukleinek@informatik.uni-freiburg.de>
|
Uwe Kleine-König <ukleinek@informatik.uni-freiburg.de>
|
||||||
|
18
Documentation/ABI/testing/debugfs-pktcdvd
Normal file
18
Documentation/ABI/testing/debugfs-pktcdvd
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
What: /sys/kernel/debug/pktcdvd/pktcdvd[0-7]
|
||||||
|
Date: Oct. 2006
|
||||||
|
KernelVersion: 2.6.20
|
||||||
|
Contact: Thomas Maier <balagi@justmail.de>
|
||||||
|
Description:
|
||||||
|
|
||||||
|
The pktcdvd module (packet writing driver) creates
|
||||||
|
these files in debugfs:
|
||||||
|
|
||||||
|
/sys/kernel/debug/pktcdvd/pktcdvd[0-7]/
|
||||||
|
|
||||||
|
==== ====== ====================================
|
||||||
|
info 0444 Lots of driver statistics and infos.
|
||||||
|
==== ====== ====================================
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
|
cat /sys/kernel/debug/pktcdvd/pktcdvd0/info
|
97
Documentation/ABI/testing/sysfs-class-pktcdvd
Normal file
97
Documentation/ABI/testing/sysfs-class-pktcdvd
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
sysfs interface
|
||||||
|
---------------
|
||||||
|
The pktcdvd module (packet writing driver) creates the following files in the
|
||||||
|
sysfs: (<devid> is in the format major:minor)
|
||||||
|
|
||||||
|
What: /sys/class/pktcdvd/add
|
||||||
|
What: /sys/class/pktcdvd/remove
|
||||||
|
What: /sys/class/pktcdvd/device_map
|
||||||
|
Date: Oct. 2006
|
||||||
|
KernelVersion: 2.6.20
|
||||||
|
Contact: Thomas Maier <balagi@justmail.de>
|
||||||
|
Description:
|
||||||
|
|
||||||
|
========== ==============================================
|
||||||
|
add (WO) Write a block device id (major:minor) to
|
||||||
|
create a new pktcdvd device and map it to the
|
||||||
|
block device.
|
||||||
|
|
||||||
|
remove (WO) Write the pktcdvd device id (major:minor)
|
||||||
|
to remove the pktcdvd device.
|
||||||
|
|
||||||
|
device_map (RO) Shows the device mapping in format:
|
||||||
|
pktcdvd[0-7] <pktdevid> <blkdevid>
|
||||||
|
========== ==============================================
|
||||||
|
|
||||||
|
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/dev
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/uevent
|
||||||
|
Date: Oct. 2006
|
||||||
|
KernelVersion: 2.6.20
|
||||||
|
Contact: Thomas Maier <balagi@justmail.de>
|
||||||
|
Description:
|
||||||
|
dev: (RO) Device id
|
||||||
|
|
||||||
|
uevent: (WO) To send a uevent
|
||||||
|
|
||||||
|
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/stat/packets_started
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/stat/packets_finished
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/stat/kb_written
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/stat/kb_read
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/stat/kb_read_gather
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/stat/reset
|
||||||
|
Date: Oct. 2006
|
||||||
|
KernelVersion: 2.6.20
|
||||||
|
Contact: Thomas Maier <balagi@justmail.de>
|
||||||
|
Description:
|
||||||
|
packets_started: (RO) Number of started packets.
|
||||||
|
|
||||||
|
packets_finished: (RO) Number of finished packets.
|
||||||
|
|
||||||
|
kb_written: (RO) kBytes written.
|
||||||
|
|
||||||
|
kb_read: (RO) kBytes read.
|
||||||
|
|
||||||
|
kb_read_gather: (RO) kBytes read to fill write packets.
|
||||||
|
|
||||||
|
reset: (WO) Write any value to it to reset
|
||||||
|
pktcdvd device statistic values, like
|
||||||
|
bytes read/written.
|
||||||
|
|
||||||
|
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/write_queue/size
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/write_queue/congestion_off
|
||||||
|
What: /sys/class/pktcdvd/pktcdvd[0-7]/write_queue/congestion_on
|
||||||
|
Date: Oct. 2006
|
||||||
|
KernelVersion: 2.6.20
|
||||||
|
Contact: Thomas Maier <balagi@justmail.de>
|
||||||
|
Description:
|
||||||
|
============== ================================================
|
||||||
|
size (RO) Contains the size of the bio write queue.
|
||||||
|
|
||||||
|
congestion_off (RW) If bio write queue size is below this mark,
|
||||||
|
accept new bio requests from the block layer.
|
||||||
|
|
||||||
|
congestion_on (RW) If bio write queue size is higher as this
|
||||||
|
mark, do no longer accept bio write requests
|
||||||
|
from the block layer and wait till the pktcdvd
|
||||||
|
device has processed enough bio's so that bio
|
||||||
|
write queue size is below congestion off mark.
|
||||||
|
A value of <= 0 disables congestion control.
|
||||||
|
============== ================================================
|
||||||
|
|
||||||
|
|
||||||
|
Example:
|
||||||
|
--------
|
||||||
|
To use the pktcdvd sysfs interface directly, you can do::
|
||||||
|
|
||||||
|
# create a new pktcdvd device mapped to /dev/hdc
|
||||||
|
echo "22:0" >/sys/class/pktcdvd/add
|
||||||
|
cat /sys/class/pktcdvd/device_map
|
||||||
|
# assuming device pktcdvd0 was created, look at stat's
|
||||||
|
cat /sys/class/pktcdvd/pktcdvd0/stat/kb_written
|
||||||
|
# print the device id of the mapped block device
|
||||||
|
fgrep pktcdvd0 /sys/class/pktcdvd/device_map
|
||||||
|
# remove device, using pktcdvd0 device id 253:0
|
||||||
|
echo "253:0" >/sys/class/pktcdvd/remove
|
@ -8,7 +8,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Atmel Advanced Encryption Standard (AES) HW cryptographic accelerator
|
title: Atmel Advanced Encryption Standard (AES) HW cryptographic accelerator
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Tudor Ambarus <tudor.ambarus@microchip.com>
|
- Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
|
|
||||||
properties:
|
properties:
|
||||||
compatible:
|
compatible:
|
||||||
|
@ -8,7 +8,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Atmel Secure Hash Algorithm (SHA) HW cryptographic accelerator
|
title: Atmel Secure Hash Algorithm (SHA) HW cryptographic accelerator
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Tudor Ambarus <tudor.ambarus@microchip.com>
|
- Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
|
|
||||||
properties:
|
properties:
|
||||||
compatible:
|
compatible:
|
||||||
|
@ -8,7 +8,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Atmel Triple Data Encryption Standard (TDES) HW cryptographic accelerator
|
title: Atmel Triple Data Encryption Standard (TDES) HW cryptographic accelerator
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Tudor Ambarus <tudor.ambarus@microchip.com>
|
- Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
|
|
||||||
properties:
|
properties:
|
||||||
compatible:
|
compatible:
|
||||||
|
@ -80,7 +80,7 @@ properties:
|
|||||||
or applicable for the respective data port.
|
or applicable for the respective data port.
|
||||||
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
||||||
minItems: 3
|
minItems: 3
|
||||||
maxItems: 5
|
maxItems: 8
|
||||||
|
|
||||||
qcom,ports-sinterval-low:
|
qcom,ports-sinterval-low:
|
||||||
$ref: /schemas/types.yaml#/definitions/uint8-array
|
$ref: /schemas/types.yaml#/definitions/uint8-array
|
||||||
@ -124,7 +124,7 @@ properties:
|
|||||||
or applicable for the respective data port.
|
or applicable for the respective data port.
|
||||||
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
||||||
minItems: 3
|
minItems: 3
|
||||||
maxItems: 5
|
maxItems: 8
|
||||||
|
|
||||||
qcom,ports-block-pack-mode:
|
qcom,ports-block-pack-mode:
|
||||||
$ref: /schemas/types.yaml#/definitions/uint8-array
|
$ref: /schemas/types.yaml#/definitions/uint8-array
|
||||||
@ -154,7 +154,7 @@ properties:
|
|||||||
or applicable for the respective data port.
|
or applicable for the respective data port.
|
||||||
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
||||||
minItems: 3
|
minItems: 3
|
||||||
maxItems: 5
|
maxItems: 8
|
||||||
items:
|
items:
|
||||||
oneOf:
|
oneOf:
|
||||||
- minimum: 0
|
- minimum: 0
|
||||||
@ -171,7 +171,7 @@ properties:
|
|||||||
or applicable for the respective data port.
|
or applicable for the respective data port.
|
||||||
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
||||||
minItems: 3
|
minItems: 3
|
||||||
maxItems: 5
|
maxItems: 8
|
||||||
items:
|
items:
|
||||||
oneOf:
|
oneOf:
|
||||||
- minimum: 0
|
- minimum: 0
|
||||||
@ -187,7 +187,7 @@ properties:
|
|||||||
or applicable for the respective data port.
|
or applicable for the respective data port.
|
||||||
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
More info in MIPI Alliance SoundWire 1.0 Specifications.
|
||||||
minItems: 3
|
minItems: 3
|
||||||
maxItems: 5
|
maxItems: 8
|
||||||
items:
|
items:
|
||||||
oneOf:
|
oneOf:
|
||||||
- minimum: 0
|
- minimum: 0
|
||||||
|
@ -8,7 +8,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Atmel SPI device
|
title: Atmel SPI device
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Tudor Ambarus <tudor.ambarus@microchip.com>
|
- Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
|
|
||||||
allOf:
|
allOf:
|
||||||
- $ref: spi-controller.yaml#
|
- $ref: spi-controller.yaml#
|
||||||
|
@ -7,7 +7,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml#
|
|||||||
title: Atmel Quad Serial Peripheral Interface (QSPI)
|
title: Atmel Quad Serial Peripheral Interface (QSPI)
|
||||||
|
|
||||||
maintainers:
|
maintainers:
|
||||||
- Tudor Ambarus <tudor.ambarus@microchip.com>
|
- Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
|
|
||||||
allOf:
|
allOf:
|
||||||
- $ref: spi-controller.yaml#
|
- $ref: spi-controller.yaml#
|
||||||
|
@ -44,9 +44,9 @@ properties:
|
|||||||
description:
|
description:
|
||||||
Maximum SPI clocking speed of the device in Hz.
|
Maximum SPI clocking speed of the device in Hz.
|
||||||
|
|
||||||
spi-cs-setup-ns:
|
spi-cs-setup-delay-ns:
|
||||||
description:
|
description:
|
||||||
Delay in nanosecods to be introduced by the controller after CS is
|
Delay in nanoseconds to be introduced by the controller after CS is
|
||||||
asserted.
|
asserted.
|
||||||
|
|
||||||
spi-rx-bus-width:
|
spi-rx-bus-width:
|
||||||
|
@ -880,8 +880,8 @@ The kernel interface functions are as follows:
|
|||||||
|
|
||||||
notify_end_rx can be NULL or it can be used to specify a function to be
|
notify_end_rx can be NULL or it can be used to specify a function to be
|
||||||
called when the call changes state to end the Tx phase. This function is
|
called when the call changes state to end the Tx phase. This function is
|
||||||
called with the call-state spinlock held to prevent any reply or final ACK
|
called with a spinlock held to prevent the last DATA packet from being
|
||||||
from being delivered first.
|
transmitted until the function returns.
|
||||||
|
|
||||||
(#) Receive data from a call::
|
(#) Receive data from a call::
|
||||||
|
|
||||||
|
17
MAINTAINERS
17
MAINTAINERS
@ -13620,7 +13620,7 @@ F: arch/microblaze/
|
|||||||
|
|
||||||
MICROCHIP AT91 DMA DRIVERS
|
MICROCHIP AT91 DMA DRIVERS
|
||||||
M: Ludovic Desroches <ludovic.desroches@microchip.com>
|
M: Ludovic Desroches <ludovic.desroches@microchip.com>
|
||||||
M: Tudor Ambarus <tudor.ambarus@microchip.com>
|
M: Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
L: dmaengine@vger.kernel.org
|
L: dmaengine@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -13665,7 +13665,7 @@ F: Documentation/devicetree/bindings/media/microchip,csi2dc.yaml
|
|||||||
F: drivers/media/platform/microchip/microchip-csi2dc.c
|
F: drivers/media/platform/microchip/microchip-csi2dc.c
|
||||||
|
|
||||||
MICROCHIP ECC DRIVER
|
MICROCHIP ECC DRIVER
|
||||||
M: Tudor Ambarus <tudor.ambarus@microchip.com>
|
M: Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
L: linux-crypto@vger.kernel.org
|
L: linux-crypto@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/crypto/atmel-ecc.*
|
F: drivers/crypto/atmel-ecc.*
|
||||||
@ -13762,7 +13762,7 @@ S: Maintained
|
|||||||
F: drivers/mmc/host/atmel-mci.c
|
F: drivers/mmc/host/atmel-mci.c
|
||||||
|
|
||||||
MICROCHIP NAND DRIVER
|
MICROCHIP NAND DRIVER
|
||||||
M: Tudor Ambarus <tudor.ambarus@microchip.com>
|
M: Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
L: linux-mtd@lists.infradead.org
|
L: linux-mtd@lists.infradead.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/devicetree/bindings/mtd/atmel-nand.txt
|
F: Documentation/devicetree/bindings/mtd/atmel-nand.txt
|
||||||
@ -13814,7 +13814,7 @@ S: Supported
|
|||||||
F: drivers/power/reset/at91-sama5d2_shdwc.c
|
F: drivers/power/reset/at91-sama5d2_shdwc.c
|
||||||
|
|
||||||
MICROCHIP SPI DRIVER
|
MICROCHIP SPI DRIVER
|
||||||
M: Tudor Ambarus <tudor.ambarus@microchip.com>
|
M: Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
S: Supported
|
S: Supported
|
||||||
F: drivers/spi/spi-atmel.*
|
F: drivers/spi/spi-atmel.*
|
||||||
|
|
||||||
@ -16617,6 +16617,13 @@ S: Supported
|
|||||||
F: Documentation/devicetree/bindings/input/pine64,pinephone-keyboard.yaml
|
F: Documentation/devicetree/bindings/input/pine64,pinephone-keyboard.yaml
|
||||||
F: drivers/input/keyboard/pinephone-keyboard.c
|
F: drivers/input/keyboard/pinephone-keyboard.c
|
||||||
|
|
||||||
|
PKTCDVD DRIVER
|
||||||
|
M: linux-block@vger.kernel.org
|
||||||
|
S: Orphan
|
||||||
|
F: drivers/block/pktcdvd.c
|
||||||
|
F: include/linux/pktcdvd.h
|
||||||
|
F: include/uapi/linux/pktcdvd.h
|
||||||
|
|
||||||
PLANTOWER PMS7003 AIR POLLUTION SENSOR DRIVER
|
PLANTOWER PMS7003 AIR POLLUTION SENSOR DRIVER
|
||||||
M: Tomasz Duszynski <tduszyns@gmail.com>
|
M: Tomasz Duszynski <tduszyns@gmail.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
@ -19679,7 +19686,7 @@ F: drivers/clk/spear/
|
|||||||
F: drivers/pinctrl/spear/
|
F: drivers/pinctrl/spear/
|
||||||
|
|
||||||
SPI NOR SUBSYSTEM
|
SPI NOR SUBSYSTEM
|
||||||
M: Tudor Ambarus <tudor.ambarus@microchip.com>
|
M: Tudor Ambarus <tudor.ambarus@linaro.org>
|
||||||
M: Pratyush Yadav <pratyush@kernel.org>
|
M: Pratyush Yadav <pratyush@kernel.org>
|
||||||
R: Michael Walle <michael@walle.cc>
|
R: Michael Walle <michael@walle.cc>
|
||||||
L: linux-mtd@lists.infradead.org
|
L: linux-mtd@lists.infradead.org
|
||||||
|
4
Makefile
4
Makefile
@ -2,7 +2,7 @@
|
|||||||
VERSION = 6
|
VERSION = 6
|
||||||
PATCHLEVEL = 2
|
PATCHLEVEL = 2
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc2
|
EXTRAVERSION = -rc3
|
||||||
NAME = Hurr durr I'ma ninja sloth
|
NAME = Hurr durr I'ma ninja sloth
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
@ -1986,7 +1986,7 @@ $(single-no-ko): $(build-dir)
|
|||||||
# Remove MODORDER when done because it is not the real one.
|
# Remove MODORDER when done because it is not the real one.
|
||||||
PHONY += single_modules
|
PHONY += single_modules
|
||||||
single_modules: $(single-no-ko) modules_prepare
|
single_modules: $(single-no-ko) modules_prepare
|
||||||
$(Q){ $(foreach m, $(single-ko), echo $(extmod_prefix)$m;) } > $(MODORDER)
|
$(Q){ $(foreach m, $(single-ko), echo $(extmod_prefix)$(m:%.ko=%.o);) } > $(MODORDER)
|
||||||
$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
|
$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
|
||||||
ifneq ($(KBUILD_MODPOST_NOFINAL),1)
|
ifneq ($(KBUILD_MODPOST_NOFINAL),1)
|
||||||
$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modfinal
|
$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modfinal
|
||||||
|
@ -128,15 +128,16 @@ extern int vfp_restore_user_hwstate(struct user_vfp *,
|
|||||||
#define TIF_NEED_RESCHED 1 /* rescheduling necessary */
|
#define TIF_NEED_RESCHED 1 /* rescheduling necessary */
|
||||||
#define TIF_NOTIFY_RESUME 2 /* callback before returning to user */
|
#define TIF_NOTIFY_RESUME 2 /* callback before returning to user */
|
||||||
#define TIF_UPROBE 3 /* breakpointed or singlestepping */
|
#define TIF_UPROBE 3 /* breakpointed or singlestepping */
|
||||||
#define TIF_SYSCALL_TRACE 4 /* syscall trace active */
|
#define TIF_NOTIFY_SIGNAL 4 /* signal notifications exist */
|
||||||
#define TIF_SYSCALL_AUDIT 5 /* syscall auditing active */
|
|
||||||
#define TIF_SYSCALL_TRACEPOINT 6 /* syscall tracepoint instrumentation */
|
|
||||||
#define TIF_SECCOMP 7 /* seccomp syscall filtering active */
|
|
||||||
#define TIF_NOTIFY_SIGNAL 8 /* signal notifications exist */
|
|
||||||
|
|
||||||
#define TIF_USING_IWMMXT 17
|
#define TIF_USING_IWMMXT 17
|
||||||
#define TIF_MEMDIE 18 /* is terminating due to OOM killer */
|
#define TIF_MEMDIE 18 /* is terminating due to OOM killer */
|
||||||
#define TIF_RESTORE_SIGMASK 20
|
#define TIF_RESTORE_SIGMASK 19
|
||||||
|
#define TIF_SYSCALL_TRACE 20 /* syscall trace active */
|
||||||
|
#define TIF_SYSCALL_AUDIT 21 /* syscall auditing active */
|
||||||
|
#define TIF_SYSCALL_TRACEPOINT 22 /* syscall tracepoint instrumentation */
|
||||||
|
#define TIF_SECCOMP 23 /* seccomp syscall filtering active */
|
||||||
|
|
||||||
|
|
||||||
#define _TIF_SIGPENDING (1 << TIF_SIGPENDING)
|
#define _TIF_SIGPENDING (1 << TIF_SIGPENDING)
|
||||||
#define _TIF_NEED_RESCHED (1 << TIF_NEED_RESCHED)
|
#define _TIF_NEED_RESCHED (1 << TIF_NEED_RESCHED)
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/linkage.h>
|
#include <linux/linkage.h>
|
||||||
|
#include <linux/cfi_types.h>
|
||||||
#include <asm/assembler.h>
|
#include <asm/assembler.h>
|
||||||
#include "sm4-ce-asm.h"
|
#include "sm4-ce-asm.h"
|
||||||
|
|
||||||
@ -104,7 +105,7 @@ SYM_FUNC_START(sm4_ce_ccm_final)
|
|||||||
SYM_FUNC_END(sm4_ce_ccm_final)
|
SYM_FUNC_END(sm4_ce_ccm_final)
|
||||||
|
|
||||||
.align 3
|
.align 3
|
||||||
SYM_FUNC_START(sm4_ce_ccm_enc)
|
SYM_TYPED_FUNC_START(sm4_ce_ccm_enc)
|
||||||
/* input:
|
/* input:
|
||||||
* x0: round key array, CTX
|
* x0: round key array, CTX
|
||||||
* x1: dst
|
* x1: dst
|
||||||
@ -216,7 +217,7 @@ SYM_FUNC_START(sm4_ce_ccm_enc)
|
|||||||
SYM_FUNC_END(sm4_ce_ccm_enc)
|
SYM_FUNC_END(sm4_ce_ccm_enc)
|
||||||
|
|
||||||
.align 3
|
.align 3
|
||||||
SYM_FUNC_START(sm4_ce_ccm_dec)
|
SYM_TYPED_FUNC_START(sm4_ce_ccm_dec)
|
||||||
/* input:
|
/* input:
|
||||||
* x0: round key array, CTX
|
* x0: round key array, CTX
|
||||||
* x1: dst
|
* x1: dst
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/linkage.h>
|
#include <linux/linkage.h>
|
||||||
|
#include <linux/cfi_types.h>
|
||||||
#include <asm/assembler.h>
|
#include <asm/assembler.h>
|
||||||
#include "sm4-ce-asm.h"
|
#include "sm4-ce-asm.h"
|
||||||
|
|
||||||
@ -370,7 +371,7 @@ SYM_FUNC_START(pmull_ghash_update)
|
|||||||
SYM_FUNC_END(pmull_ghash_update)
|
SYM_FUNC_END(pmull_ghash_update)
|
||||||
|
|
||||||
.align 3
|
.align 3
|
||||||
SYM_FUNC_START(sm4_ce_pmull_gcm_enc)
|
SYM_TYPED_FUNC_START(sm4_ce_pmull_gcm_enc)
|
||||||
/* input:
|
/* input:
|
||||||
* x0: round key array, CTX
|
* x0: round key array, CTX
|
||||||
* x1: dst
|
* x1: dst
|
||||||
@ -581,7 +582,7 @@ SYM_FUNC_END(sm4_ce_pmull_gcm_enc)
|
|||||||
#define RH3 v20
|
#define RH3 v20
|
||||||
|
|
||||||
.align 3
|
.align 3
|
||||||
SYM_FUNC_START(sm4_ce_pmull_gcm_dec)
|
SYM_TYPED_FUNC_START(sm4_ce_pmull_gcm_dec)
|
||||||
/* input:
|
/* input:
|
||||||
* x0: round key array, CTX
|
* x0: round key array, CTX
|
||||||
* x1: dst
|
* x1: dst
|
||||||
|
@ -64,7 +64,7 @@ void __init plat_mem_setup(void)
|
|||||||
dtb = get_fdt();
|
dtb = get_fdt();
|
||||||
__dt_setup_arch(dtb);
|
__dt_setup_arch(dtb);
|
||||||
|
|
||||||
if (!early_init_dt_scan_memory())
|
if (early_init_dt_scan_memory())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (soc_info.mem_detect)
|
if (soc_info.mem_detect)
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#define BSS_FIRST_SECTIONS *(.bss.prominit)
|
#define BSS_FIRST_SECTIONS *(.bss.prominit)
|
||||||
#define EMITS_PT_NOTE
|
#define EMITS_PT_NOTE
|
||||||
#define RO_EXCEPTION_TABLE_ALIGN 0
|
#define RO_EXCEPTION_TABLE_ALIGN 0
|
||||||
|
#define RUNTIME_DISCARD_EXIT
|
||||||
|
|
||||||
#define SOFT_MASK_TABLE(align) \
|
#define SOFT_MASK_TABLE(align) \
|
||||||
. = ALIGN(align); \
|
. = ALIGN(align); \
|
||||||
@ -410,9 +411,12 @@ SECTIONS
|
|||||||
DISCARDS
|
DISCARDS
|
||||||
/DISCARD/ : {
|
/DISCARD/ : {
|
||||||
*(*.EMB.apuinfo)
|
*(*.EMB.apuinfo)
|
||||||
*(.glink .iplt .plt .rela* .comment)
|
*(.glink .iplt .plt)
|
||||||
*(.gnu.version*)
|
*(.gnu.version*)
|
||||||
*(.gnu.attributes)
|
*(.gnu.attributes)
|
||||||
*(.eh_frame)
|
*(.eh_frame)
|
||||||
|
#ifndef CONFIG_RELOCATABLE
|
||||||
|
*(.rela*)
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -165,7 +165,7 @@ do { \
|
|||||||
might_fault(); \
|
might_fault(); \
|
||||||
access_ok(__p, sizeof(*__p)) ? \
|
access_ok(__p, sizeof(*__p)) ? \
|
||||||
__get_user((x), __p) : \
|
__get_user((x), __p) : \
|
||||||
((x) = 0, -EFAULT); \
|
((x) = (__force __typeof__(x))0, -EFAULT); \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define __put_user_asm(insn, x, ptr, err) \
|
#define __put_user_asm(insn, x, ptr, err) \
|
||||||
|
@ -31,9 +31,9 @@ __RISCV_INSN_FUNCS(fence, 0x7f, 0x0f);
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
__RISCV_INSN_FUNCS(c_j, 0xe003, 0xa001);
|
__RISCV_INSN_FUNCS(c_j, 0xe003, 0xa001);
|
||||||
__RISCV_INSN_FUNCS(c_jr, 0xf007, 0x8002);
|
__RISCV_INSN_FUNCS(c_jr, 0xf07f, 0x8002);
|
||||||
__RISCV_INSN_FUNCS(c_jal, 0xe003, 0x2001);
|
__RISCV_INSN_FUNCS(c_jal, 0xe003, 0x2001);
|
||||||
__RISCV_INSN_FUNCS(c_jalr, 0xf007, 0x9002);
|
__RISCV_INSN_FUNCS(c_jalr, 0xf07f, 0x9002);
|
||||||
__RISCV_INSN_FUNCS(c_beqz, 0xe003, 0xc001);
|
__RISCV_INSN_FUNCS(c_beqz, 0xe003, 0xc001);
|
||||||
__RISCV_INSN_FUNCS(c_bnez, 0xe003, 0xe001);
|
__RISCV_INSN_FUNCS(c_bnez, 0xe003, 0xe001);
|
||||||
__RISCV_INSN_FUNCS(c_ebreak, 0xffff, 0x9002);
|
__RISCV_INSN_FUNCS(c_ebreak, 0xffff, 0x9002);
|
||||||
|
@ -23,9 +23,9 @@
|
|||||||
#define memmove memmove
|
#define memmove memmove
|
||||||
#define memzero(s, n) memset((s), 0, (n))
|
#define memzero(s, n) memset((s), 0, (n))
|
||||||
|
|
||||||
#ifdef CONFIG_KERNEL_BZIP2
|
#if defined(CONFIG_KERNEL_BZIP2)
|
||||||
#define BOOT_HEAP_SIZE 0x400000
|
#define BOOT_HEAP_SIZE 0x400000
|
||||||
#elif CONFIG_KERNEL_ZSTD
|
#elif defined(CONFIG_KERNEL_ZSTD)
|
||||||
#define BOOT_HEAP_SIZE 0x30000
|
#define BOOT_HEAP_SIZE 0x30000
|
||||||
#else
|
#else
|
||||||
#define BOOT_HEAP_SIZE 0x10000
|
#define BOOT_HEAP_SIZE 0x10000
|
||||||
|
@ -190,7 +190,6 @@ CONFIG_NFT_CT=m
|
|||||||
CONFIG_NFT_LOG=m
|
CONFIG_NFT_LOG=m
|
||||||
CONFIG_NFT_LIMIT=m
|
CONFIG_NFT_LIMIT=m
|
||||||
CONFIG_NFT_NAT=m
|
CONFIG_NFT_NAT=m
|
||||||
CONFIG_NFT_OBJREF=m
|
|
||||||
CONFIG_NFT_REJECT=m
|
CONFIG_NFT_REJECT=m
|
||||||
CONFIG_NFT_COMPAT=m
|
CONFIG_NFT_COMPAT=m
|
||||||
CONFIG_NFT_HASH=m
|
CONFIG_NFT_HASH=m
|
||||||
@ -569,6 +568,7 @@ CONFIG_INPUT_EVDEV=y
|
|||||||
# CONFIG_INPUT_MOUSE is not set
|
# CONFIG_INPUT_MOUSE is not set
|
||||||
# CONFIG_SERIO is not set
|
# CONFIG_SERIO is not set
|
||||||
CONFIG_LEGACY_PTY_COUNT=0
|
CONFIG_LEGACY_PTY_COUNT=0
|
||||||
|
# CONFIG_LEGACY_TIOCSTI is not set
|
||||||
CONFIG_VIRTIO_CONSOLE=m
|
CONFIG_VIRTIO_CONSOLE=m
|
||||||
CONFIG_HW_RANDOM_VIRTIO=m
|
CONFIG_HW_RANDOM_VIRTIO=m
|
||||||
CONFIG_HANGCHECK_TIMER=m
|
CONFIG_HANGCHECK_TIMER=m
|
||||||
@ -660,6 +660,7 @@ CONFIG_CONFIGFS_FS=m
|
|||||||
CONFIG_ECRYPT_FS=m
|
CONFIG_ECRYPT_FS=m
|
||||||
CONFIG_CRAMFS=m
|
CONFIG_CRAMFS=m
|
||||||
CONFIG_SQUASHFS=m
|
CONFIG_SQUASHFS=m
|
||||||
|
CONFIG_SQUASHFS_CHOICE_DECOMP_BY_MOUNT=y
|
||||||
CONFIG_SQUASHFS_XATTR=y
|
CONFIG_SQUASHFS_XATTR=y
|
||||||
CONFIG_SQUASHFS_LZ4=y
|
CONFIG_SQUASHFS_LZ4=y
|
||||||
CONFIG_SQUASHFS_LZO=y
|
CONFIG_SQUASHFS_LZO=y
|
||||||
@ -705,6 +706,7 @@ CONFIG_SECURITY_LOCKDOWN_LSM_EARLY=y
|
|||||||
CONFIG_SECURITY_LANDLOCK=y
|
CONFIG_SECURITY_LANDLOCK=y
|
||||||
CONFIG_INTEGRITY_SIGNATURE=y
|
CONFIG_INTEGRITY_SIGNATURE=y
|
||||||
CONFIG_INTEGRITY_ASYMMETRIC_KEYS=y
|
CONFIG_INTEGRITY_ASYMMETRIC_KEYS=y
|
||||||
|
CONFIG_INTEGRITY_PLATFORM_KEYRING=y
|
||||||
CONFIG_IMA=y
|
CONFIG_IMA=y
|
||||||
CONFIG_IMA_DEFAULT_HASH_SHA256=y
|
CONFIG_IMA_DEFAULT_HASH_SHA256=y
|
||||||
CONFIG_IMA_WRITE_POLICY=y
|
CONFIG_IMA_WRITE_POLICY=y
|
||||||
@ -781,6 +783,7 @@ CONFIG_ZCRYPT=m
|
|||||||
CONFIG_PKEY=m
|
CONFIG_PKEY=m
|
||||||
CONFIG_CRYPTO_PAES_S390=m
|
CONFIG_CRYPTO_PAES_S390=m
|
||||||
CONFIG_CRYPTO_DEV_VIRTIO=m
|
CONFIG_CRYPTO_DEV_VIRTIO=m
|
||||||
|
CONFIG_SYSTEM_BLACKLIST_KEYRING=y
|
||||||
CONFIG_CORDIC=m
|
CONFIG_CORDIC=m
|
||||||
CONFIG_CRYPTO_LIB_CURVE25519=m
|
CONFIG_CRYPTO_LIB_CURVE25519=m
|
||||||
CONFIG_CRYPTO_LIB_CHACHA20POLY1305=m
|
CONFIG_CRYPTO_LIB_CHACHA20POLY1305=m
|
||||||
@ -848,7 +851,6 @@ CONFIG_PREEMPT_TRACER=y
|
|||||||
CONFIG_SCHED_TRACER=y
|
CONFIG_SCHED_TRACER=y
|
||||||
CONFIG_FTRACE_SYSCALLS=y
|
CONFIG_FTRACE_SYSCALLS=y
|
||||||
CONFIG_BLK_DEV_IO_TRACE=y
|
CONFIG_BLK_DEV_IO_TRACE=y
|
||||||
CONFIG_BPF_KPROBE_OVERRIDE=y
|
|
||||||
CONFIG_HIST_TRIGGERS=y
|
CONFIG_HIST_TRIGGERS=y
|
||||||
CONFIG_FTRACE_STARTUP_TEST=y
|
CONFIG_FTRACE_STARTUP_TEST=y
|
||||||
# CONFIG_EVENT_TRACE_STARTUP_TEST is not set
|
# CONFIG_EVENT_TRACE_STARTUP_TEST is not set
|
||||||
@ -870,7 +872,6 @@ CONFIG_FAIL_MAKE_REQUEST=y
|
|||||||
CONFIG_FAIL_IO_TIMEOUT=y
|
CONFIG_FAIL_IO_TIMEOUT=y
|
||||||
CONFIG_FAIL_FUTEX=y
|
CONFIG_FAIL_FUTEX=y
|
||||||
CONFIG_FAULT_INJECTION_DEBUG_FS=y
|
CONFIG_FAULT_INJECTION_DEBUG_FS=y
|
||||||
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
|
||||||
|
@ -181,7 +181,6 @@ CONFIG_NFT_CT=m
|
|||||||
CONFIG_NFT_LOG=m
|
CONFIG_NFT_LOG=m
|
||||||
CONFIG_NFT_LIMIT=m
|
CONFIG_NFT_LIMIT=m
|
||||||
CONFIG_NFT_NAT=m
|
CONFIG_NFT_NAT=m
|
||||||
CONFIG_NFT_OBJREF=m
|
|
||||||
CONFIG_NFT_REJECT=m
|
CONFIG_NFT_REJECT=m
|
||||||
CONFIG_NFT_COMPAT=m
|
CONFIG_NFT_COMPAT=m
|
||||||
CONFIG_NFT_HASH=m
|
CONFIG_NFT_HASH=m
|
||||||
@ -559,6 +558,7 @@ CONFIG_INPUT_EVDEV=y
|
|||||||
# CONFIG_INPUT_MOUSE is not set
|
# CONFIG_INPUT_MOUSE is not set
|
||||||
# CONFIG_SERIO is not set
|
# CONFIG_SERIO is not set
|
||||||
CONFIG_LEGACY_PTY_COUNT=0
|
CONFIG_LEGACY_PTY_COUNT=0
|
||||||
|
# CONFIG_LEGACY_TIOCSTI is not set
|
||||||
CONFIG_VIRTIO_CONSOLE=m
|
CONFIG_VIRTIO_CONSOLE=m
|
||||||
CONFIG_HW_RANDOM_VIRTIO=m
|
CONFIG_HW_RANDOM_VIRTIO=m
|
||||||
CONFIG_HANGCHECK_TIMER=m
|
CONFIG_HANGCHECK_TIMER=m
|
||||||
@ -645,6 +645,7 @@ CONFIG_CONFIGFS_FS=m
|
|||||||
CONFIG_ECRYPT_FS=m
|
CONFIG_ECRYPT_FS=m
|
||||||
CONFIG_CRAMFS=m
|
CONFIG_CRAMFS=m
|
||||||
CONFIG_SQUASHFS=m
|
CONFIG_SQUASHFS=m
|
||||||
|
CONFIG_SQUASHFS_CHOICE_DECOMP_BY_MOUNT=y
|
||||||
CONFIG_SQUASHFS_XATTR=y
|
CONFIG_SQUASHFS_XATTR=y
|
||||||
CONFIG_SQUASHFS_LZ4=y
|
CONFIG_SQUASHFS_LZ4=y
|
||||||
CONFIG_SQUASHFS_LZO=y
|
CONFIG_SQUASHFS_LZO=y
|
||||||
@ -688,6 +689,7 @@ CONFIG_SECURITY_LOCKDOWN_LSM_EARLY=y
|
|||||||
CONFIG_SECURITY_LANDLOCK=y
|
CONFIG_SECURITY_LANDLOCK=y
|
||||||
CONFIG_INTEGRITY_SIGNATURE=y
|
CONFIG_INTEGRITY_SIGNATURE=y
|
||||||
CONFIG_INTEGRITY_ASYMMETRIC_KEYS=y
|
CONFIG_INTEGRITY_ASYMMETRIC_KEYS=y
|
||||||
|
CONFIG_INTEGRITY_PLATFORM_KEYRING=y
|
||||||
CONFIG_IMA=y
|
CONFIG_IMA=y
|
||||||
CONFIG_IMA_DEFAULT_HASH_SHA256=y
|
CONFIG_IMA_DEFAULT_HASH_SHA256=y
|
||||||
CONFIG_IMA_WRITE_POLICY=y
|
CONFIG_IMA_WRITE_POLICY=y
|
||||||
@ -766,6 +768,7 @@ CONFIG_ZCRYPT=m
|
|||||||
CONFIG_PKEY=m
|
CONFIG_PKEY=m
|
||||||
CONFIG_CRYPTO_PAES_S390=m
|
CONFIG_CRYPTO_PAES_S390=m
|
||||||
CONFIG_CRYPTO_DEV_VIRTIO=m
|
CONFIG_CRYPTO_DEV_VIRTIO=m
|
||||||
|
CONFIG_SYSTEM_BLACKLIST_KEYRING=y
|
||||||
CONFIG_CORDIC=m
|
CONFIG_CORDIC=m
|
||||||
CONFIG_PRIME_NUMBERS=m
|
CONFIG_PRIME_NUMBERS=m
|
||||||
CONFIG_CRYPTO_LIB_CURVE25519=m
|
CONFIG_CRYPTO_LIB_CURVE25519=m
|
||||||
@ -798,7 +801,6 @@ CONFIG_STACK_TRACER=y
|
|||||||
CONFIG_SCHED_TRACER=y
|
CONFIG_SCHED_TRACER=y
|
||||||
CONFIG_FTRACE_SYSCALLS=y
|
CONFIG_FTRACE_SYSCALLS=y
|
||||||
CONFIG_BLK_DEV_IO_TRACE=y
|
CONFIG_BLK_DEV_IO_TRACE=y
|
||||||
CONFIG_BPF_KPROBE_OVERRIDE=y
|
|
||||||
CONFIG_HIST_TRIGGERS=y
|
CONFIG_HIST_TRIGGERS=y
|
||||||
CONFIG_SAMPLES=y
|
CONFIG_SAMPLES=y
|
||||||
CONFIG_SAMPLE_TRACE_PRINTK=m
|
CONFIG_SAMPLE_TRACE_PRINTK=m
|
||||||
|
@ -13,7 +13,6 @@ CONFIG_TUNE_ZEC12=y
|
|||||||
# CONFIG_COMPAT is not set
|
# CONFIG_COMPAT is not set
|
||||||
CONFIG_NR_CPUS=2
|
CONFIG_NR_CPUS=2
|
||||||
CONFIG_HZ_100=y
|
CONFIG_HZ_100=y
|
||||||
# CONFIG_RELOCATABLE is not set
|
|
||||||
# CONFIG_CHSC_SCH is not set
|
# CONFIG_CHSC_SCH is not set
|
||||||
# CONFIG_SCM_BUS is not set
|
# CONFIG_SCM_BUS is not set
|
||||||
CONFIG_CRASH_DUMP=y
|
CONFIG_CRASH_DUMP=y
|
||||||
@ -50,6 +49,7 @@ CONFIG_ZFCP=y
|
|||||||
# CONFIG_INPUT_KEYBOARD is not set
|
# CONFIG_INPUT_KEYBOARD is not set
|
||||||
# CONFIG_INPUT_MOUSE is not set
|
# CONFIG_INPUT_MOUSE is not set
|
||||||
# CONFIG_SERIO is not set
|
# CONFIG_SERIO is not set
|
||||||
|
# CONFIG_LEGACY_TIOCSTI is not set
|
||||||
# CONFIG_HVC_IUCV is not set
|
# CONFIG_HVC_IUCV is not set
|
||||||
# CONFIG_HW_RANDOM_S390 is not set
|
# CONFIG_HW_RANDOM_S390 is not set
|
||||||
# CONFIG_HMC_DRV is not set
|
# CONFIG_HMC_DRV is not set
|
||||||
|
@ -131,19 +131,21 @@ struct hws_combined_entry {
|
|||||||
struct hws_diag_entry diag; /* Diagnostic-sampling data entry */
|
struct hws_diag_entry diag; /* Diagnostic-sampling data entry */
|
||||||
} __packed;
|
} __packed;
|
||||||
|
|
||||||
struct hws_trailer_entry {
|
union hws_trailer_header {
|
||||||
union {
|
struct {
|
||||||
struct {
|
unsigned int f:1; /* 0 - Block Full Indicator */
|
||||||
unsigned int f:1; /* 0 - Block Full Indicator */
|
unsigned int a:1; /* 1 - Alert request control */
|
||||||
unsigned int a:1; /* 1 - Alert request control */
|
unsigned int t:1; /* 2 - Timestamp format */
|
||||||
unsigned int t:1; /* 2 - Timestamp format */
|
unsigned int :29; /* 3 - 31: Reserved */
|
||||||
unsigned int :29; /* 3 - 31: Reserved */
|
unsigned int bsdes:16; /* 32-47: size of basic SDE */
|
||||||
unsigned int bsdes:16; /* 32-47: size of basic SDE */
|
unsigned int dsdes:16; /* 48-63: size of diagnostic SDE */
|
||||||
unsigned int dsdes:16; /* 48-63: size of diagnostic SDE */
|
unsigned long long overflow; /* 64 - Overflow Count */
|
||||||
};
|
|
||||||
unsigned long long flags; /* 0 - 63: All indicators */
|
|
||||||
};
|
};
|
||||||
unsigned long long overflow; /* 64 - sample Overflow count */
|
__uint128_t val;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct hws_trailer_entry {
|
||||||
|
union hws_trailer_header header; /* 0 - 15 Flags + Overflow Count */
|
||||||
unsigned char timestamp[16]; /* 16 - 31 timestamp */
|
unsigned char timestamp[16]; /* 16 - 31 timestamp */
|
||||||
unsigned long long reserved1; /* 32 -Reserved */
|
unsigned long long reserved1; /* 32 -Reserved */
|
||||||
unsigned long long reserved2; /* */
|
unsigned long long reserved2; /* */
|
||||||
@ -290,14 +292,11 @@ static inline unsigned long sample_rate_to_freq(struct hws_qsi_info_block *qsi,
|
|||||||
return USEC_PER_SEC * qsi->cpu_speed / rate;
|
return USEC_PER_SEC * qsi->cpu_speed / rate;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SDB_TE_ALERT_REQ_MASK 0x4000000000000000UL
|
|
||||||
#define SDB_TE_BUFFER_FULL_MASK 0x8000000000000000UL
|
|
||||||
|
|
||||||
/* Return TOD timestamp contained in an trailer entry */
|
/* Return TOD timestamp contained in an trailer entry */
|
||||||
static inline unsigned long long trailer_timestamp(struct hws_trailer_entry *te)
|
static inline unsigned long long trailer_timestamp(struct hws_trailer_entry *te)
|
||||||
{
|
{
|
||||||
/* TOD in STCKE format */
|
/* TOD in STCKE format */
|
||||||
if (te->t)
|
if (te->header.t)
|
||||||
return *((unsigned long long *) &te->timestamp[1]);
|
return *((unsigned long long *) &te->timestamp[1]);
|
||||||
|
|
||||||
/* TOD in STCK format */
|
/* TOD in STCK format */
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
*
|
*
|
||||||
* Copyright IBM Corp. 1999, 2020
|
* Copyright IBM Corp. 1999, 2020
|
||||||
*/
|
*/
|
||||||
#ifndef DEBUG_H
|
#ifndef _ASM_S390_DEBUG_H
|
||||||
#define DEBUG_H
|
#define _ASM_S390_DEBUG_H
|
||||||
|
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/spinlock.h>
|
#include <linux/spinlock.h>
|
||||||
@ -487,4 +487,4 @@ void debug_register_static(debug_info_t *id, int pages_per_area, int nr_areas);
|
|||||||
|
|
||||||
#endif /* MODULE */
|
#endif /* MODULE */
|
||||||
|
|
||||||
#endif /* DEBUG_H */
|
#endif /* _ASM_S390_DEBUG_H */
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
pcp_op_T__ *ptr__; \
|
pcp_op_T__ *ptr__; \
|
||||||
preempt_disable_notrace(); \
|
preempt_disable_notrace(); \
|
||||||
ptr__ = raw_cpu_ptr(&(pcp)); \
|
ptr__ = raw_cpu_ptr(&(pcp)); \
|
||||||
prev__ = *ptr__; \
|
prev__ = READ_ONCE(*ptr__); \
|
||||||
do { \
|
do { \
|
||||||
old__ = prev__; \
|
old__ = prev__; \
|
||||||
new__ = old__ op (val); \
|
new__ = old__ op (val); \
|
||||||
|
@ -187,8 +187,6 @@ static int kexec_file_add_ipl_report(struct kimage *image,
|
|||||||
|
|
||||||
data->memsz = ALIGN(data->memsz, PAGE_SIZE);
|
data->memsz = ALIGN(data->memsz, PAGE_SIZE);
|
||||||
buf.mem = data->memsz;
|
buf.mem = data->memsz;
|
||||||
if (image->type == KEXEC_TYPE_CRASH)
|
|
||||||
buf.mem += crashk_res.start;
|
|
||||||
|
|
||||||
ptr = (void *)ipl_cert_list_addr;
|
ptr = (void *)ipl_cert_list_addr;
|
||||||
end = ptr + ipl_cert_list_size;
|
end = ptr + ipl_cert_list_size;
|
||||||
@ -225,6 +223,9 @@ static int kexec_file_add_ipl_report(struct kimage *image,
|
|||||||
data->kernel_buf + offsetof(struct lowcore, ipl_parmblock_ptr);
|
data->kernel_buf + offsetof(struct lowcore, ipl_parmblock_ptr);
|
||||||
*lc_ipl_parmblock_ptr = (__u32)buf.mem;
|
*lc_ipl_parmblock_ptr = (__u32)buf.mem;
|
||||||
|
|
||||||
|
if (image->type == KEXEC_TYPE_CRASH)
|
||||||
|
buf.mem += crashk_res.start;
|
||||||
|
|
||||||
ret = kexec_add_buffer(&buf);
|
ret = kexec_add_buffer(&buf);
|
||||||
out:
|
out:
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -163,14 +163,15 @@ static void free_sampling_buffer(struct sf_buffer *sfb)
|
|||||||
|
|
||||||
static int alloc_sample_data_block(unsigned long *sdbt, gfp_t gfp_flags)
|
static int alloc_sample_data_block(unsigned long *sdbt, gfp_t gfp_flags)
|
||||||
{
|
{
|
||||||
unsigned long sdb, *trailer;
|
struct hws_trailer_entry *te;
|
||||||
|
unsigned long sdb;
|
||||||
|
|
||||||
/* Allocate and initialize sample-data-block */
|
/* Allocate and initialize sample-data-block */
|
||||||
sdb = get_zeroed_page(gfp_flags);
|
sdb = get_zeroed_page(gfp_flags);
|
||||||
if (!sdb)
|
if (!sdb)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
trailer = trailer_entry_ptr(sdb);
|
te = (struct hws_trailer_entry *)trailer_entry_ptr(sdb);
|
||||||
*trailer = SDB_TE_ALERT_REQ_MASK;
|
te->header.a = 1;
|
||||||
|
|
||||||
/* Link SDB into the sample-data-block-table */
|
/* Link SDB into the sample-data-block-table */
|
||||||
*sdbt = sdb;
|
*sdbt = sdb;
|
||||||
@ -1206,7 +1207,7 @@ static void hw_collect_samples(struct perf_event *event, unsigned long *sdbt,
|
|||||||
"%s: Found unknown"
|
"%s: Found unknown"
|
||||||
" sampling data entry: te->f %i"
|
" sampling data entry: te->f %i"
|
||||||
" basic.def %#4x (%p)\n", __func__,
|
" basic.def %#4x (%p)\n", __func__,
|
||||||
te->f, sample->def, sample);
|
te->header.f, sample->def, sample);
|
||||||
/* Sample slot is not yet written or other record.
|
/* Sample slot is not yet written or other record.
|
||||||
*
|
*
|
||||||
* This condition can occur if the buffer was reused
|
* This condition can occur if the buffer was reused
|
||||||
@ -1217,7 +1218,7 @@ static void hw_collect_samples(struct perf_event *event, unsigned long *sdbt,
|
|||||||
* that are not full. Stop processing if the first
|
* that are not full. Stop processing if the first
|
||||||
* invalid format was detected.
|
* invalid format was detected.
|
||||||
*/
|
*/
|
||||||
if (!te->f)
|
if (!te->header.f)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1227,6 +1228,16 @@ static void hw_collect_samples(struct perf_event *event, unsigned long *sdbt,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline __uint128_t __cdsg(__uint128_t *ptr, __uint128_t old, __uint128_t new)
|
||||||
|
{
|
||||||
|
asm volatile(
|
||||||
|
" cdsg %[old],%[new],%[ptr]\n"
|
||||||
|
: [old] "+d" (old), [ptr] "+QS" (*ptr)
|
||||||
|
: [new] "d" (new)
|
||||||
|
: "memory", "cc");
|
||||||
|
return old;
|
||||||
|
}
|
||||||
|
|
||||||
/* hw_perf_event_update() - Process sampling buffer
|
/* hw_perf_event_update() - Process sampling buffer
|
||||||
* @event: The perf event
|
* @event: The perf event
|
||||||
* @flush_all: Flag to also flush partially filled sample-data-blocks
|
* @flush_all: Flag to also flush partially filled sample-data-blocks
|
||||||
@ -1243,10 +1254,11 @@ static void hw_collect_samples(struct perf_event *event, unsigned long *sdbt,
|
|||||||
*/
|
*/
|
||||||
static void hw_perf_event_update(struct perf_event *event, int flush_all)
|
static void hw_perf_event_update(struct perf_event *event, int flush_all)
|
||||||
{
|
{
|
||||||
|
unsigned long long event_overflow, sampl_overflow, num_sdb;
|
||||||
|
union hws_trailer_header old, prev, new;
|
||||||
struct hw_perf_event *hwc = &event->hw;
|
struct hw_perf_event *hwc = &event->hw;
|
||||||
struct hws_trailer_entry *te;
|
struct hws_trailer_entry *te;
|
||||||
unsigned long *sdbt;
|
unsigned long *sdbt;
|
||||||
unsigned long long event_overflow, sampl_overflow, num_sdb, te_flags;
|
|
||||||
int done;
|
int done;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1266,25 +1278,25 @@ static void hw_perf_event_update(struct perf_event *event, int flush_all)
|
|||||||
te = (struct hws_trailer_entry *) trailer_entry_ptr(*sdbt);
|
te = (struct hws_trailer_entry *) trailer_entry_ptr(*sdbt);
|
||||||
|
|
||||||
/* Leave loop if no more work to do (block full indicator) */
|
/* Leave loop if no more work to do (block full indicator) */
|
||||||
if (!te->f) {
|
if (!te->header.f) {
|
||||||
done = 1;
|
done = 1;
|
||||||
if (!flush_all)
|
if (!flush_all)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check the sample overflow count */
|
/* Check the sample overflow count */
|
||||||
if (te->overflow)
|
if (te->header.overflow)
|
||||||
/* Account sample overflows and, if a particular limit
|
/* Account sample overflows and, if a particular limit
|
||||||
* is reached, extend the sampling buffer.
|
* is reached, extend the sampling buffer.
|
||||||
* For details, see sfb_account_overflows().
|
* For details, see sfb_account_overflows().
|
||||||
*/
|
*/
|
||||||
sampl_overflow += te->overflow;
|
sampl_overflow += te->header.overflow;
|
||||||
|
|
||||||
/* Timestamps are valid for full sample-data-blocks only */
|
/* Timestamps are valid for full sample-data-blocks only */
|
||||||
debug_sprintf_event(sfdbg, 6, "%s: sdbt %#lx "
|
debug_sprintf_event(sfdbg, 6, "%s: sdbt %#lx "
|
||||||
"overflow %llu timestamp %#llx\n",
|
"overflow %llu timestamp %#llx\n",
|
||||||
__func__, (unsigned long)sdbt, te->overflow,
|
__func__, (unsigned long)sdbt, te->header.overflow,
|
||||||
(te->f) ? trailer_timestamp(te) : 0ULL);
|
(te->header.f) ? trailer_timestamp(te) : 0ULL);
|
||||||
|
|
||||||
/* Collect all samples from a single sample-data-block and
|
/* Collect all samples from a single sample-data-block and
|
||||||
* flag if an (perf) event overflow happened. If so, the PMU
|
* flag if an (perf) event overflow happened. If so, the PMU
|
||||||
@ -1294,12 +1306,16 @@ static void hw_perf_event_update(struct perf_event *event, int flush_all)
|
|||||||
num_sdb++;
|
num_sdb++;
|
||||||
|
|
||||||
/* Reset trailer (using compare-double-and-swap) */
|
/* Reset trailer (using compare-double-and-swap) */
|
||||||
|
/* READ_ONCE() 16 byte header */
|
||||||
|
prev.val = __cdsg(&te->header.val, 0, 0);
|
||||||
do {
|
do {
|
||||||
te_flags = te->flags & ~SDB_TE_BUFFER_FULL_MASK;
|
old.val = prev.val;
|
||||||
te_flags |= SDB_TE_ALERT_REQ_MASK;
|
new.val = prev.val;
|
||||||
} while (!cmpxchg_double(&te->flags, &te->overflow,
|
new.f = 0;
|
||||||
te->flags, te->overflow,
|
new.a = 1;
|
||||||
te_flags, 0ULL));
|
new.overflow = 0;
|
||||||
|
prev.val = __cdsg(&te->header.val, old.val, new.val);
|
||||||
|
} while (prev.val != old.val);
|
||||||
|
|
||||||
/* Advance to next sample-data-block */
|
/* Advance to next sample-data-block */
|
||||||
sdbt++;
|
sdbt++;
|
||||||
@ -1384,7 +1400,7 @@ static void aux_output_end(struct perf_output_handle *handle)
|
|||||||
range_scan = AUX_SDB_NUM_ALERT(aux);
|
range_scan = AUX_SDB_NUM_ALERT(aux);
|
||||||
for (i = 0, idx = aux->head; i < range_scan; i++, idx++) {
|
for (i = 0, idx = aux->head; i < range_scan; i++, idx++) {
|
||||||
te = aux_sdb_trailer(aux, idx);
|
te = aux_sdb_trailer(aux, idx);
|
||||||
if (!(te->flags & SDB_TE_BUFFER_FULL_MASK))
|
if (!te->header.f)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* i is num of SDBs which are full */
|
/* i is num of SDBs which are full */
|
||||||
@ -1392,7 +1408,7 @@ static void aux_output_end(struct perf_output_handle *handle)
|
|||||||
|
|
||||||
/* Remove alert indicators in the buffer */
|
/* Remove alert indicators in the buffer */
|
||||||
te = aux_sdb_trailer(aux, aux->alert_mark);
|
te = aux_sdb_trailer(aux, aux->alert_mark);
|
||||||
te->flags &= ~SDB_TE_ALERT_REQ_MASK;
|
te->header.a = 0;
|
||||||
|
|
||||||
debug_sprintf_event(sfdbg, 6, "%s: SDBs %ld range %ld head %ld\n",
|
debug_sprintf_event(sfdbg, 6, "%s: SDBs %ld range %ld head %ld\n",
|
||||||
__func__, i, range_scan, aux->head);
|
__func__, i, range_scan, aux->head);
|
||||||
@ -1437,9 +1453,9 @@ static int aux_output_begin(struct perf_output_handle *handle,
|
|||||||
idx = aux->empty_mark + 1;
|
idx = aux->empty_mark + 1;
|
||||||
for (i = 0; i < range_scan; i++, idx++) {
|
for (i = 0; i < range_scan; i++, idx++) {
|
||||||
te = aux_sdb_trailer(aux, idx);
|
te = aux_sdb_trailer(aux, idx);
|
||||||
te->flags &= ~(SDB_TE_BUFFER_FULL_MASK |
|
te->header.f = 0;
|
||||||
SDB_TE_ALERT_REQ_MASK);
|
te->header.a = 0;
|
||||||
te->overflow = 0;
|
te->header.overflow = 0;
|
||||||
}
|
}
|
||||||
/* Save the position of empty SDBs */
|
/* Save the position of empty SDBs */
|
||||||
aux->empty_mark = aux->head + range - 1;
|
aux->empty_mark = aux->head + range - 1;
|
||||||
@ -1448,7 +1464,7 @@ static int aux_output_begin(struct perf_output_handle *handle,
|
|||||||
/* Set alert indicator */
|
/* Set alert indicator */
|
||||||
aux->alert_mark = aux->head + range/2 - 1;
|
aux->alert_mark = aux->head + range/2 - 1;
|
||||||
te = aux_sdb_trailer(aux, aux->alert_mark);
|
te = aux_sdb_trailer(aux, aux->alert_mark);
|
||||||
te->flags = te->flags | SDB_TE_ALERT_REQ_MASK;
|
te->header.a = 1;
|
||||||
|
|
||||||
/* Reset hardware buffer head */
|
/* Reset hardware buffer head */
|
||||||
head = AUX_SDB_INDEX(aux, aux->head);
|
head = AUX_SDB_INDEX(aux, aux->head);
|
||||||
@ -1475,14 +1491,17 @@ static int aux_output_begin(struct perf_output_handle *handle,
|
|||||||
static bool aux_set_alert(struct aux_buffer *aux, unsigned long alert_index,
|
static bool aux_set_alert(struct aux_buffer *aux, unsigned long alert_index,
|
||||||
unsigned long long *overflow)
|
unsigned long long *overflow)
|
||||||
{
|
{
|
||||||
unsigned long long orig_overflow, orig_flags, new_flags;
|
union hws_trailer_header old, prev, new;
|
||||||
struct hws_trailer_entry *te;
|
struct hws_trailer_entry *te;
|
||||||
|
|
||||||
te = aux_sdb_trailer(aux, alert_index);
|
te = aux_sdb_trailer(aux, alert_index);
|
||||||
|
/* READ_ONCE() 16 byte header */
|
||||||
|
prev.val = __cdsg(&te->header.val, 0, 0);
|
||||||
do {
|
do {
|
||||||
orig_flags = te->flags;
|
old.val = prev.val;
|
||||||
*overflow = orig_overflow = te->overflow;
|
new.val = prev.val;
|
||||||
if (orig_flags & SDB_TE_BUFFER_FULL_MASK) {
|
*overflow = old.overflow;
|
||||||
|
if (old.f) {
|
||||||
/*
|
/*
|
||||||
* SDB is already set by hardware.
|
* SDB is already set by hardware.
|
||||||
* Abort and try to set somewhere
|
* Abort and try to set somewhere
|
||||||
@ -1490,10 +1509,10 @@ static bool aux_set_alert(struct aux_buffer *aux, unsigned long alert_index,
|
|||||||
*/
|
*/
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
new_flags = orig_flags | SDB_TE_ALERT_REQ_MASK;
|
new.a = 1;
|
||||||
} while (!cmpxchg_double(&te->flags, &te->overflow,
|
new.overflow = 0;
|
||||||
orig_flags, orig_overflow,
|
prev.val = __cdsg(&te->header.val, old.val, new.val);
|
||||||
new_flags, 0ULL));
|
} while (prev.val != old.val);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1522,8 +1541,9 @@ static bool aux_set_alert(struct aux_buffer *aux, unsigned long alert_index,
|
|||||||
static bool aux_reset_buffer(struct aux_buffer *aux, unsigned long range,
|
static bool aux_reset_buffer(struct aux_buffer *aux, unsigned long range,
|
||||||
unsigned long long *overflow)
|
unsigned long long *overflow)
|
||||||
{
|
{
|
||||||
unsigned long long orig_overflow, orig_flags, new_flags;
|
|
||||||
unsigned long i, range_scan, idx, idx_old;
|
unsigned long i, range_scan, idx, idx_old;
|
||||||
|
union hws_trailer_header old, prev, new;
|
||||||
|
unsigned long long orig_overflow;
|
||||||
struct hws_trailer_entry *te;
|
struct hws_trailer_entry *te;
|
||||||
|
|
||||||
debug_sprintf_event(sfdbg, 6, "%s: range %ld head %ld alert %ld "
|
debug_sprintf_event(sfdbg, 6, "%s: range %ld head %ld alert %ld "
|
||||||
@ -1554,17 +1574,20 @@ static bool aux_reset_buffer(struct aux_buffer *aux, unsigned long range,
|
|||||||
idx_old = idx = aux->empty_mark + 1;
|
idx_old = idx = aux->empty_mark + 1;
|
||||||
for (i = 0; i < range_scan; i++, idx++) {
|
for (i = 0; i < range_scan; i++, idx++) {
|
||||||
te = aux_sdb_trailer(aux, idx);
|
te = aux_sdb_trailer(aux, idx);
|
||||||
|
/* READ_ONCE() 16 byte header */
|
||||||
|
prev.val = __cdsg(&te->header.val, 0, 0);
|
||||||
do {
|
do {
|
||||||
orig_flags = te->flags;
|
old.val = prev.val;
|
||||||
orig_overflow = te->overflow;
|
new.val = prev.val;
|
||||||
new_flags = orig_flags & ~SDB_TE_BUFFER_FULL_MASK;
|
orig_overflow = old.overflow;
|
||||||
|
new.f = 0;
|
||||||
|
new.overflow = 0;
|
||||||
if (idx == aux->alert_mark)
|
if (idx == aux->alert_mark)
|
||||||
new_flags |= SDB_TE_ALERT_REQ_MASK;
|
new.a = 1;
|
||||||
else
|
else
|
||||||
new_flags &= ~SDB_TE_ALERT_REQ_MASK;
|
new.a = 0;
|
||||||
} while (!cmpxchg_double(&te->flags, &te->overflow,
|
prev.val = __cdsg(&te->header.val, old.val, new.val);
|
||||||
orig_flags, orig_overflow,
|
} while (prev.val != old.val);
|
||||||
new_flags, 0ULL));
|
|
||||||
*overflow += orig_overflow;
|
*overflow += orig_overflow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
/* Handle ro_after_init data on our own. */
|
/* Handle ro_after_init data on our own. */
|
||||||
#define RO_AFTER_INIT_DATA
|
#define RO_AFTER_INIT_DATA
|
||||||
|
|
||||||
|
#define RUNTIME_DISCARD_EXIT
|
||||||
|
|
||||||
#define EMITS_PT_NOTE
|
#define EMITS_PT_NOTE
|
||||||
|
|
||||||
#include <asm-generic/vmlinux.lds.h>
|
#include <asm-generic/vmlinux.lds.h>
|
||||||
@ -79,6 +81,7 @@ SECTIONS
|
|||||||
_end_amode31_refs = .;
|
_end_amode31_refs = .;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
. = ALIGN(PAGE_SIZE);
|
||||||
_edata = .; /* End of data section */
|
_edata = .; /* End of data section */
|
||||||
|
|
||||||
/* will be freed after init */
|
/* will be freed after init */
|
||||||
@ -193,6 +196,7 @@ SECTIONS
|
|||||||
|
|
||||||
BSS_SECTION(PAGE_SIZE, 4 * PAGE_SIZE, PAGE_SIZE)
|
BSS_SECTION(PAGE_SIZE, 4 * PAGE_SIZE, PAGE_SIZE)
|
||||||
|
|
||||||
|
. = ALIGN(PAGE_SIZE);
|
||||||
_end = . ;
|
_end = . ;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -83,8 +83,9 @@ static int sca_inject_ext_call(struct kvm_vcpu *vcpu, int src_id)
|
|||||||
struct esca_block *sca = vcpu->kvm->arch.sca;
|
struct esca_block *sca = vcpu->kvm->arch.sca;
|
||||||
union esca_sigp_ctrl *sigp_ctrl =
|
union esca_sigp_ctrl *sigp_ctrl =
|
||||||
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
||||||
union esca_sigp_ctrl new_val = {0}, old_val = *sigp_ctrl;
|
union esca_sigp_ctrl new_val = {0}, old_val;
|
||||||
|
|
||||||
|
old_val = READ_ONCE(*sigp_ctrl);
|
||||||
new_val.scn = src_id;
|
new_val.scn = src_id;
|
||||||
new_val.c = 1;
|
new_val.c = 1;
|
||||||
old_val.c = 0;
|
old_val.c = 0;
|
||||||
@ -95,8 +96,9 @@ static int sca_inject_ext_call(struct kvm_vcpu *vcpu, int src_id)
|
|||||||
struct bsca_block *sca = vcpu->kvm->arch.sca;
|
struct bsca_block *sca = vcpu->kvm->arch.sca;
|
||||||
union bsca_sigp_ctrl *sigp_ctrl =
|
union bsca_sigp_ctrl *sigp_ctrl =
|
||||||
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
||||||
union bsca_sigp_ctrl new_val = {0}, old_val = *sigp_ctrl;
|
union bsca_sigp_ctrl new_val = {0}, old_val;
|
||||||
|
|
||||||
|
old_val = READ_ONCE(*sigp_ctrl);
|
||||||
new_val.scn = src_id;
|
new_val.scn = src_id;
|
||||||
new_val.c = 1;
|
new_val.c = 1;
|
||||||
old_val.c = 0;
|
old_val.c = 0;
|
||||||
@ -126,16 +128,18 @@ static void sca_clear_ext_call(struct kvm_vcpu *vcpu)
|
|||||||
struct esca_block *sca = vcpu->kvm->arch.sca;
|
struct esca_block *sca = vcpu->kvm->arch.sca;
|
||||||
union esca_sigp_ctrl *sigp_ctrl =
|
union esca_sigp_ctrl *sigp_ctrl =
|
||||||
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
||||||
union esca_sigp_ctrl old = *sigp_ctrl;
|
union esca_sigp_ctrl old;
|
||||||
|
|
||||||
|
old = READ_ONCE(*sigp_ctrl);
|
||||||
expect = old.value;
|
expect = old.value;
|
||||||
rc = cmpxchg(&sigp_ctrl->value, old.value, 0);
|
rc = cmpxchg(&sigp_ctrl->value, old.value, 0);
|
||||||
} else {
|
} else {
|
||||||
struct bsca_block *sca = vcpu->kvm->arch.sca;
|
struct bsca_block *sca = vcpu->kvm->arch.sca;
|
||||||
union bsca_sigp_ctrl *sigp_ctrl =
|
union bsca_sigp_ctrl *sigp_ctrl =
|
||||||
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
&(sca->cpu[vcpu->vcpu_id].sigp_ctrl);
|
||||||
union bsca_sigp_ctrl old = *sigp_ctrl;
|
union bsca_sigp_ctrl old;
|
||||||
|
|
||||||
|
old = READ_ONCE(*sigp_ctrl);
|
||||||
expect = old.value;
|
expect = old.value;
|
||||||
rc = cmpxchg(&sigp_ctrl->value, old.value, 0);
|
rc = cmpxchg(&sigp_ctrl->value, old.value, 0);
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
#define pmd_ERROR(e) \
|
#define pmd_ERROR(e) \
|
||||||
printk("%s:%d: bad pmd %016llx.\n", __FILE__, __LINE__, pmd_val(e))
|
printk("%s:%d: bad pmd %016llx.\n", __FILE__, __LINE__, pmd_val(e))
|
||||||
|
|
||||||
typedef struct {
|
typedef union {
|
||||||
struct {
|
struct {
|
||||||
unsigned long pmd_low;
|
unsigned long pmd_low;
|
||||||
unsigned long pmd_high;
|
unsigned long pmd_high;
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
* MSR_CORE_C1_RES: CORE C1 Residency Counter
|
* MSR_CORE_C1_RES: CORE C1 Residency Counter
|
||||||
* perf code: 0x00
|
* perf code: 0x00
|
||||||
* Available model: SLM,AMT,GLM,CNL,ICX,TNT,ADL,RPL
|
* Available model: SLM,AMT,GLM,CNL,ICX,TNT,ADL,RPL
|
||||||
|
* MTL
|
||||||
* Scope: Core (each processor core has a MSR)
|
* Scope: Core (each processor core has a MSR)
|
||||||
* MSR_CORE_C3_RESIDENCY: CORE C3 Residency Counter
|
* MSR_CORE_C3_RESIDENCY: CORE C3 Residency Counter
|
||||||
* perf code: 0x01
|
* perf code: 0x01
|
||||||
@ -51,50 +52,50 @@
|
|||||||
* perf code: 0x02
|
* perf code: 0x02
|
||||||
* Available model: SLM,AMT,NHM,WSM,SNB,IVB,HSW,BDW,
|
* Available model: SLM,AMT,NHM,WSM,SNB,IVB,HSW,BDW,
|
||||||
* SKL,KNL,GLM,CNL,KBL,CML,ICL,ICX,
|
* SKL,KNL,GLM,CNL,KBL,CML,ICL,ICX,
|
||||||
* TGL,TNT,RKL,ADL,RPL,SPR
|
* TGL,TNT,RKL,ADL,RPL,SPR,MTL
|
||||||
* Scope: Core
|
* Scope: Core
|
||||||
* MSR_CORE_C7_RESIDENCY: CORE C7 Residency Counter
|
* MSR_CORE_C7_RESIDENCY: CORE C7 Residency Counter
|
||||||
* perf code: 0x03
|
* perf code: 0x03
|
||||||
* Available model: SNB,IVB,HSW,BDW,SKL,CNL,KBL,CML,
|
* Available model: SNB,IVB,HSW,BDW,SKL,CNL,KBL,CML,
|
||||||
* ICL,TGL,RKL,ADL,RPL
|
* ICL,TGL,RKL,ADL,RPL,MTL
|
||||||
* Scope: Core
|
* Scope: Core
|
||||||
* MSR_PKG_C2_RESIDENCY: Package C2 Residency Counter.
|
* MSR_PKG_C2_RESIDENCY: Package C2 Residency Counter.
|
||||||
* perf code: 0x00
|
* perf code: 0x00
|
||||||
* Available model: SNB,IVB,HSW,BDW,SKL,KNL,GLM,CNL,
|
* Available model: SNB,IVB,HSW,BDW,SKL,KNL,GLM,CNL,
|
||||||
* KBL,CML,ICL,ICX,TGL,TNT,RKL,ADL,
|
* KBL,CML,ICL,ICX,TGL,TNT,RKL,ADL,
|
||||||
* RPL,SPR
|
* RPL,SPR,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
* MSR_PKG_C3_RESIDENCY: Package C3 Residency Counter.
|
* MSR_PKG_C3_RESIDENCY: Package C3 Residency Counter.
|
||||||
* perf code: 0x01
|
* perf code: 0x01
|
||||||
* Available model: NHM,WSM,SNB,IVB,HSW,BDW,SKL,KNL,
|
* Available model: NHM,WSM,SNB,IVB,HSW,BDW,SKL,KNL,
|
||||||
* GLM,CNL,KBL,CML,ICL,TGL,TNT,RKL,
|
* GLM,CNL,KBL,CML,ICL,TGL,TNT,RKL,
|
||||||
* ADL,RPL
|
* ADL,RPL,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
* MSR_PKG_C6_RESIDENCY: Package C6 Residency Counter.
|
* MSR_PKG_C6_RESIDENCY: Package C6 Residency Counter.
|
||||||
* perf code: 0x02
|
* perf code: 0x02
|
||||||
* Available model: SLM,AMT,NHM,WSM,SNB,IVB,HSW,BDW,
|
* Available model: SLM,AMT,NHM,WSM,SNB,IVB,HSW,BDW,
|
||||||
* SKL,KNL,GLM,CNL,KBL,CML,ICL,ICX,
|
* SKL,KNL,GLM,CNL,KBL,CML,ICL,ICX,
|
||||||
* TGL,TNT,RKL,ADL,RPL,SPR
|
* TGL,TNT,RKL,ADL,RPL,SPR,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
* MSR_PKG_C7_RESIDENCY: Package C7 Residency Counter.
|
* MSR_PKG_C7_RESIDENCY: Package C7 Residency Counter.
|
||||||
* perf code: 0x03
|
* perf code: 0x03
|
||||||
* Available model: NHM,WSM,SNB,IVB,HSW,BDW,SKL,CNL,
|
* Available model: NHM,WSM,SNB,IVB,HSW,BDW,SKL,CNL,
|
||||||
* KBL,CML,ICL,TGL,RKL,ADL,RPL
|
* KBL,CML,ICL,TGL,RKL,ADL,RPL,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
* MSR_PKG_C8_RESIDENCY: Package C8 Residency Counter.
|
* MSR_PKG_C8_RESIDENCY: Package C8 Residency Counter.
|
||||||
* perf code: 0x04
|
* perf code: 0x04
|
||||||
* Available model: HSW ULT,KBL,CNL,CML,ICL,TGL,RKL,
|
* Available model: HSW ULT,KBL,CNL,CML,ICL,TGL,RKL,
|
||||||
* ADL,RPL
|
* ADL,RPL,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
* MSR_PKG_C9_RESIDENCY: Package C9 Residency Counter.
|
* MSR_PKG_C9_RESIDENCY: Package C9 Residency Counter.
|
||||||
* perf code: 0x05
|
* perf code: 0x05
|
||||||
* Available model: HSW ULT,KBL,CNL,CML,ICL,TGL,RKL,
|
* Available model: HSW ULT,KBL,CNL,CML,ICL,TGL,RKL,
|
||||||
* ADL,RPL
|
* ADL,RPL,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
* MSR_PKG_C10_RESIDENCY: Package C10 Residency Counter.
|
* MSR_PKG_C10_RESIDENCY: Package C10 Residency Counter.
|
||||||
* perf code: 0x06
|
* perf code: 0x06
|
||||||
* Available model: HSW ULT,KBL,GLM,CNL,CML,ICL,TGL,
|
* Available model: HSW ULT,KBL,GLM,CNL,CML,ICL,TGL,
|
||||||
* TNT,RKL,ADL,RPL
|
* TNT,RKL,ADL,RPL,MTL
|
||||||
* Scope: Package (physical package)
|
* Scope: Package (physical package)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ -686,6 +687,8 @@ static const struct x86_cpu_id intel_cstates_match[] __initconst = {
|
|||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE, &adl_cstates),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE, &adl_cstates),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, &adl_cstates),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, &adl_cstates),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_S, &adl_cstates),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_S, &adl_cstates),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(METEORLAKE, &adl_cstates),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(METEORLAKE_L, &adl_cstates),
|
||||||
{ },
|
{ },
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(x86cpu, intel_cstates_match);
|
MODULE_DEVICE_TABLE(x86cpu, intel_cstates_match);
|
||||||
|
@ -1833,6 +1833,7 @@ static const struct x86_cpu_id intel_uncore_match[] __initconst = {
|
|||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, &adl_uncore_init),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, &adl_uncore_init),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_S, &adl_uncore_init),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_S, &adl_uncore_init),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(SAPPHIRERAPIDS_X, &spr_uncore_init),
|
X86_MATCH_INTEL_FAM6_MODEL(SAPPHIRERAPIDS_X, &spr_uncore_init),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(EMERALDRAPIDS_X, &spr_uncore_init),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(ATOM_TREMONT_D, &snr_uncore_init),
|
X86_MATCH_INTEL_FAM6_MODEL(ATOM_TREMONT_D, &snr_uncore_init),
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
@ -69,6 +69,7 @@ static bool test_intel(int idx, void *data)
|
|||||||
case INTEL_FAM6_BROADWELL_G:
|
case INTEL_FAM6_BROADWELL_G:
|
||||||
case INTEL_FAM6_BROADWELL_X:
|
case INTEL_FAM6_BROADWELL_X:
|
||||||
case INTEL_FAM6_SAPPHIRERAPIDS_X:
|
case INTEL_FAM6_SAPPHIRERAPIDS_X:
|
||||||
|
case INTEL_FAM6_EMERALDRAPIDS_X:
|
||||||
|
|
||||||
case INTEL_FAM6_ATOM_SILVERMONT:
|
case INTEL_FAM6_ATOM_SILVERMONT:
|
||||||
case INTEL_FAM6_ATOM_SILVERMONT_D:
|
case INTEL_FAM6_ATOM_SILVERMONT_D:
|
||||||
@ -107,6 +108,8 @@ static bool test_intel(int idx, void *data)
|
|||||||
case INTEL_FAM6_RAPTORLAKE:
|
case INTEL_FAM6_RAPTORLAKE:
|
||||||
case INTEL_FAM6_RAPTORLAKE_P:
|
case INTEL_FAM6_RAPTORLAKE_P:
|
||||||
case INTEL_FAM6_RAPTORLAKE_S:
|
case INTEL_FAM6_RAPTORLAKE_S:
|
||||||
|
case INTEL_FAM6_METEORLAKE:
|
||||||
|
case INTEL_FAM6_METEORLAKE_L:
|
||||||
if (idx == PERF_MSR_SMI || idx == PERF_MSR_PPERF)
|
if (idx == PERF_MSR_SMI || idx == PERF_MSR_PPERF)
|
||||||
return true;
|
return true;
|
||||||
break;
|
break;
|
||||||
|
@ -800,13 +800,18 @@ static const struct x86_cpu_id rapl_model_match[] __initconst = {
|
|||||||
X86_MATCH_INTEL_FAM6_MODEL(ICELAKE_X, &model_hsx),
|
X86_MATCH_INTEL_FAM6_MODEL(ICELAKE_X, &model_hsx),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(COMETLAKE_L, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(COMETLAKE_L, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(COMETLAKE, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(COMETLAKE, &model_skl),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(TIGERLAKE_L, &model_skl),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(TIGERLAKE, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE_L, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE_L, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE_N, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE_N, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(SAPPHIRERAPIDS_X, &model_spr),
|
X86_MATCH_INTEL_FAM6_MODEL(SAPPHIRERAPIDS_X, &model_spr),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(EMERALDRAPIDS_X, &model_spr),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, &model_skl),
|
||||||
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_S, &model_skl),
|
X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_S, &model_skl),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(METEORLAKE, &model_skl),
|
||||||
|
X86_MATCH_INTEL_FAM6_MODEL(METEORLAKE_L, &model_skl),
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(x86cpu, rapl_model_match);
|
MODULE_DEVICE_TABLE(x86cpu, rapl_model_match);
|
||||||
|
@ -134,11 +134,6 @@ static inline unsigned p2m_mid_index(unsigned long pfn)
|
|||||||
return (pfn / P2M_PER_PAGE) % P2M_MID_PER_PAGE;
|
return (pfn / P2M_PER_PAGE) % P2M_MID_PER_PAGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline unsigned p2m_index(unsigned long pfn)
|
|
||||||
{
|
|
||||||
return pfn % P2M_PER_PAGE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void p2m_top_mfn_init(unsigned long *top)
|
static void p2m_top_mfn_init(unsigned long *top)
|
||||||
{
|
{
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
@ -154,11 +154,6 @@ struct thread_struct {
|
|||||||
unsigned long ra; /* kernel's a0: return address and window call size */
|
unsigned long ra; /* kernel's a0: return address and window call size */
|
||||||
unsigned long sp; /* kernel's a1: stack pointer */
|
unsigned long sp; /* kernel's a1: stack pointer */
|
||||||
|
|
||||||
/* struct xtensa_cpuinfo info; */
|
|
||||||
|
|
||||||
unsigned long bad_vaddr; /* last user fault */
|
|
||||||
unsigned long bad_uaddr; /* last kernel fault accessing user space */
|
|
||||||
unsigned long error_code;
|
|
||||||
#ifdef CONFIG_HAVE_HW_BREAKPOINT
|
#ifdef CONFIG_HAVE_HW_BREAKPOINT
|
||||||
struct perf_event *ptrace_bp[XCHAL_NUM_IBREAK];
|
struct perf_event *ptrace_bp[XCHAL_NUM_IBREAK];
|
||||||
struct perf_event *ptrace_wp[XCHAL_NUM_DBREAK];
|
struct perf_event *ptrace_wp[XCHAL_NUM_DBREAK];
|
||||||
@ -176,10 +171,6 @@ struct thread_struct {
|
|||||||
{ \
|
{ \
|
||||||
ra: 0, \
|
ra: 0, \
|
||||||
sp: sizeof(init_stack) + (long) &init_stack, \
|
sp: sizeof(init_stack) + (long) &init_stack, \
|
||||||
/*info: {0}, */ \
|
|
||||||
bad_vaddr: 0, \
|
|
||||||
bad_uaddr: 0, \
|
|
||||||
error_code: 0, \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -362,8 +362,6 @@ static void do_unaligned_user(struct pt_regs *regs)
|
|||||||
__die_if_kernel("Unhandled unaligned exception in kernel",
|
__die_if_kernel("Unhandled unaligned exception in kernel",
|
||||||
regs, SIGKILL);
|
regs, SIGKILL);
|
||||||
|
|
||||||
current->thread.bad_vaddr = regs->excvaddr;
|
|
||||||
current->thread.error_code = -3;
|
|
||||||
pr_info_ratelimited("Unaligned memory access to %08lx in '%s' "
|
pr_info_ratelimited("Unaligned memory access to %08lx in '%s' "
|
||||||
"(pid = %d, pc = %#010lx)\n",
|
"(pid = %d, pc = %#010lx)\n",
|
||||||
regs->excvaddr, current->comm,
|
regs->excvaddr, current->comm,
|
||||||
|
@ -206,8 +206,6 @@ good_area:
|
|||||||
bad_area:
|
bad_area:
|
||||||
mmap_read_unlock(mm);
|
mmap_read_unlock(mm);
|
||||||
if (user_mode(regs)) {
|
if (user_mode(regs)) {
|
||||||
current->thread.bad_vaddr = address;
|
|
||||||
current->thread.error_code = is_write;
|
|
||||||
force_sig_fault(SIGSEGV, code, (void *) address);
|
force_sig_fault(SIGSEGV, code, (void *) address);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -232,7 +230,6 @@ do_sigbus:
|
|||||||
/* Send a sigbus, regardless of whether we were in kernel
|
/* Send a sigbus, regardless of whether we were in kernel
|
||||||
* or user mode.
|
* or user mode.
|
||||||
*/
|
*/
|
||||||
current->thread.bad_vaddr = address;
|
|
||||||
force_sig_fault(SIGBUS, BUS_ADRERR, (void *) address);
|
force_sig_fault(SIGBUS, BUS_ADRERR, (void *) address);
|
||||||
|
|
||||||
/* Kernel mode? Handle exceptions or die */
|
/* Kernel mode? Handle exceptions or die */
|
||||||
@ -252,7 +249,6 @@ bad_page_fault(struct pt_regs *regs, unsigned long address, int sig)
|
|||||||
if ((entry = search_exception_tables(regs->pc)) != NULL) {
|
if ((entry = search_exception_tables(regs->pc)) != NULL) {
|
||||||
pr_debug("%s: Exception at pc=%#010lx (%lx)\n",
|
pr_debug("%s: Exception at pc=%#010lx (%lx)\n",
|
||||||
current->comm, regs->pc, entry->fixup);
|
current->comm, regs->pc, entry->fixup);
|
||||||
current->thread.bad_uaddr = address;
|
|
||||||
regs->pc = entry->fixup;
|
regs->pc = entry->fixup;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,6 @@ menuconfig BLOCK
|
|||||||
bool "Enable the block layer" if EXPERT
|
bool "Enable the block layer" if EXPERT
|
||||||
default y
|
default y
|
||||||
select SBITMAP
|
select SBITMAP
|
||||||
select SRCU
|
|
||||||
help
|
help
|
||||||
Provide block layer support for the kernel.
|
Provide block layer support for the kernel.
|
||||||
|
|
||||||
|
37
block/bio.c
37
block/bio.c
@ -1401,6 +1401,27 @@ void __bio_advance(struct bio *bio, unsigned bytes)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(__bio_advance);
|
EXPORT_SYMBOL(__bio_advance);
|
||||||
|
|
||||||
|
void bio_copy_data_iter(struct bio *dst, struct bvec_iter *dst_iter,
|
||||||
|
struct bio *src, struct bvec_iter *src_iter)
|
||||||
|
{
|
||||||
|
while (src_iter->bi_size && dst_iter->bi_size) {
|
||||||
|
struct bio_vec src_bv = bio_iter_iovec(src, *src_iter);
|
||||||
|
struct bio_vec dst_bv = bio_iter_iovec(dst, *dst_iter);
|
||||||
|
unsigned int bytes = min(src_bv.bv_len, dst_bv.bv_len);
|
||||||
|
void *src_buf = bvec_kmap_local(&src_bv);
|
||||||
|
void *dst_buf = bvec_kmap_local(&dst_bv);
|
||||||
|
|
||||||
|
memcpy(dst_buf, src_buf, bytes);
|
||||||
|
|
||||||
|
kunmap_local(dst_buf);
|
||||||
|
kunmap_local(src_buf);
|
||||||
|
|
||||||
|
bio_advance_iter_single(src, src_iter, bytes);
|
||||||
|
bio_advance_iter_single(dst, dst_iter, bytes);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(bio_copy_data_iter);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* bio_copy_data - copy contents of data buffers from one bio to another
|
* bio_copy_data - copy contents of data buffers from one bio to another
|
||||||
* @src: source bio
|
* @src: source bio
|
||||||
@ -1414,21 +1435,7 @@ void bio_copy_data(struct bio *dst, struct bio *src)
|
|||||||
struct bvec_iter src_iter = src->bi_iter;
|
struct bvec_iter src_iter = src->bi_iter;
|
||||||
struct bvec_iter dst_iter = dst->bi_iter;
|
struct bvec_iter dst_iter = dst->bi_iter;
|
||||||
|
|
||||||
while (src_iter.bi_size && dst_iter.bi_size) {
|
bio_copy_data_iter(dst, &dst_iter, src, &src_iter);
|
||||||
struct bio_vec src_bv = bio_iter_iovec(src, src_iter);
|
|
||||||
struct bio_vec dst_bv = bio_iter_iovec(dst, dst_iter);
|
|
||||||
unsigned int bytes = min(src_bv.bv_len, dst_bv.bv_len);
|
|
||||||
void *src_buf = bvec_kmap_local(&src_bv);
|
|
||||||
void *dst_buf = bvec_kmap_local(&dst_bv);
|
|
||||||
|
|
||||||
memcpy(dst_buf, src_buf, bytes);
|
|
||||||
|
|
||||||
kunmap_local(dst_buf);
|
|
||||||
kunmap_local(src_buf);
|
|
||||||
|
|
||||||
bio_advance_iter_single(src, &src_iter, bytes);
|
|
||||||
bio_advance_iter_single(dst, &dst_iter, bytes);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(bio_copy_data);
|
EXPORT_SYMBOL(bio_copy_data);
|
||||||
|
|
||||||
|
@ -309,6 +309,16 @@ static struct bio *bio_split_rw(struct bio *bio, const struct queue_limits *lim,
|
|||||||
*segs = nsegs;
|
*segs = nsegs;
|
||||||
return NULL;
|
return NULL;
|
||||||
split:
|
split:
|
||||||
|
/*
|
||||||
|
* We can't sanely support splitting for a REQ_NOWAIT bio. End it
|
||||||
|
* with EAGAIN if splitting is required and return an error pointer.
|
||||||
|
*/
|
||||||
|
if (bio->bi_opf & REQ_NOWAIT) {
|
||||||
|
bio->bi_status = BLK_STS_AGAIN;
|
||||||
|
bio_endio(bio);
|
||||||
|
return ERR_PTR(-EAGAIN);
|
||||||
|
}
|
||||||
|
|
||||||
*segs = nsegs;
|
*segs = nsegs;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -358,11 +368,13 @@ struct bio *__bio_split_to_limits(struct bio *bio,
|
|||||||
default:
|
default:
|
||||||
split = bio_split_rw(bio, lim, nr_segs, bs,
|
split = bio_split_rw(bio, lim, nr_segs, bs,
|
||||||
get_max_io_size(bio, lim) << SECTOR_SHIFT);
|
get_max_io_size(bio, lim) << SECTOR_SHIFT);
|
||||||
|
if (IS_ERR(split))
|
||||||
|
return NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (split) {
|
if (split) {
|
||||||
/* there isn't chance to merge the splitted bio */
|
/* there isn't chance to merge the split bio */
|
||||||
split->bi_opf |= REQ_NOMERGE;
|
split->bi_opf |= REQ_NOMERGE;
|
||||||
|
|
||||||
blkcg_bio_issue_init(split);
|
blkcg_bio_issue_init(split);
|
||||||
|
@ -2951,8 +2951,11 @@ void blk_mq_submit_bio(struct bio *bio)
|
|||||||
blk_status_t ret;
|
blk_status_t ret;
|
||||||
|
|
||||||
bio = blk_queue_bounce(bio, q);
|
bio = blk_queue_bounce(bio, q);
|
||||||
if (bio_may_exceed_limits(bio, &q->limits))
|
if (bio_may_exceed_limits(bio, &q->limits)) {
|
||||||
bio = __bio_split_to_limits(bio, &q->limits, &nr_segs);
|
bio = __bio_split_to_limits(bio, &q->limits, &nr_segs);
|
||||||
|
if (!bio)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!bio_integrity_prep(bio))
|
if (!bio_integrity_prep(bio))
|
||||||
return;
|
return;
|
||||||
|
@ -1201,10 +1201,21 @@ struct class block_class = {
|
|||||||
.dev_uevent = block_uevent,
|
.dev_uevent = block_uevent,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static char *block_devnode(struct device *dev, umode_t *mode,
|
||||||
|
kuid_t *uid, kgid_t *gid)
|
||||||
|
{
|
||||||
|
struct gendisk *disk = dev_to_disk(dev);
|
||||||
|
|
||||||
|
if (disk->fops->devnode)
|
||||||
|
return disk->fops->devnode(disk, mode);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
const struct device_type disk_type = {
|
const struct device_type disk_type = {
|
||||||
.name = "disk",
|
.name = "disk",
|
||||||
.groups = disk_attr_groups,
|
.groups = disk_attr_groups,
|
||||||
.release = disk_release,
|
.release = disk_release,
|
||||||
|
.devnode = block_devnode,
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_PROC_FS
|
#ifdef CONFIG_PROC_FS
|
||||||
|
@ -285,6 +285,49 @@ config BLK_DEV_RAM_SIZE
|
|||||||
The default value is 4096 kilobytes. Only change this if you know
|
The default value is 4096 kilobytes. Only change this if you know
|
||||||
what you are doing.
|
what you are doing.
|
||||||
|
|
||||||
|
config CDROM_PKTCDVD
|
||||||
|
tristate "Packet writing on CD/DVD media (DEPRECATED)"
|
||||||
|
depends on !UML
|
||||||
|
depends on SCSI
|
||||||
|
select CDROM
|
||||||
|
help
|
||||||
|
Note: This driver is deprecated and will be removed from the
|
||||||
|
kernel in the near future!
|
||||||
|
|
||||||
|
If you have a CDROM/DVD drive that supports packet writing, say
|
||||||
|
Y to include support. It should work with any MMC/Mt Fuji
|
||||||
|
compliant ATAPI or SCSI drive, which is just about any newer
|
||||||
|
DVD/CD writer.
|
||||||
|
|
||||||
|
Currently only writing to CD-RW, DVD-RW, DVD+RW and DVDRAM discs
|
||||||
|
is possible.
|
||||||
|
DVD-RW disks must be in restricted overwrite mode.
|
||||||
|
|
||||||
|
See the file <file:Documentation/cdrom/packet-writing.rst>
|
||||||
|
for further information on the use of this driver.
|
||||||
|
|
||||||
|
To compile this driver as a module, choose M here: the
|
||||||
|
module will be called pktcdvd.
|
||||||
|
|
||||||
|
config CDROM_PKTCDVD_BUFFERS
|
||||||
|
int "Free buffers for data gathering"
|
||||||
|
depends on CDROM_PKTCDVD
|
||||||
|
default "8"
|
||||||
|
help
|
||||||
|
This controls the maximum number of active concurrent packets. More
|
||||||
|
concurrent packets can increase write performance, but also require
|
||||||
|
more memory. Each concurrent packet will require approximately 64Kb
|
||||||
|
of non-swappable kernel memory, memory which will be allocated when
|
||||||
|
a disc is opened for writing.
|
||||||
|
|
||||||
|
config CDROM_PKTCDVD_WCACHE
|
||||||
|
bool "Enable write caching"
|
||||||
|
depends on CDROM_PKTCDVD
|
||||||
|
help
|
||||||
|
If enabled, write caching will be set for the CD-R/W device. For now
|
||||||
|
this option is dangerous unless the CD-RW media is known good, as we
|
||||||
|
don't do deferred write error handling yet.
|
||||||
|
|
||||||
config ATA_OVER_ETH
|
config ATA_OVER_ETH
|
||||||
tristate "ATA over Ethernet support"
|
tristate "ATA over Ethernet support"
|
||||||
depends on NET
|
depends on NET
|
||||||
|
@ -20,6 +20,7 @@ obj-$(CONFIG_AMIGA_Z2RAM) += z2ram.o
|
|||||||
obj-$(CONFIG_N64CART) += n64cart.o
|
obj-$(CONFIG_N64CART) += n64cart.o
|
||||||
obj-$(CONFIG_BLK_DEV_RAM) += brd.o
|
obj-$(CONFIG_BLK_DEV_RAM) += brd.o
|
||||||
obj-$(CONFIG_BLK_DEV_LOOP) += loop.o
|
obj-$(CONFIG_BLK_DEV_LOOP) += loop.o
|
||||||
|
obj-$(CONFIG_CDROM_PKTCDVD) += pktcdvd.o
|
||||||
obj-$(CONFIG_SUNVDC) += sunvdc.o
|
obj-$(CONFIG_SUNVDC) += sunvdc.o
|
||||||
|
|
||||||
obj-$(CONFIG_BLK_DEV_NBD) += nbd.o
|
obj-$(CONFIG_BLK_DEV_NBD) += nbd.o
|
||||||
|
@ -1607,6 +1607,8 @@ void drbd_submit_bio(struct bio *bio)
|
|||||||
struct drbd_device *device = bio->bi_bdev->bd_disk->private_data;
|
struct drbd_device *device = bio->bi_bdev->bd_disk->private_data;
|
||||||
|
|
||||||
bio = bio_split_to_limits(bio);
|
bio = bio_split_to_limits(bio);
|
||||||
|
if (!bio)
|
||||||
|
return;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* what we "blindly" assume:
|
* what we "blindly" assume:
|
||||||
|
2944
drivers/block/pktcdvd.c
Normal file
2944
drivers/block/pktcdvd.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -587,6 +587,8 @@ static void ps3vram_submit_bio(struct bio *bio)
|
|||||||
dev_dbg(&dev->core, "%s\n", __func__);
|
dev_dbg(&dev->core, "%s\n", __func__);
|
||||||
|
|
||||||
bio = bio_split_to_limits(bio);
|
bio = bio_split_to_limits(bio);
|
||||||
|
if (!bio)
|
||||||
|
return;
|
||||||
|
|
||||||
spin_lock_irq(&priv->lock);
|
spin_lock_irq(&priv->lock);
|
||||||
busy = !bio_list_empty(&priv->list);
|
busy = !bio_list_empty(&priv->list);
|
||||||
|
@ -1992,6 +1992,9 @@ static int ublk_ctrl_uring_cmd(struct io_uring_cmd *cmd,
|
|||||||
struct ublksrv_ctrl_cmd *header = (struct ublksrv_ctrl_cmd *)cmd->cmd;
|
struct ublksrv_ctrl_cmd *header = (struct ublksrv_ctrl_cmd *)cmd->cmd;
|
||||||
int ret = -EINVAL;
|
int ret = -EINVAL;
|
||||||
|
|
||||||
|
if (issue_flags & IO_URING_F_NONBLOCK)
|
||||||
|
return -EAGAIN;
|
||||||
|
|
||||||
ublk_ctrl_cmd_dump(cmd);
|
ublk_ctrl_cmd_dump(cmd);
|
||||||
|
|
||||||
if (!(issue_flags & IO_URING_F_SQE128))
|
if (!(issue_flags & IO_URING_F_SQE128))
|
||||||
|
@ -524,7 +524,7 @@ static int xen_vbd_create(struct xen_blkif *blkif, blkif_vdev_t handle,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xen_blkbk_remove(struct xenbus_device *dev)
|
static void xen_blkbk_remove(struct xenbus_device *dev)
|
||||||
{
|
{
|
||||||
struct backend_info *be = dev_get_drvdata(&dev->dev);
|
struct backend_info *be = dev_get_drvdata(&dev->dev);
|
||||||
|
|
||||||
@ -547,8 +547,6 @@ static int xen_blkbk_remove(struct xenbus_device *dev)
|
|||||||
/* Put the reference we set in xen_blkif_alloc(). */
|
/* Put the reference we set in xen_blkif_alloc(). */
|
||||||
xen_blkif_put(be->blkif);
|
xen_blkif_put(be->blkif);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int xen_blkbk_flush_diskcache(struct xenbus_transaction xbt,
|
int xen_blkbk_flush_diskcache(struct xenbus_transaction xbt,
|
||||||
|
@ -2467,7 +2467,7 @@ static void blkback_changed(struct xenbus_device *dev,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int blkfront_remove(struct xenbus_device *xbdev)
|
static void blkfront_remove(struct xenbus_device *xbdev)
|
||||||
{
|
{
|
||||||
struct blkfront_info *info = dev_get_drvdata(&xbdev->dev);
|
struct blkfront_info *info = dev_get_drvdata(&xbdev->dev);
|
||||||
|
|
||||||
@ -2488,7 +2488,6 @@ static int blkfront_remove(struct xenbus_device *xbdev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
kfree(info);
|
kfree(info);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int blkfront_is_ready(struct xenbus_device *dev)
|
static int blkfront_is_ready(struct xenbus_device *dev)
|
||||||
|
@ -412,7 +412,9 @@ int tpm_pm_suspend(struct device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
suspended:
|
suspended:
|
||||||
return rc;
|
if (rc)
|
||||||
|
dev_err(dev, "Ignoring error %d while suspending\n", rc);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(tpm_pm_suspend);
|
EXPORT_SYMBOL_GPL(tpm_pm_suspend);
|
||||||
|
|
||||||
|
@ -360,14 +360,13 @@ static int tpmfront_probe(struct xenbus_device *dev,
|
|||||||
return tpm_chip_register(priv->chip);
|
return tpm_chip_register(priv->chip);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tpmfront_remove(struct xenbus_device *dev)
|
static void tpmfront_remove(struct xenbus_device *dev)
|
||||||
{
|
{
|
||||||
struct tpm_chip *chip = dev_get_drvdata(&dev->dev);
|
struct tpm_chip *chip = dev_get_drvdata(&dev->dev);
|
||||||
struct tpm_private *priv = dev_get_drvdata(&chip->dev);
|
struct tpm_private *priv = dev_get_drvdata(&chip->dev);
|
||||||
tpm_chip_unregister(chip);
|
tpm_chip_unregister(chip);
|
||||||
ring_free(priv);
|
ring_free(priv);
|
||||||
dev_set_drvdata(&chip->dev, NULL);
|
dev_set_drvdata(&chip->dev, NULL);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tpmfront_resume(struct xenbus_device *dev)
|
static int tpmfront_resume(struct xenbus_device *dev)
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
* Microchip / Atmel ECC (I2C) driver.
|
* Microchip / Atmel ECC (I2C) driver.
|
||||||
*
|
*
|
||||||
* Copyright (c) 2017, Microchip Technology Inc.
|
* Copyright (c) 2017, Microchip Technology Inc.
|
||||||
* Author: Tudor Ambarus <tudor.ambarus@microchip.com>
|
* Author: Tudor Ambarus
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
@ -411,6 +411,6 @@ static void __exit atmel_ecc_exit(void)
|
|||||||
module_init(atmel_ecc_init);
|
module_init(atmel_ecc_init);
|
||||||
module_exit(atmel_ecc_exit);
|
module_exit(atmel_ecc_exit);
|
||||||
|
|
||||||
MODULE_AUTHOR("Tudor Ambarus <tudor.ambarus@microchip.com>");
|
MODULE_AUTHOR("Tudor Ambarus");
|
||||||
MODULE_DESCRIPTION("Microchip / Atmel ECC (I2C) driver");
|
MODULE_DESCRIPTION("Microchip / Atmel ECC (I2C) driver");
|
||||||
MODULE_LICENSE("GPL v2");
|
MODULE_LICENSE("GPL v2");
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
* Microchip / Atmel ECC (I2C) driver.
|
* Microchip / Atmel ECC (I2C) driver.
|
||||||
*
|
*
|
||||||
* Copyright (c) 2017, Microchip Technology Inc.
|
* Copyright (c) 2017, Microchip Technology Inc.
|
||||||
* Author: Tudor Ambarus <tudor.ambarus@microchip.com>
|
* Author: Tudor Ambarus
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/bitrev.h>
|
#include <linux/bitrev.h>
|
||||||
@ -390,6 +390,6 @@ static void __exit atmel_i2c_exit(void)
|
|||||||
module_init(atmel_i2c_init);
|
module_init(atmel_i2c_init);
|
||||||
module_exit(atmel_i2c_exit);
|
module_exit(atmel_i2c_exit);
|
||||||
|
|
||||||
MODULE_AUTHOR("Tudor Ambarus <tudor.ambarus@microchip.com>");
|
MODULE_AUTHOR("Tudor Ambarus");
|
||||||
MODULE_DESCRIPTION("Microchip / Atmel ECC (I2C) driver");
|
MODULE_DESCRIPTION("Microchip / Atmel ECC (I2C) driver");
|
||||||
MODULE_LICENSE("GPL v2");
|
MODULE_LICENSE("GPL v2");
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/* SPDX-License-Identifier: GPL-2.0 */
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2017, Microchip Technology Inc.
|
* Copyright (c) 2017, Microchip Technology Inc.
|
||||||
* Author: Tudor Ambarus <tudor.ambarus@microchip.com>
|
* Author: Tudor Ambarus
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __ATMEL_I2C_H__
|
#ifndef __ATMEL_I2C_H__
|
||||||
|
@ -104,7 +104,7 @@ int caam_process_blob(struct caam_blob_priv *priv,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ctrlpriv = dev_get_drvdata(jrdev->parent);
|
ctrlpriv = dev_get_drvdata(jrdev->parent);
|
||||||
moo = FIELD_GET(CSTA_MOO, ioread32(&ctrlpriv->ctrl->perfmon.status));
|
moo = FIELD_GET(CSTA_MOO, rd_reg32(&ctrlpriv->ctrl->perfmon.status));
|
||||||
if (moo != CSTA_MOO_SECURE && moo != CSTA_MOO_TRUSTED)
|
if (moo != CSTA_MOO_SECURE && moo != CSTA_MOO_TRUSTED)
|
||||||
dev_warn(jrdev,
|
dev_warn(jrdev,
|
||||||
"using insecure test key, enable HAB to use unique device key!\n");
|
"using insecure test key, enable HAB to use unique device key!\n");
|
||||||
|
@ -168,14 +168,11 @@ void dma_buf_uninit_sysfs_statistics(void)
|
|||||||
kset_unregister(dma_buf_stats_kset);
|
kset_unregister(dma_buf_stats_kset);
|
||||||
}
|
}
|
||||||
|
|
||||||
int dma_buf_stats_setup(struct dma_buf *dmabuf)
|
int dma_buf_stats_setup(struct dma_buf *dmabuf, struct file *file)
|
||||||
{
|
{
|
||||||
struct dma_buf_sysfs_entry *sysfs_entry;
|
struct dma_buf_sysfs_entry *sysfs_entry;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!dmabuf || !dmabuf->file)
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
if (!dmabuf->exp_name) {
|
if (!dmabuf->exp_name) {
|
||||||
pr_err("exporter name must not be empty if stats needed\n");
|
pr_err("exporter name must not be empty if stats needed\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -192,7 +189,7 @@ int dma_buf_stats_setup(struct dma_buf *dmabuf)
|
|||||||
|
|
||||||
/* create the directory for buffer stats */
|
/* create the directory for buffer stats */
|
||||||
ret = kobject_init_and_add(&sysfs_entry->kobj, &dma_buf_ktype, NULL,
|
ret = kobject_init_and_add(&sysfs_entry->kobj, &dma_buf_ktype, NULL,
|
||||||
"%lu", file_inode(dmabuf->file)->i_ino);
|
"%lu", file_inode(file)->i_ino);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_sysfs_dmabuf;
|
goto err_sysfs_dmabuf;
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
int dma_buf_init_sysfs_statistics(void);
|
int dma_buf_init_sysfs_statistics(void);
|
||||||
void dma_buf_uninit_sysfs_statistics(void);
|
void dma_buf_uninit_sysfs_statistics(void);
|
||||||
|
|
||||||
int dma_buf_stats_setup(struct dma_buf *dmabuf);
|
int dma_buf_stats_setup(struct dma_buf *dmabuf, struct file *file);
|
||||||
|
|
||||||
void dma_buf_stats_teardown(struct dma_buf *dmabuf);
|
void dma_buf_stats_teardown(struct dma_buf *dmabuf);
|
||||||
#else
|
#else
|
||||||
@ -25,7 +25,7 @@ static inline int dma_buf_init_sysfs_statistics(void)
|
|||||||
|
|
||||||
static inline void dma_buf_uninit_sysfs_statistics(void) {}
|
static inline void dma_buf_uninit_sysfs_statistics(void) {}
|
||||||
|
|
||||||
static inline int dma_buf_stats_setup(struct dma_buf *dmabuf)
|
static inline int dma_buf_stats_setup(struct dma_buf *dmabuf, struct file *file)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -95,10 +95,11 @@ static int dma_buf_file_release(struct inode *inode, struct file *file)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
dmabuf = file->private_data;
|
dmabuf = file->private_data;
|
||||||
|
if (dmabuf) {
|
||||||
mutex_lock(&db_list.lock);
|
mutex_lock(&db_list.lock);
|
||||||
list_del(&dmabuf->list_node);
|
list_del(&dmabuf->list_node);
|
||||||
mutex_unlock(&db_list.lock);
|
mutex_unlock(&db_list.lock);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -528,17 +529,17 @@ static inline int is_dma_buf_file(struct file *file)
|
|||||||
return file->f_op == &dma_buf_fops;
|
return file->f_op == &dma_buf_fops;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct file *dma_buf_getfile(struct dma_buf *dmabuf, int flags)
|
static struct file *dma_buf_getfile(size_t size, int flags)
|
||||||
{
|
{
|
||||||
static atomic64_t dmabuf_inode = ATOMIC64_INIT(0);
|
static atomic64_t dmabuf_inode = ATOMIC64_INIT(0);
|
||||||
struct file *file;
|
|
||||||
struct inode *inode = alloc_anon_inode(dma_buf_mnt->mnt_sb);
|
struct inode *inode = alloc_anon_inode(dma_buf_mnt->mnt_sb);
|
||||||
|
struct file *file;
|
||||||
|
|
||||||
if (IS_ERR(inode))
|
if (IS_ERR(inode))
|
||||||
return ERR_CAST(inode);
|
return ERR_CAST(inode);
|
||||||
|
|
||||||
inode->i_size = dmabuf->size;
|
inode->i_size = size;
|
||||||
inode_set_bytes(inode, dmabuf->size);
|
inode_set_bytes(inode, size);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The ->i_ino acquired from get_next_ino() is not unique thus
|
* The ->i_ino acquired from get_next_ino() is not unique thus
|
||||||
@ -552,8 +553,6 @@ static struct file *dma_buf_getfile(struct dma_buf *dmabuf, int flags)
|
|||||||
flags, &dma_buf_fops);
|
flags, &dma_buf_fops);
|
||||||
if (IS_ERR(file))
|
if (IS_ERR(file))
|
||||||
goto err_alloc_file;
|
goto err_alloc_file;
|
||||||
file->private_data = dmabuf;
|
|
||||||
file->f_path.dentry->d_fsdata = dmabuf;
|
|
||||||
|
|
||||||
return file;
|
return file;
|
||||||
|
|
||||||
@ -619,19 +618,11 @@ struct dma_buf *dma_buf_export(const struct dma_buf_export_info *exp_info)
|
|||||||
size_t alloc_size = sizeof(struct dma_buf);
|
size_t alloc_size = sizeof(struct dma_buf);
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!exp_info->resv)
|
if (WARN_ON(!exp_info->priv || !exp_info->ops
|
||||||
alloc_size += sizeof(struct dma_resv);
|
|| !exp_info->ops->map_dma_buf
|
||||||
else
|
|| !exp_info->ops->unmap_dma_buf
|
||||||
/* prevent &dma_buf[1] == dma_buf->resv */
|
|| !exp_info->ops->release))
|
||||||
alloc_size += 1;
|
|
||||||
|
|
||||||
if (WARN_ON(!exp_info->priv
|
|
||||||
|| !exp_info->ops
|
|
||||||
|| !exp_info->ops->map_dma_buf
|
|
||||||
|| !exp_info->ops->unmap_dma_buf
|
|
||||||
|| !exp_info->ops->release)) {
|
|
||||||
return ERR_PTR(-EINVAL);
|
return ERR_PTR(-EINVAL);
|
||||||
}
|
|
||||||
|
|
||||||
if (WARN_ON(exp_info->ops->cache_sgt_mapping &&
|
if (WARN_ON(exp_info->ops->cache_sgt_mapping &&
|
||||||
(exp_info->ops->pin || exp_info->ops->unpin)))
|
(exp_info->ops->pin || exp_info->ops->unpin)))
|
||||||
@ -643,10 +634,21 @@ struct dma_buf *dma_buf_export(const struct dma_buf_export_info *exp_info)
|
|||||||
if (!try_module_get(exp_info->owner))
|
if (!try_module_get(exp_info->owner))
|
||||||
return ERR_PTR(-ENOENT);
|
return ERR_PTR(-ENOENT);
|
||||||
|
|
||||||
|
file = dma_buf_getfile(exp_info->size, exp_info->flags);
|
||||||
|
if (IS_ERR(file)) {
|
||||||
|
ret = PTR_ERR(file);
|
||||||
|
goto err_module;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!exp_info->resv)
|
||||||
|
alloc_size += sizeof(struct dma_resv);
|
||||||
|
else
|
||||||
|
/* prevent &dma_buf[1] == dma_buf->resv */
|
||||||
|
alloc_size += 1;
|
||||||
dmabuf = kzalloc(alloc_size, GFP_KERNEL);
|
dmabuf = kzalloc(alloc_size, GFP_KERNEL);
|
||||||
if (!dmabuf) {
|
if (!dmabuf) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto err_module;
|
goto err_file;
|
||||||
}
|
}
|
||||||
|
|
||||||
dmabuf->priv = exp_info->priv;
|
dmabuf->priv = exp_info->priv;
|
||||||
@ -658,43 +660,35 @@ struct dma_buf *dma_buf_export(const struct dma_buf_export_info *exp_info)
|
|||||||
init_waitqueue_head(&dmabuf->poll);
|
init_waitqueue_head(&dmabuf->poll);
|
||||||
dmabuf->cb_in.poll = dmabuf->cb_out.poll = &dmabuf->poll;
|
dmabuf->cb_in.poll = dmabuf->cb_out.poll = &dmabuf->poll;
|
||||||
dmabuf->cb_in.active = dmabuf->cb_out.active = 0;
|
dmabuf->cb_in.active = dmabuf->cb_out.active = 0;
|
||||||
|
INIT_LIST_HEAD(&dmabuf->attachments);
|
||||||
|
|
||||||
if (!resv) {
|
if (!resv) {
|
||||||
resv = (struct dma_resv *)&dmabuf[1];
|
dmabuf->resv = (struct dma_resv *)&dmabuf[1];
|
||||||
dma_resv_init(resv);
|
dma_resv_init(dmabuf->resv);
|
||||||
|
} else {
|
||||||
|
dmabuf->resv = resv;
|
||||||
}
|
}
|
||||||
dmabuf->resv = resv;
|
|
||||||
|
|
||||||
file = dma_buf_getfile(dmabuf, exp_info->flags);
|
ret = dma_buf_stats_setup(dmabuf, file);
|
||||||
if (IS_ERR(file)) {
|
if (ret)
|
||||||
ret = PTR_ERR(file);
|
|
||||||
goto err_dmabuf;
|
goto err_dmabuf;
|
||||||
}
|
|
||||||
|
|
||||||
|
file->private_data = dmabuf;
|
||||||
|
file->f_path.dentry->d_fsdata = dmabuf;
|
||||||
dmabuf->file = file;
|
dmabuf->file = file;
|
||||||
|
|
||||||
INIT_LIST_HEAD(&dmabuf->attachments);
|
|
||||||
|
|
||||||
mutex_lock(&db_list.lock);
|
mutex_lock(&db_list.lock);
|
||||||
list_add(&dmabuf->list_node, &db_list.head);
|
list_add(&dmabuf->list_node, &db_list.head);
|
||||||
mutex_unlock(&db_list.lock);
|
mutex_unlock(&db_list.lock);
|
||||||
|
|
||||||
ret = dma_buf_stats_setup(dmabuf);
|
|
||||||
if (ret)
|
|
||||||
goto err_sysfs;
|
|
||||||
|
|
||||||
return dmabuf;
|
return dmabuf;
|
||||||
|
|
||||||
err_sysfs:
|
|
||||||
/*
|
|
||||||
* Set file->f_path.dentry->d_fsdata to NULL so that when
|
|
||||||
* dma_buf_release() gets invoked by dentry_ops, it exits
|
|
||||||
* early before calling the release() dma_buf op.
|
|
||||||
*/
|
|
||||||
file->f_path.dentry->d_fsdata = NULL;
|
|
||||||
fput(file);
|
|
||||||
err_dmabuf:
|
err_dmabuf:
|
||||||
|
if (!resv)
|
||||||
|
dma_resv_fini(dmabuf->resv);
|
||||||
kfree(dmabuf);
|
kfree(dmabuf);
|
||||||
|
err_file:
|
||||||
|
fput(file);
|
||||||
err_module:
|
err_module:
|
||||||
module_put(exp_info->owner);
|
module_put(exp_info->owner);
|
||||||
return ERR_PTR(ret);
|
return ERR_PTR(ret);
|
||||||
|
@ -195,6 +195,7 @@ extern int amdgpu_emu_mode;
|
|||||||
extern uint amdgpu_smu_memory_pool_size;
|
extern uint amdgpu_smu_memory_pool_size;
|
||||||
extern int amdgpu_smu_pptable_id;
|
extern int amdgpu_smu_pptable_id;
|
||||||
extern uint amdgpu_dc_feature_mask;
|
extern uint amdgpu_dc_feature_mask;
|
||||||
|
extern uint amdgpu_freesync_vid_mode;
|
||||||
extern uint amdgpu_dc_debug_mask;
|
extern uint amdgpu_dc_debug_mask;
|
||||||
extern uint amdgpu_dc_visual_confirm;
|
extern uint amdgpu_dc_visual_confirm;
|
||||||
extern uint amdgpu_dm_abm_level;
|
extern uint amdgpu_dm_abm_level;
|
||||||
|
@ -181,6 +181,7 @@ int amdgpu_mes_kiq;
|
|||||||
int amdgpu_noretry = -1;
|
int amdgpu_noretry = -1;
|
||||||
int amdgpu_force_asic_type = -1;
|
int amdgpu_force_asic_type = -1;
|
||||||
int amdgpu_tmz = -1; /* auto */
|
int amdgpu_tmz = -1; /* auto */
|
||||||
|
uint amdgpu_freesync_vid_mode;
|
||||||
int amdgpu_reset_method = -1; /* auto */
|
int amdgpu_reset_method = -1; /* auto */
|
||||||
int amdgpu_num_kcq = -1;
|
int amdgpu_num_kcq = -1;
|
||||||
int amdgpu_smartshift_bias;
|
int amdgpu_smartshift_bias;
|
||||||
@ -879,6 +880,32 @@ module_param_named(backlight, amdgpu_backlight, bint, 0444);
|
|||||||
MODULE_PARM_DESC(tmz, "Enable TMZ feature (-1 = auto (default), 0 = off, 1 = on)");
|
MODULE_PARM_DESC(tmz, "Enable TMZ feature (-1 = auto (default), 0 = off, 1 = on)");
|
||||||
module_param_named(tmz, amdgpu_tmz, int, 0444);
|
module_param_named(tmz, amdgpu_tmz, int, 0444);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DOC: freesync_video (uint)
|
||||||
|
* Enable the optimization to adjust front porch timing to achieve seamless
|
||||||
|
* mode change experience when setting a freesync supported mode for which full
|
||||||
|
* modeset is not needed.
|
||||||
|
*
|
||||||
|
* The Display Core will add a set of modes derived from the base FreeSync
|
||||||
|
* video mode into the corresponding connector's mode list based on commonly
|
||||||
|
* used refresh rates and VRR range of the connected display, when users enable
|
||||||
|
* this feature. From the userspace perspective, they can see a seamless mode
|
||||||
|
* change experience when the change between different refresh rates under the
|
||||||
|
* same resolution. Additionally, userspace applications such as Video playback
|
||||||
|
* can read this modeset list and change the refresh rate based on the video
|
||||||
|
* frame rate. Finally, the userspace can also derive an appropriate mode for a
|
||||||
|
* particular refresh rate based on the FreeSync Mode and add it to the
|
||||||
|
* connector's mode list.
|
||||||
|
*
|
||||||
|
* Note: This is an experimental feature.
|
||||||
|
*
|
||||||
|
* The default value: 0 (off).
|
||||||
|
*/
|
||||||
|
MODULE_PARM_DESC(
|
||||||
|
freesync_video,
|
||||||
|
"Enable freesync modesetting optimization feature (0 = off (default), 1 = on)");
|
||||||
|
module_param_named(freesync_video, amdgpu_freesync_vid_mode, uint, 0444);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DOC: reset_method (int)
|
* DOC: reset_method (int)
|
||||||
* GPU reset method (-1 = auto (default), 0 = legacy, 1 = mode0, 2 = mode1, 3 = mode2, 4 = baco)
|
* GPU reset method (-1 = auto (default), 0 = legacy, 1 = mode0, 2 = mode1, 3 = mode2, 4 = baco)
|
||||||
|
@ -801,7 +801,7 @@ static int kfd_build_sysfs_node_entry(struct kfd_topology_device *dev,
|
|||||||
|
|
||||||
p2plink->attr.name = "properties";
|
p2plink->attr.name = "properties";
|
||||||
p2plink->attr.mode = KFD_SYSFS_FILE_MODE;
|
p2plink->attr.mode = KFD_SYSFS_FILE_MODE;
|
||||||
sysfs_attr_init(&iolink->attr);
|
sysfs_attr_init(&p2plink->attr);
|
||||||
ret = sysfs_create_file(p2plink->kobj, &p2plink->attr);
|
ret = sysfs_create_file(p2plink->kobj, &p2plink->attr);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -5835,7 +5835,8 @@ create_stream_for_sink(struct amdgpu_dm_connector *aconnector,
|
|||||||
*/
|
*/
|
||||||
DRM_DEBUG_DRIVER("No preferred mode found\n");
|
DRM_DEBUG_DRIVER("No preferred mode found\n");
|
||||||
} else {
|
} else {
|
||||||
recalculate_timing = is_freesync_video_mode(&mode, aconnector);
|
recalculate_timing = amdgpu_freesync_vid_mode &&
|
||||||
|
is_freesync_video_mode(&mode, aconnector);
|
||||||
if (recalculate_timing) {
|
if (recalculate_timing) {
|
||||||
freesync_mode = get_highest_refresh_rate_mode(aconnector, false);
|
freesync_mode = get_highest_refresh_rate_mode(aconnector, false);
|
||||||
drm_mode_copy(&saved_mode, &mode);
|
drm_mode_copy(&saved_mode, &mode);
|
||||||
@ -6986,7 +6987,7 @@ static void amdgpu_dm_connector_add_freesync_modes(struct drm_connector *connect
|
|||||||
struct amdgpu_dm_connector *amdgpu_dm_connector =
|
struct amdgpu_dm_connector *amdgpu_dm_connector =
|
||||||
to_amdgpu_dm_connector(connector);
|
to_amdgpu_dm_connector(connector);
|
||||||
|
|
||||||
if (!edid)
|
if (!(amdgpu_freesync_vid_mode && edid))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (amdgpu_dm_connector->max_vfreq - amdgpu_dm_connector->min_vfreq > 10)
|
if (amdgpu_dm_connector->max_vfreq - amdgpu_dm_connector->min_vfreq > 10)
|
||||||
@ -8850,7 +8851,8 @@ static int dm_update_crtc_state(struct amdgpu_display_manager *dm,
|
|||||||
* TODO: Refactor this function to allow this check to work
|
* TODO: Refactor this function to allow this check to work
|
||||||
* in all conditions.
|
* in all conditions.
|
||||||
*/
|
*/
|
||||||
if (dm_new_crtc_state->stream &&
|
if (amdgpu_freesync_vid_mode &&
|
||||||
|
dm_new_crtc_state->stream &&
|
||||||
is_timing_unchanged_for_freesync(new_crtc_state, old_crtc_state))
|
is_timing_unchanged_for_freesync(new_crtc_state, old_crtc_state))
|
||||||
goto skip_modeset;
|
goto skip_modeset;
|
||||||
|
|
||||||
@ -8885,7 +8887,7 @@ static int dm_update_crtc_state(struct amdgpu_display_manager *dm,
|
|||||||
if (!dm_old_crtc_state->stream)
|
if (!dm_old_crtc_state->stream)
|
||||||
goto skip_modeset;
|
goto skip_modeset;
|
||||||
|
|
||||||
if (dm_new_crtc_state->stream &&
|
if (amdgpu_freesync_vid_mode && dm_new_crtc_state->stream &&
|
||||||
is_timing_unchanged_for_freesync(new_crtc_state,
|
is_timing_unchanged_for_freesync(new_crtc_state,
|
||||||
old_crtc_state)) {
|
old_crtc_state)) {
|
||||||
new_crtc_state->mode_changed = false;
|
new_crtc_state->mode_changed = false;
|
||||||
@ -8897,7 +8899,7 @@ static int dm_update_crtc_state(struct amdgpu_display_manager *dm,
|
|||||||
set_freesync_fixed_config(dm_new_crtc_state);
|
set_freesync_fixed_config(dm_new_crtc_state);
|
||||||
|
|
||||||
goto skip_modeset;
|
goto skip_modeset;
|
||||||
} else if (aconnector &&
|
} else if (amdgpu_freesync_vid_mode && aconnector &&
|
||||||
is_freesync_video_mode(&new_crtc_state->mode,
|
is_freesync_video_mode(&new_crtc_state->mode,
|
||||||
aconnector)) {
|
aconnector)) {
|
||||||
struct drm_display_mode *high_mode;
|
struct drm_display_mode *high_mode;
|
||||||
|
@ -6257,12 +6257,12 @@ bool dml32_CalculateDETSwathFillLatencyHiding(unsigned int NumberOfActiveSurface
|
|||||||
double SwathSizePerSurfaceC[DC__NUM_DPP__MAX];
|
double SwathSizePerSurfaceC[DC__NUM_DPP__MAX];
|
||||||
bool NotEnoughDETSwathFillLatencyHiding = false;
|
bool NotEnoughDETSwathFillLatencyHiding = false;
|
||||||
|
|
||||||
/* calculate sum of single swath size for all pipes in bytes*/
|
/* calculate sum of single swath size for all pipes in bytes */
|
||||||
for (k = 0; k < NumberOfActiveSurfaces; k++) {
|
for (k = 0; k < NumberOfActiveSurfaces; k++) {
|
||||||
SwathSizePerSurfaceY[k] += SwathHeightY[k] * SwathWidthY[k] * BytePerPixelInDETY[k] * NumOfDPP[k];
|
SwathSizePerSurfaceY[k] = SwathHeightY[k] * SwathWidthY[k] * BytePerPixelInDETY[k] * NumOfDPP[k];
|
||||||
|
|
||||||
if (SwathHeightC[k] != 0)
|
if (SwathHeightC[k] != 0)
|
||||||
SwathSizePerSurfaceC[k] += SwathHeightC[k] * SwathWidthC[k] * BytePerPixelInDETC[k] * NumOfDPP[k];
|
SwathSizePerSurfaceC[k] = SwathHeightC[k] * SwathWidthC[k] * BytePerPixelInDETC[k] * NumOfDPP[k];
|
||||||
else
|
else
|
||||||
SwathSizePerSurfaceC[k] = 0;
|
SwathSizePerSurfaceC[k] = 0;
|
||||||
|
|
||||||
|
@ -151,6 +151,22 @@ DEFINE_SIMPLE_ATTRIBUTE(vgpu_scan_nonprivbb_fops,
|
|||||||
vgpu_scan_nonprivbb_get, vgpu_scan_nonprivbb_set,
|
vgpu_scan_nonprivbb_get, vgpu_scan_nonprivbb_set,
|
||||||
"0x%llx\n");
|
"0x%llx\n");
|
||||||
|
|
||||||
|
static int vgpu_status_get(void *data, u64 *val)
|
||||||
|
{
|
||||||
|
struct intel_vgpu *vgpu = (struct intel_vgpu *)data;
|
||||||
|
|
||||||
|
*val = 0;
|
||||||
|
|
||||||
|
if (test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
|
*val |= (1 << INTEL_VGPU_STATUS_ATTACHED);
|
||||||
|
if (test_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status))
|
||||||
|
*val |= (1 << INTEL_VGPU_STATUS_ACTIVE);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFINE_SIMPLE_ATTRIBUTE(vgpu_status_fops, vgpu_status_get, NULL, "0x%llx\n");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* intel_gvt_debugfs_add_vgpu - register debugfs entries for a vGPU
|
* intel_gvt_debugfs_add_vgpu - register debugfs entries for a vGPU
|
||||||
* @vgpu: a vGPU
|
* @vgpu: a vGPU
|
||||||
@ -162,11 +178,12 @@ void intel_gvt_debugfs_add_vgpu(struct intel_vgpu *vgpu)
|
|||||||
snprintf(name, 16, "vgpu%d", vgpu->id);
|
snprintf(name, 16, "vgpu%d", vgpu->id);
|
||||||
vgpu->debugfs = debugfs_create_dir(name, vgpu->gvt->debugfs_root);
|
vgpu->debugfs = debugfs_create_dir(name, vgpu->gvt->debugfs_root);
|
||||||
|
|
||||||
debugfs_create_bool("active", 0444, vgpu->debugfs, &vgpu->active);
|
|
||||||
debugfs_create_file("mmio_diff", 0444, vgpu->debugfs, vgpu,
|
debugfs_create_file("mmio_diff", 0444, vgpu->debugfs, vgpu,
|
||||||
&vgpu_mmio_diff_fops);
|
&vgpu_mmio_diff_fops);
|
||||||
debugfs_create_file("scan_nonprivbb", 0644, vgpu->debugfs, vgpu,
|
debugfs_create_file("scan_nonprivbb", 0644, vgpu->debugfs, vgpu,
|
||||||
&vgpu_scan_nonprivbb_fops);
|
&vgpu_scan_nonprivbb_fops);
|
||||||
|
debugfs_create_file("status", 0644, vgpu->debugfs, vgpu,
|
||||||
|
&vgpu_status_fops);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -175,8 +192,13 @@ void intel_gvt_debugfs_add_vgpu(struct intel_vgpu *vgpu)
|
|||||||
*/
|
*/
|
||||||
void intel_gvt_debugfs_remove_vgpu(struct intel_vgpu *vgpu)
|
void intel_gvt_debugfs_remove_vgpu(struct intel_vgpu *vgpu)
|
||||||
{
|
{
|
||||||
debugfs_remove_recursive(vgpu->debugfs);
|
struct intel_gvt *gvt = vgpu->gvt;
|
||||||
vgpu->debugfs = NULL;
|
struct drm_minor *minor = gvt->gt->i915->drm.primary;
|
||||||
|
|
||||||
|
if (minor->debugfs_root && gvt->debugfs_root) {
|
||||||
|
debugfs_remove_recursive(vgpu->debugfs);
|
||||||
|
vgpu->debugfs = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -199,6 +221,10 @@ void intel_gvt_debugfs_init(struct intel_gvt *gvt)
|
|||||||
*/
|
*/
|
||||||
void intel_gvt_debugfs_clean(struct intel_gvt *gvt)
|
void intel_gvt_debugfs_clean(struct intel_gvt *gvt)
|
||||||
{
|
{
|
||||||
debugfs_remove_recursive(gvt->debugfs_root);
|
struct drm_minor *minor = gvt->gt->i915->drm.primary;
|
||||||
gvt->debugfs_root = NULL;
|
|
||||||
|
if (minor->debugfs_root) {
|
||||||
|
debugfs_remove_recursive(gvt->debugfs_root);
|
||||||
|
gvt->debugfs_root = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -134,7 +134,8 @@ static void dmabuf_gem_object_free(struct kref *kref)
|
|||||||
struct list_head *pos;
|
struct list_head *pos;
|
||||||
struct intel_vgpu_dmabuf_obj *dmabuf_obj;
|
struct intel_vgpu_dmabuf_obj *dmabuf_obj;
|
||||||
|
|
||||||
if (vgpu && vgpu->active && !list_empty(&vgpu->dmabuf_obj_list_head)) {
|
if (vgpu && test_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status) &&
|
||||||
|
!list_empty(&vgpu->dmabuf_obj_list_head)) {
|
||||||
list_for_each(pos, &vgpu->dmabuf_obj_list_head) {
|
list_for_each(pos, &vgpu->dmabuf_obj_list_head) {
|
||||||
dmabuf_obj = list_entry(pos, struct intel_vgpu_dmabuf_obj, list);
|
dmabuf_obj = list_entry(pos, struct intel_vgpu_dmabuf_obj, list);
|
||||||
if (dmabuf_obj == obj) {
|
if (dmabuf_obj == obj) {
|
||||||
|
@ -55,7 +55,7 @@ static bool intel_gvt_is_valid_gfn(struct intel_vgpu *vgpu, unsigned long gfn)
|
|||||||
int idx;
|
int idx;
|
||||||
bool ret;
|
bool ret;
|
||||||
|
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
idx = srcu_read_lock(&kvm->srcu);
|
idx = srcu_read_lock(&kvm->srcu);
|
||||||
@ -1178,7 +1178,7 @@ static int is_2MB_gtt_possible(struct intel_vgpu *vgpu,
|
|||||||
if (!HAS_PAGE_SIZES(vgpu->gvt->gt->i915, I915_GTT_PAGE_SIZE_2M))
|
if (!HAS_PAGE_SIZES(vgpu->gvt->gt->i915, I915_GTT_PAGE_SIZE_2M))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
pfn = gfn_to_pfn(vgpu->vfio_device.kvm, ops->get_pfn(entry));
|
pfn = gfn_to_pfn(vgpu->vfio_device.kvm, ops->get_pfn(entry));
|
||||||
if (is_error_noslot_pfn(pfn))
|
if (is_error_noslot_pfn(pfn))
|
||||||
@ -1209,10 +1209,8 @@ static int split_2MB_gtt_entry(struct intel_vgpu *vgpu,
|
|||||||
for_each_shadow_entry(sub_spt, &sub_se, sub_index) {
|
for_each_shadow_entry(sub_spt, &sub_se, sub_index) {
|
||||||
ret = intel_gvt_dma_map_guest_page(vgpu, start_gfn + sub_index,
|
ret = intel_gvt_dma_map_guest_page(vgpu, start_gfn + sub_index,
|
||||||
PAGE_SIZE, &dma_addr);
|
PAGE_SIZE, &dma_addr);
|
||||||
if (ret) {
|
if (ret)
|
||||||
ppgtt_invalidate_spt(spt);
|
goto err;
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
sub_se.val64 = se->val64;
|
sub_se.val64 = se->val64;
|
||||||
|
|
||||||
/* Copy the PAT field from PDE. */
|
/* Copy the PAT field from PDE. */
|
||||||
@ -1231,6 +1229,17 @@ static int split_2MB_gtt_entry(struct intel_vgpu *vgpu,
|
|||||||
ops->set_pfn(se, sub_spt->shadow_page.mfn);
|
ops->set_pfn(se, sub_spt->shadow_page.mfn);
|
||||||
ppgtt_set_shadow_entry(spt, se, index);
|
ppgtt_set_shadow_entry(spt, se, index);
|
||||||
return 0;
|
return 0;
|
||||||
|
err:
|
||||||
|
/* Cancel the existing addess mappings of DMA addr. */
|
||||||
|
for_each_present_shadow_entry(sub_spt, &sub_se, sub_index) {
|
||||||
|
gvt_vdbg_mm("invalidate 4K entry\n");
|
||||||
|
ppgtt_invalidate_pte(sub_spt, &sub_se);
|
||||||
|
}
|
||||||
|
/* Release the new allocated spt. */
|
||||||
|
trace_spt_change(sub_spt->vgpu->id, "release", sub_spt,
|
||||||
|
sub_spt->guest_page.gfn, sub_spt->shadow_page.type);
|
||||||
|
ppgtt_free_spt(sub_spt);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int split_64KB_gtt_entry(struct intel_vgpu *vgpu,
|
static int split_64KB_gtt_entry(struct intel_vgpu *vgpu,
|
||||||
|
@ -172,13 +172,18 @@ struct intel_vgpu_submission {
|
|||||||
|
|
||||||
#define KVMGT_DEBUGFS_FILENAME "kvmgt_nr_cache_entries"
|
#define KVMGT_DEBUGFS_FILENAME "kvmgt_nr_cache_entries"
|
||||||
|
|
||||||
|
enum {
|
||||||
|
INTEL_VGPU_STATUS_ATTACHED = 0,
|
||||||
|
INTEL_VGPU_STATUS_ACTIVE,
|
||||||
|
INTEL_VGPU_STATUS_NR_BITS,
|
||||||
|
};
|
||||||
|
|
||||||
struct intel_vgpu {
|
struct intel_vgpu {
|
||||||
struct vfio_device vfio_device;
|
struct vfio_device vfio_device;
|
||||||
struct intel_gvt *gvt;
|
struct intel_gvt *gvt;
|
||||||
struct mutex vgpu_lock;
|
struct mutex vgpu_lock;
|
||||||
int id;
|
int id;
|
||||||
bool active;
|
DECLARE_BITMAP(status, INTEL_VGPU_STATUS_NR_BITS);
|
||||||
bool attached;
|
|
||||||
bool pv_notified;
|
bool pv_notified;
|
||||||
bool failsafe;
|
bool failsafe;
|
||||||
unsigned int resetting_eng;
|
unsigned int resetting_eng;
|
||||||
@ -467,7 +472,7 @@ void intel_vgpu_write_fence(struct intel_vgpu *vgpu,
|
|||||||
|
|
||||||
#define for_each_active_vgpu(gvt, vgpu, id) \
|
#define for_each_active_vgpu(gvt, vgpu, id) \
|
||||||
idr_for_each_entry((&(gvt)->vgpu_idr), (vgpu), (id)) \
|
idr_for_each_entry((&(gvt)->vgpu_idr), (vgpu), (id)) \
|
||||||
for_each_if(vgpu->active)
|
for_each_if(test_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status))
|
||||||
|
|
||||||
static inline void intel_vgpu_write_pci_bar(struct intel_vgpu *vgpu,
|
static inline void intel_vgpu_write_pci_bar(struct intel_vgpu *vgpu,
|
||||||
u32 offset, u32 val, bool low)
|
u32 offset, u32 val, bool low)
|
||||||
@ -725,7 +730,7 @@ static inline bool intel_gvt_mmio_is_cmd_write_patch(
|
|||||||
static inline int intel_gvt_read_gpa(struct intel_vgpu *vgpu, unsigned long gpa,
|
static inline int intel_gvt_read_gpa(struct intel_vgpu *vgpu, unsigned long gpa,
|
||||||
void *buf, unsigned long len)
|
void *buf, unsigned long len)
|
||||||
{
|
{
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return -ESRCH;
|
return -ESRCH;
|
||||||
return vfio_dma_rw(&vgpu->vfio_device, gpa, buf, len, false);
|
return vfio_dma_rw(&vgpu->vfio_device, gpa, buf, len, false);
|
||||||
}
|
}
|
||||||
@ -743,7 +748,7 @@ static inline int intel_gvt_read_gpa(struct intel_vgpu *vgpu, unsigned long gpa,
|
|||||||
static inline int intel_gvt_write_gpa(struct intel_vgpu *vgpu,
|
static inline int intel_gvt_write_gpa(struct intel_vgpu *vgpu,
|
||||||
unsigned long gpa, void *buf, unsigned long len)
|
unsigned long gpa, void *buf, unsigned long len)
|
||||||
{
|
{
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return -ESRCH;
|
return -ESRCH;
|
||||||
return vfio_dma_rw(&vgpu->vfio_device, gpa, buf, len, true);
|
return vfio_dma_rw(&vgpu->vfio_device, gpa, buf, len, true);
|
||||||
}
|
}
|
||||||
|
@ -433,7 +433,7 @@ static int inject_virtual_interrupt(struct intel_vgpu *vgpu)
|
|||||||
* enabled by guest. so if msi_trigger is null, success is still
|
* enabled by guest. so if msi_trigger is null, success is still
|
||||||
* returned and don't inject interrupt into guest.
|
* returned and don't inject interrupt into guest.
|
||||||
*/
|
*/
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return -ESRCH;
|
return -ESRCH;
|
||||||
if (vgpu->msi_trigger && eventfd_signal(vgpu->msi_trigger, 1) != 1)
|
if (vgpu->msi_trigger && eventfd_signal(vgpu->msi_trigger, 1) != 1)
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
@ -638,7 +638,7 @@ static bool __kvmgt_vgpu_exist(struct intel_vgpu *vgpu)
|
|||||||
|
|
||||||
mutex_lock(&vgpu->gvt->lock);
|
mutex_lock(&vgpu->gvt->lock);
|
||||||
for_each_active_vgpu(vgpu->gvt, itr, id) {
|
for_each_active_vgpu(vgpu->gvt, itr, id) {
|
||||||
if (!itr->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, itr->status))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (vgpu->vfio_device.kvm == itr->vfio_device.kvm) {
|
if (vgpu->vfio_device.kvm == itr->vfio_device.kvm) {
|
||||||
@ -655,9 +655,6 @@ static int intel_vgpu_open_device(struct vfio_device *vfio_dev)
|
|||||||
{
|
{
|
||||||
struct intel_vgpu *vgpu = vfio_dev_to_vgpu(vfio_dev);
|
struct intel_vgpu *vgpu = vfio_dev_to_vgpu(vfio_dev);
|
||||||
|
|
||||||
if (vgpu->attached)
|
|
||||||
return -EEXIST;
|
|
||||||
|
|
||||||
if (!vgpu->vfio_device.kvm ||
|
if (!vgpu->vfio_device.kvm ||
|
||||||
vgpu->vfio_device.kvm->mm != current->mm) {
|
vgpu->vfio_device.kvm->mm != current->mm) {
|
||||||
gvt_vgpu_err("KVM is required to use Intel vGPU\n");
|
gvt_vgpu_err("KVM is required to use Intel vGPU\n");
|
||||||
@ -667,14 +664,14 @@ static int intel_vgpu_open_device(struct vfio_device *vfio_dev)
|
|||||||
if (__kvmgt_vgpu_exist(vgpu))
|
if (__kvmgt_vgpu_exist(vgpu))
|
||||||
return -EEXIST;
|
return -EEXIST;
|
||||||
|
|
||||||
vgpu->attached = true;
|
|
||||||
|
|
||||||
vgpu->track_node.track_write = kvmgt_page_track_write;
|
vgpu->track_node.track_write = kvmgt_page_track_write;
|
||||||
vgpu->track_node.track_flush_slot = kvmgt_page_track_flush_slot;
|
vgpu->track_node.track_flush_slot = kvmgt_page_track_flush_slot;
|
||||||
kvm_get_kvm(vgpu->vfio_device.kvm);
|
kvm_get_kvm(vgpu->vfio_device.kvm);
|
||||||
kvm_page_track_register_notifier(vgpu->vfio_device.kvm,
|
kvm_page_track_register_notifier(vgpu->vfio_device.kvm,
|
||||||
&vgpu->track_node);
|
&vgpu->track_node);
|
||||||
|
|
||||||
|
set_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status);
|
||||||
|
|
||||||
debugfs_create_ulong(KVMGT_DEBUGFS_FILENAME, 0444, vgpu->debugfs,
|
debugfs_create_ulong(KVMGT_DEBUGFS_FILENAME, 0444, vgpu->debugfs,
|
||||||
&vgpu->nr_cache_entries);
|
&vgpu->nr_cache_entries);
|
||||||
|
|
||||||
@ -698,11 +695,10 @@ static void intel_vgpu_close_device(struct vfio_device *vfio_dev)
|
|||||||
{
|
{
|
||||||
struct intel_vgpu *vgpu = vfio_dev_to_vgpu(vfio_dev);
|
struct intel_vgpu *vgpu = vfio_dev_to_vgpu(vfio_dev);
|
||||||
|
|
||||||
if (!vgpu->attached)
|
|
||||||
return;
|
|
||||||
|
|
||||||
intel_gvt_release_vgpu(vgpu);
|
intel_gvt_release_vgpu(vgpu);
|
||||||
|
|
||||||
|
clear_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status);
|
||||||
|
|
||||||
debugfs_remove(debugfs_lookup(KVMGT_DEBUGFS_FILENAME, vgpu->debugfs));
|
debugfs_remove(debugfs_lookup(KVMGT_DEBUGFS_FILENAME, vgpu->debugfs));
|
||||||
|
|
||||||
kvm_page_track_unregister_notifier(vgpu->vfio_device.kvm,
|
kvm_page_track_unregister_notifier(vgpu->vfio_device.kvm,
|
||||||
@ -718,8 +714,6 @@ static void intel_vgpu_close_device(struct vfio_device *vfio_dev)
|
|||||||
vgpu->dma_addr_cache = RB_ROOT;
|
vgpu->dma_addr_cache = RB_ROOT;
|
||||||
|
|
||||||
intel_vgpu_release_msi_eventfd_ctx(vgpu);
|
intel_vgpu_release_msi_eventfd_ctx(vgpu);
|
||||||
|
|
||||||
vgpu->attached = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static u64 intel_vgpu_get_bar_addr(struct intel_vgpu *vgpu, int bar)
|
static u64 intel_vgpu_get_bar_addr(struct intel_vgpu *vgpu, int bar)
|
||||||
@ -1512,9 +1506,6 @@ static void intel_vgpu_remove(struct mdev_device *mdev)
|
|||||||
{
|
{
|
||||||
struct intel_vgpu *vgpu = dev_get_drvdata(&mdev->dev);
|
struct intel_vgpu *vgpu = dev_get_drvdata(&mdev->dev);
|
||||||
|
|
||||||
if (WARN_ON_ONCE(vgpu->attached))
|
|
||||||
return;
|
|
||||||
|
|
||||||
vfio_unregister_group_dev(&vgpu->vfio_device);
|
vfio_unregister_group_dev(&vgpu->vfio_device);
|
||||||
vfio_put_device(&vgpu->vfio_device);
|
vfio_put_device(&vgpu->vfio_device);
|
||||||
}
|
}
|
||||||
@ -1559,7 +1550,7 @@ int intel_gvt_page_track_add(struct intel_vgpu *info, u64 gfn)
|
|||||||
struct kvm_memory_slot *slot;
|
struct kvm_memory_slot *slot;
|
||||||
int idx;
|
int idx;
|
||||||
|
|
||||||
if (!info->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, info->status))
|
||||||
return -ESRCH;
|
return -ESRCH;
|
||||||
|
|
||||||
idx = srcu_read_lock(&kvm->srcu);
|
idx = srcu_read_lock(&kvm->srcu);
|
||||||
@ -1589,8 +1580,8 @@ int intel_gvt_page_track_remove(struct intel_vgpu *info, u64 gfn)
|
|||||||
struct kvm_memory_slot *slot;
|
struct kvm_memory_slot *slot;
|
||||||
int idx;
|
int idx;
|
||||||
|
|
||||||
if (!info->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, info->status))
|
||||||
return 0;
|
return -ESRCH;
|
||||||
|
|
||||||
idx = srcu_read_lock(&kvm->srcu);
|
idx = srcu_read_lock(&kvm->srcu);
|
||||||
slot = gfn_to_memslot(kvm, gfn);
|
slot = gfn_to_memslot(kvm, gfn);
|
||||||
@ -1668,7 +1659,7 @@ int intel_gvt_dma_map_guest_page(struct intel_vgpu *vgpu, unsigned long gfn,
|
|||||||
struct gvt_dma *entry;
|
struct gvt_dma *entry;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
mutex_lock(&vgpu->cache_lock);
|
mutex_lock(&vgpu->cache_lock);
|
||||||
@ -1714,8 +1705,8 @@ int intel_gvt_dma_pin_guest_page(struct intel_vgpu *vgpu, dma_addr_t dma_addr)
|
|||||||
struct gvt_dma *entry;
|
struct gvt_dma *entry;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return -ENODEV;
|
return -EINVAL;
|
||||||
|
|
||||||
mutex_lock(&vgpu->cache_lock);
|
mutex_lock(&vgpu->cache_lock);
|
||||||
entry = __gvt_cache_find_dma_addr(vgpu, dma_addr);
|
entry = __gvt_cache_find_dma_addr(vgpu, dma_addr);
|
||||||
@ -1742,7 +1733,7 @@ void intel_gvt_dma_unmap_guest_page(struct intel_vgpu *vgpu,
|
|||||||
{
|
{
|
||||||
struct gvt_dma *entry;
|
struct gvt_dma *entry;
|
||||||
|
|
||||||
if (!vgpu->attached)
|
if (!test_bit(INTEL_VGPU_STATUS_ATTACHED, vgpu->status))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
mutex_lock(&vgpu->cache_lock);
|
mutex_lock(&vgpu->cache_lock);
|
||||||
@ -1778,7 +1769,7 @@ static void intel_gvt_test_and_emulate_vblank(struct intel_gvt *gvt)
|
|||||||
idr_for_each_entry((&(gvt)->vgpu_idr), (vgpu), (id)) {
|
idr_for_each_entry((&(gvt)->vgpu_idr), (vgpu), (id)) {
|
||||||
if (test_and_clear_bit(INTEL_GVT_REQUEST_EMULATE_VBLANK + id,
|
if (test_and_clear_bit(INTEL_GVT_REQUEST_EMULATE_VBLANK + id,
|
||||||
(void *)&gvt->service_request)) {
|
(void *)&gvt->service_request)) {
|
||||||
if (vgpu->active)
|
if (test_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status))
|
||||||
intel_vgpu_emulate_vblank(vgpu);
|
intel_vgpu_emulate_vblank(vgpu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -695,6 +695,7 @@ intel_vgpu_shadow_mm_pin(struct intel_vgpu_workload *workload)
|
|||||||
|
|
||||||
if (workload->shadow_mm->type != INTEL_GVT_MM_PPGTT ||
|
if (workload->shadow_mm->type != INTEL_GVT_MM_PPGTT ||
|
||||||
!workload->shadow_mm->ppgtt_mm.shadowed) {
|
!workload->shadow_mm->ppgtt_mm.shadowed) {
|
||||||
|
intel_vgpu_unpin_mm(workload->shadow_mm);
|
||||||
gvt_vgpu_err("workload shadow ppgtt isn't ready\n");
|
gvt_vgpu_err("workload shadow ppgtt isn't ready\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
@ -865,7 +866,8 @@ pick_next_workload(struct intel_gvt *gvt, struct intel_engine_cs *engine)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!scheduler->current_vgpu->active ||
|
if (!test_bit(INTEL_VGPU_STATUS_ACTIVE,
|
||||||
|
scheduler->current_vgpu->status) ||
|
||||||
list_empty(workload_q_head(scheduler->current_vgpu, engine)))
|
list_empty(workload_q_head(scheduler->current_vgpu, engine)))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
@ -166,9 +166,7 @@ void intel_gvt_clean_vgpu_types(struct intel_gvt *gvt)
|
|||||||
*/
|
*/
|
||||||
void intel_gvt_activate_vgpu(struct intel_vgpu *vgpu)
|
void intel_gvt_activate_vgpu(struct intel_vgpu *vgpu)
|
||||||
{
|
{
|
||||||
mutex_lock(&vgpu->vgpu_lock);
|
set_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status);
|
||||||
vgpu->active = true;
|
|
||||||
mutex_unlock(&vgpu->vgpu_lock);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -183,7 +181,7 @@ void intel_gvt_deactivate_vgpu(struct intel_vgpu *vgpu)
|
|||||||
{
|
{
|
||||||
mutex_lock(&vgpu->vgpu_lock);
|
mutex_lock(&vgpu->vgpu_lock);
|
||||||
|
|
||||||
vgpu->active = false;
|
clear_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status);
|
||||||
|
|
||||||
if (atomic_read(&vgpu->submission.running_workload_num)) {
|
if (atomic_read(&vgpu->submission.running_workload_num)) {
|
||||||
mutex_unlock(&vgpu->vgpu_lock);
|
mutex_unlock(&vgpu->vgpu_lock);
|
||||||
@ -228,7 +226,8 @@ void intel_gvt_destroy_vgpu(struct intel_vgpu *vgpu)
|
|||||||
struct intel_gvt *gvt = vgpu->gvt;
|
struct intel_gvt *gvt = vgpu->gvt;
|
||||||
struct drm_i915_private *i915 = gvt->gt->i915;
|
struct drm_i915_private *i915 = gvt->gt->i915;
|
||||||
|
|
||||||
drm_WARN(&i915->drm, vgpu->active, "vGPU is still active!\n");
|
drm_WARN(&i915->drm, test_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status),
|
||||||
|
"vGPU is still active!\n");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* remove idr first so later clean can judge if need to stop
|
* remove idr first so later clean can judge if need to stop
|
||||||
@ -285,8 +284,7 @@ struct intel_vgpu *intel_gvt_create_idle_vgpu(struct intel_gvt *gvt)
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto out_free_vgpu;
|
goto out_free_vgpu;
|
||||||
|
|
||||||
vgpu->active = false;
|
clear_bit(INTEL_VGPU_STATUS_ACTIVE, vgpu->status);
|
||||||
|
|
||||||
return vgpu;
|
return vgpu;
|
||||||
|
|
||||||
out_free_vgpu:
|
out_free_vgpu:
|
||||||
|
@ -614,6 +614,11 @@ static void ipu_plane_atomic_update(struct drm_plane *plane,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ipu_plane->dp_flow == IPU_DP_FLOW_SYNC_BG)
|
||||||
|
width = ipu_src_rect_width(new_state);
|
||||||
|
else
|
||||||
|
width = drm_rect_width(&new_state->src) >> 16;
|
||||||
|
|
||||||
eba = drm_plane_state_to_eba(new_state, 0);
|
eba = drm_plane_state_to_eba(new_state, 0);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -622,8 +627,7 @@ static void ipu_plane_atomic_update(struct drm_plane *plane,
|
|||||||
*/
|
*/
|
||||||
if (ipu_state->use_pre) {
|
if (ipu_state->use_pre) {
|
||||||
axi_id = ipu_chan_assign_axi_id(ipu_plane->dma);
|
axi_id = ipu_chan_assign_axi_id(ipu_plane->dma);
|
||||||
ipu_prg_channel_configure(ipu_plane->ipu_ch, axi_id,
|
ipu_prg_channel_configure(ipu_plane->ipu_ch, axi_id, width,
|
||||||
ipu_src_rect_width(new_state),
|
|
||||||
drm_rect_height(&new_state->src) >> 16,
|
drm_rect_height(&new_state->src) >> 16,
|
||||||
fb->pitches[0], fb->format->format,
|
fb->pitches[0], fb->format->format,
|
||||||
fb->modifier, &eba);
|
fb->modifier, &eba);
|
||||||
@ -678,9 +682,8 @@ static void ipu_plane_atomic_update(struct drm_plane *plane,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ipu_dmfc_config_wait4eot(ipu_plane->dmfc, ALIGN(drm_rect_width(dst), 8));
|
ipu_dmfc_config_wait4eot(ipu_plane->dmfc, width);
|
||||||
|
|
||||||
width = ipu_src_rect_width(new_state);
|
|
||||||
height = drm_rect_height(&new_state->src) >> 16;
|
height = drm_rect_height(&new_state->src) >> 16;
|
||||||
info = drm_format_info(fb->format->format);
|
info = drm_format_info(fb->format->format);
|
||||||
ipu_calculate_bursts(width, info->cpp[0], fb->pitches[0],
|
ipu_calculate_bursts(width, info->cpp[0], fb->pitches[0],
|
||||||
@ -744,8 +747,7 @@ static void ipu_plane_atomic_update(struct drm_plane *plane,
|
|||||||
ipu_cpmem_set_burstsize(ipu_plane->ipu_ch, 16);
|
ipu_cpmem_set_burstsize(ipu_plane->ipu_ch, 16);
|
||||||
|
|
||||||
ipu_cpmem_zero(ipu_plane->alpha_ch);
|
ipu_cpmem_zero(ipu_plane->alpha_ch);
|
||||||
ipu_cpmem_set_resolution(ipu_plane->alpha_ch,
|
ipu_cpmem_set_resolution(ipu_plane->alpha_ch, width,
|
||||||
ipu_src_rect_width(new_state),
|
|
||||||
drm_rect_height(&new_state->src) >> 16);
|
drm_rect_height(&new_state->src) >> 16);
|
||||||
ipu_cpmem_set_format_passthrough(ipu_plane->alpha_ch, 8);
|
ipu_cpmem_set_format_passthrough(ipu_plane->alpha_ch, 8);
|
||||||
ipu_cpmem_set_high_priority(ipu_plane->alpha_ch);
|
ipu_cpmem_set_high_priority(ipu_plane->alpha_ch);
|
||||||
|
@ -436,15 +436,14 @@ void meson_viu_init(struct meson_drm *priv)
|
|||||||
|
|
||||||
/* Initialize OSD1 fifo control register */
|
/* Initialize OSD1 fifo control register */
|
||||||
reg = VIU_OSD_DDR_PRIORITY_URGENT |
|
reg = VIU_OSD_DDR_PRIORITY_URGENT |
|
||||||
VIU_OSD_HOLD_FIFO_LINES(31) |
|
|
||||||
VIU_OSD_FIFO_DEPTH_VAL(32) | /* fifo_depth_val: 32*8=256 */
|
VIU_OSD_FIFO_DEPTH_VAL(32) | /* fifo_depth_val: 32*8=256 */
|
||||||
VIU_OSD_WORDS_PER_BURST(4) | /* 4 words in 1 burst */
|
VIU_OSD_WORDS_PER_BURST(4) | /* 4 words in 1 burst */
|
||||||
VIU_OSD_FIFO_LIMITS(2); /* fifo_lim: 2*16=32 */
|
VIU_OSD_FIFO_LIMITS(2); /* fifo_lim: 2*16=32 */
|
||||||
|
|
||||||
if (meson_vpu_is_compatible(priv, VPU_COMPATIBLE_G12A))
|
if (meson_vpu_is_compatible(priv, VPU_COMPATIBLE_G12A))
|
||||||
reg |= VIU_OSD_BURST_LENGTH_32;
|
reg |= (VIU_OSD_BURST_LENGTH_32 | VIU_OSD_HOLD_FIFO_LINES(31));
|
||||||
else
|
else
|
||||||
reg |= VIU_OSD_BURST_LENGTH_64;
|
reg |= (VIU_OSD_BURST_LENGTH_64 | VIU_OSD_HOLD_FIFO_LINES(4));
|
||||||
|
|
||||||
writel_relaxed(reg, priv->io_base + _REG(VIU_OSD1_FIFO_CTRL_STAT));
|
writel_relaxed(reg, priv->io_base + _REG(VIU_OSD1_FIFO_CTRL_STAT));
|
||||||
writel_relaxed(reg, priv->io_base + _REG(VIU_OSD2_FIFO_CTRL_STAT));
|
writel_relaxed(reg, priv->io_base + _REG(VIU_OSD2_FIFO_CTRL_STAT));
|
||||||
|
@ -82,6 +82,7 @@ static int panfrost_ioctl_create_bo(struct drm_device *dev, void *data,
|
|||||||
struct panfrost_gem_object *bo;
|
struct panfrost_gem_object *bo;
|
||||||
struct drm_panfrost_create_bo *args = data;
|
struct drm_panfrost_create_bo *args = data;
|
||||||
struct panfrost_gem_mapping *mapping;
|
struct panfrost_gem_mapping *mapping;
|
||||||
|
int ret;
|
||||||
|
|
||||||
if (!args->size || args->pad ||
|
if (!args->size || args->pad ||
|
||||||
(args->flags & ~(PANFROST_BO_NOEXEC | PANFROST_BO_HEAP)))
|
(args->flags & ~(PANFROST_BO_NOEXEC | PANFROST_BO_HEAP)))
|
||||||
@ -92,21 +93,29 @@ static int panfrost_ioctl_create_bo(struct drm_device *dev, void *data,
|
|||||||
!(args->flags & PANFROST_BO_NOEXEC))
|
!(args->flags & PANFROST_BO_NOEXEC))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
bo = panfrost_gem_create_with_handle(file, dev, args->size, args->flags,
|
bo = panfrost_gem_create(dev, args->size, args->flags);
|
||||||
&args->handle);
|
|
||||||
if (IS_ERR(bo))
|
if (IS_ERR(bo))
|
||||||
return PTR_ERR(bo);
|
return PTR_ERR(bo);
|
||||||
|
|
||||||
|
ret = drm_gem_handle_create(file, &bo->base.base, &args->handle);
|
||||||
|
if (ret)
|
||||||
|
goto out;
|
||||||
|
|
||||||
mapping = panfrost_gem_mapping_get(bo, priv);
|
mapping = panfrost_gem_mapping_get(bo, priv);
|
||||||
if (!mapping) {
|
if (mapping) {
|
||||||
drm_gem_object_put(&bo->base.base);
|
args->offset = mapping->mmnode.start << PAGE_SHIFT;
|
||||||
return -EINVAL;
|
panfrost_gem_mapping_put(mapping);
|
||||||
|
} else {
|
||||||
|
/* This can only happen if the handle from
|
||||||
|
* drm_gem_handle_create() has already been guessed and freed
|
||||||
|
* by user space
|
||||||
|
*/
|
||||||
|
ret = -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
args->offset = mapping->mmnode.start << PAGE_SHIFT;
|
out:
|
||||||
panfrost_gem_mapping_put(mapping);
|
drm_gem_object_put(&bo->base.base);
|
||||||
|
return ret;
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -235,12 +235,8 @@ struct drm_gem_object *panfrost_gem_create_object(struct drm_device *dev, size_t
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct panfrost_gem_object *
|
struct panfrost_gem_object *
|
||||||
panfrost_gem_create_with_handle(struct drm_file *file_priv,
|
panfrost_gem_create(struct drm_device *dev, size_t size, u32 flags)
|
||||||
struct drm_device *dev, size_t size,
|
|
||||||
u32 flags,
|
|
||||||
uint32_t *handle)
|
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
struct drm_gem_shmem_object *shmem;
|
struct drm_gem_shmem_object *shmem;
|
||||||
struct panfrost_gem_object *bo;
|
struct panfrost_gem_object *bo;
|
||||||
|
|
||||||
@ -256,16 +252,6 @@ panfrost_gem_create_with_handle(struct drm_file *file_priv,
|
|||||||
bo->noexec = !!(flags & PANFROST_BO_NOEXEC);
|
bo->noexec = !!(flags & PANFROST_BO_NOEXEC);
|
||||||
bo->is_heap = !!(flags & PANFROST_BO_HEAP);
|
bo->is_heap = !!(flags & PANFROST_BO_HEAP);
|
||||||
|
|
||||||
/*
|
|
||||||
* Allocate an id of idr table where the obj is registered
|
|
||||||
* and handle has the id what user can see.
|
|
||||||
*/
|
|
||||||
ret = drm_gem_handle_create(file_priv, &shmem->base, handle);
|
|
||||||
/* drop reference from allocate - handle holds it now. */
|
|
||||||
drm_gem_object_put(&shmem->base);
|
|
||||||
if (ret)
|
|
||||||
return ERR_PTR(ret);
|
|
||||||
|
|
||||||
return bo;
|
return bo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,10 +69,7 @@ panfrost_gem_prime_import_sg_table(struct drm_device *dev,
|
|||||||
struct sg_table *sgt);
|
struct sg_table *sgt);
|
||||||
|
|
||||||
struct panfrost_gem_object *
|
struct panfrost_gem_object *
|
||||||
panfrost_gem_create_with_handle(struct drm_file *file_priv,
|
panfrost_gem_create(struct drm_device *dev, size_t size, u32 flags);
|
||||||
struct drm_device *dev, size_t size,
|
|
||||||
u32 flags,
|
|
||||||
uint32_t *handle);
|
|
||||||
|
|
||||||
int panfrost_gem_open(struct drm_gem_object *obj, struct drm_file *file_priv);
|
int panfrost_gem_open(struct drm_gem_object *obj, struct drm_file *file_priv);
|
||||||
void panfrost_gem_close(struct drm_gem_object *obj,
|
void panfrost_gem_close(struct drm_gem_object *obj,
|
||||||
|
@ -81,7 +81,7 @@ int drm_sched_entity_init(struct drm_sched_entity *entity,
|
|||||||
init_completion(&entity->entity_idle);
|
init_completion(&entity->entity_idle);
|
||||||
|
|
||||||
/* We start in an idle state. */
|
/* We start in an idle state. */
|
||||||
complete(&entity->entity_idle);
|
complete_all(&entity->entity_idle);
|
||||||
|
|
||||||
spin_lock_init(&entity->rq_lock);
|
spin_lock_init(&entity->rq_lock);
|
||||||
spsc_queue_init(&entity->job_queue);
|
spsc_queue_init(&entity->job_queue);
|
||||||
|
@ -987,7 +987,7 @@ static int drm_sched_main(void *param)
|
|||||||
sched_job = drm_sched_entity_pop_job(entity);
|
sched_job = drm_sched_entity_pop_job(entity);
|
||||||
|
|
||||||
if (!sched_job) {
|
if (!sched_job) {
|
||||||
complete(&entity->entity_idle);
|
complete_all(&entity->entity_idle);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -998,7 +998,7 @@ static int drm_sched_main(void *param)
|
|||||||
|
|
||||||
trace_drm_run_job(sched_job, entity);
|
trace_drm_run_job(sched_job, entity);
|
||||||
fence = sched->ops->run_job(sched_job);
|
fence = sched->ops->run_job(sched_job);
|
||||||
complete(&entity->entity_idle);
|
complete_all(&entity->entity_idle);
|
||||||
drm_sched_fence_scheduled(s_fence);
|
drm_sched_fence_scheduled(s_fence);
|
||||||
|
|
||||||
if (!IS_ERR_OR_NULL(fence)) {
|
if (!IS_ERR_OR_NULL(fence)) {
|
||||||
|
@ -12,3 +12,5 @@ obj-$(CONFIG_DRM_KUNIT_TEST) += \
|
|||||||
drm_mm_test.o \
|
drm_mm_test.o \
|
||||||
drm_plane_helper_test.o \
|
drm_plane_helper_test.o \
|
||||||
drm_rect_test.o
|
drm_rect_test.o
|
||||||
|
|
||||||
|
CFLAGS_drm_mm_test.o := $(DISABLE_STRUCTLEAK_PLUGIN)
|
||||||
|
@ -298,9 +298,9 @@ static bool expect_reserve_fail(struct kunit *test, struct drm_mm *mm, struct dr
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool check_reserve_boundaries(struct kunit *test, struct drm_mm *mm,
|
static bool noinline_for_stack check_reserve_boundaries(struct kunit *test, struct drm_mm *mm,
|
||||||
unsigned int count,
|
unsigned int count,
|
||||||
u64 size)
|
u64 size)
|
||||||
{
|
{
|
||||||
const struct boundary {
|
const struct boundary {
|
||||||
u64 start, size;
|
u64 start, size;
|
||||||
|
@ -184,7 +184,7 @@ int virtio_gpu_object_create(struct virtio_gpu_device *vgdev,
|
|||||||
struct virtio_gpu_object_array *objs = NULL;
|
struct virtio_gpu_object_array *objs = NULL;
|
||||||
struct drm_gem_shmem_object *shmem_obj;
|
struct drm_gem_shmem_object *shmem_obj;
|
||||||
struct virtio_gpu_object *bo;
|
struct virtio_gpu_object *bo;
|
||||||
struct virtio_gpu_mem_entry *ents;
|
struct virtio_gpu_mem_entry *ents = NULL;
|
||||||
unsigned int nents;
|
unsigned int nents;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -210,7 +210,7 @@ int virtio_gpu_object_create(struct virtio_gpu_device *vgdev,
|
|||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
objs = virtio_gpu_array_alloc(1);
|
objs = virtio_gpu_array_alloc(1);
|
||||||
if (!objs)
|
if (!objs)
|
||||||
goto err_put_id;
|
goto err_free_entry;
|
||||||
virtio_gpu_array_add_obj(objs, &bo->base.base);
|
virtio_gpu_array_add_obj(objs, &bo->base.base);
|
||||||
|
|
||||||
ret = virtio_gpu_array_lock_resv(objs);
|
ret = virtio_gpu_array_lock_resv(objs);
|
||||||
@ -239,6 +239,8 @@ int virtio_gpu_object_create(struct virtio_gpu_device *vgdev,
|
|||||||
|
|
||||||
err_put_objs:
|
err_put_objs:
|
||||||
virtio_gpu_array_put_free(objs);
|
virtio_gpu_array_put_free(objs);
|
||||||
|
err_free_entry:
|
||||||
|
kvfree(ents);
|
||||||
err_put_id:
|
err_put_id:
|
||||||
virtio_gpu_resource_id_put(vgdev, bo->hw_res_handle);
|
virtio_gpu_resource_id_put(vgdev, bo->hw_res_handle);
|
||||||
err_free_gem:
|
err_free_gem:
|
||||||
|
@ -717,7 +717,7 @@ static int xen_drv_probe(struct xenbus_device *xb_dev,
|
|||||||
return xenbus_switch_state(xb_dev, XenbusStateInitialising);
|
return xenbus_switch_state(xb_dev, XenbusStateInitialising);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xen_drv_remove(struct xenbus_device *dev)
|
static void xen_drv_remove(struct xenbus_device *dev)
|
||||||
{
|
{
|
||||||
struct xen_drm_front_info *front_info = dev_get_drvdata(&dev->dev);
|
struct xen_drm_front_info *front_info = dev_get_drvdata(&dev->dev);
|
||||||
int to = 100;
|
int to = 100;
|
||||||
@ -751,7 +751,6 @@ static int xen_drv_remove(struct xenbus_device *dev)
|
|||||||
|
|
||||||
xen_drm_drv_fini(front_info);
|
xen_drm_drv_fini(front_info);
|
||||||
xenbus_frontend_closed(dev);
|
xenbus_frontend_closed(dev);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct xenbus_device_id xen_driver_ids[] = {
|
static const struct xenbus_device_id xen_driver_ids[] = {
|
||||||
|
@ -278,7 +278,6 @@ static int do_get_hw_stats(struct ib_device *ibdev,
|
|||||||
const struct mlx5_ib_counters *cnts = get_counters(dev, port_num - 1);
|
const struct mlx5_ib_counters *cnts = get_counters(dev, port_num - 1);
|
||||||
struct mlx5_core_dev *mdev;
|
struct mlx5_core_dev *mdev;
|
||||||
int ret, num_counters;
|
int ret, num_counters;
|
||||||
u32 mdev_port_num;
|
|
||||||
|
|
||||||
if (!stats)
|
if (!stats)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -299,8 +298,9 @@ static int do_get_hw_stats(struct ib_device *ibdev,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (MLX5_CAP_GEN(dev->mdev, cc_query_allowed)) {
|
if (MLX5_CAP_GEN(dev->mdev, cc_query_allowed)) {
|
||||||
mdev = mlx5_ib_get_native_port_mdev(dev, port_num,
|
if (!port_num)
|
||||||
&mdev_port_num);
|
port_num = 1;
|
||||||
|
mdev = mlx5_ib_get_native_port_mdev(dev, port_num, NULL);
|
||||||
if (!mdev) {
|
if (!mdev) {
|
||||||
/* If port is not affiliated yet, its in down state
|
/* If port is not affiliated yet, its in down state
|
||||||
* which doesn't have any counters yet, so it would be
|
* which doesn't have any counters yet, so it would be
|
||||||
|
@ -4502,6 +4502,40 @@ static bool mlx5_ib_modify_qp_allowed(struct mlx5_ib_dev *dev,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int validate_rd_atomic(struct mlx5_ib_dev *dev, struct ib_qp_attr *attr,
|
||||||
|
int attr_mask, enum ib_qp_type qp_type)
|
||||||
|
{
|
||||||
|
int log_max_ra_res;
|
||||||
|
int log_max_ra_req;
|
||||||
|
|
||||||
|
if (qp_type == MLX5_IB_QPT_DCI) {
|
||||||
|
log_max_ra_res = 1 << MLX5_CAP_GEN(dev->mdev,
|
||||||
|
log_max_ra_res_dc);
|
||||||
|
log_max_ra_req = 1 << MLX5_CAP_GEN(dev->mdev,
|
||||||
|
log_max_ra_req_dc);
|
||||||
|
} else {
|
||||||
|
log_max_ra_res = 1 << MLX5_CAP_GEN(dev->mdev,
|
||||||
|
log_max_ra_res_qp);
|
||||||
|
log_max_ra_req = 1 << MLX5_CAP_GEN(dev->mdev,
|
||||||
|
log_max_ra_req_qp);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (attr_mask & IB_QP_MAX_QP_RD_ATOMIC &&
|
||||||
|
attr->max_rd_atomic > log_max_ra_res) {
|
||||||
|
mlx5_ib_dbg(dev, "invalid max_rd_atomic value %d\n",
|
||||||
|
attr->max_rd_atomic);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (attr_mask & IB_QP_MAX_DEST_RD_ATOMIC &&
|
||||||
|
attr->max_dest_rd_atomic > log_max_ra_req) {
|
||||||
|
mlx5_ib_dbg(dev, "invalid max_dest_rd_atomic value %d\n",
|
||||||
|
attr->max_dest_rd_atomic);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
int mlx5_ib_modify_qp(struct ib_qp *ibqp, struct ib_qp_attr *attr,
|
int mlx5_ib_modify_qp(struct ib_qp *ibqp, struct ib_qp_attr *attr,
|
||||||
int attr_mask, struct ib_udata *udata)
|
int attr_mask, struct ib_udata *udata)
|
||||||
{
|
{
|
||||||
@ -4589,21 +4623,8 @@ int mlx5_ib_modify_qp(struct ib_qp *ibqp, struct ib_qp_attr *attr,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (attr_mask & IB_QP_MAX_QP_RD_ATOMIC &&
|
if (!validate_rd_atomic(dev, attr, attr_mask, qp_type))
|
||||||
attr->max_rd_atomic >
|
|
||||||
(1 << MLX5_CAP_GEN(dev->mdev, log_max_ra_res_qp))) {
|
|
||||||
mlx5_ib_dbg(dev, "invalid max_rd_atomic value %d\n",
|
|
||||||
attr->max_rd_atomic);
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
|
|
||||||
if (attr_mask & IB_QP_MAX_DEST_RD_ATOMIC &&
|
|
||||||
attr->max_dest_rd_atomic >
|
|
||||||
(1 << MLX5_CAP_GEN(dev->mdev, log_max_ra_req_qp))) {
|
|
||||||
mlx5_ib_dbg(dev, "invalid max_dest_rd_atomic value %d\n",
|
|
||||||
attr->max_dest_rd_atomic);
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cur_state == new_state && cur_state == IB_QPS_RESET) {
|
if (cur_state == new_state && cur_state == IB_QPS_RESET) {
|
||||||
err = 0;
|
err = 0;
|
||||||
|
@ -62,9 +62,6 @@ enum {
|
|||||||
SRP_DEFAULT_CMD_SQ_SIZE = SRP_DEFAULT_QUEUE_SIZE - SRP_RSP_SQ_SIZE -
|
SRP_DEFAULT_CMD_SQ_SIZE = SRP_DEFAULT_QUEUE_SIZE - SRP_RSP_SQ_SIZE -
|
||||||
SRP_TSK_MGMT_SQ_SIZE,
|
SRP_TSK_MGMT_SQ_SIZE,
|
||||||
|
|
||||||
SRP_TAG_NO_REQ = ~0U,
|
|
||||||
SRP_TAG_TSK_MGMT = 1U << 31,
|
|
||||||
|
|
||||||
SRP_MAX_PAGES_PER_MR = 512,
|
SRP_MAX_PAGES_PER_MR = 512,
|
||||||
|
|
||||||
SRP_MAX_ADD_CDB_LEN = 16,
|
SRP_MAX_ADD_CDB_LEN = 16,
|
||||||
@ -79,6 +76,11 @@ enum {
|
|||||||
sizeof(struct srp_imm_buf),
|
sizeof(struct srp_imm_buf),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
SRP_TAG_NO_REQ = ~0U,
|
||||||
|
SRP_TAG_TSK_MGMT = BIT(31),
|
||||||
|
};
|
||||||
|
|
||||||
enum srp_target_state {
|
enum srp_target_state {
|
||||||
SRP_TARGET_SCANNING,
|
SRP_TARGET_SCANNING,
|
||||||
SRP_TARGET_LIVE,
|
SRP_TARGET_LIVE,
|
||||||
|
@ -51,7 +51,7 @@ module_param_array(ptr_size, int, NULL, 0444);
|
|||||||
MODULE_PARM_DESC(ptr_size,
|
MODULE_PARM_DESC(ptr_size,
|
||||||
"Pointing device width, height in pixels (default 800,600)");
|
"Pointing device width, height in pixels (default 800,600)");
|
||||||
|
|
||||||
static int xenkbd_remove(struct xenbus_device *);
|
static void xenkbd_remove(struct xenbus_device *);
|
||||||
static int xenkbd_connect_backend(struct xenbus_device *, struct xenkbd_info *);
|
static int xenkbd_connect_backend(struct xenbus_device *, struct xenkbd_info *);
|
||||||
static void xenkbd_disconnect_backend(struct xenkbd_info *);
|
static void xenkbd_disconnect_backend(struct xenkbd_info *);
|
||||||
|
|
||||||
@ -404,7 +404,7 @@ static int xenkbd_resume(struct xenbus_device *dev)
|
|||||||
return xenkbd_connect_backend(dev, info);
|
return xenkbd_connect_backend(dev, info);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xenkbd_remove(struct xenbus_device *dev)
|
static void xenkbd_remove(struct xenbus_device *dev)
|
||||||
{
|
{
|
||||||
struct xenkbd_info *info = dev_get_drvdata(&dev->dev);
|
struct xenkbd_info *info = dev_get_drvdata(&dev->dev);
|
||||||
|
|
||||||
@ -417,7 +417,6 @@ static int xenkbd_remove(struct xenbus_device *dev)
|
|||||||
input_unregister_device(info->mtouch);
|
input_unregister_device(info->mtouch);
|
||||||
free_page((unsigned long)info->page);
|
free_page((unsigned long)info->page);
|
||||||
kfree(info);
|
kfree(info);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xenkbd_connect_backend(struct xenbus_device *dev,
|
static int xenkbd_connect_backend(struct xenbus_device *dev,
|
||||||
|
@ -1742,6 +1742,8 @@ static void dm_split_and_process_bio(struct mapped_device *md,
|
|||||||
* otherwise associated queue_limits won't be imposed.
|
* otherwise associated queue_limits won't be imposed.
|
||||||
*/
|
*/
|
||||||
bio = bio_split_to_limits(bio);
|
bio = bio_split_to_limits(bio);
|
||||||
|
if (!bio)
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
init_clone_info(&ci, md, map, bio, is_abnormal);
|
init_clone_info(&ci, md, map, bio, is_abnormal);
|
||||||
|
@ -455,6 +455,8 @@ static void md_submit_bio(struct bio *bio)
|
|||||||
}
|
}
|
||||||
|
|
||||||
bio = bio_split_to_limits(bio);
|
bio = bio_split_to_limits(bio);
|
||||||
|
if (!bio)
|
||||||
|
return;
|
||||||
|
|
||||||
if (mddev->ro == MD_RDONLY && unlikely(rw == WRITE)) {
|
if (mddev->ro == MD_RDONLY && unlikely(rw == WRITE)) {
|
||||||
if (bio_sectors(bio) != 0)
|
if (bio_sectors(bio) != 0)
|
||||||
|
@ -50,7 +50,7 @@ static int scpart_scan_partmap(struct mtd_info *master, loff_t partmap_offs,
|
|||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
int res = 0;
|
int res = 0;
|
||||||
int res2;
|
int res2;
|
||||||
loff_t offs;
|
uint32_t offs;
|
||||||
size_t retlen;
|
size_t retlen;
|
||||||
struct sc_part_desc *pdesc = NULL;
|
struct sc_part_desc *pdesc = NULL;
|
||||||
struct sc_part_desc *tmpdesc;
|
struct sc_part_desc *tmpdesc;
|
||||||
|
@ -91,7 +91,7 @@ static int mtd_parser_tplink_safeloader_parse(struct mtd_info *mtd,
|
|||||||
buf = mtd_parser_tplink_safeloader_read_table(mtd);
|
buf = mtd_parser_tplink_safeloader_read_table(mtd);
|
||||||
if (!buf) {
|
if (!buf) {
|
||||||
err = -ENOENT;
|
err = -ENOENT;
|
||||||
goto err_out;
|
goto err_free_parts;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (idx = 0, offset = TPLINK_SAFELOADER_DATA_OFFSET;
|
for (idx = 0, offset = TPLINK_SAFELOADER_DATA_OFFSET;
|
||||||
@ -118,6 +118,8 @@ static int mtd_parser_tplink_safeloader_parse(struct mtd_info *mtd,
|
|||||||
err_free:
|
err_free:
|
||||||
for (idx -= 1; idx >= 0; idx--)
|
for (idx -= 1; idx >= 0; idx--)
|
||||||
kfree(parts[idx].name);
|
kfree(parts[idx].name);
|
||||||
|
err_free_parts:
|
||||||
|
kfree(parts);
|
||||||
err_out:
|
err_out:
|
||||||
return err;
|
return err;
|
||||||
};
|
};
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include <linux/err.h>
|
#include <linux/err.h>
|
||||||
#include <linux/errno.h>
|
#include <linux/errno.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
#include <linux/delay.h>
|
||||||
#include <linux/device.h>
|
#include <linux/device.h>
|
||||||
#include <linux/mutex.h>
|
#include <linux/mutex.h>
|
||||||
#include <linux/math64.h>
|
#include <linux/math64.h>
|
||||||
|
@ -993,7 +993,7 @@ static struct sk_buff *bnxt_rx_multi_page_skb(struct bnxt *bp,
|
|||||||
DMA_ATTR_WEAK_ORDERING);
|
DMA_ATTR_WEAK_ORDERING);
|
||||||
skb = build_skb(page_address(page), PAGE_SIZE);
|
skb = build_skb(page_address(page), PAGE_SIZE);
|
||||||
if (!skb) {
|
if (!skb) {
|
||||||
__free_page(page);
|
page_pool_recycle_direct(rxr->page_pool, page);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
skb_mark_for_recycle(skb);
|
skb_mark_for_recycle(skb);
|
||||||
@ -1031,7 +1031,7 @@ static struct sk_buff *bnxt_rx_page_skb(struct bnxt *bp,
|
|||||||
|
|
||||||
skb = napi_alloc_skb(&rxr->bnapi->napi, payload);
|
skb = napi_alloc_skb(&rxr->bnapi->napi, payload);
|
||||||
if (!skb) {
|
if (!skb) {
|
||||||
__free_page(page);
|
page_pool_recycle_direct(rxr->page_pool, page);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3130,7 +3130,7 @@ static int hclgevf_set_channels(struct hnae3_handle *handle, u32 new_tqps_num,
|
|||||||
|
|
||||||
hclgevf_update_rss_size(handle, new_tqps_num);
|
hclgevf_update_rss_size(handle, new_tqps_num);
|
||||||
|
|
||||||
hclge_comm_get_rss_tc_info(cur_rss_size, hdev->hw_tc_map,
|
hclge_comm_get_rss_tc_info(kinfo->rss_size, hdev->hw_tc_map,
|
||||||
tc_offset, tc_valid, tc_size);
|
tc_offset, tc_valid, tc_size);
|
||||||
ret = hclge_comm_set_rss_tc_mode(&hdev->hw.hw, tc_offset,
|
ret = hclge_comm_set_rss_tc_mode(&hdev->hw.hw, tc_offset,
|
||||||
tc_valid, tc_size);
|
tc_valid, tc_size);
|
||||||
|
@ -3850,7 +3850,7 @@ static int iavf_parse_cls_flower(struct iavf_adapter *adapter,
|
|||||||
field_flags |= IAVF_CLOUD_FIELD_IIP;
|
field_flags |= IAVF_CLOUD_FIELD_IIP;
|
||||||
} else {
|
} else {
|
||||||
dev_err(&adapter->pdev->dev, "Bad ip src mask 0x%08x\n",
|
dev_err(&adapter->pdev->dev, "Bad ip src mask 0x%08x\n",
|
||||||
be32_to_cpu(match.mask->dst));
|
be32_to_cpu(match.mask->src));
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -363,6 +363,7 @@ ice_gnss_tty_write(struct tty_struct *tty, const unsigned char *buf, int count)
|
|||||||
/* Send the data out to a hardware port */
|
/* Send the data out to a hardware port */
|
||||||
write_buf = kzalloc(sizeof(*write_buf), GFP_KERNEL);
|
write_buf = kzalloc(sizeof(*write_buf), GFP_KERNEL);
|
||||||
if (!write_buf) {
|
if (!write_buf) {
|
||||||
|
kfree(cmd_buf);
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
@ -460,6 +461,9 @@ static struct tty_driver *ice_gnss_create_tty_driver(struct ice_pf *pf)
|
|||||||
for (i = 0; i < ICE_GNSS_TTY_MINOR_DEVICES; i++) {
|
for (i = 0; i < ICE_GNSS_TTY_MINOR_DEVICES; i++) {
|
||||||
pf->gnss_tty_port[i] = kzalloc(sizeof(*pf->gnss_tty_port[i]),
|
pf->gnss_tty_port[i] = kzalloc(sizeof(*pf->gnss_tty_port[i]),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
|
if (!pf->gnss_tty_port[i])
|
||||||
|
goto err_out;
|
||||||
|
|
||||||
pf->gnss_serial[i] = NULL;
|
pf->gnss_serial[i] = NULL;
|
||||||
|
|
||||||
tty_port_init(pf->gnss_tty_port[i]);
|
tty_port_init(pf->gnss_tty_port[i]);
|
||||||
@ -469,21 +473,23 @@ static struct tty_driver *ice_gnss_create_tty_driver(struct ice_pf *pf)
|
|||||||
err = tty_register_driver(tty_driver);
|
err = tty_register_driver(tty_driver);
|
||||||
if (err) {
|
if (err) {
|
||||||
dev_err(dev, "Failed to register TTY driver err=%d\n", err);
|
dev_err(dev, "Failed to register TTY driver err=%d\n", err);
|
||||||
|
goto err_out;
|
||||||
for (i = 0; i < ICE_GNSS_TTY_MINOR_DEVICES; i++) {
|
|
||||||
tty_port_destroy(pf->gnss_tty_port[i]);
|
|
||||||
kfree(pf->gnss_tty_port[i]);
|
|
||||||
}
|
|
||||||
kfree(ttydrv_name);
|
|
||||||
tty_driver_kref_put(pf->ice_gnss_tty_driver);
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < ICE_GNSS_TTY_MINOR_DEVICES; i++)
|
for (i = 0; i < ICE_GNSS_TTY_MINOR_DEVICES; i++)
|
||||||
dev_info(dev, "%s%d registered\n", ttydrv_name, i);
|
dev_info(dev, "%s%d registered\n", ttydrv_name, i);
|
||||||
|
|
||||||
return tty_driver;
|
return tty_driver;
|
||||||
|
|
||||||
|
err_out:
|
||||||
|
while (i--) {
|
||||||
|
tty_port_destroy(pf->gnss_tty_port[i]);
|
||||||
|
kfree(pf->gnss_tty_port[i]);
|
||||||
|
}
|
||||||
|
kfree(ttydrv_name);
|
||||||
|
tty_driver_kref_put(pf->ice_gnss_tty_driver);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -475,7 +475,9 @@
|
|||||||
#define IGC_TSAUXC_EN_TT0 BIT(0) /* Enable target time 0. */
|
#define IGC_TSAUXC_EN_TT0 BIT(0) /* Enable target time 0. */
|
||||||
#define IGC_TSAUXC_EN_TT1 BIT(1) /* Enable target time 1. */
|
#define IGC_TSAUXC_EN_TT1 BIT(1) /* Enable target time 1. */
|
||||||
#define IGC_TSAUXC_EN_CLK0 BIT(2) /* Enable Configurable Frequency Clock 0. */
|
#define IGC_TSAUXC_EN_CLK0 BIT(2) /* Enable Configurable Frequency Clock 0. */
|
||||||
|
#define IGC_TSAUXC_ST0 BIT(4) /* Start Clock 0 Toggle on Target Time 0. */
|
||||||
#define IGC_TSAUXC_EN_CLK1 BIT(5) /* Enable Configurable Frequency Clock 1. */
|
#define IGC_TSAUXC_EN_CLK1 BIT(5) /* Enable Configurable Frequency Clock 1. */
|
||||||
|
#define IGC_TSAUXC_ST1 BIT(7) /* Start Clock 1 Toggle on Target Time 1. */
|
||||||
#define IGC_TSAUXC_EN_TS0 BIT(8) /* Enable hardware timestamp 0. */
|
#define IGC_TSAUXC_EN_TS0 BIT(8) /* Enable hardware timestamp 0. */
|
||||||
#define IGC_TSAUXC_AUTT0 BIT(9) /* Auxiliary Timestamp Taken. */
|
#define IGC_TSAUXC_AUTT0 BIT(9) /* Auxiliary Timestamp Taken. */
|
||||||
#define IGC_TSAUXC_EN_TS1 BIT(10) /* Enable hardware timestamp 0. */
|
#define IGC_TSAUXC_EN_TS1 BIT(10) /* Enable hardware timestamp 0. */
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user