Merge branch 'linus' into x86/dma, to resolve a conflict with upstream
Conflicts: arch/x86/mm/init_64.c Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
commit
ea2301b622
@ -1,110 +1,139 @@
|
|||||||
What: /sys/class/ata_...
|
What: /sys/class/ata_...
|
||||||
Date: August 2008
|
|
||||||
Contact: Gwendal Grignou<gwendal@google.com>
|
|
||||||
Description:
|
Description:
|
||||||
|
Provide a place in sysfs for storing the ATA topology of the
|
||||||
Provide a place in sysfs for storing the ATA topology of the system. This allows
|
system. This allows retrieving various information about ATA
|
||||||
retrieving various information about ATA objects.
|
objects.
|
||||||
|
|
||||||
Files under /sys/class/ata_port
|
Files under /sys/class/ata_port
|
||||||
-------------------------------
|
-------------------------------
|
||||||
|
|
||||||
For each port, a directory ataX is created where X is the ata_port_id of
|
For each port, a directory ataX is created where X is the ata_port_id of the
|
||||||
the port. The device parent is the ata host device.
|
port. The device parent is the ata host device.
|
||||||
|
|
||||||
idle_irq (read)
|
|
||||||
|
|
||||||
Number of IRQ received by the port while idle [some ata HBA only].
|
What: /sys/class/ata_port/ataX/nr_pmp_links
|
||||||
|
What: /sys/class/ata_port/ataX/idle_irq
|
||||||
|
Date: May, 2010
|
||||||
|
KernelVersion: v2.6.37
|
||||||
|
Contact: Gwendal Grignou <gwendal@chromium.org>
|
||||||
|
Description:
|
||||||
|
nr_pmp_links: (RO) If a SATA Port Multiplier (PM) is
|
||||||
|
connected, the number of links behind it.
|
||||||
|
|
||||||
nr_pmp_links (read)
|
idle_irq: (RO) Number of IRQ received by the port while
|
||||||
|
idle [some ata HBA only].
|
||||||
|
|
||||||
If a SATA Port Multiplier (PM) is connected, number of link behind it.
|
|
||||||
|
What: /sys/class/ata_port/ataX/port_no
|
||||||
|
Date: May, 2013
|
||||||
|
KernelVersion: v3.11
|
||||||
|
Contact: Gwendal Grignou <gwendal@chromium.org>
|
||||||
|
Description:
|
||||||
|
(RO) Host local port number. While registering host controller,
|
||||||
|
port numbers are tracked based upon number of ports available on
|
||||||
|
the controller. This attribute is needed by udev for composing
|
||||||
|
persistent links in /dev/disk/by-path.
|
||||||
|
|
||||||
Files under /sys/class/ata_link
|
Files under /sys/class/ata_link
|
||||||
-------------------------------
|
-------------------------------
|
||||||
|
|
||||||
Behind each port, there is a ata_link. If there is a SATA PM in the
|
Behind each port, there is a ata_link. If there is a SATA PM in the topology, 15
|
||||||
topology, 15 ata_link objects are created.
|
ata_link objects are created.
|
||||||
|
|
||||||
If a link is behind a port, the directory name is linkX, where X is
|
If a link is behind a port, the directory name is linkX, where X is ata_port_id
|
||||||
ata_port_id of the port.
|
of the port. If a link is behind a PM, its name is linkX.Y where X is
|
||||||
If a link is behind a PM, its name is linkX.Y where X is ata_port_id
|
ata_port_id of the parent port and Y the PM port.
|
||||||
of the parent port and Y the PM port.
|
|
||||||
|
|
||||||
hw_sata_spd_limit
|
|
||||||
|
|
||||||
Maximum speed supported by the connected SATA device.
|
What: /sys/class/ata_link/linkX[.Y]/hw_sata_spd_limit
|
||||||
|
What: /sys/class/ata_link/linkX[.Y]/sata_spd_limit
|
||||||
|
What: /sys/class/ata_link/linkX[.Y]/sata_spd
|
||||||
|
Date: May, 2010
|
||||||
|
KernelVersion: v2.6.37
|
||||||
|
Contact: Gwendal Grignou <gwendal@chromium.org>
|
||||||
|
Description:
|
||||||
|
hw_sata_spd_limit: (RO) Maximum speed supported by the
|
||||||
|
connected SATA device.
|
||||||
|
|
||||||
sata_spd_limit
|
sata_spd_limit: (RO) Maximum speed imposed by libata.
|
||||||
|
|
||||||
Maximum speed imposed by libata.
|
sata_spd: (RO) Current speed of the link
|
||||||
|
eg. 1.5, 3 Gbps etc.
|
||||||
|
|
||||||
sata_spd
|
|
||||||
|
|
||||||
Current speed of the link [1.5, 3Gps,...].
|
|
||||||
|
|
||||||
Files under /sys/class/ata_device
|
Files under /sys/class/ata_device
|
||||||
---------------------------------
|
---------------------------------
|
||||||
|
|
||||||
Behind each link, up to two ata device are created.
|
Behind each link, up to two ata devices are created.
|
||||||
The name of the directory is devX[.Y].Z where:
|
The name of the directory is devX[.Y].Z where:
|
||||||
- X is ata_port_id of the port where the device is connected,
|
- X is ata_port_id of the port where the device is connected,
|
||||||
- Y the port of the PM if any, and
|
- Y the port of the PM if any, and
|
||||||
- Z the device id: for PATA, there is usually 2 devices [0,1],
|
- Z the device id: for PATA, there is usually 2 devices [0,1], only 1 for SATA.
|
||||||
only 1 for SATA.
|
|
||||||
|
|
||||||
class
|
|
||||||
Device class. Can be "ata" for disk, "atapi" for packet device,
|
|
||||||
"pmp" for PM, or "none" if no device was found behind the link.
|
|
||||||
|
|
||||||
dma_mode
|
What: /sys/class/ata_device/devX[.Y].Z/spdn_cnt
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/gscr
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/ering
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/id
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/pio_mode
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/xfer_mode
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/dma_mode
|
||||||
|
What: /sys/class/ata_device/devX[.Y].Z/class
|
||||||
|
Date: May, 2010
|
||||||
|
KernelVersion: v2.6.37
|
||||||
|
Contact: Gwendal Grignou <gwendal@chromium.org>
|
||||||
|
Description:
|
||||||
|
spdn_cnt: (RO) Number of times libata decided to lower the
|
||||||
|
speed of link due to errors.
|
||||||
|
|
||||||
Transfer modes supported by the device when in DMA mode.
|
gscr: (RO) Cached result of the dump of PM GSCR
|
||||||
Mostly used by PATA device.
|
register. Valid registers are:
|
||||||
|
|
||||||
pio_mode
|
0: SATA_PMP_GSCR_PROD_ID,
|
||||||
|
1: SATA_PMP_GSCR_REV,
|
||||||
|
2: SATA_PMP_GSCR_PORT_INFO,
|
||||||
|
32: SATA_PMP_GSCR_ERROR,
|
||||||
|
33: SATA_PMP_GSCR_ERROR_EN,
|
||||||
|
64: SATA_PMP_GSCR_FEAT,
|
||||||
|
96: SATA_PMP_GSCR_FEAT_EN,
|
||||||
|
130: SATA_PMP_GSCR_SII_GPIO
|
||||||
|
|
||||||
Transfer modes supported by the device when in PIO mode.
|
Only valid if the device is a PM.
|
||||||
Mostly used by PATA device.
|
|
||||||
|
|
||||||
xfer_mode
|
ering: (RO) Formatted output of the error ring of the
|
||||||
|
device.
|
||||||
|
|
||||||
Current transfer mode.
|
id: (RO) Cached result of IDENTIFY command, as
|
||||||
|
described in ATA8 7.16 and 7.17. Only valid if
|
||||||
|
the device is not a PM.
|
||||||
|
|
||||||
id
|
pio_mode: (RO) Transfer modes supported by the device when
|
||||||
|
in PIO mode. Mostly used by PATA device.
|
||||||
|
|
||||||
Cached result of IDENTIFY command, as described in ATA8 7.16 and 7.17.
|
xfer_mode: (RO) Current transfer mode
|
||||||
Only valid if the device is not a PM.
|
|
||||||
|
|
||||||
gscr
|
dma_mode: (RO) Transfer modes supported by the device when
|
||||||
|
in DMA mode. Mostly used by PATA device.
|
||||||
|
|
||||||
Cached result of the dump of PM GSCR register.
|
class: (RO) Device class. Can be "ata" for disk,
|
||||||
Valid registers are:
|
"atapi" for packet device, "pmp" for PM, or
|
||||||
0: SATA_PMP_GSCR_PROD_ID,
|
"none" if no device was found behind the link.
|
||||||
1: SATA_PMP_GSCR_REV,
|
|
||||||
2: SATA_PMP_GSCR_PORT_INFO,
|
|
||||||
32: SATA_PMP_GSCR_ERROR,
|
|
||||||
33: SATA_PMP_GSCR_ERROR_EN,
|
|
||||||
64: SATA_PMP_GSCR_FEAT,
|
|
||||||
96: SATA_PMP_GSCR_FEAT_EN,
|
|
||||||
130: SATA_PMP_GSCR_SII_GPIO
|
|
||||||
Only valid if the device is a PM.
|
|
||||||
|
|
||||||
trim
|
|
||||||
|
|
||||||
Shows the DSM TRIM mode currently used by the device. Valid
|
What: /sys/class/ata_device/devX[.Y].Z/trim
|
||||||
values are:
|
Date: May, 2015
|
||||||
unsupported: Drive does not support DSM TRIM
|
KernelVersion: v4.10
|
||||||
unqueued: Drive supports unqueued DSM TRIM only
|
Contact: Gwendal Grignou <gwendal@chromium.org>
|
||||||
queued: Drive supports queued DSM TRIM
|
Description:
|
||||||
forced_unqueued: Drive's queued DSM support is known to be
|
(RO) Shows the DSM TRIM mode currently used by the device. Valid
|
||||||
buggy and only unqueued TRIM commands
|
values are:
|
||||||
are sent
|
|
||||||
|
|
||||||
spdn_cnt
|
unsupported: Drive does not support DSM TRIM
|
||||||
|
|
||||||
Number of time libata decided to lower the speed of link due to errors.
|
unqueued: Drive supports unqueued DSM TRIM only
|
||||||
|
|
||||||
ering
|
queued: Drive supports queued DSM TRIM
|
||||||
|
|
||||||
Formatted output of the error ring of the device.
|
forced_unqueued: Drive's queued DSM support is known to
|
||||||
|
be buggy and only unqueued TRIM commands
|
||||||
|
are sent
|
||||||
|
58
Documentation/ABI/testing/sysfs-block-device
Normal file
58
Documentation/ABI/testing/sysfs-block-device
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
What: /sys/block/*/device/sw_activity
|
||||||
|
Date: Jun, 2008
|
||||||
|
KernelVersion: v2.6.27
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RW) Used by drivers which support software controlled activity
|
||||||
|
LEDs.
|
||||||
|
|
||||||
|
It has the following valid values:
|
||||||
|
|
||||||
|
0 OFF - the LED is not activated on activity
|
||||||
|
1 BLINK_ON - the LED blinks on every 10ms when activity is
|
||||||
|
detected.
|
||||||
|
2 BLINK_OFF - the LED is on when idle, and blinks off
|
||||||
|
every 10ms when activity is detected.
|
||||||
|
|
||||||
|
Note that the user must turn sw_activity OFF it they wish to
|
||||||
|
control the activity LED via the em_message file.
|
||||||
|
|
||||||
|
|
||||||
|
What: /sys/block/*/device/unload_heads
|
||||||
|
Date: Sep, 2008
|
||||||
|
KernelVersion: v2.6.28
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RW) Hard disk shock protection
|
||||||
|
|
||||||
|
Writing an integer value to this file will take the heads of the
|
||||||
|
respective drive off the platter and block all I/O operations
|
||||||
|
for the specified number of milliseconds.
|
||||||
|
|
||||||
|
- If the device does not support the unload heads feature,
|
||||||
|
access is denied with -EOPNOTSUPP.
|
||||||
|
- The maximal value accepted for a timeout is 30000
|
||||||
|
milliseconds.
|
||||||
|
- A previously set timeout can be cancelled and disk can resume
|
||||||
|
normal operation immediately by specifying a timeout of 0.
|
||||||
|
- Some hard drives only comply with an earlier version of the
|
||||||
|
ATA standard, but support the unload feature nonetheless.
|
||||||
|
There is no safe way Linux can detect these devices, so this
|
||||||
|
is not enabled by default. If it is known that your device
|
||||||
|
does support the unload feature, then you can tell the kernel
|
||||||
|
to enable it by writing -1. It can be disabled again by
|
||||||
|
writing -2.
|
||||||
|
- Values below -2 are rejected with -EINVAL
|
||||||
|
|
||||||
|
For more information, see
|
||||||
|
Documentation/laptops/disk-shock-protection.txt
|
||||||
|
|
||||||
|
|
||||||
|
What: /sys/block/*/device/ncq_prio_enable
|
||||||
|
Date: Oct, 2016
|
||||||
|
KernelVersion: v4.10
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RW) Write to the file to turn on or off the SATA ncq (native
|
||||||
|
command queueing) support. By default this feature is turned
|
||||||
|
off.
|
@ -27,3 +27,92 @@ Description: This file contains the current status of the "SSD Smart Path"
|
|||||||
the direct i/o path to physical devices. This setting is
|
the direct i/o path to physical devices. This setting is
|
||||||
controller wide, affecting all configured logical drives on the
|
controller wide, affecting all configured logical drives on the
|
||||||
controller. This file is readable and writable.
|
controller. This file is readable and writable.
|
||||||
|
|
||||||
|
What: /sys/class/scsi_host/hostX/link_power_management_policy
|
||||||
|
Date: Oct, 2007
|
||||||
|
KernelVersion: v2.6.24
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RW) This parameter allows the user to read and set the link
|
||||||
|
(interface) power management.
|
||||||
|
|
||||||
|
There are four possible options:
|
||||||
|
|
||||||
|
min_power: Tell the controller to try to make the link use the
|
||||||
|
least possible power when possible. This may sacrifice some
|
||||||
|
performance due to increased latency when coming out of lower
|
||||||
|
power states.
|
||||||
|
|
||||||
|
max_performance: Generally, this means no power management.
|
||||||
|
Tell the controller to have performance be a priority over power
|
||||||
|
management.
|
||||||
|
|
||||||
|
medium_power: Tell the controller to enter a lower power state
|
||||||
|
when possible, but do not enter the lowest power state, thus
|
||||||
|
improving latency over min_power setting.
|
||||||
|
|
||||||
|
med_power_with_dipm: Identical to the existing medium_power
|
||||||
|
setting except that it enables dipm (device initiated power
|
||||||
|
management) on top, which makes it match the Windows IRST (Intel
|
||||||
|
Rapid Storage Technology) driver settings. This setting is also
|
||||||
|
close to min_power, except that:
|
||||||
|
a) It does not use host-initiated slumber mode, but it does
|
||||||
|
allow device-initiated slumber
|
||||||
|
b) It does not enable low power device sleep mode (DevSlp).
|
||||||
|
|
||||||
|
What: /sys/class/scsi_host/hostX/em_message
|
||||||
|
What: /sys/class/scsi_host/hostX/em_message_type
|
||||||
|
Date: Jun, 2008
|
||||||
|
KernelVersion: v2.6.27
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
em_message: (RW) Enclosure management support. For the LED
|
||||||
|
protocol, writes and reads correspond to the LED message format
|
||||||
|
as defined in the AHCI spec.
|
||||||
|
|
||||||
|
The user must turn sw_activity (under /sys/block/*/device/) OFF
|
||||||
|
it they wish to control the activity LED via the em_message
|
||||||
|
file.
|
||||||
|
|
||||||
|
em_message_type: (RO) Displays the current enclosure management
|
||||||
|
protocol that is being used by the driver (for eg. LED, SAF-TE,
|
||||||
|
SES-2, SGPIO etc).
|
||||||
|
|
||||||
|
What: /sys/class/scsi_host/hostX/ahci_port_cmd
|
||||||
|
What: /sys/class/scsi_host/hostX/ahci_host_caps
|
||||||
|
What: /sys/class/scsi_host/hostX/ahci_host_cap2
|
||||||
|
Date: Mar, 2010
|
||||||
|
KernelVersion: v2.6.35
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
[to be documented]
|
||||||
|
|
||||||
|
What: /sys/class/scsi_host/hostX/ahci_host_version
|
||||||
|
Date: Mar, 2010
|
||||||
|
KernelVersion: v2.6.35
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RO) Display the version of the AHCI spec implemented by the
|
||||||
|
host.
|
||||||
|
|
||||||
|
What: /sys/class/scsi_host/hostX/em_buffer
|
||||||
|
Date: Apr, 2010
|
||||||
|
KernelVersion: v2.6.35
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RW) Allows access to AHCI EM (enclosure management) buffer
|
||||||
|
directly if the host supports EM.
|
||||||
|
|
||||||
|
For eg. the AHCI driver supports SGPIO EM messages but the
|
||||||
|
SATA/AHCI specs do not define the SGPIO message format of the EM
|
||||||
|
buffer. Different hardware(HW) vendors may have different
|
||||||
|
definitions. With the em_buffer attribute, this issue can be
|
||||||
|
solved by allowing HW vendors to provide userland drivers and
|
||||||
|
tools for their SGPIO initiators.
|
||||||
|
|
||||||
|
What: /sys/class/scsi_host/hostX/em_message_supported
|
||||||
|
Date: Oct, 2009
|
||||||
|
KernelVersion: v2.6.39
|
||||||
|
Contact: linux-ide@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
(RO) Displays supported enclosure management message types.
|
||||||
|
@ -16,6 +16,7 @@ Required properties:
|
|||||||
- ddc: phandle to the hdmi ddc node
|
- ddc: phandle to the hdmi ddc node
|
||||||
- phy: phandle to the hdmi phy node
|
- phy: phandle to the hdmi phy node
|
||||||
- samsung,syscon-phandle: phandle for system controller node for PMU.
|
- samsung,syscon-phandle: phandle for system controller node for PMU.
|
||||||
|
- #sound-dai-cells: should be 0.
|
||||||
|
|
||||||
Required properties for Exynos 4210, 4212, 5420 and 5433:
|
Required properties for Exynos 4210, 4212, 5420 and 5433:
|
||||||
- clocks: list of clock IDs from SoC clock driver.
|
- clocks: list of clock IDs from SoC clock driver.
|
||||||
|
@ -3,11 +3,11 @@ Device-Tree bindings for sigma delta modulator
|
|||||||
Required properties:
|
Required properties:
|
||||||
- compatible: should be "ads1201", "sd-modulator". "sd-modulator" can be use
|
- compatible: should be "ads1201", "sd-modulator". "sd-modulator" can be use
|
||||||
as a generic SD modulator if modulator not specified in compatible list.
|
as a generic SD modulator if modulator not specified in compatible list.
|
||||||
- #io-channel-cells = <1>: See the IIO bindings section "IIO consumers".
|
- #io-channel-cells = <0>: See the IIO bindings section "IIO consumers".
|
||||||
|
|
||||||
Example node:
|
Example node:
|
||||||
|
|
||||||
ads1202: adc@0 {
|
ads1202: adc@0 {
|
||||||
compatible = "sd-modulator";
|
compatible = "sd-modulator";
|
||||||
#io-channel-cells = <1>;
|
#io-channel-cells = <0>;
|
||||||
};
|
};
|
||||||
|
@ -50,14 +50,15 @@ Example:
|
|||||||
compatible = "marvell,mv88e6085";
|
compatible = "marvell,mv88e6085";
|
||||||
reg = <0>;
|
reg = <0>;
|
||||||
reset-gpios = <&gpio5 1 GPIO_ACTIVE_LOW>;
|
reset-gpios = <&gpio5 1 GPIO_ACTIVE_LOW>;
|
||||||
};
|
|
||||||
mdio {
|
mdio {
|
||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
switch1phy0: switch1phy0@0 {
|
switch1phy0: switch1phy0@0 {
|
||||||
reg = <0>;
|
reg = <0>;
|
||||||
interrupt-parent = <&switch0>;
|
interrupt-parent = <&switch0>;
|
||||||
interrupts = <0 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <0 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -74,23 +75,24 @@ Example:
|
|||||||
compatible = "marvell,mv88e6390";
|
compatible = "marvell,mv88e6390";
|
||||||
reg = <0>;
|
reg = <0>;
|
||||||
reset-gpios = <&gpio5 1 GPIO_ACTIVE_LOW>;
|
reset-gpios = <&gpio5 1 GPIO_ACTIVE_LOW>;
|
||||||
};
|
|
||||||
mdio {
|
|
||||||
#address-cells = <1>;
|
|
||||||
#size-cells = <0>;
|
|
||||||
switch1phy0: switch1phy0@0 {
|
|
||||||
reg = <0>;
|
|
||||||
interrupt-parent = <&switch0>;
|
|
||||||
interrupts = <0 IRQ_TYPE_LEVEL_HIGH>;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
mdio1 {
|
mdio {
|
||||||
compatible = "marvell,mv88e6xxx-mdio-external";
|
#address-cells = <1>;
|
||||||
#address-cells = <1>;
|
#size-cells = <0>;
|
||||||
#size-cells = <0>;
|
switch1phy0: switch1phy0@0 {
|
||||||
switch1phy9: switch1phy0@9 {
|
reg = <0>;
|
||||||
reg = <9>;
|
interrupt-parent = <&switch0>;
|
||||||
|
interrupts = <0 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
mdio1 {
|
||||||
|
compatible = "marvell,mv88e6xxx-mdio-external";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
switch1phy9: switch1phy0@9 {
|
||||||
|
reg = <9>;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -27,7 +27,11 @@ Required properties:
|
|||||||
SoC-specific version corresponding to the platform first followed by
|
SoC-specific version corresponding to the platform first followed by
|
||||||
the generic version.
|
the generic version.
|
||||||
|
|
||||||
- reg: offset and length of (1) the register block and (2) the stream buffer.
|
- reg: Offset and length of (1) the register block and (2) the stream buffer.
|
||||||
|
The region for the register block is mandatory.
|
||||||
|
The region for the stream buffer is optional, as it is only present on
|
||||||
|
R-Car Gen2 and RZ/G1 SoCs, and on R-Car H3 (R8A7795), M3-W (R8A7796),
|
||||||
|
and M3-N (R8A77965).
|
||||||
- interrupts: A list of interrupt-specifiers, one for each entry in
|
- interrupts: A list of interrupt-specifiers, one for each entry in
|
||||||
interrupt-names.
|
interrupt-names.
|
||||||
If interrupt-names is not present, an interrupt specifier
|
If interrupt-names is not present, an interrupt specifier
|
||||||
|
@ -19,7 +19,7 @@ Required properties:
|
|||||||
configured in FS mode;
|
configured in FS mode;
|
||||||
- "st,stm32f4x9-hsotg": The DWC2 USB HS controller instance in STM32F4x9 SoCs
|
- "st,stm32f4x9-hsotg": The DWC2 USB HS controller instance in STM32F4x9 SoCs
|
||||||
configured in HS mode;
|
configured in HS mode;
|
||||||
- "st,stm32f7xx-hsotg": The DWC2 USB HS controller instance in STM32F7xx SoCs
|
- "st,stm32f7-hsotg": The DWC2 USB HS controller instance in STM32F7 SoCs
|
||||||
configured in HS mode;
|
configured in HS mode;
|
||||||
- reg : Should contain 1 register range (address and length)
|
- reg : Should contain 1 register range (address and length)
|
||||||
- interrupts : Should contain 1 interrupt
|
- interrupts : Should contain 1 interrupt
|
||||||
|
@ -4,6 +4,7 @@ Required properties:
|
|||||||
- compatible: Must contain one of the following:
|
- compatible: Must contain one of the following:
|
||||||
- "renesas,r8a7795-usb3-peri"
|
- "renesas,r8a7795-usb3-peri"
|
||||||
- "renesas,r8a7796-usb3-peri"
|
- "renesas,r8a7796-usb3-peri"
|
||||||
|
- "renesas,r8a77965-usb3-peri"
|
||||||
- "renesas,rcar-gen3-usb3-peri" for a generic R-Car Gen3 compatible
|
- "renesas,rcar-gen3-usb3-peri" for a generic R-Car Gen3 compatible
|
||||||
device
|
device
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@ Required properties:
|
|||||||
- "renesas,usbhs-r8a7794" for r8a7794 (R-Car E2) compatible device
|
- "renesas,usbhs-r8a7794" for r8a7794 (R-Car E2) compatible device
|
||||||
- "renesas,usbhs-r8a7795" for r8a7795 (R-Car H3) compatible device
|
- "renesas,usbhs-r8a7795" for r8a7795 (R-Car H3) compatible device
|
||||||
- "renesas,usbhs-r8a7796" for r8a7796 (R-Car M3-W) compatible device
|
- "renesas,usbhs-r8a7796" for r8a7796 (R-Car M3-W) compatible device
|
||||||
|
- "renesas,usbhs-r8a77965" for r8a77965 (R-Car M3-N) compatible device
|
||||||
- "renesas,usbhs-r8a77995" for r8a77995 (R-Car D3) compatible device
|
- "renesas,usbhs-r8a77995" for r8a77995 (R-Car D3) compatible device
|
||||||
- "renesas,usbhs-r7s72100" for r7s72100 (RZ/A1) compatible device
|
- "renesas,usbhs-r7s72100" for r7s72100 (RZ/A1) compatible device
|
||||||
- "renesas,rcar-gen2-usbhs" for R-Car Gen2 or RZ/G1 compatible devices
|
- "renesas,rcar-gen2-usbhs" for R-Car Gen2 or RZ/G1 compatible devices
|
||||||
|
@ -13,6 +13,7 @@ Required properties:
|
|||||||
- "renesas,xhci-r8a7793" for r8a7793 SoC
|
- "renesas,xhci-r8a7793" for r8a7793 SoC
|
||||||
- "renesas,xhci-r8a7795" for r8a7795 SoC
|
- "renesas,xhci-r8a7795" for r8a7795 SoC
|
||||||
- "renesas,xhci-r8a7796" for r8a7796 SoC
|
- "renesas,xhci-r8a7796" for r8a7796 SoC
|
||||||
|
- "renesas,xhci-r8a77965" for r8a77965 SoC
|
||||||
- "renesas,rcar-gen2-xhci" for a generic R-Car Gen2 or RZ/G1 compatible
|
- "renesas,rcar-gen2-xhci" for a generic R-Car Gen2 or RZ/G1 compatible
|
||||||
device
|
device
|
||||||
- "renesas,rcar-gen3-xhci" for a generic R-Car Gen3 compatible device
|
- "renesas,rcar-gen3-xhci" for a generic R-Car Gen3 compatible device
|
||||||
|
@ -20,8 +20,8 @@ TCP Segmentation Offload
|
|||||||
|
|
||||||
TCP segmentation allows a device to segment a single frame into multiple
|
TCP segmentation allows a device to segment a single frame into multiple
|
||||||
frames with a data payload size specified in skb_shinfo()->gso_size.
|
frames with a data payload size specified in skb_shinfo()->gso_size.
|
||||||
When TCP segmentation requested the bit for either SKB_GSO_TCP or
|
When TCP segmentation requested the bit for either SKB_GSO_TCPV4 or
|
||||||
SKB_GSO_TCP6 should be set in skb_shinfo()->gso_type and
|
SKB_GSO_TCPV6 should be set in skb_shinfo()->gso_type and
|
||||||
skb_shinfo()->gso_size should be set to a non-zero value.
|
skb_shinfo()->gso_size should be set to a non-zero value.
|
||||||
|
|
||||||
TCP segmentation is dependent on support for the use of partial checksum
|
TCP segmentation is dependent on support for the use of partial checksum
|
||||||
@ -153,8 +153,18 @@ To signal this, gso_size is set to the special value GSO_BY_FRAGS.
|
|||||||
|
|
||||||
Therefore, any code in the core networking stack must be aware of the
|
Therefore, any code in the core networking stack must be aware of the
|
||||||
possibility that gso_size will be GSO_BY_FRAGS and handle that case
|
possibility that gso_size will be GSO_BY_FRAGS and handle that case
|
||||||
appropriately. (For size checks, the skb_gso_validate_*_len family of
|
appropriately.
|
||||||
helpers do this automatically.)
|
|
||||||
|
There are some helpers to make this easier:
|
||||||
|
|
||||||
|
- skb_is_gso(skb) && skb_is_gso_sctp(skb) is the best way to see if
|
||||||
|
an skb is an SCTP GSO skb.
|
||||||
|
|
||||||
|
- For size checks, the skb_gso_validate_*_len family of helpers correctly
|
||||||
|
considers GSO_BY_FRAGS.
|
||||||
|
|
||||||
|
- For manipulating packets, skb_increase_gso_size and skb_decrease_gso_size
|
||||||
|
will check for GSO_BY_FRAGS and WARN if asked to manipulate these skbs.
|
||||||
|
|
||||||
This also affects drivers with the NETIF_F_FRAGLIST & NETIF_F_GSO_SCTP bits
|
This also affects drivers with the NETIF_F_FRAGLIST & NETIF_F_GSO_SCTP bits
|
||||||
set. Note also that NETIF_F_GSO_SCTP is included in NETIF_F_GSO_SOFTWARE.
|
set. Note also that NETIF_F_GSO_SCTP is included in NETIF_F_GSO_SOFTWARE.
|
||||||
|
11
MAINTAINERS
11
MAINTAINERS
@ -9925,6 +9925,13 @@ F: Documentation/ABI/stable/sysfs-bus-nvmem
|
|||||||
F: include/linux/nvmem-consumer.h
|
F: include/linux/nvmem-consumer.h
|
||||||
F: include/linux/nvmem-provider.h
|
F: include/linux/nvmem-provider.h
|
||||||
|
|
||||||
|
NXP SGTL5000 DRIVER
|
||||||
|
M: Fabio Estevam <fabio.estevam@nxp.com>
|
||||||
|
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
||||||
|
S: Maintained
|
||||||
|
F: Documentation/devicetree/bindings/sound/sgtl5000.txt
|
||||||
|
F: sound/soc/codecs/sgtl5000*
|
||||||
|
|
||||||
NXP TDA998X DRM DRIVER
|
NXP TDA998X DRM DRIVER
|
||||||
M: Russell King <linux@armlinux.org.uk>
|
M: Russell King <linux@armlinux.org.uk>
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -10327,7 +10334,7 @@ F: drivers/oprofile/
|
|||||||
F: include/linux/oprofile.h
|
F: include/linux/oprofile.h
|
||||||
|
|
||||||
ORACLE CLUSTER FILESYSTEM 2 (OCFS2)
|
ORACLE CLUSTER FILESYSTEM 2 (OCFS2)
|
||||||
M: Mark Fasheh <mfasheh@versity.com>
|
M: Mark Fasheh <mark@fasheh.com>
|
||||||
M: Joel Becker <jlbec@evilplan.org>
|
M: Joel Becker <jlbec@evilplan.org>
|
||||||
L: ocfs2-devel@oss.oracle.com (moderated for non-subscribers)
|
L: ocfs2-devel@oss.oracle.com (moderated for non-subscribers)
|
||||||
W: http://ocfs2.wiki.kernel.org
|
W: http://ocfs2.wiki.kernel.org
|
||||||
@ -10837,6 +10844,7 @@ F: drivers/platform/x86/peaq-wmi.c
|
|||||||
PER-CPU MEMORY ALLOCATOR
|
PER-CPU MEMORY ALLOCATOR
|
||||||
M: Tejun Heo <tj@kernel.org>
|
M: Tejun Heo <tj@kernel.org>
|
||||||
M: Christoph Lameter <cl@linux.com>
|
M: Christoph Lameter <cl@linux.com>
|
||||||
|
M: Dennis Zhou <dennisszhou@gmail.com>
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/tj/percpu.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/tj/percpu.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: include/linux/percpu*.h
|
F: include/linux/percpu*.h
|
||||||
@ -12107,6 +12115,7 @@ M: Sylwester Nawrocki <s.nawrocki@samsung.com>
|
|||||||
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
L: alsa-devel@alsa-project.org (moderated for non-subscribers)
|
||||||
S: Supported
|
S: Supported
|
||||||
F: sound/soc/samsung/
|
F: sound/soc/samsung/
|
||||||
|
F: Documentation/devicetree/bindings/sound/samsung*
|
||||||
|
|
||||||
SAMSUNG EXYNOS PSEUDO RANDOM NUMBER GENERATOR (RNG) DRIVER
|
SAMSUNG EXYNOS PSEUDO RANDOM NUMBER GENERATOR (RNG) DRIVER
|
||||||
M: Krzysztof Kozlowski <krzk@kernel.org>
|
M: Krzysztof Kozlowski <krzk@kernel.org>
|
||||||
|
11
Makefile
11
Makefile
@ -2,7 +2,7 @@
|
|||||||
VERSION = 4
|
VERSION = 4
|
||||||
PATCHLEVEL = 16
|
PATCHLEVEL = 16
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc5
|
EXTRAVERSION = -rc6
|
||||||
NAME = Fearless Coyote
|
NAME = Fearless Coyote
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
@ -826,6 +826,15 @@ KBUILD_CFLAGS += $(call cc-disable-warning, pointer-sign)
|
|||||||
# disable invalid "can't wrap" optimizations for signed / pointers
|
# disable invalid "can't wrap" optimizations for signed / pointers
|
||||||
KBUILD_CFLAGS += $(call cc-option,-fno-strict-overflow)
|
KBUILD_CFLAGS += $(call cc-option,-fno-strict-overflow)
|
||||||
|
|
||||||
|
# clang sets -fmerge-all-constants by default as optimization, but this
|
||||||
|
# is non-conforming behavior for C and in fact breaks the kernel, so we
|
||||||
|
# need to disable it here generally.
|
||||||
|
KBUILD_CFLAGS += $(call cc-option,-fno-merge-all-constants)
|
||||||
|
|
||||||
|
# for gcc -fno-merge-all-constants disables everything, but it is fine
|
||||||
|
# to have actual conforming behavior enabled.
|
||||||
|
KBUILD_CFLAGS += $(call cc-option,-fmerge-constants)
|
||||||
|
|
||||||
# Make sure -fstack-check isn't enabled (like gentoo apparently did)
|
# Make sure -fstack-check isn't enabled (like gentoo apparently did)
|
||||||
KBUILD_CFLAGS += $(call cc-option,-fno-stack-check,)
|
KBUILD_CFLAGS += $(call cc-option,-fno-stack-check,)
|
||||||
|
|
||||||
|
@ -363,8 +363,6 @@ int kvm_arch_vcpu_ioctl_set_guest_debug(struct kvm_vcpu *vcpu,
|
|||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
vcpu_load(vcpu);
|
|
||||||
|
|
||||||
trace_kvm_set_guest_debug(vcpu, dbg->control);
|
trace_kvm_set_guest_debug(vcpu, dbg->control);
|
||||||
|
|
||||||
if (dbg->control & ~KVM_GUESTDBG_VALID_MASK) {
|
if (dbg->control & ~KVM_GUESTDBG_VALID_MASK) {
|
||||||
@ -386,7 +384,6 @@ int kvm_arch_vcpu_ioctl_set_guest_debug(struct kvm_vcpu *vcpu,
|
|||||||
}
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
vcpu_put(vcpu);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -972,3 +972,13 @@ int pmd_clear_huge(pmd_t *pmdp)
|
|||||||
pmd_clear(pmdp);
|
pmd_clear(pmdp);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int pud_free_pmd_page(pud_t *pud)
|
||||||
|
{
|
||||||
|
return pud_none(*pud);
|
||||||
|
}
|
||||||
|
|
||||||
|
int pmd_free_pte_page(pmd_t *pmd)
|
||||||
|
{
|
||||||
|
return pmd_none(*pmd);
|
||||||
|
}
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
#ifndef __H8300_BYTEORDER_H__
|
#ifndef __H8300_BYTEORDER_H__
|
||||||
#define __H8300_BYTEORDER_H__
|
#define __H8300_BYTEORDER_H__
|
||||||
|
|
||||||
#define __BIG_ENDIAN __ORDER_BIG_ENDIAN__
|
|
||||||
#include <linux/byteorder/big_endian.h>
|
#include <linux/byteorder/big_endian.h>
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -24,6 +24,7 @@ config MICROBLAZE
|
|||||||
select HAVE_FTRACE_MCOUNT_RECORD
|
select HAVE_FTRACE_MCOUNT_RECORD
|
||||||
select HAVE_FUNCTION_GRAPH_TRACER
|
select HAVE_FUNCTION_GRAPH_TRACER
|
||||||
select HAVE_FUNCTION_TRACER
|
select HAVE_FUNCTION_TRACER
|
||||||
|
select NO_BOOTMEM
|
||||||
select HAVE_MEMBLOCK
|
select HAVE_MEMBLOCK
|
||||||
select HAVE_MEMBLOCK_NODE_MAP
|
select HAVE_MEMBLOCK_NODE_MAP
|
||||||
select HAVE_OPROFILE
|
select HAVE_OPROFILE
|
||||||
|
@ -8,7 +8,6 @@ menu "Platform options"
|
|||||||
|
|
||||||
config OPT_LIB_FUNCTION
|
config OPT_LIB_FUNCTION
|
||||||
bool "Optimalized lib function"
|
bool "Optimalized lib function"
|
||||||
depends on CPU_LITTLE_ENDIAN
|
|
||||||
default y
|
default y
|
||||||
help
|
help
|
||||||
Allows turn on optimalized library function (memcpy and memmove).
|
Allows turn on optimalized library function (memcpy and memmove).
|
||||||
@ -21,6 +20,7 @@ config OPT_LIB_FUNCTION
|
|||||||
config OPT_LIB_ASM
|
config OPT_LIB_ASM
|
||||||
bool "Optimalized lib function ASM"
|
bool "Optimalized lib function ASM"
|
||||||
depends on OPT_LIB_FUNCTION && (XILINX_MICROBLAZE0_USE_BARREL = 1)
|
depends on OPT_LIB_FUNCTION && (XILINX_MICROBLAZE0_USE_BARREL = 1)
|
||||||
|
depends on CPU_BIG_ENDIAN
|
||||||
default n
|
default n
|
||||||
help
|
help
|
||||||
Allows turn on optimalized library function (memcpy and memmove).
|
Allows turn on optimalized library function (memcpy and memmove).
|
||||||
|
@ -44,7 +44,6 @@ void machine_shutdown(void);
|
|||||||
void machine_halt(void);
|
void machine_halt(void);
|
||||||
void machine_power_off(void);
|
void machine_power_off(void);
|
||||||
|
|
||||||
extern void *alloc_maybe_bootmem(size_t size, gfp_t mask);
|
|
||||||
extern void *zalloc_maybe_bootmem(size_t size, gfp_t mask);
|
extern void *zalloc_maybe_bootmem(size_t size, gfp_t mask);
|
||||||
|
|
||||||
# endif /* __ASSEMBLY__ */
|
# endif /* __ASSEMBLY__ */
|
||||||
|
@ -29,10 +29,6 @@
|
|||||||
* between mem locations with size of xfer spec'd in bytes
|
* between mem locations with size of xfer spec'd in bytes
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef __MICROBLAZEEL__
|
|
||||||
#error Microblaze LE not support ASM optimized lib func. Disable OPT_LIB_ASM.
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <linux/linkage.h>
|
#include <linux/linkage.h>
|
||||||
.text
|
.text
|
||||||
.globl memcpy
|
.globl memcpy
|
||||||
|
@ -32,9 +32,6 @@ int mem_init_done;
|
|||||||
#ifndef CONFIG_MMU
|
#ifndef CONFIG_MMU
|
||||||
unsigned int __page_offset;
|
unsigned int __page_offset;
|
||||||
EXPORT_SYMBOL(__page_offset);
|
EXPORT_SYMBOL(__page_offset);
|
||||||
|
|
||||||
#else
|
|
||||||
static int init_bootmem_done;
|
|
||||||
#endif /* CONFIG_MMU */
|
#endif /* CONFIG_MMU */
|
||||||
|
|
||||||
char *klimit = _end;
|
char *klimit = _end;
|
||||||
@ -117,7 +114,6 @@ static void __init paging_init(void)
|
|||||||
|
|
||||||
void __init setup_memory(void)
|
void __init setup_memory(void)
|
||||||
{
|
{
|
||||||
unsigned long map_size;
|
|
||||||
struct memblock_region *reg;
|
struct memblock_region *reg;
|
||||||
|
|
||||||
#ifndef CONFIG_MMU
|
#ifndef CONFIG_MMU
|
||||||
@ -174,17 +170,6 @@ void __init setup_memory(void)
|
|||||||
pr_info("%s: max_low_pfn: %#lx\n", __func__, max_low_pfn);
|
pr_info("%s: max_low_pfn: %#lx\n", __func__, max_low_pfn);
|
||||||
pr_info("%s: max_pfn: %#lx\n", __func__, max_pfn);
|
pr_info("%s: max_pfn: %#lx\n", __func__, max_pfn);
|
||||||
|
|
||||||
/*
|
|
||||||
* Find an area to use for the bootmem bitmap.
|
|
||||||
* We look for the first area which is at least
|
|
||||||
* 128kB in length (128kB is enough for a bitmap
|
|
||||||
* for 4GB of memory, using 4kB pages), plus 1 page
|
|
||||||
* (in case the address isn't page-aligned).
|
|
||||||
*/
|
|
||||||
map_size = init_bootmem_node(NODE_DATA(0),
|
|
||||||
PFN_UP(TOPHYS((u32)klimit)), min_low_pfn, max_low_pfn);
|
|
||||||
memblock_reserve(PFN_UP(TOPHYS((u32)klimit)) << PAGE_SHIFT, map_size);
|
|
||||||
|
|
||||||
/* Add active regions with valid PFNs */
|
/* Add active regions with valid PFNs */
|
||||||
for_each_memblock(memory, reg) {
|
for_each_memblock(memory, reg) {
|
||||||
unsigned long start_pfn, end_pfn;
|
unsigned long start_pfn, end_pfn;
|
||||||
@ -196,32 +181,9 @@ void __init setup_memory(void)
|
|||||||
&memblock.memory, 0);
|
&memblock.memory, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* free bootmem is whole main memory */
|
|
||||||
free_bootmem_with_active_regions(0, max_low_pfn);
|
|
||||||
|
|
||||||
/* reserve allocate blocks */
|
|
||||||
for_each_memblock(reserved, reg) {
|
|
||||||
unsigned long top = reg->base + reg->size - 1;
|
|
||||||
|
|
||||||
pr_debug("reserved - 0x%08x-0x%08x, %lx, %lx\n",
|
|
||||||
(u32) reg->base, (u32) reg->size, top,
|
|
||||||
memory_start + lowmem_size - 1);
|
|
||||||
|
|
||||||
if (top <= (memory_start + lowmem_size - 1)) {
|
|
||||||
reserve_bootmem(reg->base, reg->size, BOOTMEM_DEFAULT);
|
|
||||||
} else if (reg->base < (memory_start + lowmem_size - 1)) {
|
|
||||||
unsigned long trunc_size = memory_start + lowmem_size -
|
|
||||||
reg->base;
|
|
||||||
reserve_bootmem(reg->base, trunc_size, BOOTMEM_DEFAULT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* XXX need to clip this if using highmem? */
|
/* XXX need to clip this if using highmem? */
|
||||||
sparse_memory_present_with_active_regions(0);
|
sparse_memory_present_with_active_regions(0);
|
||||||
|
|
||||||
#ifdef CONFIG_MMU
|
|
||||||
init_bootmem_done = 1;
|
|
||||||
#endif
|
|
||||||
paging_init();
|
paging_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -398,30 +360,16 @@ asmlinkage void __init mmu_init(void)
|
|||||||
/* This is only called until mem_init is done. */
|
/* This is only called until mem_init is done. */
|
||||||
void __init *early_get_page(void)
|
void __init *early_get_page(void)
|
||||||
{
|
{
|
||||||
void *p;
|
/*
|
||||||
if (init_bootmem_done) {
|
* Mem start + kernel_tlb -> here is limit
|
||||||
p = alloc_bootmem_pages(PAGE_SIZE);
|
* because of mem mapping from head.S
|
||||||
} else {
|
*/
|
||||||
/*
|
return __va(memblock_alloc_base(PAGE_SIZE, PAGE_SIZE,
|
||||||
* Mem start + kernel_tlb -> here is limit
|
memory_start + kernel_tlb));
|
||||||
* because of mem mapping from head.S
|
|
||||||
*/
|
|
||||||
p = __va(memblock_alloc_base(PAGE_SIZE, PAGE_SIZE,
|
|
||||||
memory_start + kernel_tlb));
|
|
||||||
}
|
|
||||||
return p;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_MMU */
|
#endif /* CONFIG_MMU */
|
||||||
|
|
||||||
void * __ref alloc_maybe_bootmem(size_t size, gfp_t mask)
|
|
||||||
{
|
|
||||||
if (mem_init_done)
|
|
||||||
return kmalloc(size, mask);
|
|
||||||
else
|
|
||||||
return alloc_bootmem(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
void * __ref zalloc_maybe_bootmem(size_t size, gfp_t mask)
|
void * __ref zalloc_maybe_bootmem(size_t size, gfp_t mask)
|
||||||
{
|
{
|
||||||
void *p;
|
void *p;
|
||||||
|
@ -13,6 +13,8 @@ choice
|
|||||||
config SOC_AMAZON_SE
|
config SOC_AMAZON_SE
|
||||||
bool "Amazon SE"
|
bool "Amazon SE"
|
||||||
select SOC_TYPE_XWAY
|
select SOC_TYPE_XWAY
|
||||||
|
select MFD_SYSCON
|
||||||
|
select MFD_CORE
|
||||||
|
|
||||||
config SOC_XWAY
|
config SOC_XWAY
|
||||||
bool "XWAY"
|
bool "XWAY"
|
||||||
|
@ -549,9 +549,9 @@ void __init ltq_soc_init(void)
|
|||||||
clkdev_add_static(ltq_ar9_cpu_hz(), ltq_ar9_fpi_hz(),
|
clkdev_add_static(ltq_ar9_cpu_hz(), ltq_ar9_fpi_hz(),
|
||||||
ltq_ar9_fpi_hz(), CLOCK_250M);
|
ltq_ar9_fpi_hz(), CLOCK_250M);
|
||||||
clkdev_add_pmu("1f203018.usb2-phy", "phy", 1, 0, PMU_USB0_P);
|
clkdev_add_pmu("1f203018.usb2-phy", "phy", 1, 0, PMU_USB0_P);
|
||||||
clkdev_add_pmu("1e101000.usb", "otg", 1, 0, PMU_USB0);
|
clkdev_add_pmu("1e101000.usb", "otg", 1, 0, PMU_USB0 | PMU_AHBM);
|
||||||
clkdev_add_pmu("1f203034.usb2-phy", "phy", 1, 0, PMU_USB1_P);
|
clkdev_add_pmu("1f203034.usb2-phy", "phy", 1, 0, PMU_USB1_P);
|
||||||
clkdev_add_pmu("1e106000.usb", "otg", 1, 0, PMU_USB1);
|
clkdev_add_pmu("1e106000.usb", "otg", 1, 0, PMU_USB1 | PMU_AHBM);
|
||||||
clkdev_add_pmu("1e180000.etop", "switch", 1, 0, PMU_SWITCH);
|
clkdev_add_pmu("1e180000.etop", "switch", 1, 0, PMU_SWITCH);
|
||||||
clkdev_add_pmu("1e103000.sdio", NULL, 1, 0, PMU_SDIO);
|
clkdev_add_pmu("1e103000.sdio", NULL, 1, 0, PMU_SDIO);
|
||||||
clkdev_add_pmu("1e103100.deu", NULL, 1, 0, PMU_DEU);
|
clkdev_add_pmu("1e103100.deu", NULL, 1, 0, PMU_DEU);
|
||||||
@ -560,7 +560,7 @@ void __init ltq_soc_init(void)
|
|||||||
} else {
|
} else {
|
||||||
clkdev_add_static(ltq_danube_cpu_hz(), ltq_danube_fpi_hz(),
|
clkdev_add_static(ltq_danube_cpu_hz(), ltq_danube_fpi_hz(),
|
||||||
ltq_danube_fpi_hz(), ltq_danube_pp32_hz());
|
ltq_danube_fpi_hz(), ltq_danube_pp32_hz());
|
||||||
clkdev_add_pmu("1f203018.usb2-phy", "ctrl", 1, 0, PMU_USB0);
|
clkdev_add_pmu("1e101000.usb", "otg", 1, 0, PMU_USB0 | PMU_AHBM);
|
||||||
clkdev_add_pmu("1f203018.usb2-phy", "phy", 1, 0, PMU_USB0_P);
|
clkdev_add_pmu("1f203018.usb2-phy", "phy", 1, 0, PMU_USB0_P);
|
||||||
clkdev_add_pmu("1e103000.sdio", NULL, 1, 0, PMU_SDIO);
|
clkdev_add_pmu("1e103000.sdio", NULL, 1, 0, PMU_SDIO);
|
||||||
clkdev_add_pmu("1e103100.deu", NULL, 1, 0, PMU_DEU);
|
clkdev_add_pmu("1e103100.deu", NULL, 1, 0, PMU_DEU);
|
||||||
|
@ -170,6 +170,28 @@ void prom_soc_init(struct ralink_soc_info *soc_info)
|
|||||||
u32 n1;
|
u32 n1;
|
||||||
u32 rev;
|
u32 rev;
|
||||||
|
|
||||||
|
/* Early detection of CMP support */
|
||||||
|
mips_cm_probe();
|
||||||
|
mips_cpc_probe();
|
||||||
|
|
||||||
|
if (mips_cps_numiocu(0)) {
|
||||||
|
/*
|
||||||
|
* mips_cm_probe() wipes out bootloader
|
||||||
|
* config for CM regions and we have to configure them
|
||||||
|
* again. This SoC cannot talk to pamlbus devices
|
||||||
|
* witout proper iocu region set up.
|
||||||
|
*
|
||||||
|
* FIXME: it would be better to do this with values
|
||||||
|
* from DT, but we need this very early because
|
||||||
|
* without this we cannot talk to pretty much anything
|
||||||
|
* including serial.
|
||||||
|
*/
|
||||||
|
write_gcr_reg0_base(MT7621_PALMBUS_BASE);
|
||||||
|
write_gcr_reg0_mask(~MT7621_PALMBUS_SIZE |
|
||||||
|
CM_GCR_REGn_MASK_CMTGT_IOCU0);
|
||||||
|
__sync();
|
||||||
|
}
|
||||||
|
|
||||||
n0 = __raw_readl(sysc + SYSC_REG_CHIP_NAME0);
|
n0 = __raw_readl(sysc + SYSC_REG_CHIP_NAME0);
|
||||||
n1 = __raw_readl(sysc + SYSC_REG_CHIP_NAME1);
|
n1 = __raw_readl(sysc + SYSC_REG_CHIP_NAME1);
|
||||||
|
|
||||||
@ -194,26 +216,6 @@ void prom_soc_init(struct ralink_soc_info *soc_info)
|
|||||||
|
|
||||||
rt2880_pinmux_data = mt7621_pinmux_data;
|
rt2880_pinmux_data = mt7621_pinmux_data;
|
||||||
|
|
||||||
/* Early detection of CMP support */
|
|
||||||
mips_cm_probe();
|
|
||||||
mips_cpc_probe();
|
|
||||||
|
|
||||||
if (mips_cps_numiocu(0)) {
|
|
||||||
/*
|
|
||||||
* mips_cm_probe() wipes out bootloader
|
|
||||||
* config for CM regions and we have to configure them
|
|
||||||
* again. This SoC cannot talk to pamlbus devices
|
|
||||||
* witout proper iocu region set up.
|
|
||||||
*
|
|
||||||
* FIXME: it would be better to do this with values
|
|
||||||
* from DT, but we need this very early because
|
|
||||||
* without this we cannot talk to pretty much anything
|
|
||||||
* including serial.
|
|
||||||
*/
|
|
||||||
write_gcr_reg0_base(MT7621_PALMBUS_BASE);
|
|
||||||
write_gcr_reg0_mask(~MT7621_PALMBUS_SIZE |
|
|
||||||
CM_GCR_REGn_MASK_CMTGT_IOCU0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!register_cps_smp_ops())
|
if (!register_cps_smp_ops())
|
||||||
return;
|
return;
|
||||||
|
@ -96,16 +96,9 @@ static void ralink_restart(char *command)
|
|||||||
unreachable();
|
unreachable();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ralink_halt(void)
|
|
||||||
{
|
|
||||||
local_irq_disable();
|
|
||||||
unreachable();
|
|
||||||
}
|
|
||||||
|
|
||||||
static int __init mips_reboot_setup(void)
|
static int __init mips_reboot_setup(void)
|
||||||
{
|
{
|
||||||
_machine_restart = ralink_restart;
|
_machine_restart = ralink_restart;
|
||||||
_machine_halt = ralink_halt;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -543,7 +543,8 @@ void flush_cache_mm(struct mm_struct *mm)
|
|||||||
rp3440, etc. So, avoid it if the mm isn't too big. */
|
rp3440, etc. So, avoid it if the mm isn't too big. */
|
||||||
if ((!IS_ENABLED(CONFIG_SMP) || !arch_irqs_disabled()) &&
|
if ((!IS_ENABLED(CONFIG_SMP) || !arch_irqs_disabled()) &&
|
||||||
mm_total_size(mm) >= parisc_cache_flush_threshold) {
|
mm_total_size(mm) >= parisc_cache_flush_threshold) {
|
||||||
flush_tlb_all();
|
if (mm->context)
|
||||||
|
flush_tlb_all();
|
||||||
flush_cache_all();
|
flush_cache_all();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -571,6 +572,8 @@ void flush_cache_mm(struct mm_struct *mm)
|
|||||||
pfn = pte_pfn(*ptep);
|
pfn = pte_pfn(*ptep);
|
||||||
if (!pfn_valid(pfn))
|
if (!pfn_valid(pfn))
|
||||||
continue;
|
continue;
|
||||||
|
if (unlikely(mm->context))
|
||||||
|
flush_tlb_page(vma, addr);
|
||||||
__flush_cache_page(vma, addr, PFN_PHYS(pfn));
|
__flush_cache_page(vma, addr, PFN_PHYS(pfn));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -579,26 +582,46 @@ void flush_cache_mm(struct mm_struct *mm)
|
|||||||
void flush_cache_range(struct vm_area_struct *vma,
|
void flush_cache_range(struct vm_area_struct *vma,
|
||||||
unsigned long start, unsigned long end)
|
unsigned long start, unsigned long end)
|
||||||
{
|
{
|
||||||
|
pgd_t *pgd;
|
||||||
|
unsigned long addr;
|
||||||
|
|
||||||
if ((!IS_ENABLED(CONFIG_SMP) || !arch_irqs_disabled()) &&
|
if ((!IS_ENABLED(CONFIG_SMP) || !arch_irqs_disabled()) &&
|
||||||
end - start >= parisc_cache_flush_threshold) {
|
end - start >= parisc_cache_flush_threshold) {
|
||||||
flush_tlb_range(vma, start, end);
|
if (vma->vm_mm->context)
|
||||||
|
flush_tlb_range(vma, start, end);
|
||||||
flush_cache_all();
|
flush_cache_all();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
flush_user_dcache_range_asm(start, end);
|
if (vma->vm_mm->context == mfsp(3)) {
|
||||||
if (vma->vm_flags & VM_EXEC)
|
flush_user_dcache_range_asm(start, end);
|
||||||
flush_user_icache_range_asm(start, end);
|
if (vma->vm_flags & VM_EXEC)
|
||||||
flush_tlb_range(vma, start, end);
|
flush_user_icache_range_asm(start, end);
|
||||||
|
flush_tlb_range(vma, start, end);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
pgd = vma->vm_mm->pgd;
|
||||||
|
for (addr = vma->vm_start; addr < vma->vm_end; addr += PAGE_SIZE) {
|
||||||
|
unsigned long pfn;
|
||||||
|
pte_t *ptep = get_ptep(pgd, addr);
|
||||||
|
if (!ptep)
|
||||||
|
continue;
|
||||||
|
pfn = pte_pfn(*ptep);
|
||||||
|
if (pfn_valid(pfn)) {
|
||||||
|
if (unlikely(vma->vm_mm->context))
|
||||||
|
flush_tlb_page(vma, addr);
|
||||||
|
__flush_cache_page(vma, addr, PFN_PHYS(pfn));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
flush_cache_page(struct vm_area_struct *vma, unsigned long vmaddr, unsigned long pfn)
|
flush_cache_page(struct vm_area_struct *vma, unsigned long vmaddr, unsigned long pfn)
|
||||||
{
|
{
|
||||||
BUG_ON(!vma->vm_mm->context);
|
|
||||||
|
|
||||||
if (pfn_valid(pfn)) {
|
if (pfn_valid(pfn)) {
|
||||||
flush_tlb_page(vma, vmaddr);
|
if (likely(vma->vm_mm->context))
|
||||||
|
flush_tlb_page(vma, vmaddr);
|
||||||
__flush_cache_page(vma, vmaddr, PFN_PHYS(pfn));
|
__flush_cache_page(vma, vmaddr, PFN_PHYS(pfn));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -320,7 +320,6 @@ kvm_novcpu_exit:
|
|||||||
stw r12, STACK_SLOT_TRAP(r1)
|
stw r12, STACK_SLOT_TRAP(r1)
|
||||||
bl kvmhv_commence_exit
|
bl kvmhv_commence_exit
|
||||||
nop
|
nop
|
||||||
lwz r12, STACK_SLOT_TRAP(r1)
|
|
||||||
b kvmhv_switch_to_host
|
b kvmhv_switch_to_host
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1220,6 +1219,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_ARCH_300)
|
|||||||
|
|
||||||
secondary_too_late:
|
secondary_too_late:
|
||||||
li r12, 0
|
li r12, 0
|
||||||
|
stw r12, STACK_SLOT_TRAP(r1)
|
||||||
cmpdi r4, 0
|
cmpdi r4, 0
|
||||||
beq 11f
|
beq 11f
|
||||||
stw r12, VCPU_TRAP(r4)
|
stw r12, VCPU_TRAP(r4)
|
||||||
@ -1558,12 +1558,12 @@ mc_cont:
|
|||||||
3: stw r5,VCPU_SLB_MAX(r9)
|
3: stw r5,VCPU_SLB_MAX(r9)
|
||||||
|
|
||||||
guest_bypass:
|
guest_bypass:
|
||||||
|
stw r12, STACK_SLOT_TRAP(r1)
|
||||||
mr r3, r12
|
mr r3, r12
|
||||||
/* Increment exit count, poke other threads to exit */
|
/* Increment exit count, poke other threads to exit */
|
||||||
bl kvmhv_commence_exit
|
bl kvmhv_commence_exit
|
||||||
nop
|
nop
|
||||||
ld r9, HSTATE_KVM_VCPU(r13)
|
ld r9, HSTATE_KVM_VCPU(r13)
|
||||||
lwz r12, VCPU_TRAP(r9)
|
|
||||||
|
|
||||||
/* Stop others sending VCPU interrupts to this physical CPU */
|
/* Stop others sending VCPU interrupts to this physical CPU */
|
||||||
li r0, -1
|
li r0, -1
|
||||||
@ -1898,6 +1898,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_POWER9_DD1)
|
|||||||
* POWER7/POWER8 guest -> host partition switch code.
|
* POWER7/POWER8 guest -> host partition switch code.
|
||||||
* We don't have to lock against tlbies but we do
|
* We don't have to lock against tlbies but we do
|
||||||
* have to coordinate the hardware threads.
|
* have to coordinate the hardware threads.
|
||||||
|
* Here STACK_SLOT_TRAP(r1) contains the trap number.
|
||||||
*/
|
*/
|
||||||
kvmhv_switch_to_host:
|
kvmhv_switch_to_host:
|
||||||
/* Secondary threads wait for primary to do partition switch */
|
/* Secondary threads wait for primary to do partition switch */
|
||||||
@ -1950,12 +1951,12 @@ BEGIN_FTR_SECTION
|
|||||||
END_FTR_SECTION_IFSET(CPU_FTR_ARCH_207S)
|
END_FTR_SECTION_IFSET(CPU_FTR_ARCH_207S)
|
||||||
|
|
||||||
/* If HMI, call kvmppc_realmode_hmi_handler() */
|
/* If HMI, call kvmppc_realmode_hmi_handler() */
|
||||||
|
lwz r12, STACK_SLOT_TRAP(r1)
|
||||||
cmpwi r12, BOOK3S_INTERRUPT_HMI
|
cmpwi r12, BOOK3S_INTERRUPT_HMI
|
||||||
bne 27f
|
bne 27f
|
||||||
bl kvmppc_realmode_hmi_handler
|
bl kvmppc_realmode_hmi_handler
|
||||||
nop
|
nop
|
||||||
cmpdi r3, 0
|
cmpdi r3, 0
|
||||||
li r12, BOOK3S_INTERRUPT_HMI
|
|
||||||
/*
|
/*
|
||||||
* At this point kvmppc_realmode_hmi_handler may have resync-ed
|
* At this point kvmppc_realmode_hmi_handler may have resync-ed
|
||||||
* the TB, and if it has, we must not subtract the guest timebase
|
* the TB, and if it has, we must not subtract the guest timebase
|
||||||
@ -2008,10 +2009,8 @@ BEGIN_FTR_SECTION
|
|||||||
lwz r8, KVM_SPLIT_DO_RESTORE(r3)
|
lwz r8, KVM_SPLIT_DO_RESTORE(r3)
|
||||||
cmpwi r8, 0
|
cmpwi r8, 0
|
||||||
beq 47f
|
beq 47f
|
||||||
stw r12, STACK_SLOT_TRAP(r1)
|
|
||||||
bl kvmhv_p9_restore_lpcr
|
bl kvmhv_p9_restore_lpcr
|
||||||
nop
|
nop
|
||||||
lwz r12, STACK_SLOT_TRAP(r1)
|
|
||||||
b 48f
|
b 48f
|
||||||
47:
|
47:
|
||||||
END_FTR_SECTION_IFSET(CPU_FTR_ARCH_300)
|
END_FTR_SECTION_IFSET(CPU_FTR_ARCH_300)
|
||||||
@ -2049,6 +2048,7 @@ END_MMU_FTR_SECTION_IFSET(MMU_FTR_TYPE_RADIX)
|
|||||||
li r0, KVM_GUEST_MODE_NONE
|
li r0, KVM_GUEST_MODE_NONE
|
||||||
stb r0, HSTATE_IN_GUEST(r13)
|
stb r0, HSTATE_IN_GUEST(r13)
|
||||||
|
|
||||||
|
lwz r12, STACK_SLOT_TRAP(r1) /* return trap # in r12 */
|
||||||
ld r0, SFS+PPC_LR_STKOFF(r1)
|
ld r0, SFS+PPC_LR_STKOFF(r1)
|
||||||
addi r1, r1, SFS
|
addi r1, r1, SFS
|
||||||
mtlr r0
|
mtlr r0
|
||||||
|
@ -163,13 +163,10 @@ static void tlb_batch_pmd_scan(struct mm_struct *mm, unsigned long vaddr,
|
|||||||
pte_unmap(pte);
|
pte_unmap(pte);
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_pmd_at(struct mm_struct *mm, unsigned long addr,
|
|
||||||
pmd_t *pmdp, pmd_t pmd)
|
static void __set_pmd_acct(struct mm_struct *mm, unsigned long addr,
|
||||||
|
pmd_t orig, pmd_t pmd)
|
||||||
{
|
{
|
||||||
pmd_t orig = *pmdp;
|
|
||||||
|
|
||||||
*pmdp = pmd;
|
|
||||||
|
|
||||||
if (mm == &init_mm)
|
if (mm == &init_mm)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -219,6 +216,15 @@ void set_pmd_at(struct mm_struct *mm, unsigned long addr,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void set_pmd_at(struct mm_struct *mm, unsigned long addr,
|
||||||
|
pmd_t *pmdp, pmd_t pmd)
|
||||||
|
{
|
||||||
|
pmd_t orig = *pmdp;
|
||||||
|
|
||||||
|
*pmdp = pmd;
|
||||||
|
__set_pmd_acct(mm, addr, orig, pmd);
|
||||||
|
}
|
||||||
|
|
||||||
static inline pmd_t pmdp_establish(struct vm_area_struct *vma,
|
static inline pmd_t pmdp_establish(struct vm_area_struct *vma,
|
||||||
unsigned long address, pmd_t *pmdp, pmd_t pmd)
|
unsigned long address, pmd_t *pmdp, pmd_t pmd)
|
||||||
{
|
{
|
||||||
@ -227,6 +233,7 @@ static inline pmd_t pmdp_establish(struct vm_area_struct *vma,
|
|||||||
do {
|
do {
|
||||||
old = *pmdp;
|
old = *pmdp;
|
||||||
} while (cmpxchg64(&pmdp->pmd, old.pmd, pmd.pmd) != old.pmd);
|
} while (cmpxchg64(&pmdp->pmd, old.pmd, pmd.pmd) != old.pmd);
|
||||||
|
__set_pmd_acct(vma->vm_mm, address, old, pmd);
|
||||||
|
|
||||||
return old;
|
return old;
|
||||||
}
|
}
|
||||||
|
@ -352,6 +352,7 @@ enum vmcs_field {
|
|||||||
#define INTR_TYPE_NMI_INTR (2 << 8) /* NMI */
|
#define INTR_TYPE_NMI_INTR (2 << 8) /* NMI */
|
||||||
#define INTR_TYPE_HARD_EXCEPTION (3 << 8) /* processor exception */
|
#define INTR_TYPE_HARD_EXCEPTION (3 << 8) /* processor exception */
|
||||||
#define INTR_TYPE_SOFT_INTR (4 << 8) /* software interrupt */
|
#define INTR_TYPE_SOFT_INTR (4 << 8) /* software interrupt */
|
||||||
|
#define INTR_TYPE_PRIV_SW_EXCEPTION (5 << 8) /* ICE breakpoint - undocumented */
|
||||||
#define INTR_TYPE_SOFT_EXCEPTION (6 << 8) /* software exception */
|
#define INTR_TYPE_SOFT_EXCEPTION (6 << 8) /* software exception */
|
||||||
|
|
||||||
/* GUEST_INTERRUPTIBILITY_INFO flags. */
|
/* GUEST_INTERRUPTIBILITY_INFO flags. */
|
||||||
|
@ -2770,8 +2770,10 @@ static int set_spte(struct kvm_vcpu *vcpu, u64 *sptep,
|
|||||||
else
|
else
|
||||||
pte_access &= ~ACC_WRITE_MASK;
|
pte_access &= ~ACC_WRITE_MASK;
|
||||||
|
|
||||||
|
if (!kvm_is_mmio_pfn(pfn))
|
||||||
|
spte |= shadow_me_mask;
|
||||||
|
|
||||||
spte |= (u64)pfn << PAGE_SHIFT;
|
spte |= (u64)pfn << PAGE_SHIFT;
|
||||||
spte |= shadow_me_mask;
|
|
||||||
|
|
||||||
if (pte_access & ACC_WRITE_MASK) {
|
if (pte_access & ACC_WRITE_MASK) {
|
||||||
|
|
||||||
|
@ -1045,6 +1045,13 @@ static inline bool is_machine_check(u32 intr_info)
|
|||||||
(INTR_TYPE_HARD_EXCEPTION | MC_VECTOR | INTR_INFO_VALID_MASK);
|
(INTR_TYPE_HARD_EXCEPTION | MC_VECTOR | INTR_INFO_VALID_MASK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Undocumented: icebp/int1 */
|
||||||
|
static inline bool is_icebp(u32 intr_info)
|
||||||
|
{
|
||||||
|
return (intr_info & (INTR_INFO_INTR_TYPE_MASK | INTR_INFO_VALID_MASK))
|
||||||
|
== (INTR_TYPE_PRIV_SW_EXCEPTION | INTR_INFO_VALID_MASK);
|
||||||
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_vmx_msr_bitmap(void)
|
static inline bool cpu_has_vmx_msr_bitmap(void)
|
||||||
{
|
{
|
||||||
return vmcs_config.cpu_based_exec_ctrl & CPU_BASED_USE_MSR_BITMAPS;
|
return vmcs_config.cpu_based_exec_ctrl & CPU_BASED_USE_MSR_BITMAPS;
|
||||||
@ -6179,7 +6186,7 @@ static int handle_exception(struct kvm_vcpu *vcpu)
|
|||||||
(KVM_GUESTDBG_SINGLESTEP | KVM_GUESTDBG_USE_HW_BP))) {
|
(KVM_GUESTDBG_SINGLESTEP | KVM_GUESTDBG_USE_HW_BP))) {
|
||||||
vcpu->arch.dr6 &= ~15;
|
vcpu->arch.dr6 &= ~15;
|
||||||
vcpu->arch.dr6 |= dr6 | DR6_RTM;
|
vcpu->arch.dr6 |= dr6 | DR6_RTM;
|
||||||
if (!(dr6 & ~DR6_RESERVED)) /* icebp */
|
if (is_icebp(intr_info))
|
||||||
skip_emulated_instruction(vcpu);
|
skip_emulated_instruction(vcpu);
|
||||||
|
|
||||||
kvm_queue_exception(vcpu, DB_VECTOR);
|
kvm_queue_exception(vcpu, DB_VECTOR);
|
||||||
|
@ -806,17 +806,11 @@ int arch_add_memory(int nid, u64 start, u64 size, struct vmem_altmap *altmap,
|
|||||||
|
|
||||||
#define PAGE_INUSE 0xFD
|
#define PAGE_INUSE 0xFD
|
||||||
|
|
||||||
static void __meminit free_pagetable(struct page *page, int order,
|
static void __meminit free_pagetable(struct page *page, int order)
|
||||||
struct vmem_altmap *altmap)
|
|
||||||
{
|
{
|
||||||
unsigned long magic;
|
unsigned long magic;
|
||||||
unsigned int nr_pages = 1 << order;
|
unsigned int nr_pages = 1 << order;
|
||||||
|
|
||||||
if (altmap) {
|
|
||||||
vmem_altmap_free(altmap, nr_pages);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* bootmem page has reserved flag */
|
/* bootmem page has reserved flag */
|
||||||
if (PageReserved(page)) {
|
if (PageReserved(page)) {
|
||||||
__ClearPageReserved(page);
|
__ClearPageReserved(page);
|
||||||
@ -832,8 +826,16 @@ static void __meminit free_pagetable(struct page *page, int order,
|
|||||||
free_pages((unsigned long)page_address(page), order);
|
free_pages((unsigned long)page_address(page), order);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __meminit free_pte_table(pte_t *pte_start, pmd_t *pmd,
|
static void __meminit free_hugepage_table(struct page *page,
|
||||||
struct vmem_altmap *altmap)
|
struct vmem_altmap *altmap)
|
||||||
|
{
|
||||||
|
if (altmap)
|
||||||
|
vmem_altmap_free(altmap, PMD_SIZE / PAGE_SIZE);
|
||||||
|
else
|
||||||
|
free_pagetable(page, get_order(PMD_SIZE));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __meminit free_pte_table(pte_t *pte_start, pmd_t *pmd)
|
||||||
{
|
{
|
||||||
pte_t *pte;
|
pte_t *pte;
|
||||||
int i;
|
int i;
|
||||||
@ -845,14 +847,13 @@ static void __meminit free_pte_table(pte_t *pte_start, pmd_t *pmd,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* free a pte talbe */
|
/* free a pte talbe */
|
||||||
free_pagetable(pmd_page(*pmd), 0, altmap);
|
free_pagetable(pmd_page(*pmd), 0);
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pmd_clear(pmd);
|
pmd_clear(pmd);
|
||||||
spin_unlock(&init_mm.page_table_lock);
|
spin_unlock(&init_mm.page_table_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __meminit free_pmd_table(pmd_t *pmd_start, pud_t *pud,
|
static void __meminit free_pmd_table(pmd_t *pmd_start, pud_t *pud)
|
||||||
struct vmem_altmap *altmap)
|
|
||||||
{
|
{
|
||||||
pmd_t *pmd;
|
pmd_t *pmd;
|
||||||
int i;
|
int i;
|
||||||
@ -864,14 +865,13 @@ static void __meminit free_pmd_table(pmd_t *pmd_start, pud_t *pud,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* free a pmd talbe */
|
/* free a pmd talbe */
|
||||||
free_pagetable(pud_page(*pud), 0, altmap);
|
free_pagetable(pud_page(*pud), 0);
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pud_clear(pud);
|
pud_clear(pud);
|
||||||
spin_unlock(&init_mm.page_table_lock);
|
spin_unlock(&init_mm.page_table_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __meminit free_pud_table(pud_t *pud_start, p4d_t *p4d,
|
static void __meminit free_pud_table(pud_t *pud_start, p4d_t *p4d)
|
||||||
struct vmem_altmap *altmap)
|
|
||||||
{
|
{
|
||||||
pud_t *pud;
|
pud_t *pud;
|
||||||
int i;
|
int i;
|
||||||
@ -883,7 +883,7 @@ static void __meminit free_pud_table(pud_t *pud_start, p4d_t *p4d,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* free a pud talbe */
|
/* free a pud talbe */
|
||||||
free_pagetable(p4d_page(*p4d), 0, altmap);
|
free_pagetable(p4d_page(*p4d), 0);
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
p4d_clear(p4d);
|
p4d_clear(p4d);
|
||||||
spin_unlock(&init_mm.page_table_lock);
|
spin_unlock(&init_mm.page_table_lock);
|
||||||
@ -891,7 +891,7 @@ static void __meminit free_pud_table(pud_t *pud_start, p4d_t *p4d,
|
|||||||
|
|
||||||
static void __meminit
|
static void __meminit
|
||||||
remove_pte_table(pte_t *pte_start, unsigned long addr, unsigned long end,
|
remove_pte_table(pte_t *pte_start, unsigned long addr, unsigned long end,
|
||||||
struct vmem_altmap *altmap, bool direct)
|
bool direct)
|
||||||
{
|
{
|
||||||
unsigned long next, pages = 0;
|
unsigned long next, pages = 0;
|
||||||
pte_t *pte;
|
pte_t *pte;
|
||||||
@ -922,7 +922,7 @@ remove_pte_table(pte_t *pte_start, unsigned long addr, unsigned long end,
|
|||||||
* freed when offlining, or simplely not in use.
|
* freed when offlining, or simplely not in use.
|
||||||
*/
|
*/
|
||||||
if (!direct)
|
if (!direct)
|
||||||
free_pagetable(pte_page(*pte), 0, altmap);
|
free_pagetable(pte_page(*pte), 0);
|
||||||
|
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pte_clear(&init_mm, addr, pte);
|
pte_clear(&init_mm, addr, pte);
|
||||||
@ -945,7 +945,7 @@ remove_pte_table(pte_t *pte_start, unsigned long addr, unsigned long end,
|
|||||||
|
|
||||||
page_addr = page_address(pte_page(*pte));
|
page_addr = page_address(pte_page(*pte));
|
||||||
if (!memchr_inv(page_addr, PAGE_INUSE, PAGE_SIZE)) {
|
if (!memchr_inv(page_addr, PAGE_INUSE, PAGE_SIZE)) {
|
||||||
free_pagetable(pte_page(*pte), 0, altmap);
|
free_pagetable(pte_page(*pte), 0);
|
||||||
|
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pte_clear(&init_mm, addr, pte);
|
pte_clear(&init_mm, addr, pte);
|
||||||
@ -980,9 +980,8 @@ remove_pmd_table(pmd_t *pmd_start, unsigned long addr, unsigned long end,
|
|||||||
if (IS_ALIGNED(addr, PMD_SIZE) &&
|
if (IS_ALIGNED(addr, PMD_SIZE) &&
|
||||||
IS_ALIGNED(next, PMD_SIZE)) {
|
IS_ALIGNED(next, PMD_SIZE)) {
|
||||||
if (!direct)
|
if (!direct)
|
||||||
free_pagetable(pmd_page(*pmd),
|
free_hugepage_table(pmd_page(*pmd),
|
||||||
get_order(PMD_SIZE),
|
altmap);
|
||||||
altmap);
|
|
||||||
|
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pmd_clear(pmd);
|
pmd_clear(pmd);
|
||||||
@ -995,9 +994,8 @@ remove_pmd_table(pmd_t *pmd_start, unsigned long addr, unsigned long end,
|
|||||||
page_addr = page_address(pmd_page(*pmd));
|
page_addr = page_address(pmd_page(*pmd));
|
||||||
if (!memchr_inv(page_addr, PAGE_INUSE,
|
if (!memchr_inv(page_addr, PAGE_INUSE,
|
||||||
PMD_SIZE)) {
|
PMD_SIZE)) {
|
||||||
free_pagetable(pmd_page(*pmd),
|
free_hugepage_table(pmd_page(*pmd),
|
||||||
get_order(PMD_SIZE),
|
altmap);
|
||||||
altmap);
|
|
||||||
|
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pmd_clear(pmd);
|
pmd_clear(pmd);
|
||||||
@ -1009,8 +1007,8 @@ remove_pmd_table(pmd_t *pmd_start, unsigned long addr, unsigned long end,
|
|||||||
}
|
}
|
||||||
|
|
||||||
pte_base = (pte_t *)pmd_page_vaddr(*pmd);
|
pte_base = (pte_t *)pmd_page_vaddr(*pmd);
|
||||||
remove_pte_table(pte_base, addr, next, altmap, direct);
|
remove_pte_table(pte_base, addr, next, direct);
|
||||||
free_pte_table(pte_base, pmd, altmap);
|
free_pte_table(pte_base, pmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Call free_pmd_table() in remove_pud_table(). */
|
/* Call free_pmd_table() in remove_pud_table(). */
|
||||||
@ -1039,8 +1037,7 @@ remove_pud_table(pud_t *pud_start, unsigned long addr, unsigned long end,
|
|||||||
IS_ALIGNED(next, PUD_SIZE)) {
|
IS_ALIGNED(next, PUD_SIZE)) {
|
||||||
if (!direct)
|
if (!direct)
|
||||||
free_pagetable(pud_page(*pud),
|
free_pagetable(pud_page(*pud),
|
||||||
get_order(PUD_SIZE),
|
get_order(PUD_SIZE));
|
||||||
altmap);
|
|
||||||
|
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pud_clear(pud);
|
pud_clear(pud);
|
||||||
@ -1054,8 +1051,7 @@ remove_pud_table(pud_t *pud_start, unsigned long addr, unsigned long end,
|
|||||||
if (!memchr_inv(page_addr, PAGE_INUSE,
|
if (!memchr_inv(page_addr, PAGE_INUSE,
|
||||||
PUD_SIZE)) {
|
PUD_SIZE)) {
|
||||||
free_pagetable(pud_page(*pud),
|
free_pagetable(pud_page(*pud),
|
||||||
get_order(PUD_SIZE),
|
get_order(PUD_SIZE));
|
||||||
altmap);
|
|
||||||
|
|
||||||
spin_lock(&init_mm.page_table_lock);
|
spin_lock(&init_mm.page_table_lock);
|
||||||
pud_clear(pud);
|
pud_clear(pud);
|
||||||
@ -1068,7 +1064,7 @@ remove_pud_table(pud_t *pud_start, unsigned long addr, unsigned long end,
|
|||||||
|
|
||||||
pmd_base = pmd_offset(pud, 0);
|
pmd_base = pmd_offset(pud, 0);
|
||||||
remove_pmd_table(pmd_base, addr, next, direct, altmap);
|
remove_pmd_table(pmd_base, addr, next, direct, altmap);
|
||||||
free_pmd_table(pmd_base, pud, altmap);
|
free_pmd_table(pmd_base, pud);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (direct)
|
if (direct)
|
||||||
@ -1100,7 +1096,7 @@ remove_p4d_table(p4d_t *p4d_start, unsigned long addr, unsigned long end,
|
|||||||
* to adapt for boot-time switching between 4 and 5 level page tables.
|
* to adapt for boot-time switching between 4 and 5 level page tables.
|
||||||
*/
|
*/
|
||||||
if (pgtable_l5_enabled)
|
if (pgtable_l5_enabled)
|
||||||
free_pud_table(pud_base, p4d, altmap);
|
free_pud_table(pud_base, p4d);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (direct)
|
if (direct)
|
||||||
|
@ -702,4 +702,52 @@ int pmd_clear_huge(pmd_t *pmd)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* pud_free_pmd_page - Clear pud entry and free pmd page.
|
||||||
|
* @pud: Pointer to a PUD.
|
||||||
|
*
|
||||||
|
* Context: The pud range has been unmaped and TLB purged.
|
||||||
|
* Return: 1 if clearing the entry succeeded. 0 otherwise.
|
||||||
|
*/
|
||||||
|
int pud_free_pmd_page(pud_t *pud)
|
||||||
|
{
|
||||||
|
pmd_t *pmd;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (pud_none(*pud))
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
pmd = (pmd_t *)pud_page_vaddr(*pud);
|
||||||
|
|
||||||
|
for (i = 0; i < PTRS_PER_PMD; i++)
|
||||||
|
if (!pmd_free_pte_page(&pmd[i]))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
pud_clear(pud);
|
||||||
|
free_page((unsigned long)pmd);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* pmd_free_pte_page - Clear pmd entry and free pte page.
|
||||||
|
* @pmd: Pointer to a PMD.
|
||||||
|
*
|
||||||
|
* Context: The pmd range has been unmaped and TLB purged.
|
||||||
|
* Return: 1 if clearing the entry succeeded. 0 otherwise.
|
||||||
|
*/
|
||||||
|
int pmd_free_pte_page(pmd_t *pmd)
|
||||||
|
{
|
||||||
|
pte_t *pte;
|
||||||
|
|
||||||
|
if (pmd_none(*pmd))
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
pte = (pte_t *)pmd_page_vaddr(*pmd);
|
||||||
|
pmd_clear(pmd);
|
||||||
|
free_page((unsigned long)pte);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
#endif /* CONFIG_HAVE_ARCH_HUGE_VMAP */
|
#endif /* CONFIG_HAVE_ARCH_HUGE_VMAP */
|
||||||
|
@ -1188,7 +1188,7 @@ skip_init_addrs:
|
|||||||
* may converge on the last pass. In such case do one more
|
* may converge on the last pass. In such case do one more
|
||||||
* pass to emit the final image
|
* pass to emit the final image
|
||||||
*/
|
*/
|
||||||
for (pass = 0; pass < 10 || image; pass++) {
|
for (pass = 0; pass < 20 || image; pass++) {
|
||||||
proglen = do_jit(prog, addrs, image, oldproglen, &ctx);
|
proglen = do_jit(prog, addrs, image, oldproglen, &ctx);
|
||||||
if (proglen <= 0) {
|
if (proglen <= 0) {
|
||||||
image = NULL;
|
image = NULL;
|
||||||
@ -1215,6 +1215,7 @@ skip_init_addrs:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
oldproglen = proglen;
|
oldproglen = proglen;
|
||||||
|
cond_resched();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bpf_jit_enable > 1)
|
if (bpf_jit_enable > 1)
|
||||||
|
@ -74,10 +74,10 @@ void __init acpi_watchdog_init(void)
|
|||||||
res.start = gas->address;
|
res.start = gas->address;
|
||||||
if (gas->space_id == ACPI_ADR_SPACE_SYSTEM_MEMORY) {
|
if (gas->space_id == ACPI_ADR_SPACE_SYSTEM_MEMORY) {
|
||||||
res.flags = IORESOURCE_MEM;
|
res.flags = IORESOURCE_MEM;
|
||||||
res.end = res.start + ALIGN(gas->access_width, 4);
|
res.end = res.start + ALIGN(gas->access_width, 4) - 1;
|
||||||
} else if (gas->space_id == ACPI_ADR_SPACE_SYSTEM_IO) {
|
} else if (gas->space_id == ACPI_ADR_SPACE_SYSTEM_IO) {
|
||||||
res.flags = IORESOURCE_IO;
|
res.flags = IORESOURCE_IO;
|
||||||
res.end = res.start + gas->access_width;
|
res.end = res.start + gas->access_width - 1;
|
||||||
} else {
|
} else {
|
||||||
pr_warn("Unsupported address space: %u\n",
|
pr_warn("Unsupported address space: %u\n",
|
||||||
gas->space_id);
|
gas->space_id);
|
||||||
|
@ -70,7 +70,6 @@ static async_cookie_t async_cookie;
|
|||||||
static bool battery_driver_registered;
|
static bool battery_driver_registered;
|
||||||
static int battery_bix_broken_package;
|
static int battery_bix_broken_package;
|
||||||
static int battery_notification_delay_ms;
|
static int battery_notification_delay_ms;
|
||||||
static int battery_full_discharging;
|
|
||||||
static unsigned int cache_time = 1000;
|
static unsigned int cache_time = 1000;
|
||||||
module_param(cache_time, uint, 0644);
|
module_param(cache_time, uint, 0644);
|
||||||
MODULE_PARM_DESC(cache_time, "cache time in milliseconds");
|
MODULE_PARM_DESC(cache_time, "cache time in milliseconds");
|
||||||
@ -215,12 +214,9 @@ static int acpi_battery_get_property(struct power_supply *psy,
|
|||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
switch (psp) {
|
switch (psp) {
|
||||||
case POWER_SUPPLY_PROP_STATUS:
|
case POWER_SUPPLY_PROP_STATUS:
|
||||||
if (battery->state & ACPI_BATTERY_STATE_DISCHARGING) {
|
if (battery->state & ACPI_BATTERY_STATE_DISCHARGING)
|
||||||
if (battery_full_discharging && battery->rate_now == 0)
|
val->intval = POWER_SUPPLY_STATUS_DISCHARGING;
|
||||||
val->intval = POWER_SUPPLY_STATUS_FULL;
|
else if (battery->state & ACPI_BATTERY_STATE_CHARGING)
|
||||||
else
|
|
||||||
val->intval = POWER_SUPPLY_STATUS_DISCHARGING;
|
|
||||||
} else if (battery->state & ACPI_BATTERY_STATE_CHARGING)
|
|
||||||
val->intval = POWER_SUPPLY_STATUS_CHARGING;
|
val->intval = POWER_SUPPLY_STATUS_CHARGING;
|
||||||
else if (acpi_battery_is_charged(battery))
|
else if (acpi_battery_is_charged(battery))
|
||||||
val->intval = POWER_SUPPLY_STATUS_FULL;
|
val->intval = POWER_SUPPLY_STATUS_FULL;
|
||||||
@ -1170,12 +1166,6 @@ battery_notification_delay_quirk(const struct dmi_system_id *d)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __init battery_full_discharging_quirk(const struct dmi_system_id *d)
|
|
||||||
{
|
|
||||||
battery_full_discharging = 1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct dmi_system_id bat_dmi_table[] __initconst = {
|
static const struct dmi_system_id bat_dmi_table[] __initconst = {
|
||||||
{
|
{
|
||||||
.callback = battery_bix_broken_package_quirk,
|
.callback = battery_bix_broken_package_quirk,
|
||||||
@ -1193,38 +1183,6 @@ static const struct dmi_system_id bat_dmi_table[] __initconst = {
|
|||||||
DMI_MATCH(DMI_PRODUCT_NAME, "Aspire V5-573G"),
|
DMI_MATCH(DMI_PRODUCT_NAME, "Aspire V5-573G"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
|
||||||
.callback = battery_full_discharging_quirk,
|
|
||||||
.ident = "ASUS GL502VSK",
|
|
||||||
.matches = {
|
|
||||||
DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
|
|
||||||
DMI_MATCH(DMI_PRODUCT_NAME, "GL502VSK"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.callback = battery_full_discharging_quirk,
|
|
||||||
.ident = "ASUS UX305LA",
|
|
||||||
.matches = {
|
|
||||||
DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
|
|
||||||
DMI_MATCH(DMI_PRODUCT_NAME, "UX305LA"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.callback = battery_full_discharging_quirk,
|
|
||||||
.ident = "ASUS UX360UA",
|
|
||||||
.matches = {
|
|
||||||
DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
|
|
||||||
DMI_MATCH(DMI_PRODUCT_NAME, "UX360UA"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.callback = battery_full_discharging_quirk,
|
|
||||||
.ident = "ASUS UX410UAK",
|
|
||||||
.matches = {
|
|
||||||
DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
|
|
||||||
DMI_MATCH(DMI_PRODUCT_NAME, "UX410UAK"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -2675,10 +2675,14 @@ static int acpi_nfit_register_region(struct acpi_nfit_desc *acpi_desc,
|
|||||||
else
|
else
|
||||||
ndr_desc->numa_node = NUMA_NO_NODE;
|
ndr_desc->numa_node = NUMA_NO_NODE;
|
||||||
|
|
||||||
if(acpi_desc->platform_cap & ACPI_NFIT_CAPABILITY_CACHE_FLUSH)
|
/*
|
||||||
|
* Persistence domain bits are hierarchical, if
|
||||||
|
* ACPI_NFIT_CAPABILITY_CACHE_FLUSH is set then
|
||||||
|
* ACPI_NFIT_CAPABILITY_MEM_FLUSH is implied.
|
||||||
|
*/
|
||||||
|
if (acpi_desc->platform_cap & ACPI_NFIT_CAPABILITY_CACHE_FLUSH)
|
||||||
set_bit(ND_REGION_PERSIST_CACHE, &ndr_desc->flags);
|
set_bit(ND_REGION_PERSIST_CACHE, &ndr_desc->flags);
|
||||||
|
else if (acpi_desc->platform_cap & ACPI_NFIT_CAPABILITY_MEM_FLUSH)
|
||||||
if (acpi_desc->platform_cap & ACPI_NFIT_CAPABILITY_MEM_FLUSH)
|
|
||||||
set_bit(ND_REGION_PERSIST_MEMCTRL, &ndr_desc->flags);
|
set_bit(ND_REGION_PERSIST_MEMCTRL, &ndr_desc->flags);
|
||||||
|
|
||||||
list_for_each_entry(nfit_memdev, &acpi_desc->memdevs, list) {
|
list_for_each_entry(nfit_memdev, &acpi_desc->memdevs, list) {
|
||||||
|
@ -103,25 +103,27 @@ int acpi_map_pxm_to_node(int pxm)
|
|||||||
*/
|
*/
|
||||||
int acpi_map_pxm_to_online_node(int pxm)
|
int acpi_map_pxm_to_online_node(int pxm)
|
||||||
{
|
{
|
||||||
int node, n, dist, min_dist;
|
int node, min_node;
|
||||||
|
|
||||||
node = acpi_map_pxm_to_node(pxm);
|
node = acpi_map_pxm_to_node(pxm);
|
||||||
|
|
||||||
if (node == NUMA_NO_NODE)
|
if (node == NUMA_NO_NODE)
|
||||||
node = 0;
|
node = 0;
|
||||||
|
|
||||||
|
min_node = node;
|
||||||
if (!node_online(node)) {
|
if (!node_online(node)) {
|
||||||
min_dist = INT_MAX;
|
int min_dist = INT_MAX, dist, n;
|
||||||
|
|
||||||
for_each_online_node(n) {
|
for_each_online_node(n) {
|
||||||
dist = node_distance(node, n);
|
dist = node_distance(node, n);
|
||||||
if (dist < min_dist) {
|
if (dist < min_dist) {
|
||||||
min_dist = dist;
|
min_dist = dist;
|
||||||
node = n;
|
min_node = n;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return node;
|
return min_node;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(acpi_map_pxm_to_online_node);
|
EXPORT_SYMBOL(acpi_map_pxm_to_online_node);
|
||||||
|
|
||||||
|
@ -550,7 +550,9 @@ static const struct pci_device_id ahci_pci_tbl[] = {
|
|||||||
.driver_data = board_ahci_yes_fbs },
|
.driver_data = board_ahci_yes_fbs },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_MARVELL_EXT, 0x9230),
|
{ PCI_DEVICE(PCI_VENDOR_ID_MARVELL_EXT, 0x9230),
|
||||||
.driver_data = board_ahci_yes_fbs },
|
.driver_data = board_ahci_yes_fbs },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_TTI, 0x0642),
|
{ PCI_DEVICE(PCI_VENDOR_ID_TTI, 0x0642), /* highpoint rocketraid 642L */
|
||||||
|
.driver_data = board_ahci_yes_fbs },
|
||||||
|
{ PCI_DEVICE(PCI_VENDOR_ID_TTI, 0x0645), /* highpoint rocketraid 644L */
|
||||||
.driver_data = board_ahci_yes_fbs },
|
.driver_data = board_ahci_yes_fbs },
|
||||||
|
|
||||||
/* Promise */
|
/* Promise */
|
||||||
|
@ -665,6 +665,16 @@ int ahci_stop_engine(struct ata_port *ap)
|
|||||||
if ((tmp & (PORT_CMD_START | PORT_CMD_LIST_ON)) == 0)
|
if ((tmp & (PORT_CMD_START | PORT_CMD_LIST_ON)) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Don't try to issue commands but return with ENODEV if the
|
||||||
|
* AHCI controller not available anymore (e.g. due to PCIe hot
|
||||||
|
* unplugging). Otherwise a 500ms delay for each port is added.
|
||||||
|
*/
|
||||||
|
if (tmp == 0xffffffff) {
|
||||||
|
dev_err(ap->host->dev, "AHCI controller unavailable!\n");
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
/* setting HBA to idle */
|
/* setting HBA to idle */
|
||||||
tmp &= ~PORT_CMD_START;
|
tmp &= ~PORT_CMD_START;
|
||||||
writel(tmp, port_mmio + PORT_CMD);
|
writel(tmp, port_mmio + PORT_CMD);
|
||||||
|
@ -340,7 +340,7 @@ static int ahci_platform_get_regulator(struct ahci_host_priv *hpriv, u32 port,
|
|||||||
* 2) regulator for controlling the targets power (optional)
|
* 2) regulator for controlling the targets power (optional)
|
||||||
* 3) 0 - AHCI_MAX_CLKS clocks, as specified in the devs devicetree node,
|
* 3) 0 - AHCI_MAX_CLKS clocks, as specified in the devs devicetree node,
|
||||||
* or for non devicetree enabled platforms a single clock
|
* or for non devicetree enabled platforms a single clock
|
||||||
* 4) phys (optional)
|
* 4) phys (optional)
|
||||||
*
|
*
|
||||||
* RETURNS:
|
* RETURNS:
|
||||||
* The allocated ahci_host_priv on success, otherwise an ERR_PTR value
|
* The allocated ahci_host_priv on success, otherwise an ERR_PTR value
|
||||||
|
@ -4530,6 +4530,25 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
|
|||||||
{ "PIONEER DVD-RW DVR-212D", NULL, ATA_HORKAGE_NOSETXFER },
|
{ "PIONEER DVD-RW DVR-212D", NULL, ATA_HORKAGE_NOSETXFER },
|
||||||
{ "PIONEER DVD-RW DVR-216D", NULL, ATA_HORKAGE_NOSETXFER },
|
{ "PIONEER DVD-RW DVR-216D", NULL, ATA_HORKAGE_NOSETXFER },
|
||||||
|
|
||||||
|
/* Crucial BX100 SSD 500GB has broken LPM support */
|
||||||
|
{ "CT500BX100SSD1", NULL, ATA_HORKAGE_NOLPM },
|
||||||
|
|
||||||
|
/* 512GB MX100 with MU01 firmware has both queued TRIM and LPM issues */
|
||||||
|
{ "Crucial_CT512MX100*", "MU01", ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
|
ATA_HORKAGE_ZERO_AFTER_TRIM |
|
||||||
|
ATA_HORKAGE_NOLPM, },
|
||||||
|
/* 512GB MX100 with newer firmware has only LPM issues */
|
||||||
|
{ "Crucial_CT512MX100*", NULL, ATA_HORKAGE_ZERO_AFTER_TRIM |
|
||||||
|
ATA_HORKAGE_NOLPM, },
|
||||||
|
|
||||||
|
/* 480GB+ M500 SSDs have both queued TRIM and LPM issues */
|
||||||
|
{ "Crucial_CT480M500*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
|
ATA_HORKAGE_ZERO_AFTER_TRIM |
|
||||||
|
ATA_HORKAGE_NOLPM, },
|
||||||
|
{ "Crucial_CT960M500*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
|
ATA_HORKAGE_ZERO_AFTER_TRIM |
|
||||||
|
ATA_HORKAGE_NOLPM, },
|
||||||
|
|
||||||
/* devices that don't properly handle queued TRIM commands */
|
/* devices that don't properly handle queued TRIM commands */
|
||||||
{ "Micron_M500_*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
{ "Micron_M500_*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
||||||
@ -4541,7 +4560,9 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
|
|||||||
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
||||||
{ "Crucial_CT*MX100*", "MU01", ATA_HORKAGE_NO_NCQ_TRIM |
|
{ "Crucial_CT*MX100*", "MU01", ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
||||||
{ "Samsung SSD 8*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
{ "Samsung SSD 840*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
||||||
|
{ "Samsung SSD 850*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
||||||
{ "FCCT*M500*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
{ "FCCT*M500*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
||||||
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
||||||
@ -5401,8 +5422,7 @@ void ata_qc_issue(struct ata_queued_cmd *qc)
|
|||||||
* We guarantee to LLDs that they will have at least one
|
* We guarantee to LLDs that they will have at least one
|
||||||
* non-zero sg if the command is a data command.
|
* non-zero sg if the command is a data command.
|
||||||
*/
|
*/
|
||||||
if (WARN_ON_ONCE(ata_is_data(prot) &&
|
if (ata_is_data(prot) && (!qc->sg || !qc->n_elem || !qc->nbytes))
|
||||||
(!qc->sg || !qc->n_elem || !qc->nbytes)))
|
|
||||||
goto sys_err;
|
goto sys_err;
|
||||||
|
|
||||||
if (ata_is_dma(prot) || (ata_is_pio(prot) &&
|
if (ata_is_dma(prot) || (ata_is_pio(prot) &&
|
||||||
|
@ -815,7 +815,8 @@ void ata_scsi_port_error_handler(struct Scsi_Host *host, struct ata_port *ap)
|
|||||||
|
|
||||||
if (ap->pflags & ATA_PFLAG_LOADING)
|
if (ap->pflags & ATA_PFLAG_LOADING)
|
||||||
ap->pflags &= ~ATA_PFLAG_LOADING;
|
ap->pflags &= ~ATA_PFLAG_LOADING;
|
||||||
else if (ap->pflags & ATA_PFLAG_SCSI_HOTPLUG)
|
else if ((ap->pflags & ATA_PFLAG_SCSI_HOTPLUG) &&
|
||||||
|
!(ap->flags & ATA_FLAG_SAS_HOST))
|
||||||
schedule_delayed_work(&ap->hotplug_task, 0);
|
schedule_delayed_work(&ap->hotplug_task, 0);
|
||||||
|
|
||||||
if (ap->pflags & ATA_PFLAG_RECOVERED)
|
if (ap->pflags & ATA_PFLAG_RECOVERED)
|
||||||
|
@ -3316,6 +3316,12 @@ static unsigned int ata_scsi_pass_thru(struct ata_queued_cmd *qc)
|
|||||||
goto invalid_fld;
|
goto invalid_fld;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* We may not issue NCQ commands to devices not supporting NCQ */
|
||||||
|
if (ata_is_ncq(tf->protocol) && !ata_ncq_enabled(dev)) {
|
||||||
|
fp = 1;
|
||||||
|
goto invalid_fld;
|
||||||
|
}
|
||||||
|
|
||||||
/* sanity check for pio multi commands */
|
/* sanity check for pio multi commands */
|
||||||
if ((cdb[1] & 0xe0) && !is_multi_taskfile(tf)) {
|
if ((cdb[1] & 0xe0) && !is_multi_taskfile(tf)) {
|
||||||
fp = 1;
|
fp = 1;
|
||||||
@ -4282,7 +4288,7 @@ static inline void ata_scsi_dump_cdb(struct ata_port *ap,
|
|||||||
#ifdef ATA_DEBUG
|
#ifdef ATA_DEBUG
|
||||||
struct scsi_device *scsidev = cmd->device;
|
struct scsi_device *scsidev = cmd->device;
|
||||||
|
|
||||||
DPRINTK("CDB (%u:%d,%d,%d) %9ph\n",
|
DPRINTK("CDB (%u:%d,%d,%lld) %9ph\n",
|
||||||
ap->print_id,
|
ap->print_id,
|
||||||
scsidev->channel, scsidev->id, scsidev->lun,
|
scsidev->channel, scsidev->id, scsidev->lun,
|
||||||
cmd->cmnd);
|
cmd->cmnd);
|
||||||
@ -4309,7 +4315,9 @@ static inline int __ata_scsi_queuecmd(struct scsi_cmnd *scmd,
|
|||||||
if (likely((scsi_op != ATA_16) || !atapi_passthru16)) {
|
if (likely((scsi_op != ATA_16) || !atapi_passthru16)) {
|
||||||
/* relay SCSI command to ATAPI device */
|
/* relay SCSI command to ATAPI device */
|
||||||
int len = COMMAND_SIZE(scsi_op);
|
int len = COMMAND_SIZE(scsi_op);
|
||||||
if (unlikely(len > scmd->cmd_len || len > dev->cdb_len))
|
if (unlikely(len > scmd->cmd_len ||
|
||||||
|
len > dev->cdb_len ||
|
||||||
|
scmd->cmd_len > ATAPI_CDB_LEN))
|
||||||
goto bad_cdb_len;
|
goto bad_cdb_len;
|
||||||
|
|
||||||
xlat_func = atapi_xlat;
|
xlat_func = atapi_xlat;
|
||||||
|
@ -146,6 +146,7 @@
|
|||||||
enum sata_rcar_type {
|
enum sata_rcar_type {
|
||||||
RCAR_GEN1_SATA,
|
RCAR_GEN1_SATA,
|
||||||
RCAR_GEN2_SATA,
|
RCAR_GEN2_SATA,
|
||||||
|
RCAR_GEN3_SATA,
|
||||||
RCAR_R8A7790_ES1_SATA,
|
RCAR_R8A7790_ES1_SATA,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -784,26 +785,11 @@ static void sata_rcar_setup_port(struct ata_host *host)
|
|||||||
ioaddr->command_addr = ioaddr->cmd_addr + (ATA_REG_CMD << 2);
|
ioaddr->command_addr = ioaddr->cmd_addr + (ATA_REG_CMD << 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sata_rcar_init_controller(struct ata_host *host)
|
static void sata_rcar_init_module(struct sata_rcar_priv *priv)
|
||||||
{
|
{
|
||||||
struct sata_rcar_priv *priv = host->private_data;
|
|
||||||
void __iomem *base = priv->base;
|
void __iomem *base = priv->base;
|
||||||
u32 val;
|
u32 val;
|
||||||
|
|
||||||
/* reset and setup phy */
|
|
||||||
switch (priv->type) {
|
|
||||||
case RCAR_GEN1_SATA:
|
|
||||||
sata_rcar_gen1_phy_init(priv);
|
|
||||||
break;
|
|
||||||
case RCAR_GEN2_SATA:
|
|
||||||
case RCAR_R8A7790_ES1_SATA:
|
|
||||||
sata_rcar_gen2_phy_init(priv);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
dev_warn(host->dev, "SATA phy is not initialized\n");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SATA-IP reset state */
|
/* SATA-IP reset state */
|
||||||
val = ioread32(base + ATAPI_CONTROL1_REG);
|
val = ioread32(base + ATAPI_CONTROL1_REG);
|
||||||
val |= ATAPI_CONTROL1_RESET;
|
val |= ATAPI_CONTROL1_RESET;
|
||||||
@ -824,10 +810,33 @@ static void sata_rcar_init_controller(struct ata_host *host)
|
|||||||
/* ack and mask */
|
/* ack and mask */
|
||||||
iowrite32(0, base + SATAINTSTAT_REG);
|
iowrite32(0, base + SATAINTSTAT_REG);
|
||||||
iowrite32(0x7ff, base + SATAINTMASK_REG);
|
iowrite32(0x7ff, base + SATAINTMASK_REG);
|
||||||
|
|
||||||
/* enable interrupts */
|
/* enable interrupts */
|
||||||
iowrite32(ATAPI_INT_ENABLE_SATAINT, base + ATAPI_INT_ENABLE_REG);
|
iowrite32(ATAPI_INT_ENABLE_SATAINT, base + ATAPI_INT_ENABLE_REG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void sata_rcar_init_controller(struct ata_host *host)
|
||||||
|
{
|
||||||
|
struct sata_rcar_priv *priv = host->private_data;
|
||||||
|
|
||||||
|
/* reset and setup phy */
|
||||||
|
switch (priv->type) {
|
||||||
|
case RCAR_GEN1_SATA:
|
||||||
|
sata_rcar_gen1_phy_init(priv);
|
||||||
|
break;
|
||||||
|
case RCAR_GEN2_SATA:
|
||||||
|
case RCAR_GEN3_SATA:
|
||||||
|
case RCAR_R8A7790_ES1_SATA:
|
||||||
|
sata_rcar_gen2_phy_init(priv);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
dev_warn(host->dev, "SATA phy is not initialized\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
sata_rcar_init_module(priv);
|
||||||
|
}
|
||||||
|
|
||||||
static const struct of_device_id sata_rcar_match[] = {
|
static const struct of_device_id sata_rcar_match[] = {
|
||||||
{
|
{
|
||||||
/* Deprecated by "renesas,sata-r8a7779" */
|
/* Deprecated by "renesas,sata-r8a7779" */
|
||||||
@ -856,7 +865,7 @@ static const struct of_device_id sata_rcar_match[] = {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
.compatible = "renesas,sata-r8a7795",
|
.compatible = "renesas,sata-r8a7795",
|
||||||
.data = (void *)RCAR_GEN2_SATA
|
.data = (void *)RCAR_GEN3_SATA
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.compatible = "renesas,rcar-gen2-sata",
|
.compatible = "renesas,rcar-gen2-sata",
|
||||||
@ -864,7 +873,7 @@ static const struct of_device_id sata_rcar_match[] = {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
.compatible = "renesas,rcar-gen3-sata",
|
.compatible = "renesas,rcar-gen3-sata",
|
||||||
.data = (void *)RCAR_GEN2_SATA
|
.data = (void *)RCAR_GEN3_SATA
|
||||||
},
|
},
|
||||||
{ },
|
{ },
|
||||||
};
|
};
|
||||||
@ -982,11 +991,18 @@ static int sata_rcar_resume(struct device *dev)
|
|||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
/* ack and mask */
|
if (priv->type == RCAR_GEN3_SATA) {
|
||||||
iowrite32(0, base + SATAINTSTAT_REG);
|
sata_rcar_gen2_phy_init(priv);
|
||||||
iowrite32(0x7ff, base + SATAINTMASK_REG);
|
sata_rcar_init_module(priv);
|
||||||
/* enable interrupts */
|
} else {
|
||||||
iowrite32(ATAPI_INT_ENABLE_SATAINT, base + ATAPI_INT_ENABLE_REG);
|
/* ack and mask */
|
||||||
|
iowrite32(0, base + SATAINTSTAT_REG);
|
||||||
|
iowrite32(0x7ff, base + SATAINTMASK_REG);
|
||||||
|
|
||||||
|
/* enable interrupts */
|
||||||
|
iowrite32(ATAPI_INT_ENABLE_SATAINT,
|
||||||
|
base + ATAPI_INT_ENABLE_REG);
|
||||||
|
}
|
||||||
|
|
||||||
ata_host_resume(host);
|
ata_host_resume(host);
|
||||||
|
|
||||||
|
@ -97,7 +97,7 @@ static struct img_ascii_lcd_config boston_config = {
|
|||||||
static void malta_update(struct img_ascii_lcd_ctx *ctx)
|
static void malta_update(struct img_ascii_lcd_ctx *ctx)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
int err;
|
int err = 0;
|
||||||
|
|
||||||
for (i = 0; i < ctx->cfg->num_chars; i++) {
|
for (i = 0; i < ctx->cfg->num_chars; i++) {
|
||||||
err = regmap_write(ctx->regmap,
|
err = regmap_write(ctx->regmap,
|
||||||
@ -180,7 +180,7 @@ static int sead3_wait_lcd_idle(struct img_ascii_lcd_ctx *ctx)
|
|||||||
static void sead3_update(struct img_ascii_lcd_ctx *ctx)
|
static void sead3_update(struct img_ascii_lcd_ctx *ctx)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
int err;
|
int err = 0;
|
||||||
|
|
||||||
for (i = 0; i < ctx->cfg->num_chars; i++) {
|
for (i = 0; i < ctx->cfg->num_chars; i++) {
|
||||||
err = sead3_wait_lcd_idle(ctx);
|
err = sead3_wait_lcd_idle(ctx);
|
||||||
@ -224,7 +224,7 @@ MODULE_DEVICE_TABLE(of, img_ascii_lcd_matches);
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* img_ascii_lcd_scroll() - scroll the display by a character
|
* img_ascii_lcd_scroll() - scroll the display by a character
|
||||||
* @arg: really a pointer to the private data structure
|
* @t: really a pointer to the private data structure
|
||||||
*
|
*
|
||||||
* Scroll the current message along the LCD by one character, rearming the
|
* Scroll the current message along the LCD by one character, rearming the
|
||||||
* timer if required.
|
* timer if required.
|
||||||
|
@ -1372,7 +1372,7 @@ static void panel_process_inputs(void)
|
|||||||
break;
|
break;
|
||||||
input->rise_timer = 0;
|
input->rise_timer = 0;
|
||||||
input->state = INPUT_ST_RISING;
|
input->state = INPUT_ST_RISING;
|
||||||
/* no break here, fall through */
|
/* fall through */
|
||||||
case INPUT_ST_RISING:
|
case INPUT_ST_RISING:
|
||||||
if ((phys_curr & input->mask) != input->value) {
|
if ((phys_curr & input->mask) != input->value) {
|
||||||
input->state = INPUT_ST_LOW;
|
input->state = INPUT_ST_LOW;
|
||||||
@ -1385,11 +1385,11 @@ static void panel_process_inputs(void)
|
|||||||
}
|
}
|
||||||
input->high_timer = 0;
|
input->high_timer = 0;
|
||||||
input->state = INPUT_ST_HIGH;
|
input->state = INPUT_ST_HIGH;
|
||||||
/* no break here, fall through */
|
/* fall through */
|
||||||
case INPUT_ST_HIGH:
|
case INPUT_ST_HIGH:
|
||||||
if (input_state_high(input))
|
if (input_state_high(input))
|
||||||
break;
|
break;
|
||||||
/* no break here, fall through */
|
/* fall through */
|
||||||
case INPUT_ST_FALLING:
|
case INPUT_ST_FALLING:
|
||||||
input_state_falling(input);
|
input_state_falling(input);
|
||||||
}
|
}
|
||||||
|
@ -231,7 +231,6 @@ static const struct usb_device_id blacklist_table[] = {
|
|||||||
{ USB_DEVICE(0x0930, 0x0227), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0930, 0x0227), .driver_info = BTUSB_ATH3012 },
|
||||||
{ USB_DEVICE(0x0b05, 0x17d0), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0b05, 0x17d0), .driver_info = BTUSB_ATH3012 },
|
||||||
{ USB_DEVICE(0x0cf3, 0x0036), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0cf3, 0x0036), .driver_info = BTUSB_ATH3012 },
|
||||||
{ USB_DEVICE(0x0cf3, 0x3004), .driver_info = BTUSB_ATH3012 },
|
|
||||||
{ USB_DEVICE(0x0cf3, 0x3008), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0cf3, 0x3008), .driver_info = BTUSB_ATH3012 },
|
||||||
{ USB_DEVICE(0x0cf3, 0x311d), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0cf3, 0x311d), .driver_info = BTUSB_ATH3012 },
|
||||||
{ USB_DEVICE(0x0cf3, 0x311e), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0cf3, 0x311e), .driver_info = BTUSB_ATH3012 },
|
||||||
@ -264,6 +263,7 @@ static const struct usb_device_id blacklist_table[] = {
|
|||||||
{ USB_DEVICE(0x0489, 0xe03c), .driver_info = BTUSB_ATH3012 },
|
{ USB_DEVICE(0x0489, 0xe03c), .driver_info = BTUSB_ATH3012 },
|
||||||
|
|
||||||
/* QCA ROME chipset */
|
/* QCA ROME chipset */
|
||||||
|
{ USB_DEVICE(0x0cf3, 0x3004), .driver_info = BTUSB_QCA_ROME },
|
||||||
{ USB_DEVICE(0x0cf3, 0xe007), .driver_info = BTUSB_QCA_ROME },
|
{ USB_DEVICE(0x0cf3, 0xe007), .driver_info = BTUSB_QCA_ROME },
|
||||||
{ USB_DEVICE(0x0cf3, 0xe009), .driver_info = BTUSB_QCA_ROME },
|
{ USB_DEVICE(0x0cf3, 0xe009), .driver_info = BTUSB_QCA_ROME },
|
||||||
{ USB_DEVICE(0x0cf3, 0xe010), .driver_info = BTUSB_QCA_ROME },
|
{ USB_DEVICE(0x0cf3, 0xe010), .driver_info = BTUSB_QCA_ROME },
|
||||||
@ -386,10 +386,10 @@ static const struct usb_device_id blacklist_table[] = {
|
|||||||
*/
|
*/
|
||||||
static const struct dmi_system_id btusb_needs_reset_resume_table[] = {
|
static const struct dmi_system_id btusb_needs_reset_resume_table[] = {
|
||||||
{
|
{
|
||||||
/* Lenovo Yoga 920 (QCA Rome device 0cf3:e300) */
|
/* Dell OptiPlex 3060 (QCA ROME device 0cf3:e007) */
|
||||||
.matches = {
|
.matches = {
|
||||||
DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
|
DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
|
||||||
DMI_MATCH(DMI_PRODUCT_VERSION, "Lenovo YOGA 920"),
|
DMI_MATCH(DMI_PRODUCT_NAME, "OptiPlex 3060"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{}
|
{}
|
||||||
|
@ -244,7 +244,9 @@ static irqreturn_t bcm_host_wake(int irq, void *data)
|
|||||||
|
|
||||||
bt_dev_dbg(bdev, "Host wake IRQ");
|
bt_dev_dbg(bdev, "Host wake IRQ");
|
||||||
|
|
||||||
pm_request_resume(bdev->dev);
|
pm_runtime_get(bdev->dev);
|
||||||
|
pm_runtime_mark_last_busy(bdev->dev);
|
||||||
|
pm_runtime_put_autosuspend(bdev->dev);
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
@ -301,7 +303,7 @@ static const struct bcm_set_sleep_mode default_sleep_params = {
|
|||||||
.usb_auto_sleep = 0,
|
.usb_auto_sleep = 0,
|
||||||
.usb_resume_timeout = 0,
|
.usb_resume_timeout = 0,
|
||||||
.break_to_host = 0,
|
.break_to_host = 0,
|
||||||
.pulsed_host_wake = 0,
|
.pulsed_host_wake = 1,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int bcm_setup_sleep(struct hci_uart *hu)
|
static int bcm_setup_sleep(struct hci_uart *hu)
|
||||||
@ -586,8 +588,11 @@ static int bcm_recv(struct hci_uart *hu, const void *data, int count)
|
|||||||
} else if (!bcm->rx_skb) {
|
} else if (!bcm->rx_skb) {
|
||||||
/* Delay auto-suspend when receiving completed packet */
|
/* Delay auto-suspend when receiving completed packet */
|
||||||
mutex_lock(&bcm_device_lock);
|
mutex_lock(&bcm_device_lock);
|
||||||
if (bcm->dev && bcm_device_exists(bcm->dev))
|
if (bcm->dev && bcm_device_exists(bcm->dev)) {
|
||||||
pm_request_resume(bcm->dev->dev);
|
pm_runtime_get(bcm->dev->dev);
|
||||||
|
pm_runtime_mark_last_busy(bcm->dev->dev);
|
||||||
|
pm_runtime_put_autosuspend(bcm->dev->dev);
|
||||||
|
}
|
||||||
mutex_unlock(&bcm_device_lock);
|
mutex_unlock(&bcm_device_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -449,17 +449,17 @@ struct bcm2835_pll_ana_bits {
|
|||||||
static const struct bcm2835_pll_ana_bits bcm2835_ana_default = {
|
static const struct bcm2835_pll_ana_bits bcm2835_ana_default = {
|
||||||
.mask0 = 0,
|
.mask0 = 0,
|
||||||
.set0 = 0,
|
.set0 = 0,
|
||||||
.mask1 = (u32)~(A2W_PLL_KI_MASK | A2W_PLL_KP_MASK),
|
.mask1 = A2W_PLL_KI_MASK | A2W_PLL_KP_MASK,
|
||||||
.set1 = (2 << A2W_PLL_KI_SHIFT) | (8 << A2W_PLL_KP_SHIFT),
|
.set1 = (2 << A2W_PLL_KI_SHIFT) | (8 << A2W_PLL_KP_SHIFT),
|
||||||
.mask3 = (u32)~A2W_PLL_KA_MASK,
|
.mask3 = A2W_PLL_KA_MASK,
|
||||||
.set3 = (2 << A2W_PLL_KA_SHIFT),
|
.set3 = (2 << A2W_PLL_KA_SHIFT),
|
||||||
.fb_prediv_mask = BIT(14),
|
.fb_prediv_mask = BIT(14),
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct bcm2835_pll_ana_bits bcm2835_ana_pllh = {
|
static const struct bcm2835_pll_ana_bits bcm2835_ana_pllh = {
|
||||||
.mask0 = (u32)~(A2W_PLLH_KA_MASK | A2W_PLLH_KI_LOW_MASK),
|
.mask0 = A2W_PLLH_KA_MASK | A2W_PLLH_KI_LOW_MASK,
|
||||||
.set0 = (2 << A2W_PLLH_KA_SHIFT) | (2 << A2W_PLLH_KI_LOW_SHIFT),
|
.set0 = (2 << A2W_PLLH_KA_SHIFT) | (2 << A2W_PLLH_KI_LOW_SHIFT),
|
||||||
.mask1 = (u32)~(A2W_PLLH_KI_HIGH_MASK | A2W_PLLH_KP_MASK),
|
.mask1 = A2W_PLLH_KI_HIGH_MASK | A2W_PLLH_KP_MASK,
|
||||||
.set1 = (6 << A2W_PLLH_KP_SHIFT),
|
.set1 = (6 << A2W_PLLH_KP_SHIFT),
|
||||||
.mask3 = 0,
|
.mask3 = 0,
|
||||||
.set3 = 0,
|
.set3 = 0,
|
||||||
@ -623,8 +623,10 @@ static int bcm2835_pll_on(struct clk_hw *hw)
|
|||||||
~A2W_PLL_CTRL_PWRDN);
|
~A2W_PLL_CTRL_PWRDN);
|
||||||
|
|
||||||
/* Take the PLL out of reset. */
|
/* Take the PLL out of reset. */
|
||||||
|
spin_lock(&cprman->regs_lock);
|
||||||
cprman_write(cprman, data->cm_ctrl_reg,
|
cprman_write(cprman, data->cm_ctrl_reg,
|
||||||
cprman_read(cprman, data->cm_ctrl_reg) & ~CM_PLL_ANARST);
|
cprman_read(cprman, data->cm_ctrl_reg) & ~CM_PLL_ANARST);
|
||||||
|
spin_unlock(&cprman->regs_lock);
|
||||||
|
|
||||||
/* Wait for the PLL to lock. */
|
/* Wait for the PLL to lock. */
|
||||||
timeout = ktime_add_ns(ktime_get(), LOCK_TIMEOUT_NS);
|
timeout = ktime_add_ns(ktime_get(), LOCK_TIMEOUT_NS);
|
||||||
@ -701,9 +703,11 @@ static int bcm2835_pll_set_rate(struct clk_hw *hw,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Unmask the reference clock from the oscillator. */
|
/* Unmask the reference clock from the oscillator. */
|
||||||
|
spin_lock(&cprman->regs_lock);
|
||||||
cprman_write(cprman, A2W_XOSC_CTRL,
|
cprman_write(cprman, A2W_XOSC_CTRL,
|
||||||
cprman_read(cprman, A2W_XOSC_CTRL) |
|
cprman_read(cprman, A2W_XOSC_CTRL) |
|
||||||
data->reference_enable_mask);
|
data->reference_enable_mask);
|
||||||
|
spin_unlock(&cprman->regs_lock);
|
||||||
|
|
||||||
if (do_ana_setup_first)
|
if (do_ana_setup_first)
|
||||||
bcm2835_pll_write_ana(cprman, data->ana_reg_base, ana);
|
bcm2835_pll_write_ana(cprman, data->ana_reg_base, ana);
|
||||||
|
@ -205,6 +205,18 @@ static const struct aspeed_clk_soc_data ast2400_data = {
|
|||||||
.calc_pll = aspeed_ast2400_calc_pll,
|
.calc_pll = aspeed_ast2400_calc_pll,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int aspeed_clk_is_enabled(struct clk_hw *hw)
|
||||||
|
{
|
||||||
|
struct aspeed_clk_gate *gate = to_aspeed_clk_gate(hw);
|
||||||
|
u32 clk = BIT(gate->clock_idx);
|
||||||
|
u32 enval = (gate->flags & CLK_GATE_SET_TO_DISABLE) ? 0 : clk;
|
||||||
|
u32 reg;
|
||||||
|
|
||||||
|
regmap_read(gate->map, ASPEED_CLK_STOP_CTRL, ®);
|
||||||
|
|
||||||
|
return ((reg & clk) == enval) ? 1 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int aspeed_clk_enable(struct clk_hw *hw)
|
static int aspeed_clk_enable(struct clk_hw *hw)
|
||||||
{
|
{
|
||||||
struct aspeed_clk_gate *gate = to_aspeed_clk_gate(hw);
|
struct aspeed_clk_gate *gate = to_aspeed_clk_gate(hw);
|
||||||
@ -215,6 +227,11 @@ static int aspeed_clk_enable(struct clk_hw *hw)
|
|||||||
|
|
||||||
spin_lock_irqsave(gate->lock, flags);
|
spin_lock_irqsave(gate->lock, flags);
|
||||||
|
|
||||||
|
if (aspeed_clk_is_enabled(hw)) {
|
||||||
|
spin_unlock_irqrestore(gate->lock, flags);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (gate->reset_idx >= 0) {
|
if (gate->reset_idx >= 0) {
|
||||||
/* Put IP in reset */
|
/* Put IP in reset */
|
||||||
regmap_update_bits(gate->map, ASPEED_RESET_CTRL, rst, rst);
|
regmap_update_bits(gate->map, ASPEED_RESET_CTRL, rst, rst);
|
||||||
@ -255,17 +272,6 @@ static void aspeed_clk_disable(struct clk_hw *hw)
|
|||||||
spin_unlock_irqrestore(gate->lock, flags);
|
spin_unlock_irqrestore(gate->lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int aspeed_clk_is_enabled(struct clk_hw *hw)
|
|
||||||
{
|
|
||||||
struct aspeed_clk_gate *gate = to_aspeed_clk_gate(hw);
|
|
||||||
u32 clk = BIT(gate->clock_idx);
|
|
||||||
u32 reg;
|
|
||||||
|
|
||||||
regmap_read(gate->map, ASPEED_CLK_STOP_CTRL, ®);
|
|
||||||
|
|
||||||
return (reg & clk) ? 0 : 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct clk_ops aspeed_clk_gate_ops = {
|
static const struct clk_ops aspeed_clk_gate_ops = {
|
||||||
.enable = aspeed_clk_enable,
|
.enable = aspeed_clk_enable,
|
||||||
.disable = aspeed_clk_disable,
|
.disable = aspeed_clk_disable,
|
||||||
|
@ -1125,8 +1125,10 @@ static int clk_core_round_rate_nolock(struct clk_core *core,
|
|||||||
{
|
{
|
||||||
lockdep_assert_held(&prepare_lock);
|
lockdep_assert_held(&prepare_lock);
|
||||||
|
|
||||||
if (!core)
|
if (!core) {
|
||||||
|
req->rate = 0;
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
clk_core_init_rate_req(core, req);
|
clk_core_init_rate_req(core, req);
|
||||||
|
|
||||||
@ -2309,8 +2311,11 @@ static int clk_core_set_phase_nolock(struct clk_core *core, int degrees)
|
|||||||
|
|
||||||
trace_clk_set_phase(core, degrees);
|
trace_clk_set_phase(core, degrees);
|
||||||
|
|
||||||
if (core->ops->set_phase)
|
if (core->ops->set_phase) {
|
||||||
ret = core->ops->set_phase(core->hw, degrees);
|
ret = core->ops->set_phase(core->hw, degrees);
|
||||||
|
if (!ret)
|
||||||
|
core->phase = degrees;
|
||||||
|
}
|
||||||
|
|
||||||
trace_clk_set_phase_complete(core, degrees);
|
trace_clk_set_phase_complete(core, degrees);
|
||||||
|
|
||||||
@ -2967,23 +2972,38 @@ static int __clk_core_init(struct clk_core *core)
|
|||||||
rate = 0;
|
rate = 0;
|
||||||
core->rate = core->req_rate = rate;
|
core->rate = core->req_rate = rate;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Enable CLK_IS_CRITICAL clocks so newly added critical clocks
|
||||||
|
* don't get accidentally disabled when walking the orphan tree and
|
||||||
|
* reparenting clocks
|
||||||
|
*/
|
||||||
|
if (core->flags & CLK_IS_CRITICAL) {
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
|
clk_core_prepare(core);
|
||||||
|
|
||||||
|
flags = clk_enable_lock();
|
||||||
|
clk_core_enable(core);
|
||||||
|
clk_enable_unlock(flags);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* walk the list of orphan clocks and reparent any that newly finds a
|
* walk the list of orphan clocks and reparent any that newly finds a
|
||||||
* parent.
|
* parent.
|
||||||
*/
|
*/
|
||||||
hlist_for_each_entry_safe(orphan, tmp2, &clk_orphan_list, child_node) {
|
hlist_for_each_entry_safe(orphan, tmp2, &clk_orphan_list, child_node) {
|
||||||
struct clk_core *parent = __clk_init_parent(orphan);
|
struct clk_core *parent = __clk_init_parent(orphan);
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* we could call __clk_set_parent, but that would result in a
|
* We need to use __clk_set_parent_before() and _after() to
|
||||||
* redundant call to the .set_rate op, if it exists
|
* to properly migrate any prepare/enable count of the orphan
|
||||||
|
* clock. This is important for CLK_IS_CRITICAL clocks, which
|
||||||
|
* are enabled during init but might not have a parent yet.
|
||||||
*/
|
*/
|
||||||
if (parent) {
|
if (parent) {
|
||||||
/* update the clk tree topology */
|
/* update the clk tree topology */
|
||||||
flags = clk_enable_lock();
|
__clk_set_parent_before(orphan, parent);
|
||||||
clk_reparent(orphan, parent);
|
__clk_set_parent_after(orphan, parent, NULL);
|
||||||
clk_enable_unlock(flags);
|
|
||||||
__clk_recalc_accuracies(orphan);
|
__clk_recalc_accuracies(orphan);
|
||||||
__clk_recalc_rates(orphan, 0);
|
__clk_recalc_rates(orphan, 0);
|
||||||
}
|
}
|
||||||
@ -3000,16 +3020,6 @@ static int __clk_core_init(struct clk_core *core)
|
|||||||
if (core->ops->init)
|
if (core->ops->init)
|
||||||
core->ops->init(core->hw);
|
core->ops->init(core->hw);
|
||||||
|
|
||||||
if (core->flags & CLK_IS_CRITICAL) {
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
clk_core_prepare(core);
|
|
||||||
|
|
||||||
flags = clk_enable_lock();
|
|
||||||
clk_core_enable(core);
|
|
||||||
clk_enable_unlock(flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
kref_init(&core->ref);
|
kref_init(&core->ref);
|
||||||
out:
|
out:
|
||||||
clk_pm_runtime_put(core);
|
clk_pm_runtime_put(core);
|
||||||
|
@ -149,6 +149,8 @@ static int hi3660_stub_clk_probe(struct platform_device *pdev)
|
|||||||
return PTR_ERR(stub_clk_chan.mbox);
|
return PTR_ERR(stub_clk_chan.mbox);
|
||||||
|
|
||||||
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
||||||
|
if (!res)
|
||||||
|
return -EINVAL;
|
||||||
freq_reg = devm_ioremap(dev, res->start, resource_size(res));
|
freq_reg = devm_ioremap(dev, res->start, resource_size(res));
|
||||||
if (!freq_reg)
|
if (!freq_reg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
@ -131,7 +131,17 @@ static const char *ieee1588_sels[] = { "pll3_sw", "pll4_sw", "dummy" /* usbphy2_
|
|||||||
static struct clk *clk[IMX5_CLK_END];
|
static struct clk *clk[IMX5_CLK_END];
|
||||||
static struct clk_onecell_data clk_data;
|
static struct clk_onecell_data clk_data;
|
||||||
|
|
||||||
static struct clk ** const uart_clks[] __initconst = {
|
static struct clk ** const uart_clks_mx51[] __initconst = {
|
||||||
|
&clk[IMX5_CLK_UART1_IPG_GATE],
|
||||||
|
&clk[IMX5_CLK_UART1_PER_GATE],
|
||||||
|
&clk[IMX5_CLK_UART2_IPG_GATE],
|
||||||
|
&clk[IMX5_CLK_UART2_PER_GATE],
|
||||||
|
&clk[IMX5_CLK_UART3_IPG_GATE],
|
||||||
|
&clk[IMX5_CLK_UART3_PER_GATE],
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct clk ** const uart_clks_mx50_mx53[] __initconst = {
|
||||||
&clk[IMX5_CLK_UART1_IPG_GATE],
|
&clk[IMX5_CLK_UART1_IPG_GATE],
|
||||||
&clk[IMX5_CLK_UART1_PER_GATE],
|
&clk[IMX5_CLK_UART1_PER_GATE],
|
||||||
&clk[IMX5_CLK_UART2_IPG_GATE],
|
&clk[IMX5_CLK_UART2_IPG_GATE],
|
||||||
@ -321,8 +331,6 @@ static void __init mx5_clocks_common_init(void __iomem *ccm_base)
|
|||||||
clk_prepare_enable(clk[IMX5_CLK_TMAX1]);
|
clk_prepare_enable(clk[IMX5_CLK_TMAX1]);
|
||||||
clk_prepare_enable(clk[IMX5_CLK_TMAX2]); /* esdhc2, fec */
|
clk_prepare_enable(clk[IMX5_CLK_TMAX2]); /* esdhc2, fec */
|
||||||
clk_prepare_enable(clk[IMX5_CLK_TMAX3]); /* esdhc1, esdhc4 */
|
clk_prepare_enable(clk[IMX5_CLK_TMAX3]); /* esdhc1, esdhc4 */
|
||||||
|
|
||||||
imx_register_uart_clocks(uart_clks);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init mx50_clocks_init(struct device_node *np)
|
static void __init mx50_clocks_init(struct device_node *np)
|
||||||
@ -388,6 +396,8 @@ static void __init mx50_clocks_init(struct device_node *np)
|
|||||||
|
|
||||||
r = clk_round_rate(clk[IMX5_CLK_USBOH3_PER_GATE], 54000000);
|
r = clk_round_rate(clk[IMX5_CLK_USBOH3_PER_GATE], 54000000);
|
||||||
clk_set_rate(clk[IMX5_CLK_USBOH3_PER_GATE], r);
|
clk_set_rate(clk[IMX5_CLK_USBOH3_PER_GATE], r);
|
||||||
|
|
||||||
|
imx_register_uart_clocks(uart_clks_mx50_mx53);
|
||||||
}
|
}
|
||||||
CLK_OF_DECLARE(imx50_ccm, "fsl,imx50-ccm", mx50_clocks_init);
|
CLK_OF_DECLARE(imx50_ccm, "fsl,imx50-ccm", mx50_clocks_init);
|
||||||
|
|
||||||
@ -477,6 +487,8 @@ static void __init mx51_clocks_init(struct device_node *np)
|
|||||||
val = readl(MXC_CCM_CLPCR);
|
val = readl(MXC_CCM_CLPCR);
|
||||||
val |= 1 << 23;
|
val |= 1 << 23;
|
||||||
writel(val, MXC_CCM_CLPCR);
|
writel(val, MXC_CCM_CLPCR);
|
||||||
|
|
||||||
|
imx_register_uart_clocks(uart_clks_mx51);
|
||||||
}
|
}
|
||||||
CLK_OF_DECLARE(imx51_ccm, "fsl,imx51-ccm", mx51_clocks_init);
|
CLK_OF_DECLARE(imx51_ccm, "fsl,imx51-ccm", mx51_clocks_init);
|
||||||
|
|
||||||
@ -606,5 +618,7 @@ static void __init mx53_clocks_init(struct device_node *np)
|
|||||||
|
|
||||||
r = clk_round_rate(clk[IMX5_CLK_USBOH3_PER_GATE], 54000000);
|
r = clk_round_rate(clk[IMX5_CLK_USBOH3_PER_GATE], 54000000);
|
||||||
clk_set_rate(clk[IMX5_CLK_USBOH3_PER_GATE], r);
|
clk_set_rate(clk[IMX5_CLK_USBOH3_PER_GATE], r);
|
||||||
|
|
||||||
|
imx_register_uart_clocks(uart_clks_mx50_mx53);
|
||||||
}
|
}
|
||||||
CLK_OF_DECLARE(imx53_ccm, "fsl,imx53-ccm", mx53_clocks_init);
|
CLK_OF_DECLARE(imx53_ccm, "fsl,imx53-ccm", mx53_clocks_init);
|
||||||
|
@ -49,11 +49,10 @@ static int qcom_apcs_msm8916_clk_probe(struct platform_device *pdev)
|
|||||||
struct clk_regmap_mux_div *a53cc;
|
struct clk_regmap_mux_div *a53cc;
|
||||||
struct regmap *regmap;
|
struct regmap *regmap;
|
||||||
struct clk_init_data init = { };
|
struct clk_init_data init = { };
|
||||||
int ret;
|
int ret = -ENODEV;
|
||||||
|
|
||||||
regmap = dev_get_regmap(parent, NULL);
|
regmap = dev_get_regmap(parent, NULL);
|
||||||
if (IS_ERR(regmap)) {
|
if (!regmap) {
|
||||||
ret = PTR_ERR(regmap);
|
|
||||||
dev_err(dev, "failed to get regmap: %d\n", ret);
|
dev_err(dev, "failed to get regmap: %d\n", ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -762,7 +762,7 @@ static struct ccu_mp out_a_clk = {
|
|||||||
.features = CCU_FEATURE_FIXED_PREDIV,
|
.features = CCU_FEATURE_FIXED_PREDIV,
|
||||||
.hw.init = CLK_HW_INIT_PARENTS("out-a",
|
.hw.init = CLK_HW_INIT_PARENTS("out-a",
|
||||||
clk_out_parents,
|
clk_out_parents,
|
||||||
&ccu_div_ops,
|
&ccu_mp_ops,
|
||||||
0),
|
0),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -783,7 +783,7 @@ static struct ccu_mp out_b_clk = {
|
|||||||
.features = CCU_FEATURE_FIXED_PREDIV,
|
.features = CCU_FEATURE_FIXED_PREDIV,
|
||||||
.hw.init = CLK_HW_INIT_PARENTS("out-b",
|
.hw.init = CLK_HW_INIT_PARENTS("out-b",
|
||||||
clk_out_parents,
|
clk_out_parents,
|
||||||
&ccu_div_ops,
|
&ccu_mp_ops,
|
||||||
0),
|
0),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -804,7 +804,7 @@ static struct ccu_mp out_c_clk = {
|
|||||||
.features = CCU_FEATURE_FIXED_PREDIV,
|
.features = CCU_FEATURE_FIXED_PREDIV,
|
||||||
.hw.init = CLK_HW_INIT_PARENTS("out-c",
|
.hw.init = CLK_HW_INIT_PARENTS("out-c",
|
||||||
clk_out_parents,
|
clk_out_parents,
|
||||||
&ccu_div_ops,
|
&ccu_mp_ops,
|
||||||
0),
|
0),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -45,7 +45,7 @@ static const struct omap_clkctrl_bit_data am3_gpio4_bit_data[] __initconst = {
|
|||||||
|
|
||||||
static const struct omap_clkctrl_reg_data am3_l4_per_clkctrl_regs[] __initconst = {
|
static const struct omap_clkctrl_reg_data am3_l4_per_clkctrl_regs[] __initconst = {
|
||||||
{ AM3_CPGMAC0_CLKCTRL, NULL, CLKF_SW_SUP, "cpsw_125mhz_gclk", "cpsw_125mhz_clkdm" },
|
{ AM3_CPGMAC0_CLKCTRL, NULL, CLKF_SW_SUP, "cpsw_125mhz_gclk", "cpsw_125mhz_clkdm" },
|
||||||
{ AM3_LCDC_CLKCTRL, NULL, CLKF_SW_SUP, "lcd_gclk", "lcdc_clkdm" },
|
{ AM3_LCDC_CLKCTRL, NULL, CLKF_SW_SUP | CLKF_SET_RATE_PARENT, "lcd_gclk", "lcdc_clkdm" },
|
||||||
{ AM3_USB_OTG_HS_CLKCTRL, NULL, CLKF_SW_SUP, "usbotg_fck", "l3s_clkdm" },
|
{ AM3_USB_OTG_HS_CLKCTRL, NULL, CLKF_SW_SUP, "usbotg_fck", "l3s_clkdm" },
|
||||||
{ AM3_TPTC0_CLKCTRL, NULL, CLKF_SW_SUP, "l3_gclk", "l3_clkdm" },
|
{ AM3_TPTC0_CLKCTRL, NULL, CLKF_SW_SUP, "l3_gclk", "l3_clkdm" },
|
||||||
{ AM3_EMIF_CLKCTRL, NULL, CLKF_SW_SUP, "dpll_ddr_m2_div2_ck", "l3_clkdm" },
|
{ AM3_EMIF_CLKCTRL, NULL, CLKF_SW_SUP, "dpll_ddr_m2_div2_ck", "l3_clkdm" },
|
||||||
|
@ -187,7 +187,7 @@ static const struct omap_clkctrl_reg_data am4_l4_per_clkctrl_regs[] __initconst
|
|||||||
{ AM4_OCP2SCP0_CLKCTRL, NULL, CLKF_SW_SUP, "l4ls_gclk" },
|
{ AM4_OCP2SCP0_CLKCTRL, NULL, CLKF_SW_SUP, "l4ls_gclk" },
|
||||||
{ AM4_OCP2SCP1_CLKCTRL, NULL, CLKF_SW_SUP, "l4ls_gclk" },
|
{ AM4_OCP2SCP1_CLKCTRL, NULL, CLKF_SW_SUP, "l4ls_gclk" },
|
||||||
{ AM4_EMIF_CLKCTRL, NULL, CLKF_SW_SUP, "dpll_ddr_m2_ck", "emif_clkdm" },
|
{ AM4_EMIF_CLKCTRL, NULL, CLKF_SW_SUP, "dpll_ddr_m2_ck", "emif_clkdm" },
|
||||||
{ AM4_DSS_CORE_CLKCTRL, NULL, CLKF_SW_SUP, "disp_clk", "dss_clkdm" },
|
{ AM4_DSS_CORE_CLKCTRL, NULL, CLKF_SW_SUP | CLKF_SET_RATE_PARENT, "disp_clk", "dss_clkdm" },
|
||||||
{ AM4_CPGMAC0_CLKCTRL, NULL, CLKF_SW_SUP, "cpsw_125mhz_gclk", "cpsw_125mhz_clkdm" },
|
{ AM4_CPGMAC0_CLKCTRL, NULL, CLKF_SW_SUP, "cpsw_125mhz_gclk", "cpsw_125mhz_clkdm" },
|
||||||
{ 0 },
|
{ 0 },
|
||||||
};
|
};
|
||||||
|
@ -537,6 +537,8 @@ static void __init _ti_omap4_clkctrl_setup(struct device_node *node)
|
|||||||
init.parent_names = ®_data->parent;
|
init.parent_names = ®_data->parent;
|
||||||
init.num_parents = 1;
|
init.num_parents = 1;
|
||||||
init.flags = 0;
|
init.flags = 0;
|
||||||
|
if (reg_data->flags & CLKF_SET_RATE_PARENT)
|
||||||
|
init.flags |= CLK_SET_RATE_PARENT;
|
||||||
init.name = kasprintf(GFP_KERNEL, "%s:%s:%04x:%d",
|
init.name = kasprintf(GFP_KERNEL, "%s:%s:%04x:%d",
|
||||||
node->parent->name, node->name,
|
node->parent->name, node->name,
|
||||||
reg_data->offset, 0);
|
reg_data->offset, 0);
|
||||||
|
@ -639,7 +639,7 @@ static void __exit dcdbas_exit(void)
|
|||||||
platform_driver_unregister(&dcdbas_driver);
|
platform_driver_unregister(&dcdbas_driver);
|
||||||
}
|
}
|
||||||
|
|
||||||
module_init(dcdbas_init);
|
subsys_initcall_sync(dcdbas_init);
|
||||||
module_exit(dcdbas_exit);
|
module_exit(dcdbas_exit);
|
||||||
|
|
||||||
MODULE_DESCRIPTION(DRIVER_DESCRIPTION " (version " DRIVER_VERSION ")");
|
MODULE_DESCRIPTION(DRIVER_DESCRIPTION " (version " DRIVER_VERSION ")");
|
||||||
|
@ -68,11 +68,11 @@ void efi_retrieve_tpm2_eventlog_1_2(efi_system_table_t *sys_table_arg)
|
|||||||
efi_guid_t linux_eventlog_guid = LINUX_EFI_TPM_EVENT_LOG_GUID;
|
efi_guid_t linux_eventlog_guid = LINUX_EFI_TPM_EVENT_LOG_GUID;
|
||||||
efi_status_t status;
|
efi_status_t status;
|
||||||
efi_physical_addr_t log_location, log_last_entry;
|
efi_physical_addr_t log_location, log_last_entry;
|
||||||
struct linux_efi_tpm_eventlog *log_tbl;
|
struct linux_efi_tpm_eventlog *log_tbl = NULL;
|
||||||
unsigned long first_entry_addr, last_entry_addr;
|
unsigned long first_entry_addr, last_entry_addr;
|
||||||
size_t log_size, last_entry_size;
|
size_t log_size, last_entry_size;
|
||||||
efi_bool_t truncated;
|
efi_bool_t truncated;
|
||||||
void *tcg2_protocol;
|
void *tcg2_protocol = NULL;
|
||||||
|
|
||||||
status = efi_call_early(locate_protocol, &tcg2_guid, NULL,
|
status = efi_call_early(locate_protocol, &tcg2_guid, NULL,
|
||||||
&tcg2_protocol);
|
&tcg2_protocol);
|
||||||
|
@ -69,25 +69,18 @@ void amdgpu_connector_hotplug(struct drm_connector *connector)
|
|||||||
/* don't do anything if sink is not display port, i.e.,
|
/* don't do anything if sink is not display port, i.e.,
|
||||||
* passive dp->(dvi|hdmi) adaptor
|
* passive dp->(dvi|hdmi) adaptor
|
||||||
*/
|
*/
|
||||||
if (dig_connector->dp_sink_type == CONNECTOR_OBJECT_ID_DISPLAYPORT) {
|
if (dig_connector->dp_sink_type == CONNECTOR_OBJECT_ID_DISPLAYPORT &&
|
||||||
int saved_dpms = connector->dpms;
|
amdgpu_display_hpd_sense(adev, amdgpu_connector->hpd.hpd) &&
|
||||||
/* Only turn off the display if it's physically disconnected */
|
amdgpu_atombios_dp_needs_link_train(amdgpu_connector)) {
|
||||||
if (!amdgpu_display_hpd_sense(adev, amdgpu_connector->hpd.hpd)) {
|
/* Don't start link training before we have the DPCD */
|
||||||
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_OFF);
|
if (amdgpu_atombios_dp_get_dpcd(amdgpu_connector))
|
||||||
} else if (amdgpu_atombios_dp_needs_link_train(amdgpu_connector)) {
|
return;
|
||||||
/* Don't try to start link training before we
|
|
||||||
* have the dpcd */
|
|
||||||
if (amdgpu_atombios_dp_get_dpcd(amdgpu_connector))
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* set it to OFF so that drm_helper_connector_dpms()
|
/* Turn the connector off and back on immediately, which
|
||||||
* won't return immediately since the current state
|
* will trigger link training
|
||||||
* is ON at this point.
|
*/
|
||||||
*/
|
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_OFF);
|
||||||
connector->dpms = DRM_MODE_DPMS_OFF;
|
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_ON);
|
||||||
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_ON);
|
|
||||||
}
|
|
||||||
connector->dpms = saved_dpms;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2063,9 +2063,12 @@ void amdgpu_device_fini(struct amdgpu_device *adev)
|
|||||||
|
|
||||||
DRM_INFO("amdgpu: finishing device.\n");
|
DRM_INFO("amdgpu: finishing device.\n");
|
||||||
adev->shutdown = true;
|
adev->shutdown = true;
|
||||||
if (adev->mode_info.mode_config_initialized)
|
if (adev->mode_info.mode_config_initialized){
|
||||||
drm_crtc_force_disable_all(adev->ddev);
|
if (!amdgpu_device_has_dc_support(adev))
|
||||||
|
drm_crtc_force_disable_all(adev->ddev);
|
||||||
|
else
|
||||||
|
drm_atomic_helper_shutdown(adev->ddev);
|
||||||
|
}
|
||||||
amdgpu_ib_pool_fini(adev);
|
amdgpu_ib_pool_fini(adev);
|
||||||
amdgpu_fence_driver_fini(adev);
|
amdgpu_fence_driver_fini(adev);
|
||||||
amdgpu_fbdev_fini(adev);
|
amdgpu_fbdev_fini(adev);
|
||||||
|
@ -36,8 +36,6 @@ void amdgpu_gem_object_free(struct drm_gem_object *gobj)
|
|||||||
struct amdgpu_bo *robj = gem_to_amdgpu_bo(gobj);
|
struct amdgpu_bo *robj = gem_to_amdgpu_bo(gobj);
|
||||||
|
|
||||||
if (robj) {
|
if (robj) {
|
||||||
if (robj->gem_base.import_attach)
|
|
||||||
drm_prime_gem_destroy(&robj->gem_base, robj->tbo.sg);
|
|
||||||
amdgpu_mn_unregister(robj);
|
amdgpu_mn_unregister(robj);
|
||||||
amdgpu_bo_unref(&robj);
|
amdgpu_bo_unref(&robj);
|
||||||
}
|
}
|
||||||
|
@ -352,6 +352,7 @@ struct amdgpu_mode_info {
|
|||||||
u16 firmware_flags;
|
u16 firmware_flags;
|
||||||
/* pointer to backlight encoder */
|
/* pointer to backlight encoder */
|
||||||
struct amdgpu_encoder *bl_encoder;
|
struct amdgpu_encoder *bl_encoder;
|
||||||
|
u8 bl_level; /* saved backlight level */
|
||||||
struct amdgpu_audio audio; /* audio stuff */
|
struct amdgpu_audio audio; /* audio stuff */
|
||||||
int num_crtc; /* number of crtcs */
|
int num_crtc; /* number of crtcs */
|
||||||
int num_hpd; /* number of hpd pins */
|
int num_hpd; /* number of hpd pins */
|
||||||
|
@ -56,6 +56,8 @@ static void amdgpu_ttm_bo_destroy(struct ttm_buffer_object *tbo)
|
|||||||
|
|
||||||
amdgpu_bo_kunmap(bo);
|
amdgpu_bo_kunmap(bo);
|
||||||
|
|
||||||
|
if (bo->gem_base.import_attach)
|
||||||
|
drm_prime_gem_destroy(&bo->gem_base, bo->tbo.sg);
|
||||||
drm_gem_object_release(&bo->gem_base);
|
drm_gem_object_release(&bo->gem_base);
|
||||||
amdgpu_bo_unref(&bo->parent);
|
amdgpu_bo_unref(&bo->parent);
|
||||||
if (!list_empty(&bo->shadow_list)) {
|
if (!list_empty(&bo->shadow_list)) {
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
#include <linux/backlight.h>
|
#include <linux/backlight.h>
|
||||||
#include "bif/bif_4_1_d.h"
|
#include "bif/bif_4_1_d.h"
|
||||||
|
|
||||||
static u8
|
u8
|
||||||
amdgpu_atombios_encoder_get_backlight_level_from_reg(struct amdgpu_device *adev)
|
amdgpu_atombios_encoder_get_backlight_level_from_reg(struct amdgpu_device *adev)
|
||||||
{
|
{
|
||||||
u8 backlight_level;
|
u8 backlight_level;
|
||||||
@ -48,7 +48,7 @@ amdgpu_atombios_encoder_get_backlight_level_from_reg(struct amdgpu_device *adev)
|
|||||||
return backlight_level;
|
return backlight_level;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
void
|
||||||
amdgpu_atombios_encoder_set_backlight_level_to_reg(struct amdgpu_device *adev,
|
amdgpu_atombios_encoder_set_backlight_level_to_reg(struct amdgpu_device *adev,
|
||||||
u8 backlight_level)
|
u8 backlight_level)
|
||||||
{
|
{
|
||||||
|
@ -24,6 +24,11 @@
|
|||||||
#ifndef __ATOMBIOS_ENCODER_H__
|
#ifndef __ATOMBIOS_ENCODER_H__
|
||||||
#define __ATOMBIOS_ENCODER_H__
|
#define __ATOMBIOS_ENCODER_H__
|
||||||
|
|
||||||
|
u8
|
||||||
|
amdgpu_atombios_encoder_get_backlight_level_from_reg(struct amdgpu_device *adev);
|
||||||
|
void
|
||||||
|
amdgpu_atombios_encoder_set_backlight_level_to_reg(struct amdgpu_device *adev,
|
||||||
|
u8 backlight_level);
|
||||||
u8
|
u8
|
||||||
amdgpu_atombios_encoder_get_backlight_level(struct amdgpu_encoder *amdgpu_encoder);
|
amdgpu_atombios_encoder_get_backlight_level(struct amdgpu_encoder *amdgpu_encoder);
|
||||||
void
|
void
|
||||||
|
@ -2921,6 +2921,11 @@ static int dce_v10_0_hw_fini(void *handle)
|
|||||||
|
|
||||||
static int dce_v10_0_suspend(void *handle)
|
static int dce_v10_0_suspend(void *handle)
|
||||||
{
|
{
|
||||||
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
|
|
||||||
|
adev->mode_info.bl_level =
|
||||||
|
amdgpu_atombios_encoder_get_backlight_level_from_reg(adev);
|
||||||
|
|
||||||
return dce_v10_0_hw_fini(handle);
|
return dce_v10_0_hw_fini(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2929,6 +2934,9 @@ static int dce_v10_0_resume(void *handle)
|
|||||||
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
amdgpu_atombios_encoder_set_backlight_level_to_reg(adev,
|
||||||
|
adev->mode_info.bl_level);
|
||||||
|
|
||||||
ret = dce_v10_0_hw_init(handle);
|
ret = dce_v10_0_hw_init(handle);
|
||||||
|
|
||||||
/* turn on the BL */
|
/* turn on the BL */
|
||||||
|
@ -3047,6 +3047,11 @@ static int dce_v11_0_hw_fini(void *handle)
|
|||||||
|
|
||||||
static int dce_v11_0_suspend(void *handle)
|
static int dce_v11_0_suspend(void *handle)
|
||||||
{
|
{
|
||||||
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
|
|
||||||
|
adev->mode_info.bl_level =
|
||||||
|
amdgpu_atombios_encoder_get_backlight_level_from_reg(adev);
|
||||||
|
|
||||||
return dce_v11_0_hw_fini(handle);
|
return dce_v11_0_hw_fini(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3055,6 +3060,9 @@ static int dce_v11_0_resume(void *handle)
|
|||||||
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
amdgpu_atombios_encoder_set_backlight_level_to_reg(adev,
|
||||||
|
adev->mode_info.bl_level);
|
||||||
|
|
||||||
ret = dce_v11_0_hw_init(handle);
|
ret = dce_v11_0_hw_init(handle);
|
||||||
|
|
||||||
/* turn on the BL */
|
/* turn on the BL */
|
||||||
|
@ -2787,6 +2787,11 @@ static int dce_v6_0_hw_fini(void *handle)
|
|||||||
|
|
||||||
static int dce_v6_0_suspend(void *handle)
|
static int dce_v6_0_suspend(void *handle)
|
||||||
{
|
{
|
||||||
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
|
|
||||||
|
adev->mode_info.bl_level =
|
||||||
|
amdgpu_atombios_encoder_get_backlight_level_from_reg(adev);
|
||||||
|
|
||||||
return dce_v6_0_hw_fini(handle);
|
return dce_v6_0_hw_fini(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2795,6 +2800,9 @@ static int dce_v6_0_resume(void *handle)
|
|||||||
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
amdgpu_atombios_encoder_set_backlight_level_to_reg(adev,
|
||||||
|
adev->mode_info.bl_level);
|
||||||
|
|
||||||
ret = dce_v6_0_hw_init(handle);
|
ret = dce_v6_0_hw_init(handle);
|
||||||
|
|
||||||
/* turn on the BL */
|
/* turn on the BL */
|
||||||
|
@ -2819,6 +2819,11 @@ static int dce_v8_0_hw_fini(void *handle)
|
|||||||
|
|
||||||
static int dce_v8_0_suspend(void *handle)
|
static int dce_v8_0_suspend(void *handle)
|
||||||
{
|
{
|
||||||
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
|
|
||||||
|
adev->mode_info.bl_level =
|
||||||
|
amdgpu_atombios_encoder_get_backlight_level_from_reg(adev);
|
||||||
|
|
||||||
return dce_v8_0_hw_fini(handle);
|
return dce_v8_0_hw_fini(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2827,6 +2832,9 @@ static int dce_v8_0_resume(void *handle)
|
|||||||
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
amdgpu_atombios_encoder_set_backlight_level_to_reg(adev,
|
||||||
|
adev->mode_info.bl_level);
|
||||||
|
|
||||||
ret = dce_v8_0_hw_init(handle);
|
ret = dce_v8_0_hw_init(handle);
|
||||||
|
|
||||||
/* turn on the BL */
|
/* turn on the BL */
|
||||||
|
@ -3134,8 +3134,6 @@ static int amdgpu_dm_plane_init(struct amdgpu_display_manager *dm,
|
|||||||
|
|
||||||
switch (aplane->base.type) {
|
switch (aplane->base.type) {
|
||||||
case DRM_PLANE_TYPE_PRIMARY:
|
case DRM_PLANE_TYPE_PRIMARY:
|
||||||
aplane->base.format_default = true;
|
|
||||||
|
|
||||||
res = drm_universal_plane_init(
|
res = drm_universal_plane_init(
|
||||||
dm->adev->ddev,
|
dm->adev->ddev,
|
||||||
&aplane->base,
|
&aplane->base,
|
||||||
@ -4794,6 +4792,9 @@ static int dm_atomic_check_plane_state_fb(struct drm_atomic_state *state,
|
|||||||
return -EDEADLK;
|
return -EDEADLK;
|
||||||
|
|
||||||
crtc_state = drm_atomic_get_crtc_state(plane_state->state, crtc);
|
crtc_state = drm_atomic_get_crtc_state(plane_state->state, crtc);
|
||||||
|
if (IS_ERR(crtc_state))
|
||||||
|
return PTR_ERR(crtc_state);
|
||||||
|
|
||||||
if (crtc->primary == plane && crtc_state->active) {
|
if (crtc->primary == plane && crtc_state->active) {
|
||||||
if (!plane_state->fb)
|
if (!plane_state->fb)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -109,7 +109,7 @@ enum dc_edid_status dm_helpers_parse_edid_caps(
|
|||||||
struct cea_sad *sad = &sads[i];
|
struct cea_sad *sad = &sads[i];
|
||||||
|
|
||||||
edid_caps->audio_modes[i].format_code = sad->format;
|
edid_caps->audio_modes[i].format_code = sad->format;
|
||||||
edid_caps->audio_modes[i].channel_count = sad->channels;
|
edid_caps->audio_modes[i].channel_count = sad->channels + 1;
|
||||||
edid_caps->audio_modes[i].sample_rate = sad->freq;
|
edid_caps->audio_modes[i].sample_rate = sad->freq;
|
||||||
edid_caps->audio_modes[i].sample_size = sad->byte2;
|
edid_caps->audio_modes[i].sample_size = sad->byte2;
|
||||||
}
|
}
|
||||||
|
@ -496,6 +496,9 @@ struct dce_hwseq_registers {
|
|||||||
HWS_SF(, DOMAIN7_PG_STATUS, DOMAIN7_PGFSM_PWR_STATUS, mask_sh), \
|
HWS_SF(, DOMAIN7_PG_STATUS, DOMAIN7_PGFSM_PWR_STATUS, mask_sh), \
|
||||||
HWS_SF(, DC_IP_REQUEST_CNTL, IP_REQUEST_EN, mask_sh), \
|
HWS_SF(, DC_IP_REQUEST_CNTL, IP_REQUEST_EN, mask_sh), \
|
||||||
HWS_SF(, D1VGA_CONTROL, D1VGA_MODE_ENABLE, mask_sh),\
|
HWS_SF(, D1VGA_CONTROL, D1VGA_MODE_ENABLE, mask_sh),\
|
||||||
|
HWS_SF(, D2VGA_CONTROL, D2VGA_MODE_ENABLE, mask_sh),\
|
||||||
|
HWS_SF(, D3VGA_CONTROL, D3VGA_MODE_ENABLE, mask_sh),\
|
||||||
|
HWS_SF(, D4VGA_CONTROL, D4VGA_MODE_ENABLE, mask_sh),\
|
||||||
HWS_SF(, VGA_TEST_CONTROL, VGA_TEST_ENABLE, mask_sh),\
|
HWS_SF(, VGA_TEST_CONTROL, VGA_TEST_ENABLE, mask_sh),\
|
||||||
HWS_SF(, VGA_TEST_CONTROL, VGA_TEST_RENDER_START, mask_sh),\
|
HWS_SF(, VGA_TEST_CONTROL, VGA_TEST_RENDER_START, mask_sh),\
|
||||||
HWS_SF(, LVTMA_PWRSEQ_CNTL, LVTMA_BLON, mask_sh), \
|
HWS_SF(, LVTMA_PWRSEQ_CNTL, LVTMA_BLON, mask_sh), \
|
||||||
@ -591,7 +594,10 @@ struct dce_hwseq_registers {
|
|||||||
type DENTIST_DISPCLK_WDIVIDER; \
|
type DENTIST_DISPCLK_WDIVIDER; \
|
||||||
type VGA_TEST_ENABLE; \
|
type VGA_TEST_ENABLE; \
|
||||||
type VGA_TEST_RENDER_START; \
|
type VGA_TEST_RENDER_START; \
|
||||||
type D1VGA_MODE_ENABLE;
|
type D1VGA_MODE_ENABLE; \
|
||||||
|
type D2VGA_MODE_ENABLE; \
|
||||||
|
type D3VGA_MODE_ENABLE; \
|
||||||
|
type D4VGA_MODE_ENABLE;
|
||||||
|
|
||||||
struct dce_hwseq_shift {
|
struct dce_hwseq_shift {
|
||||||
HWSEQ_REG_FIELD_LIST(uint8_t)
|
HWSEQ_REG_FIELD_LIST(uint8_t)
|
||||||
|
@ -128,23 +128,22 @@ static void set_truncation(
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* on other format-to do */
|
/* on other format-to do */
|
||||||
if (params->flags.TRUNCATE_ENABLED == 0 ||
|
if (params->flags.TRUNCATE_ENABLED == 0)
|
||||||
params->flags.TRUNCATE_DEPTH == 2)
|
|
||||||
return;
|
return;
|
||||||
/*Set truncation depth and Enable truncation*/
|
/*Set truncation depth and Enable truncation*/
|
||||||
REG_UPDATE_3(FMT_BIT_DEPTH_CONTROL,
|
REG_UPDATE_3(FMT_BIT_DEPTH_CONTROL,
|
||||||
FMT_TRUNCATE_EN, 1,
|
FMT_TRUNCATE_EN, 1,
|
||||||
FMT_TRUNCATE_DEPTH,
|
FMT_TRUNCATE_DEPTH,
|
||||||
params->flags.TRUNCATE_MODE,
|
params->flags.TRUNCATE_DEPTH,
|
||||||
FMT_TRUNCATE_MODE,
|
FMT_TRUNCATE_MODE,
|
||||||
params->flags.TRUNCATE_DEPTH);
|
params->flags.TRUNCATE_MODE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set_spatial_dither
|
* set_spatial_dither
|
||||||
* 1) set spatial dithering mode: pattern of seed
|
* 1) set spatial dithering mode: pattern of seed
|
||||||
* 2) set spatical dithering depth: 0 for 18bpp or 1 for 24bpp
|
* 2) set spatial dithering depth: 0 for 18bpp or 1 for 24bpp
|
||||||
* 3) set random seed
|
* 3) set random seed
|
||||||
* 4) set random mode
|
* 4) set random mode
|
||||||
* lfsr is reset every frame or not reset
|
* lfsr is reset every frame or not reset
|
||||||
|
@ -238,14 +238,24 @@ static void enable_power_gating_plane(
|
|||||||
static void disable_vga(
|
static void disable_vga(
|
||||||
struct dce_hwseq *hws)
|
struct dce_hwseq *hws)
|
||||||
{
|
{
|
||||||
unsigned int in_vga_mode = 0;
|
unsigned int in_vga1_mode = 0;
|
||||||
|
unsigned int in_vga2_mode = 0;
|
||||||
|
unsigned int in_vga3_mode = 0;
|
||||||
|
unsigned int in_vga4_mode = 0;
|
||||||
|
|
||||||
REG_GET(D1VGA_CONTROL, D1VGA_MODE_ENABLE, &in_vga_mode);
|
REG_GET(D1VGA_CONTROL, D1VGA_MODE_ENABLE, &in_vga1_mode);
|
||||||
|
REG_GET(D2VGA_CONTROL, D2VGA_MODE_ENABLE, &in_vga2_mode);
|
||||||
|
REG_GET(D3VGA_CONTROL, D3VGA_MODE_ENABLE, &in_vga3_mode);
|
||||||
|
REG_GET(D4VGA_CONTROL, D4VGA_MODE_ENABLE, &in_vga4_mode);
|
||||||
|
|
||||||
if (in_vga_mode == 0)
|
if (in_vga1_mode == 0 && in_vga2_mode == 0 &&
|
||||||
|
in_vga3_mode == 0 && in_vga4_mode == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
REG_WRITE(D1VGA_CONTROL, 0);
|
REG_WRITE(D1VGA_CONTROL, 0);
|
||||||
|
REG_WRITE(D2VGA_CONTROL, 0);
|
||||||
|
REG_WRITE(D3VGA_CONTROL, 0);
|
||||||
|
REG_WRITE(D4VGA_CONTROL, 0);
|
||||||
|
|
||||||
/* HW Engineer's Notes:
|
/* HW Engineer's Notes:
|
||||||
* During switch from vga->extended, if we set the VGA_TEST_ENABLE and
|
* During switch from vga->extended, if we set the VGA_TEST_ENABLE and
|
||||||
|
@ -97,7 +97,7 @@ static const struct ast_vbios_dclk_info dclk_table[] = {
|
|||||||
{0x67, 0x22, 0x00}, /* 0E: VCLK157_5 */
|
{0x67, 0x22, 0x00}, /* 0E: VCLK157_5 */
|
||||||
{0x6A, 0x22, 0x00}, /* 0F: VCLK162 */
|
{0x6A, 0x22, 0x00}, /* 0F: VCLK162 */
|
||||||
{0x4d, 0x4c, 0x80}, /* 10: VCLK154 */
|
{0x4d, 0x4c, 0x80}, /* 10: VCLK154 */
|
||||||
{0xa7, 0x78, 0x80}, /* 11: VCLK83.5 */
|
{0x68, 0x6f, 0x80}, /* 11: VCLK83.5 */
|
||||||
{0x28, 0x49, 0x80}, /* 12: VCLK106.5 */
|
{0x28, 0x49, 0x80}, /* 12: VCLK106.5 */
|
||||||
{0x37, 0x49, 0x80}, /* 13: VCLK146.25 */
|
{0x37, 0x49, 0x80}, /* 13: VCLK146.25 */
|
||||||
{0x1f, 0x45, 0x80}, /* 14: VCLK148.5 */
|
{0x1f, 0x45, 0x80}, /* 14: VCLK148.5 */
|
||||||
@ -127,7 +127,7 @@ static const struct ast_vbios_dclk_info dclk_table_ast2500[] = {
|
|||||||
{0x67, 0x22, 0x00}, /* 0E: VCLK157_5 */
|
{0x67, 0x22, 0x00}, /* 0E: VCLK157_5 */
|
||||||
{0x6A, 0x22, 0x00}, /* 0F: VCLK162 */
|
{0x6A, 0x22, 0x00}, /* 0F: VCLK162 */
|
||||||
{0x4d, 0x4c, 0x80}, /* 10: VCLK154 */
|
{0x4d, 0x4c, 0x80}, /* 10: VCLK154 */
|
||||||
{0xa7, 0x78, 0x80}, /* 11: VCLK83.5 */
|
{0x68, 0x6f, 0x80}, /* 11: VCLK83.5 */
|
||||||
{0x28, 0x49, 0x80}, /* 12: VCLK106.5 */
|
{0x28, 0x49, 0x80}, /* 12: VCLK106.5 */
|
||||||
{0x37, 0x49, 0x80}, /* 13: VCLK146.25 */
|
{0x37, 0x49, 0x80}, /* 13: VCLK146.25 */
|
||||||
{0x1f, 0x45, 0x80}, /* 14: VCLK148.5 */
|
{0x1f, 0x45, 0x80}, /* 14: VCLK148.5 */
|
||||||
|
@ -461,6 +461,12 @@ int drm_mode_getfb(struct drm_device *dev,
|
|||||||
if (!fb)
|
if (!fb)
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
|
|
||||||
|
/* Multi-planar framebuffers need getfb2. */
|
||||||
|
if (fb->format->num_planes > 1) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
r->height = fb->height;
|
r->height = fb->height;
|
||||||
r->width = fb->width;
|
r->width = fb->width;
|
||||||
r->depth = fb->format->depth;
|
r->depth = fb->format->depth;
|
||||||
@ -484,6 +490,7 @@ int drm_mode_getfb(struct drm_device *dev,
|
|||||||
ret = -ENODEV;
|
ret = -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out:
|
||||||
drm_framebuffer_put(fb);
|
drm_framebuffer_put(fb);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -471,6 +471,7 @@ struct parser_exec_state {
|
|||||||
* used when ret from 2nd level batch buffer
|
* used when ret from 2nd level batch buffer
|
||||||
*/
|
*/
|
||||||
int saved_buf_addr_type;
|
int saved_buf_addr_type;
|
||||||
|
bool is_ctx_wa;
|
||||||
|
|
||||||
struct cmd_info *info;
|
struct cmd_info *info;
|
||||||
|
|
||||||
@ -1715,6 +1716,11 @@ static int perform_bb_shadow(struct parser_exec_state *s)
|
|||||||
bb->accessing = true;
|
bb->accessing = true;
|
||||||
bb->bb_start_cmd_va = s->ip_va;
|
bb->bb_start_cmd_va = s->ip_va;
|
||||||
|
|
||||||
|
if ((s->buf_type == BATCH_BUFFER_INSTRUCTION) && (!s->is_ctx_wa))
|
||||||
|
bb->bb_offset = s->ip_va - s->rb_va;
|
||||||
|
else
|
||||||
|
bb->bb_offset = 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ip_va saves the virtual address of the shadow batch buffer, while
|
* ip_va saves the virtual address of the shadow batch buffer, while
|
||||||
* ip_gma saves the graphics address of the original batch buffer.
|
* ip_gma saves the graphics address of the original batch buffer.
|
||||||
@ -2571,6 +2577,7 @@ static int scan_workload(struct intel_vgpu_workload *workload)
|
|||||||
s.ring_tail = gma_tail;
|
s.ring_tail = gma_tail;
|
||||||
s.rb_va = workload->shadow_ring_buffer_va;
|
s.rb_va = workload->shadow_ring_buffer_va;
|
||||||
s.workload = workload;
|
s.workload = workload;
|
||||||
|
s.is_ctx_wa = false;
|
||||||
|
|
||||||
if ((bypass_scan_mask & (1 << workload->ring_id)) ||
|
if ((bypass_scan_mask & (1 << workload->ring_id)) ||
|
||||||
gma_head == gma_tail)
|
gma_head == gma_tail)
|
||||||
@ -2624,6 +2631,7 @@ static int scan_wa_ctx(struct intel_shadow_wa_ctx *wa_ctx)
|
|||||||
s.ring_tail = gma_tail;
|
s.ring_tail = gma_tail;
|
||||||
s.rb_va = wa_ctx->indirect_ctx.shadow_va;
|
s.rb_va = wa_ctx->indirect_ctx.shadow_va;
|
||||||
s.workload = workload;
|
s.workload = workload;
|
||||||
|
s.is_ctx_wa = true;
|
||||||
|
|
||||||
if (!intel_gvt_ggtt_validate_range(s.vgpu, s.ring_start, s.ring_size)) {
|
if (!intel_gvt_ggtt_validate_range(s.vgpu, s.ring_start, s.ring_size)) {
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
|
@ -394,9 +394,11 @@ void intel_gvt_switch_mmio(struct intel_vgpu *pre,
|
|||||||
* performace for batch mmio read/write, so we need
|
* performace for batch mmio read/write, so we need
|
||||||
* handle forcewake mannually.
|
* handle forcewake mannually.
|
||||||
*/
|
*/
|
||||||
|
intel_runtime_pm_get(dev_priv);
|
||||||
intel_uncore_forcewake_get(dev_priv, FORCEWAKE_ALL);
|
intel_uncore_forcewake_get(dev_priv, FORCEWAKE_ALL);
|
||||||
switch_mmio(pre, next, ring_id);
|
switch_mmio(pre, next, ring_id);
|
||||||
intel_uncore_forcewake_put(dev_priv, FORCEWAKE_ALL);
|
intel_uncore_forcewake_put(dev_priv, FORCEWAKE_ALL);
|
||||||
|
intel_runtime_pm_put(dev_priv);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -52,6 +52,54 @@ static void set_context_pdp_root_pointer(
|
|||||||
pdp_pair[i].val = pdp[7 - i];
|
pdp_pair[i].val = pdp[7 - i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* when populating shadow ctx from guest, we should not overrride oa related
|
||||||
|
* registers, so that they will not be overlapped by guest oa configs. Thus
|
||||||
|
* made it possible to capture oa data from host for both host and guests.
|
||||||
|
*/
|
||||||
|
static void sr_oa_regs(struct intel_vgpu_workload *workload,
|
||||||
|
u32 *reg_state, bool save)
|
||||||
|
{
|
||||||
|
struct drm_i915_private *dev_priv = workload->vgpu->gvt->dev_priv;
|
||||||
|
u32 ctx_oactxctrl = dev_priv->perf.oa.ctx_oactxctrl_offset;
|
||||||
|
u32 ctx_flexeu0 = dev_priv->perf.oa.ctx_flexeu0_offset;
|
||||||
|
int i = 0;
|
||||||
|
u32 flex_mmio[] = {
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL0),
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL1),
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL2),
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL3),
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL4),
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL5),
|
||||||
|
i915_mmio_reg_offset(EU_PERF_CNTL6),
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!workload || !reg_state || workload->ring_id != RCS)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (save) {
|
||||||
|
workload->oactxctrl = reg_state[ctx_oactxctrl + 1];
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(workload->flex_mmio); i++) {
|
||||||
|
u32 state_offset = ctx_flexeu0 + i * 2;
|
||||||
|
|
||||||
|
workload->flex_mmio[i] = reg_state[state_offset + 1];
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
reg_state[ctx_oactxctrl] =
|
||||||
|
i915_mmio_reg_offset(GEN8_OACTXCONTROL);
|
||||||
|
reg_state[ctx_oactxctrl + 1] = workload->oactxctrl;
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(workload->flex_mmio); i++) {
|
||||||
|
u32 state_offset = ctx_flexeu0 + i * 2;
|
||||||
|
u32 mmio = flex_mmio[i];
|
||||||
|
|
||||||
|
reg_state[state_offset] = mmio;
|
||||||
|
reg_state[state_offset + 1] = workload->flex_mmio[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int populate_shadow_context(struct intel_vgpu_workload *workload)
|
static int populate_shadow_context(struct intel_vgpu_workload *workload)
|
||||||
{
|
{
|
||||||
struct intel_vgpu *vgpu = workload->vgpu;
|
struct intel_vgpu *vgpu = workload->vgpu;
|
||||||
@ -98,6 +146,7 @@ static int populate_shadow_context(struct intel_vgpu_workload *workload)
|
|||||||
page = i915_gem_object_get_page(ctx_obj, LRC_STATE_PN);
|
page = i915_gem_object_get_page(ctx_obj, LRC_STATE_PN);
|
||||||
shadow_ring_context = kmap(page);
|
shadow_ring_context = kmap(page);
|
||||||
|
|
||||||
|
sr_oa_regs(workload, (u32 *)shadow_ring_context, true);
|
||||||
#define COPY_REG(name) \
|
#define COPY_REG(name) \
|
||||||
intel_gvt_hypervisor_read_gpa(vgpu, workload->ring_context_gpa \
|
intel_gvt_hypervisor_read_gpa(vgpu, workload->ring_context_gpa \
|
||||||
+ RING_CTX_OFF(name.val), &shadow_ring_context->name.val, 4)
|
+ RING_CTX_OFF(name.val), &shadow_ring_context->name.val, 4)
|
||||||
@ -122,6 +171,7 @@ static int populate_shadow_context(struct intel_vgpu_workload *workload)
|
|||||||
sizeof(*shadow_ring_context),
|
sizeof(*shadow_ring_context),
|
||||||
I915_GTT_PAGE_SIZE - sizeof(*shadow_ring_context));
|
I915_GTT_PAGE_SIZE - sizeof(*shadow_ring_context));
|
||||||
|
|
||||||
|
sr_oa_regs(workload, (u32 *)shadow_ring_context, false);
|
||||||
kunmap(page);
|
kunmap(page);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -376,6 +426,17 @@ static int prepare_shadow_batch_buffer(struct intel_vgpu_workload *workload)
|
|||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* For privilge batch buffer and not wa_ctx, the bb_start_cmd_va
|
||||||
|
* is only updated into ring_scan_buffer, not real ring address
|
||||||
|
* allocated in later copy_workload_to_ring_buffer. pls be noted
|
||||||
|
* shadow_ring_buffer_va is now pointed to real ring buffer va
|
||||||
|
* in copy_workload_to_ring_buffer.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (bb->bb_offset)
|
||||||
|
bb->bb_start_cmd_va = workload->shadow_ring_buffer_va
|
||||||
|
+ bb->bb_offset;
|
||||||
|
|
||||||
/* relocate shadow batch buffer */
|
/* relocate shadow batch buffer */
|
||||||
bb->bb_start_cmd_va[1] = i915_ggtt_offset(bb->vma);
|
bb->bb_start_cmd_va[1] = i915_ggtt_offset(bb->vma);
|
||||||
if (gmadr_bytes == 8)
|
if (gmadr_bytes == 8)
|
||||||
@ -1044,10 +1105,12 @@ int intel_vgpu_setup_submission(struct intel_vgpu *vgpu)
|
|||||||
|
|
||||||
bitmap_zero(s->shadow_ctx_desc_updated, I915_NUM_ENGINES);
|
bitmap_zero(s->shadow_ctx_desc_updated, I915_NUM_ENGINES);
|
||||||
|
|
||||||
s->workloads = kmem_cache_create("gvt-g_vgpu_workload",
|
s->workloads = kmem_cache_create_usercopy("gvt-g_vgpu_workload",
|
||||||
sizeof(struct intel_vgpu_workload), 0,
|
sizeof(struct intel_vgpu_workload), 0,
|
||||||
SLAB_HWCACHE_ALIGN,
|
SLAB_HWCACHE_ALIGN,
|
||||||
NULL);
|
offsetof(struct intel_vgpu_workload, rb_tail),
|
||||||
|
sizeof_field(struct intel_vgpu_workload, rb_tail),
|
||||||
|
NULL);
|
||||||
|
|
||||||
if (!s->workloads) {
|
if (!s->workloads) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
|
@ -110,6 +110,10 @@ struct intel_vgpu_workload {
|
|||||||
/* shadow batch buffer */
|
/* shadow batch buffer */
|
||||||
struct list_head shadow_bb;
|
struct list_head shadow_bb;
|
||||||
struct intel_shadow_wa_ctx wa_ctx;
|
struct intel_shadow_wa_ctx wa_ctx;
|
||||||
|
|
||||||
|
/* oa registers */
|
||||||
|
u32 oactxctrl;
|
||||||
|
u32 flex_mmio[7];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct intel_vgpu_shadow_bb {
|
struct intel_vgpu_shadow_bb {
|
||||||
@ -120,6 +124,7 @@ struct intel_vgpu_shadow_bb {
|
|||||||
u32 *bb_start_cmd_va;
|
u32 *bb_start_cmd_va;
|
||||||
unsigned int clflush;
|
unsigned int clflush;
|
||||||
bool accessing;
|
bool accessing;
|
||||||
|
unsigned long bb_offset;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define workload_q_head(vgpu, ring_id) \
|
#define workload_q_head(vgpu, ring_id) \
|
||||||
|
@ -434,20 +434,28 @@ i915_gem_object_wait_reservation(struct reservation_object *resv,
|
|||||||
dma_fence_put(shared[i]);
|
dma_fence_put(shared[i]);
|
||||||
kfree(shared);
|
kfree(shared);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If both shared fences and an exclusive fence exist,
|
||||||
|
* then by construction the shared fences must be later
|
||||||
|
* than the exclusive fence. If we successfully wait for
|
||||||
|
* all the shared fences, we know that the exclusive fence
|
||||||
|
* must all be signaled. If all the shared fences are
|
||||||
|
* signaled, we can prune the array and recover the
|
||||||
|
* floating references on the fences/requests.
|
||||||
|
*/
|
||||||
prune_fences = count && timeout >= 0;
|
prune_fences = count && timeout >= 0;
|
||||||
} else {
|
} else {
|
||||||
excl = reservation_object_get_excl_rcu(resv);
|
excl = reservation_object_get_excl_rcu(resv);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (excl && timeout >= 0) {
|
if (excl && timeout >= 0)
|
||||||
timeout = i915_gem_object_wait_fence(excl, flags, timeout,
|
timeout = i915_gem_object_wait_fence(excl, flags, timeout,
|
||||||
rps_client);
|
rps_client);
|
||||||
prune_fences = timeout >= 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
dma_fence_put(excl);
|
dma_fence_put(excl);
|
||||||
|
|
||||||
/* Oportunistically prune the fences iff we know they have *all* been
|
/*
|
||||||
|
* Opportunistically prune the fences iff we know they have *all* been
|
||||||
* signaled and that the reservation object has not been changed (i.e.
|
* signaled and that the reservation object has not been changed (i.e.
|
||||||
* no new fences have been added).
|
* no new fences have been added).
|
||||||
*/
|
*/
|
||||||
|
@ -304,8 +304,9 @@ static ssize_t gt_boost_freq_mhz_store(struct device *kdev,
|
|||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = kdev_minor_to_i915(kdev);
|
struct drm_i915_private *dev_priv = kdev_minor_to_i915(kdev);
|
||||||
struct intel_rps *rps = &dev_priv->gt_pm.rps;
|
struct intel_rps *rps = &dev_priv->gt_pm.rps;
|
||||||
u32 val;
|
bool boost = false;
|
||||||
ssize_t ret;
|
ssize_t ret;
|
||||||
|
u32 val;
|
||||||
|
|
||||||
ret = kstrtou32(buf, 0, &val);
|
ret = kstrtou32(buf, 0, &val);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -317,8 +318,13 @@ static ssize_t gt_boost_freq_mhz_store(struct device *kdev,
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
mutex_lock(&dev_priv->pcu_lock);
|
mutex_lock(&dev_priv->pcu_lock);
|
||||||
rps->boost_freq = val;
|
if (val != rps->boost_freq) {
|
||||||
|
rps->boost_freq = val;
|
||||||
|
boost = atomic_read(&rps->num_waiters);
|
||||||
|
}
|
||||||
mutex_unlock(&dev_priv->pcu_lock);
|
mutex_unlock(&dev_priv->pcu_lock);
|
||||||
|
if (boost)
|
||||||
|
schedule_work(&rps->work);
|
||||||
|
|
||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
@ -2175,8 +2175,7 @@ static void intel_ddi_pre_enable_dp(struct intel_encoder *encoder,
|
|||||||
intel_prepare_dp_ddi_buffers(encoder, crtc_state);
|
intel_prepare_dp_ddi_buffers(encoder, crtc_state);
|
||||||
|
|
||||||
intel_ddi_init_dp_buf_reg(encoder);
|
intel_ddi_init_dp_buf_reg(encoder);
|
||||||
if (!is_mst)
|
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON);
|
||||||
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON);
|
|
||||||
intel_dp_start_link_train(intel_dp);
|
intel_dp_start_link_train(intel_dp);
|
||||||
if (port != PORT_A || INTEL_GEN(dev_priv) >= 9)
|
if (port != PORT_A || INTEL_GEN(dev_priv) >= 9)
|
||||||
intel_dp_stop_link_train(intel_dp);
|
intel_dp_stop_link_train(intel_dp);
|
||||||
@ -2274,14 +2273,12 @@ static void intel_ddi_post_disable_dp(struct intel_encoder *encoder,
|
|||||||
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
|
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
|
||||||
struct intel_digital_port *dig_port = enc_to_dig_port(&encoder->base);
|
struct intel_digital_port *dig_port = enc_to_dig_port(&encoder->base);
|
||||||
struct intel_dp *intel_dp = &dig_port->dp;
|
struct intel_dp *intel_dp = &dig_port->dp;
|
||||||
bool is_mst = intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_DP_MST);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Power down sink before disabling the port, otherwise we end
|
* Power down sink before disabling the port, otherwise we end
|
||||||
* up getting interrupts from the sink on detecting link loss.
|
* up getting interrupts from the sink on detecting link loss.
|
||||||
*/
|
*/
|
||||||
if (!is_mst)
|
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_OFF);
|
||||||
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_OFF);
|
|
||||||
|
|
||||||
intel_disable_ddi_buf(encoder);
|
intel_disable_ddi_buf(encoder);
|
||||||
|
|
||||||
|
@ -620,19 +620,15 @@ static int
|
|||||||
bxt_power_sequencer_idx(struct intel_dp *intel_dp)
|
bxt_power_sequencer_idx(struct intel_dp *intel_dp)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(intel_dp_to_dev(intel_dp));
|
struct drm_i915_private *dev_priv = to_i915(intel_dp_to_dev(intel_dp));
|
||||||
|
int backlight_controller = dev_priv->vbt.backlight.controller;
|
||||||
|
|
||||||
lockdep_assert_held(&dev_priv->pps_mutex);
|
lockdep_assert_held(&dev_priv->pps_mutex);
|
||||||
|
|
||||||
/* We should never land here with regular DP ports */
|
/* We should never land here with regular DP ports */
|
||||||
WARN_ON(!intel_dp_is_edp(intel_dp));
|
WARN_ON(!intel_dp_is_edp(intel_dp));
|
||||||
|
|
||||||
/*
|
|
||||||
* TODO: BXT has 2 PPS instances. The correct port->PPS instance
|
|
||||||
* mapping needs to be retrieved from VBT, for now just hard-code to
|
|
||||||
* use instance #0 always.
|
|
||||||
*/
|
|
||||||
if (!intel_dp->pps_reset)
|
if (!intel_dp->pps_reset)
|
||||||
return 0;
|
return backlight_controller;
|
||||||
|
|
||||||
intel_dp->pps_reset = false;
|
intel_dp->pps_reset = false;
|
||||||
|
|
||||||
@ -642,7 +638,7 @@ bxt_power_sequencer_idx(struct intel_dp *intel_dp)
|
|||||||
*/
|
*/
|
||||||
intel_dp_init_panel_power_sequencer_registers(intel_dp, false);
|
intel_dp_init_panel_power_sequencer_registers(intel_dp, false);
|
||||||
|
|
||||||
return 0;
|
return backlight_controller;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef bool (*vlv_pipe_check)(struct drm_i915_private *dev_priv,
|
typedef bool (*vlv_pipe_check)(struct drm_i915_private *dev_priv,
|
||||||
|
@ -246,7 +246,7 @@ engine_stuck(struct intel_engine_cs *engine, u64 acthd)
|
|||||||
*/
|
*/
|
||||||
tmp = I915_READ_CTL(engine);
|
tmp = I915_READ_CTL(engine);
|
||||||
if (tmp & RING_WAIT) {
|
if (tmp & RING_WAIT) {
|
||||||
i915_handle_error(dev_priv, 0,
|
i915_handle_error(dev_priv, BIT(engine->id),
|
||||||
"Kicking stuck wait on %s",
|
"Kicking stuck wait on %s",
|
||||||
engine->name);
|
engine->name);
|
||||||
I915_WRITE_CTL(engine, tmp);
|
I915_WRITE_CTL(engine, tmp);
|
||||||
@ -258,7 +258,7 @@ engine_stuck(struct intel_engine_cs *engine, u64 acthd)
|
|||||||
default:
|
default:
|
||||||
return ENGINE_DEAD;
|
return ENGINE_DEAD;
|
||||||
case 1:
|
case 1:
|
||||||
i915_handle_error(dev_priv, 0,
|
i915_handle_error(dev_priv, ALL_ENGINES,
|
||||||
"Kicking stuck semaphore on %s",
|
"Kicking stuck semaphore on %s",
|
||||||
engine->name);
|
engine->name);
|
||||||
I915_WRITE_CTL(engine, tmp);
|
I915_WRITE_CTL(engine, tmp);
|
||||||
|
@ -225,7 +225,11 @@ static void ipu_crtc_atomic_begin(struct drm_crtc *crtc,
|
|||||||
struct drm_crtc_state *old_crtc_state)
|
struct drm_crtc_state *old_crtc_state)
|
||||||
{
|
{
|
||||||
drm_crtc_vblank_on(crtc);
|
drm_crtc_vblank_on(crtc);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ipu_crtc_atomic_flush(struct drm_crtc *crtc,
|
||||||
|
struct drm_crtc_state *old_crtc_state)
|
||||||
|
{
|
||||||
spin_lock_irq(&crtc->dev->event_lock);
|
spin_lock_irq(&crtc->dev->event_lock);
|
||||||
if (crtc->state->event) {
|
if (crtc->state->event) {
|
||||||
WARN_ON(drm_crtc_vblank_get(crtc));
|
WARN_ON(drm_crtc_vblank_get(crtc));
|
||||||
@ -293,6 +297,7 @@ static const struct drm_crtc_helper_funcs ipu_helper_funcs = {
|
|||||||
.mode_set_nofb = ipu_crtc_mode_set_nofb,
|
.mode_set_nofb = ipu_crtc_mode_set_nofb,
|
||||||
.atomic_check = ipu_crtc_atomic_check,
|
.atomic_check = ipu_crtc_atomic_check,
|
||||||
.atomic_begin = ipu_crtc_atomic_begin,
|
.atomic_begin = ipu_crtc_atomic_begin,
|
||||||
|
.atomic_flush = ipu_crtc_atomic_flush,
|
||||||
.atomic_disable = ipu_crtc_atomic_disable,
|
.atomic_disable = ipu_crtc_atomic_disable,
|
||||||
.atomic_enable = ipu_crtc_atomic_enable,
|
.atomic_enable = ipu_crtc_atomic_enable,
|
||||||
};
|
};
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include <drm/drm_plane_helper.h>
|
#include <drm/drm_plane_helper.h>
|
||||||
|
|
||||||
#include "video/imx-ipu-v3.h"
|
#include "video/imx-ipu-v3.h"
|
||||||
|
#include "imx-drm.h"
|
||||||
#include "ipuv3-plane.h"
|
#include "ipuv3-plane.h"
|
||||||
|
|
||||||
struct ipu_plane_state {
|
struct ipu_plane_state {
|
||||||
@ -272,7 +273,7 @@ static void ipu_plane_destroy(struct drm_plane *plane)
|
|||||||
kfree(ipu_plane);
|
kfree(ipu_plane);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ipu_plane_state_reset(struct drm_plane *plane)
|
static void ipu_plane_state_reset(struct drm_plane *plane)
|
||||||
{
|
{
|
||||||
struct ipu_plane_state *ipu_state;
|
struct ipu_plane_state *ipu_state;
|
||||||
|
|
||||||
@ -292,7 +293,8 @@ void ipu_plane_state_reset(struct drm_plane *plane)
|
|||||||
plane->state = &ipu_state->base;
|
plane->state = &ipu_state->base;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct drm_plane_state *ipu_plane_duplicate_state(struct drm_plane *plane)
|
static struct drm_plane_state *
|
||||||
|
ipu_plane_duplicate_state(struct drm_plane *plane)
|
||||||
{
|
{
|
||||||
struct ipu_plane_state *state;
|
struct ipu_plane_state *state;
|
||||||
|
|
||||||
@ -306,8 +308,8 @@ struct drm_plane_state *ipu_plane_duplicate_state(struct drm_plane *plane)
|
|||||||
return &state->base;
|
return &state->base;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ipu_plane_destroy_state(struct drm_plane *plane,
|
static void ipu_plane_destroy_state(struct drm_plane *plane,
|
||||||
struct drm_plane_state *state)
|
struct drm_plane_state *state)
|
||||||
{
|
{
|
||||||
struct ipu_plane_state *ipu_state = to_ipu_plane_state(state);
|
struct ipu_plane_state *ipu_state = to_ipu_plane_state(state);
|
||||||
|
|
||||||
|
@ -134,7 +134,7 @@ nv50_get_intensity(struct backlight_device *bd)
|
|||||||
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
||||||
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
||||||
struct nvif_object *device = &drm->client.device.object;
|
struct nvif_object *device = &drm->client.device.object;
|
||||||
int or = nv_encoder->or;
|
int or = ffs(nv_encoder->dcb->or) - 1;
|
||||||
u32 div = 1025;
|
u32 div = 1025;
|
||||||
u32 val;
|
u32 val;
|
||||||
|
|
||||||
@ -149,7 +149,7 @@ nv50_set_intensity(struct backlight_device *bd)
|
|||||||
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
||||||
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
||||||
struct nvif_object *device = &drm->client.device.object;
|
struct nvif_object *device = &drm->client.device.object;
|
||||||
int or = nv_encoder->or;
|
int or = ffs(nv_encoder->dcb->or) - 1;
|
||||||
u32 div = 1025;
|
u32 div = 1025;
|
||||||
u32 val = (bd->props.brightness * div) / 100;
|
u32 val = (bd->props.brightness * div) / 100;
|
||||||
|
|
||||||
@ -170,7 +170,7 @@ nva3_get_intensity(struct backlight_device *bd)
|
|||||||
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
||||||
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
||||||
struct nvif_object *device = &drm->client.device.object;
|
struct nvif_object *device = &drm->client.device.object;
|
||||||
int or = nv_encoder->or;
|
int or = ffs(nv_encoder->dcb->or) - 1;
|
||||||
u32 div, val;
|
u32 div, val;
|
||||||
|
|
||||||
div = nvif_rd32(device, NV50_PDISP_SOR_PWM_DIV(or));
|
div = nvif_rd32(device, NV50_PDISP_SOR_PWM_DIV(or));
|
||||||
@ -188,7 +188,7 @@ nva3_set_intensity(struct backlight_device *bd)
|
|||||||
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
struct nouveau_encoder *nv_encoder = bl_get_data(bd);
|
||||||
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
struct nouveau_drm *drm = nouveau_drm(nv_encoder->base.base.dev);
|
||||||
struct nvif_object *device = &drm->client.device.object;
|
struct nvif_object *device = &drm->client.device.object;
|
||||||
int or = nv_encoder->or;
|
int or = ffs(nv_encoder->dcb->or) - 1;
|
||||||
u32 div, val;
|
u32 div, val;
|
||||||
|
|
||||||
div = nvif_rd32(device, NV50_PDISP_SOR_PWM_DIV(or));
|
div = nvif_rd32(device, NV50_PDISP_SOR_PWM_DIV(or));
|
||||||
@ -228,7 +228,7 @@ nv50_backlight_init(struct drm_connector *connector)
|
|||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!nvif_rd32(device, NV50_PDISP_SOR_PWM_CTL(nv_encoder->or)))
|
if (!nvif_rd32(device, NV50_PDISP_SOR_PWM_CTL(ffs(nv_encoder->dcb->or) - 1)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (drm->client.device.info.chipset <= 0xa0 ||
|
if (drm->client.device.info.chipset <= 0xa0 ||
|
||||||
@ -268,13 +268,13 @@ nouveau_backlight_init(struct drm_device *dev)
|
|||||||
struct nvif_device *device = &drm->client.device;
|
struct nvif_device *device = &drm->client.device;
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
|
|
||||||
|
INIT_LIST_HEAD(&drm->bl_connectors);
|
||||||
|
|
||||||
if (apple_gmux_present()) {
|
if (apple_gmux_present()) {
|
||||||
NV_INFO(drm, "Apple GMUX detected: not registering Nouveau backlight interface\n");
|
NV_INFO(drm, "Apple GMUX detected: not registering Nouveau backlight interface\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
INIT_LIST_HEAD(&drm->bl_connectors);
|
|
||||||
|
|
||||||
list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
|
list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
|
||||||
if (connector->connector_type != DRM_MODE_CONNECTOR_LVDS &&
|
if (connector->connector_type != DRM_MODE_CONNECTOR_LVDS &&
|
||||||
connector->connector_type != DRM_MODE_CONNECTOR_eDP)
|
connector->connector_type != DRM_MODE_CONNECTOR_eDP)
|
||||||
|
@ -1354,7 +1354,7 @@ nvkm_vmm_get_locked(struct nvkm_vmm *vmm, bool getref, bool mapref, bool sparse,
|
|||||||
|
|
||||||
tail = this->addr + this->size;
|
tail = this->addr + this->size;
|
||||||
if (vmm->func->page_block && next && next->page != p)
|
if (vmm->func->page_block && next && next->page != p)
|
||||||
tail = ALIGN_DOWN(addr, vmm->func->page_block);
|
tail = ALIGN_DOWN(tail, vmm->func->page_block);
|
||||||
|
|
||||||
if (addr <= tail && tail - addr >= size) {
|
if (addr <= tail && tail - addr >= size) {
|
||||||
rb_erase(&this->tree, &vmm->free);
|
rb_erase(&this->tree, &vmm->free);
|
||||||
|
@ -90,25 +90,18 @@ void radeon_connector_hotplug(struct drm_connector *connector)
|
|||||||
/* don't do anything if sink is not display port, i.e.,
|
/* don't do anything if sink is not display port, i.e.,
|
||||||
* passive dp->(dvi|hdmi) adaptor
|
* passive dp->(dvi|hdmi) adaptor
|
||||||
*/
|
*/
|
||||||
if (dig_connector->dp_sink_type == CONNECTOR_OBJECT_ID_DISPLAYPORT) {
|
if (dig_connector->dp_sink_type == CONNECTOR_OBJECT_ID_DISPLAYPORT &&
|
||||||
int saved_dpms = connector->dpms;
|
radeon_hpd_sense(rdev, radeon_connector->hpd.hpd) &&
|
||||||
/* Only turn off the display if it's physically disconnected */
|
radeon_dp_needs_link_train(radeon_connector)) {
|
||||||
if (!radeon_hpd_sense(rdev, radeon_connector->hpd.hpd)) {
|
/* Don't start link training before we have the DPCD */
|
||||||
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_OFF);
|
if (!radeon_dp_getdpcd(radeon_connector))
|
||||||
} else if (radeon_dp_needs_link_train(radeon_connector)) {
|
return;
|
||||||
/* Don't try to start link training before we
|
|
||||||
* have the dpcd */
|
|
||||||
if (!radeon_dp_getdpcd(radeon_connector))
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* set it to OFF so that drm_helper_connector_dpms()
|
/* Turn the connector off and back on immediately, which
|
||||||
* won't return immediately since the current state
|
* will trigger link training
|
||||||
* is ON at this point.
|
*/
|
||||||
*/
|
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_OFF);
|
||||||
connector->dpms = DRM_MODE_DPMS_OFF;
|
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_ON);
|
||||||
drm_helper_connector_dpms(connector, DRM_MODE_DPMS_ON);
|
|
||||||
}
|
|
||||||
connector->dpms = saved_dpms;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,8 +34,6 @@ void radeon_gem_object_free(struct drm_gem_object *gobj)
|
|||||||
struct radeon_bo *robj = gem_to_radeon_bo(gobj);
|
struct radeon_bo *robj = gem_to_radeon_bo(gobj);
|
||||||
|
|
||||||
if (robj) {
|
if (robj) {
|
||||||
if (robj->gem_base.import_attach)
|
|
||||||
drm_prime_gem_destroy(&robj->gem_base, robj->tbo.sg);
|
|
||||||
radeon_mn_unregister(robj);
|
radeon_mn_unregister(robj);
|
||||||
radeon_bo_unref(&robj);
|
radeon_bo_unref(&robj);
|
||||||
}
|
}
|
||||||
|
@ -82,6 +82,8 @@ static void radeon_ttm_bo_destroy(struct ttm_buffer_object *tbo)
|
|||||||
mutex_unlock(&bo->rdev->gem.mutex);
|
mutex_unlock(&bo->rdev->gem.mutex);
|
||||||
radeon_bo_clear_surface_reg(bo);
|
radeon_bo_clear_surface_reg(bo);
|
||||||
WARN_ON_ONCE(!list_empty(&bo->va));
|
WARN_ON_ONCE(!list_empty(&bo->va));
|
||||||
|
if (bo->gem_base.import_attach)
|
||||||
|
drm_prime_gem_destroy(&bo->gem_base, bo->tbo.sg);
|
||||||
drm_gem_object_release(&bo->gem_base);
|
drm_gem_object_release(&bo->gem_base);
|
||||||
kfree(bo);
|
kfree(bo);
|
||||||
}
|
}
|
||||||
|
@ -111,7 +111,7 @@ static int sun4i_drv_bind(struct device *dev)
|
|||||||
/* drm_vblank_init calls kcalloc, which can fail */
|
/* drm_vblank_init calls kcalloc, which can fail */
|
||||||
ret = drm_vblank_init(drm, drm->mode_config.num_crtc);
|
ret = drm_vblank_init(drm, drm->mode_config.num_crtc);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto free_mem_region;
|
goto cleanup_mode_config;
|
||||||
|
|
||||||
drm->irq_enabled = true;
|
drm->irq_enabled = true;
|
||||||
|
|
||||||
@ -139,7 +139,6 @@ finish_poll:
|
|||||||
sun4i_framebuffer_free(drm);
|
sun4i_framebuffer_free(drm);
|
||||||
cleanup_mode_config:
|
cleanup_mode_config:
|
||||||
drm_mode_config_cleanup(drm);
|
drm_mode_config_cleanup(drm);
|
||||||
free_mem_region:
|
|
||||||
of_reserved_mem_device_release(dev);
|
of_reserved_mem_device_release(dev);
|
||||||
free_drm:
|
free_drm:
|
||||||
drm_dev_unref(drm);
|
drm_dev_unref(drm);
|
||||||
|
@ -538,7 +538,8 @@ static int sun4i_hdmi_bind(struct device *dev, struct device *master,
|
|||||||
&sun4i_hdmi_regmap_config);
|
&sun4i_hdmi_regmap_config);
|
||||||
if (IS_ERR(hdmi->regmap)) {
|
if (IS_ERR(hdmi->regmap)) {
|
||||||
dev_err(dev, "Couldn't create HDMI encoder regmap\n");
|
dev_err(dev, "Couldn't create HDMI encoder regmap\n");
|
||||||
return PTR_ERR(hdmi->regmap);
|
ret = PTR_ERR(hdmi->regmap);
|
||||||
|
goto err_disable_mod_clk;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = sun4i_tmds_create(hdmi);
|
ret = sun4i_tmds_create(hdmi);
|
||||||
@ -551,7 +552,8 @@ static int sun4i_hdmi_bind(struct device *dev, struct device *master,
|
|||||||
hdmi->ddc_parent_clk = devm_clk_get(dev, "ddc");
|
hdmi->ddc_parent_clk = devm_clk_get(dev, "ddc");
|
||||||
if (IS_ERR(hdmi->ddc_parent_clk)) {
|
if (IS_ERR(hdmi->ddc_parent_clk)) {
|
||||||
dev_err(dev, "Couldn't get the HDMI DDC clock\n");
|
dev_err(dev, "Couldn't get the HDMI DDC clock\n");
|
||||||
return PTR_ERR(hdmi->ddc_parent_clk);
|
ret = PTR_ERR(hdmi->ddc_parent_clk);
|
||||||
|
goto err_disable_mod_clk;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
hdmi->ddc_parent_clk = hdmi->tmds_clk;
|
hdmi->ddc_parent_clk = hdmi->tmds_clk;
|
||||||
|
@ -103,6 +103,7 @@ static void sun4i_tcon_channel_set_status(struct sun4i_tcon *tcon, int channel,
|
|||||||
|
|
||||||
if (enabled) {
|
if (enabled) {
|
||||||
clk_prepare_enable(clk);
|
clk_prepare_enable(clk);
|
||||||
|
clk_rate_exclusive_get(clk);
|
||||||
} else {
|
} else {
|
||||||
clk_rate_exclusive_put(clk);
|
clk_rate_exclusive_put(clk);
|
||||||
clk_disable_unprepare(clk);
|
clk_disable_unprepare(clk);
|
||||||
@ -262,7 +263,7 @@ static void sun4i_tcon0_mode_set_common(struct sun4i_tcon *tcon,
|
|||||||
const struct drm_display_mode *mode)
|
const struct drm_display_mode *mode)
|
||||||
{
|
{
|
||||||
/* Configure the dot clock */
|
/* Configure the dot clock */
|
||||||
clk_set_rate_exclusive(tcon->dclk, mode->crtc_clock * 1000);
|
clk_set_rate(tcon->dclk, mode->crtc_clock * 1000);
|
||||||
|
|
||||||
/* Set the resolution */
|
/* Set the resolution */
|
||||||
regmap_write(tcon->regs, SUN4I_TCON0_BASIC0_REG,
|
regmap_write(tcon->regs, SUN4I_TCON0_BASIC0_REG,
|
||||||
@ -423,7 +424,7 @@ static void sun4i_tcon1_mode_set(struct sun4i_tcon *tcon,
|
|||||||
WARN_ON(!tcon->quirks->has_channel_1);
|
WARN_ON(!tcon->quirks->has_channel_1);
|
||||||
|
|
||||||
/* Configure the dot clock */
|
/* Configure the dot clock */
|
||||||
clk_set_rate_exclusive(tcon->sclk1, mode->crtc_clock * 1000);
|
clk_set_rate(tcon->sclk1, mode->crtc_clock * 1000);
|
||||||
|
|
||||||
/* Adjust clock delay */
|
/* Adjust clock delay */
|
||||||
clk_delay = sun4i_tcon_get_clk_delay(mode, 1);
|
clk_delay = sun4i_tcon_get_clk_delay(mode, 1);
|
||||||
|
@ -1903,8 +1903,12 @@ cleanup:
|
|||||||
if (!IS_ERR(primary))
|
if (!IS_ERR(primary))
|
||||||
drm_plane_cleanup(primary);
|
drm_plane_cleanup(primary);
|
||||||
|
|
||||||
if (group && tegra->domain) {
|
if (group && dc->domain) {
|
||||||
iommu_detach_group(tegra->domain, group);
|
if (group == tegra->group) {
|
||||||
|
iommu_detach_group(dc->domain, group);
|
||||||
|
tegra->group = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
dc->domain = NULL;
|
dc->domain = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1913,8 +1917,10 @@ cleanup:
|
|||||||
|
|
||||||
static int tegra_dc_exit(struct host1x_client *client)
|
static int tegra_dc_exit(struct host1x_client *client)
|
||||||
{
|
{
|
||||||
|
struct drm_device *drm = dev_get_drvdata(client->parent);
|
||||||
struct iommu_group *group = iommu_group_get(client->dev);
|
struct iommu_group *group = iommu_group_get(client->dev);
|
||||||
struct tegra_dc *dc = host1x_client_to_dc(client);
|
struct tegra_dc *dc = host1x_client_to_dc(client);
|
||||||
|
struct tegra_drm *tegra = drm->dev_private;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
devm_free_irq(dc->dev, dc->irq, dc);
|
devm_free_irq(dc->dev, dc->irq, dc);
|
||||||
@ -1926,7 +1932,11 @@ static int tegra_dc_exit(struct host1x_client *client)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (group && dc->domain) {
|
if (group && dc->domain) {
|
||||||
iommu_detach_group(dc->domain, group);
|
if (group == tegra->group) {
|
||||||
|
iommu_detach_group(dc->domain, group);
|
||||||
|
tegra->group = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
dc->domain = NULL;
|
dc->domain = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user