Commit 719fce75 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'soc-fixes-5.17-2' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc

Pull ARM SoC fixes from Arnd Bergmann:
 "The code changes address mostly minor problems:

   - Several NXP/FSL SoC driver fixes, addressing issues with error
     handling and compilation

   - Fix a clock disabling imbalance in gpcv2 driver.

   - Arm Juno DMA coherency issue

   - Trivial firmware driver fixes for op-tee and scmi firmware

  The remaining changes address issues in the devicetree files:

   - A timer regression for the OMAP devkit8000, which has to use the
     alternative timer.

   - A hang in the i.MX8MM power domain configuration

   - Multiple fixes for the Rockchip RK3399 addressing issues with sound
     and eMMC

   - Cosmetic fixes for i.MX8ULP, RK3xxx, and Tegra124"

* tag 'soc-fixes-5.17-2' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc: (32 commits)
  ARM: tegra: Move panels to AUX bus
  soc: imx: gpcv2: Fix clock disabling imbalance in error path
  soc: fsl: qe: Check of ioremap return value
  soc: fsl: qe: fix typo in a comment
  soc: fsl: guts: Add a missing memory allocation failure check
  soc: fsl: guts: Revert commit 3c0d64e8
  soc: fsl: Correct MAINTAINERS database (SOC)
  soc: fsl: Correct MAINTAINERS database (QUICC ENGINE LIBRARY)
  soc: fsl: Replace kernel.h with the necessary inclusions
  dt-bindings: fsl,layerscape-dcfg: add missing compatible for lx2160a
  dt-bindings: qoriq-clock: add missing compatible for lx2160a
  ARM: dts: Use 32KiHz oscillator on devkit8000
  ARM: dts: switch timer config to common devkit8000 devicetree
  tee: optee: fix error return code in probe function
  arm64: dts: imx8ulp: Set #thermal-sensor-cells to 1 as required
  arm64: dts: imx8mm: Fix VPU Hanging
  ARM: dts: rockchip: fix a typo on rk3288 crypto-controller
  ARM: dts: rockchip: reorder rk322x hmdi clocks
  firmware: arm_scmi: Remove space in MODULE_ALIAS name
  arm64: dts: agilex: use the compatible "intel,socfpga-agilex-hsotg"
  ...
parents 201b5c01 c253bf70
...@@ -895,6 +895,12 @@ S: 3000 FORE Drive ...@@ -895,6 +895,12 @@ S: 3000 FORE Drive
S: Warrendale, Pennsylvania 15086 S: Warrendale, Pennsylvania 15086
S: USA S: USA
N: Ludovic Desroches
E: ludovic.desroches@microchip.com
D: Maintainer for ARM/Microchip (AT91) SoC support
D: Author of ADC, pinctrl, XDMA and SDHCI drivers for this platform
S: France
N: Martin Devera N: Martin Devera
E: devik@cdi.cz E: devik@cdi.cz
W: http://luxik.cdi.cz/~devik/qos/ W: http://luxik.cdi.cz/~devik/qos/
......
...@@ -8,7 +8,8 @@ title: Atmel AT91 device tree bindings. ...@@ -8,7 +8,8 @@ title: Atmel AT91 device tree bindings.
maintainers: maintainers:
- Alexandre Belloni <alexandre.belloni@bootlin.com> - Alexandre Belloni <alexandre.belloni@bootlin.com>
- Ludovic Desroches <ludovic.desroches@microchip.com> - Claudiu Beznea <claudiu.beznea@microchip.com>
- Nicolas Ferre <nicolas.ferre@microchip.com>
description: | description: |
Boards with a SoC of the Atmel AT91 or SMART family shall have the following Boards with a SoC of the Atmel AT91 or SMART family shall have the following
......
...@@ -8,7 +8,7 @@ Required properties: ...@@ -8,7 +8,7 @@ Required properties:
- compatible: Should contain a chip-specific compatible string, - compatible: Should contain a chip-specific compatible string,
Chip-specific strings are of the form "fsl,<chip>-dcfg", Chip-specific strings are of the form "fsl,<chip>-dcfg",
The following <chip>s are known to be supported: The following <chip>s are known to be supported:
ls1012a, ls1021a, ls1043a, ls1046a, ls2080a. ls1012a, ls1021a, ls1043a, ls1046a, ls2080a, lx2160a
- reg : should contain base address and length of DCFG memory-mapped registers - reg : should contain base address and length of DCFG memory-mapped registers
......
...@@ -44,6 +44,7 @@ Required properties: ...@@ -44,6 +44,7 @@ Required properties:
* "fsl,ls1046a-clockgen" * "fsl,ls1046a-clockgen"
* "fsl,ls1088a-clockgen" * "fsl,ls1088a-clockgen"
* "fsl,ls2080a-clockgen" * "fsl,ls2080a-clockgen"
* "fsl,lx2160a-clockgen"
Chassis-version clock strings include: Chassis-version clock strings include:
* "fsl,qoriq-clockgen-1.0": for chassis 1.0 clocks * "fsl,qoriq-clockgen-1.0": for chassis 1.0 clocks
* "fsl,qoriq-clockgen-2.0": for chassis 2.0 clocks * "fsl,qoriq-clockgen-2.0": for chassis 2.0 clocks
......
...@@ -53,6 +53,7 @@ properties: ...@@ -53,6 +53,7 @@ properties:
- const: st,stm32mp15-hsotg - const: st,stm32mp15-hsotg
- const: snps,dwc2 - const: snps,dwc2
- const: samsung,s3c6400-hsotg - const: samsung,s3c6400-hsotg
- const: intel,socfpga-agilex-hsotg
reg: reg:
maxItems: 1 maxItems: 1
......
...@@ -2254,7 +2254,7 @@ F: drivers/phy/mediatek/ ...@@ -2254,7 +2254,7 @@ F: drivers/phy/mediatek/
ARM/Microchip (AT91) SoC support ARM/Microchip (AT91) SoC support
M: Nicolas Ferre <nicolas.ferre@microchip.com> M: Nicolas Ferre <nicolas.ferre@microchip.com>
M: Alexandre Belloni <alexandre.belloni@bootlin.com> M: Alexandre Belloni <alexandre.belloni@bootlin.com>
M: Ludovic Desroches <ludovic.desroches@microchip.com> M: Claudiu Beznea <claudiu.beznea@microchip.com>
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
S: Supported S: Supported
W: http://www.linux4sam.org W: http://www.linux4sam.org
...@@ -7744,8 +7744,7 @@ M: Qiang Zhao <qiang.zhao@nxp.com> ...@@ -7744,8 +7744,7 @@ M: Qiang Zhao <qiang.zhao@nxp.com>
L: linuxppc-dev@lists.ozlabs.org L: linuxppc-dev@lists.ozlabs.org
S: Maintained S: Maintained
F: drivers/soc/fsl/qe/ F: drivers/soc/fsl/qe/
F: include/soc/fsl/*qe*.h F: include/soc/fsl/qe/
F: include/soc/fsl/*ucc*.h
FREESCALE QUICC ENGINE UCC ETHERNET DRIVER FREESCALE QUICC ENGINE UCC ETHERNET DRIVER
M: Li Yang <leoyang.li@nxp.com> M: Li Yang <leoyang.li@nxp.com>
...@@ -7776,6 +7775,7 @@ F: Documentation/devicetree/bindings/misc/fsl,dpaa2-console.yaml ...@@ -7776,6 +7775,7 @@ F: Documentation/devicetree/bindings/misc/fsl,dpaa2-console.yaml
F: Documentation/devicetree/bindings/soc/fsl/ F: Documentation/devicetree/bindings/soc/fsl/
F: drivers/soc/fsl/ F: drivers/soc/fsl/
F: include/linux/fsl/ F: include/linux/fsl/
F: include/soc/fsl/
FREESCALE SOC FS_ENET DRIVER FREESCALE SOC FS_ENET DRIVER
M: Pantelis Antoniou <pantelis.antoniou@gmail.com> M: Pantelis Antoniou <pantelis.antoniou@gmail.com>
......
...@@ -158,6 +158,24 @@ &mmc3 { ...@@ -158,6 +158,24 @@ &mmc3 {
status = "disabled"; status = "disabled";
}; };
/* Unusable as clockevent because if unreliable oscillator, allow to idle */
&timer1_target {
/delete-property/ti,no-reset-on-init;
/delete-property/ti,no-idle;
timer@0 {
/delete-property/ti,timer-alwon;
};
};
/* Preferred timer for clockevent */
&timer12_target {
ti,no-reset-on-init;
ti,no-idle;
timer@0 {
/* Always clocked by secure_32k_fck */
};
};
&twl_gpio { &twl_gpio {
ti,use-leds; ti,use-leds;
/* /*
......
...@@ -14,36 +14,3 @@ aliases { ...@@ -14,36 +14,3 @@ aliases {
display2 = &tv0; display2 = &tv0;
}; };
}; };
/* Unusable as clocksource because of unreliable oscillator */
&counter32k {
status = "disabled";
};
/* Unusable as clockevent because if unreliable oscillator, allow to idle */
&timer1_target {
/delete-property/ti,no-reset-on-init;
/delete-property/ti,no-idle;
timer@0 {
/delete-property/ti,timer-alwon;
};
};
/* Preferred always-on timer for clocksource */
&timer12_target {
ti,no-reset-on-init;
ti,no-idle;
timer@0 {
/* Always clocked by secure_32k_fck */
};
};
/* Preferred timer for clockevent */
&timer2_target {
ti,no-reset-on-init;
ti,no-idle;
timer@0 {
assigned-clocks = <&gpt2_fck>;
assigned-clock-parents = <&sys_ck>;
};
};
...@@ -718,8 +718,8 @@ hdmi: hdmi@200a0000 { ...@@ -718,8 +718,8 @@ hdmi: hdmi@200a0000 {
interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
assigned-clocks = <&cru SCLK_HDMI_PHY>; assigned-clocks = <&cru SCLK_HDMI_PHY>;
assigned-clock-parents = <&hdmi_phy>; assigned-clock-parents = <&hdmi_phy>;
clocks = <&cru SCLK_HDMI_HDCP>, <&cru PCLK_HDMI_CTRL>, <&cru SCLK_HDMI_CEC>; clocks = <&cru PCLK_HDMI_CTRL>, <&cru SCLK_HDMI_HDCP>, <&cru SCLK_HDMI_CEC>;
clock-names = "isfr", "iahb", "cec"; clock-names = "iahb", "isfr", "cec";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&hdmii2c_xfer &hdmi_hpd &hdmi_cec>; pinctrl-0 = <&hdmii2c_xfer &hdmi_hpd &hdmi_cec>;
resets = <&cru SRST_HDMI_P>; resets = <&cru SRST_HDMI_P>;
......
...@@ -971,7 +971,7 @@ i2s: i2s@ff890000 { ...@@ -971,7 +971,7 @@ i2s: i2s@ff890000 {
status = "disabled"; status = "disabled";
}; };
crypto: cypto-controller@ff8a0000 { crypto: crypto@ff8a0000 {
compatible = "rockchip,rk3288-crypto"; compatible = "rockchip,rk3288-crypto";
reg = <0x0 0xff8a0000 0x0 0x4000>; reg = <0x0 0xff8a0000 0x0 0x4000>;
interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
......
...@@ -13,12 +13,15 @@ / { ...@@ -13,12 +13,15 @@ / {
"google,nyan-big-rev1", "google,nyan-big-rev0", "google,nyan-big-rev1", "google,nyan-big-rev0",
"google,nyan-big", "google,nyan", "nvidia,tegra124"; "google,nyan-big", "google,nyan", "nvidia,tegra124";
panel: panel { host1x@50000000 {
compatible = "auo,b133xtn01"; dpaux@545c0000 {
aux-bus {
power-supply = <&vdd_3v3_panel>; panel: panel {
backlight = <&backlight>; compatible = "auo,b133xtn01";
ddc-i2c-bus = <&dpaux>; backlight = <&backlight>;
};
};
};
}; };
mmc@700b0400 { /* SD Card on this bus */ mmc@700b0400 { /* SD Card on this bus */
......
...@@ -15,12 +15,15 @@ / { ...@@ -15,12 +15,15 @@ / {
"google,nyan-blaze-rev0", "google,nyan-blaze", "google,nyan-blaze-rev0", "google,nyan-blaze",
"google,nyan", "nvidia,tegra124"; "google,nyan", "nvidia,tegra124";
panel: panel { host1x@50000000 {
compatible = "samsung,ltn140at29-301"; dpaux@545c0000 {
aux-bus {
power-supply = <&vdd_3v3_panel>; panel: panel {
backlight = <&backlight>; compatible = "samsung,ltn140at29-301";
ddc-i2c-bus = <&dpaux>; backlight = <&backlight>;
};
};
};
}; };
sound { sound {
......
...@@ -48,6 +48,13 @@ sor@54540000 { ...@@ -48,6 +48,13 @@ sor@54540000 {
dpaux@545c0000 { dpaux@545c0000 {
vdd-supply = <&vdd_3v3_panel>; vdd-supply = <&vdd_3v3_panel>;
status = "okay"; status = "okay";
aux-bus {
panel: panel {
compatible = "lg,lp129qe";
backlight = <&backlight>;
};
};
}; };
}; };
...@@ -1080,13 +1087,6 @@ power { ...@@ -1080,13 +1087,6 @@ power {
}; };
}; };
panel: panel {
compatible = "lg,lp129qe";
power-supply = <&vdd_3v3_panel>;
backlight = <&backlight>;
ddc-i2c-bus = <&dpaux>;
};
vdd_mux: regulator-mux { vdd_mux: regulator-mux {
compatible = "regulator-fixed"; compatible = "regulator-fixed";
regulator-name = "+VDD_MUX"; regulator-name = "+VDD_MUX";
......
...@@ -543,8 +543,7 @@ pcie_ctlr: pcie@40000000 { ...@@ -543,8 +543,7 @@ pcie_ctlr: pcie@40000000 {
<0x02000000 0x00 0x50000000 0x00 0x50000000 0x0 0x08000000>, <0x02000000 0x00 0x50000000 0x00 0x50000000 0x0 0x08000000>,
<0x42000000 0x40 0x00000000 0x40 0x00000000 0x1 0x00000000>; <0x42000000 0x40 0x00000000 0x40 0x00000000 0x1 0x00000000>;
/* Standard AXI Translation entries as programmed by EDK2 */ /* Standard AXI Translation entries as programmed by EDK2 */
dma-ranges = <0x02000000 0x0 0x2c1c0000 0x0 0x2c1c0000 0x0 0x00040000>, dma-ranges = <0x02000000 0x0 0x80000000 0x0 0x80000000 0x0 0x80000000>,
<0x02000000 0x0 0x80000000 0x0 0x80000000 0x0 0x80000000>,
<0x43000000 0x8 0x00000000 0x8 0x00000000 0x2 0x00000000>; <0x43000000 0x8 0x00000000 0x8 0x00000000 0x2 0x00000000>;
#interrupt-cells = <1>; #interrupt-cells = <1>;
interrupt-map-mask = <0 0 0 7>; interrupt-map-mask = <0 0 0 7>;
......
...@@ -707,7 +707,6 @@ pgc_vpumix: power-domain@6 { ...@@ -707,7 +707,6 @@ pgc_vpumix: power-domain@6 {
clocks = <&clk IMX8MM_CLK_VPU_DEC_ROOT>; clocks = <&clk IMX8MM_CLK_VPU_DEC_ROOT>;
assigned-clocks = <&clk IMX8MM_CLK_VPU_BUS>; assigned-clocks = <&clk IMX8MM_CLK_VPU_BUS>;
assigned-clock-parents = <&clk IMX8MM_SYS_PLL1_800M>; assigned-clock-parents = <&clk IMX8MM_SYS_PLL1_800M>;
resets = <&src IMX8MQ_RESET_VPU_RESET>;
}; };
pgc_vpu_g1: power-domain@7 { pgc_vpu_g1: power-domain@7 {
......
...@@ -132,7 +132,7 @@ scmi_devpd: protocol@11 { ...@@ -132,7 +132,7 @@ scmi_devpd: protocol@11 {
scmi_sensor: protocol@15 { scmi_sensor: protocol@15 {
reg = <0x15>; reg = <0x15>;
#thermal-sensor-cells = <0>; #thermal-sensor-cells = <1>;
}; };
}; };
}; };
......
...@@ -502,7 +502,7 @@ uart1: serial@ffc02100 { ...@@ -502,7 +502,7 @@ uart1: serial@ffc02100 {
}; };
usb0: usb@ffb00000 { usb0: usb@ffb00000 {
compatible = "snps,dwc2"; compatible = "intel,socfpga-agilex-hsotg", "snps,dwc2";
reg = <0xffb00000 0x40000>; reg = <0xffb00000 0x40000>;
interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
phys = <&usbphy0>; phys = <&usbphy0>;
...@@ -515,7 +515,7 @@ usb0: usb@ffb00000 { ...@@ -515,7 +515,7 @@ usb0: usb@ffb00000 {
}; };
usb1: usb@ffb40000 { usb1: usb@ffb40000 {
compatible = "snps,dwc2"; compatible = "intel,socfpga-agilex-hsotg", "snps,dwc2";
reg = <0xffb40000 0x40000>; reg = <0xffb40000 0x40000>;
interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
phys = <&usbphy0>; phys = <&usbphy0>;
......
...@@ -711,7 +711,7 @@ rktimer: timer@ff210000 { ...@@ -711,7 +711,7 @@ rktimer: timer@ff210000 {
clock-names = "pclk", "timer"; clock-names = "pclk", "timer";
}; };
dmac: dmac@ff240000 { dmac: dma-controller@ff240000 {
compatible = "arm,pl330", "arm,primecell"; compatible = "arm,pl330", "arm,primecell";
reg = <0x0 0xff240000 0x0 0x4000>; reg = <0x0 0xff240000 0x0 0x4000>;
interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>, interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
......
...@@ -489,7 +489,7 @@ pwm3: pwm@ff1b0030 { ...@@ -489,7 +489,7 @@ pwm3: pwm@ff1b0030 {
status = "disabled"; status = "disabled";
}; };
dmac: dmac@ff1f0000 { dmac: dma-controller@ff1f0000 {
compatible = "arm,pl330", "arm,primecell"; compatible = "arm,pl330", "arm,primecell";
reg = <0x0 0xff1f0000 0x0 0x4000>; reg = <0x0 0xff1f0000 0x0 0x4000>;
interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>, interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
......
...@@ -286,7 +286,7 @@ max98357a: max98357a { ...@@ -286,7 +286,7 @@ max98357a: max98357a {
sound: sound { sound: sound {
compatible = "rockchip,rk3399-gru-sound"; compatible = "rockchip,rk3399-gru-sound";
rockchip,cpu = <&i2s0 &i2s2>; rockchip,cpu = <&i2s0 &spdif>;
}; };
}; };
...@@ -437,10 +437,6 @@ &i2s0 { ...@@ -437,10 +437,6 @@ &i2s0 {
status = "okay"; status = "okay";
}; };
&i2s2 {
status = "okay";
};
&io_domains { &io_domains {
status = "okay"; status = "okay";
...@@ -537,6 +533,17 @@ &sdmmc { ...@@ -537,6 +533,17 @@ &sdmmc {
vqmmc-supply = <&ppvar_sd_card_io>; vqmmc-supply = <&ppvar_sd_card_io>;
}; };
&spdif {
status = "okay";
/*
* SPDIF is routed internally to DP; we either don't use these pins, or
* mux them to something else.
*/
/delete-property/ pinctrl-0;
/delete-property/ pinctrl-names;
};
&spi1 { &spi1 {
status = "okay"; status = "okay";
......
...@@ -232,6 +232,7 @@ &usbdrd3_0 { ...@@ -232,6 +232,7 @@ &usbdrd3_0 {
&usbdrd_dwc3_0 { &usbdrd_dwc3_0 {
dr_mode = "otg"; dr_mode = "otg";
extcon = <&extcon_usb3>;
status = "okay"; status = "okay";
}; };
......
...@@ -25,6 +25,13 @@ module_led: led-0 { ...@@ -25,6 +25,13 @@ module_led: led-0 {
}; };
}; };
extcon_usb3: extcon-usb3 {
compatible = "linux,extcon-usb-gpio";
id-gpio = <&gpio1 RK_PC2 GPIO_ACTIVE_HIGH>;
pinctrl-names = "default";
pinctrl-0 = <&usb3_id>;
};
clkin_gmac: external-gmac-clock { clkin_gmac: external-gmac-clock {
compatible = "fixed-clock"; compatible = "fixed-clock";
clock-frequency = <125000000>; clock-frequency = <125000000>;
...@@ -422,9 +429,22 @@ vcc5v0_host_en: vcc5v0-host-en { ...@@ -422,9 +429,22 @@ vcc5v0_host_en: vcc5v0-host-en {
<4 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>; <4 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;
}; };
}; };
usb3 {
usb3_id: usb3-id {
rockchip,pins =
<1 RK_PC2 RK_FUNC_GPIO &pcfg_pull_none>;
};
};
}; };
&sdhci { &sdhci {
/*
* Signal integrity isn't great at 200MHz but 100MHz has proven stable
* enough.
*/
max-frequency = <100000000>;
bus-width = <8>; bus-width = <8>;
mmc-hs400-1_8v; mmc-hs400-1_8v;
mmc-hs400-enhanced-strobe; mmc-hs400-enhanced-strobe;
......
...@@ -1881,10 +1881,10 @@ hdmi: hdmi@ff940000 { ...@@ -1881,10 +1881,10 @@ hdmi: hdmi@ff940000 {
interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH 0>; interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH 0>;
clocks = <&cru PCLK_HDMI_CTRL>, clocks = <&cru PCLK_HDMI_CTRL>,
<&cru SCLK_HDMI_SFR>, <&cru SCLK_HDMI_SFR>,
<&cru PLL_VPLL>, <&cru SCLK_HDMI_CEC>,
<&cru PCLK_VIO_GRF>, <&cru PCLK_VIO_GRF>,
<&cru SCLK_HDMI_CEC>; <&cru PLL_VPLL>;
clock-names = "iahb", "isfr", "vpll", "grf", "cec"; clock-names = "iahb", "isfr", "cec", "grf", "vpll";
power-domains = <&power RK3399_PD_HDCP>; power-domains = <&power RK3399_PD_HDCP>;
reg-io-width = <4>; reg-io-width = <4>;
rockchip,grf = <&grf>; rockchip,grf = <&grf>;
......
...@@ -285,8 +285,6 @@ regulator-state-mem { ...@@ -285,8 +285,6 @@ regulator-state-mem {
vcc_ddr: DCDC_REG3 { vcc_ddr: DCDC_REG3 {
regulator-always-on; regulator-always-on;
regulator-boot-on; regulator-boot-on;
regulator-min-microvolt = <1100000>;
regulator-max-microvolt = <1100000>;
regulator-initial-mode = <0x2>; regulator-initial-mode = <0x2>;
regulator-name = "vcc_ddr"; regulator-name = "vcc_ddr";
regulator-state-mem { regulator-state-mem {
......
...@@ -32,13 +32,11 @@ gmac0: ethernet@fe2a0000 { ...@@ -32,13 +32,11 @@ gmac0: ethernet@fe2a0000 {
clocks = <&cru SCLK_GMAC0>, <&cru SCLK_GMAC0_RX_TX>, clocks = <&cru SCLK_GMAC0>, <&cru SCLK_GMAC0_RX_TX>,
<&cru SCLK_GMAC0_RX_TX>, <&cru CLK_MAC0_REFOUT>, <&cru SCLK_GMAC0_RX_TX>, <&cru CLK_MAC0_REFOUT>,
<&cru ACLK_GMAC0>, <&cru PCLK_GMAC0>, <&cru ACLK_GMAC0>, <&cru PCLK_GMAC0>,
<&cru SCLK_GMAC0_RX_TX>, <&cru CLK_GMAC0_PTP_REF>, <&cru SCLK_GMAC0_RX_TX>, <&cru CLK_GMAC0_PTP_REF>;
<&cru PCLK_XPCS>;
clock-names = "stmmaceth", "mac_clk_rx", clock-names = "stmmaceth", "mac_clk_rx",
"mac_clk_tx", "clk_mac_refout", "mac_clk_tx", "clk_mac_refout",
"aclk_mac", "pclk_mac", "aclk_mac", "pclk_mac",
"clk_mac_speed", "ptp_ref", "clk_mac_speed", "ptp_ref";
"pclk_xpcs";
resets = <&cru SRST_A_GMAC0>; resets = <&cru SRST_A_GMAC0>;
reset-names = "stmmaceth"; reset-names = "stmmaceth";
rockchip,grf = <&grf>; rockchip,grf = <&grf>;
......
...@@ -651,7 +651,7 @@ &i2s1m0_sdo0 &i2s1m0_sdo1 ...@@ -651,7 +651,7 @@ &i2s1m0_sdo0 &i2s1m0_sdo1
status = "disabled"; status = "disabled";
}; };
dmac0: dmac@fe530000 { dmac0: dma-controller@fe530000 {
compatible = "arm,pl330", "arm,primecell"; compatible = "arm,pl330", "arm,primecell";
reg = <0x0 0xfe530000 0x0 0x4000>; reg = <0x0 0xfe530000 0x0 0x4000>;
interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>, interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>,
...@@ -662,7 +662,7 @@ dmac0: dmac@fe530000 { ...@@ -662,7 +662,7 @@ dmac0: dmac@fe530000 {
#dma-cells = <1>; #dma-cells = <1>;
}; };
dmac1: dmac@fe550000 { dmac1: dma-controller@fe550000 {
compatible = "arm,pl330", "arm,primecell"; compatible = "arm,pl330", "arm,primecell";
reg = <0x0 0xfe550000 0x0 0x4000>; reg = <0x0 0xfe550000 0x0 0x4000>;
interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>, interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>,
......
...@@ -241,8 +241,7 @@ static void __init dmtimer_systimer_assign_alwon(void) ...@@ -241,8 +241,7 @@ static void __init dmtimer_systimer_assign_alwon(void)
bool quirk_unreliable_oscillator = false; bool quirk_unreliable_oscillator = false;
/* Quirk unreliable 32 KiHz oscillator with incomplete dts */ /* Quirk unreliable 32 KiHz oscillator with incomplete dts */
if (of_machine_is_compatible("ti,omap3-beagle-ab4") || if (of_machine_is_compatible("ti,omap3-beagle-ab4")) {
of_machine_is_compatible("timll,omap3-devkit8000")) {
quirk_unreliable_oscillator = true; quirk_unreliable_oscillator = true;
counter_32k = -ENODEV; counter_32k = -ENODEV;
} }
......
...@@ -2112,7 +2112,7 @@ static void __exit scmi_driver_exit(void) ...@@ -2112,7 +2112,7 @@ static void __exit scmi_driver_exit(void)
} }
module_exit(scmi_driver_exit); module_exit(scmi_driver_exit);
MODULE_ALIAS("platform: arm-scmi"); MODULE_ALIAS("platform:arm-scmi");
MODULE_AUTHOR("Sudeep Holla <sudeep.holla@arm.com>"); MODULE_AUTHOR("Sudeep Holla <sudeep.holla@arm.com>");
MODULE_DESCRIPTION("ARM SCMI protocol driver"); MODULE_DESCRIPTION("ARM SCMI protocol driver");
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL v2");
...@@ -28,7 +28,6 @@ struct fsl_soc_die_attr { ...@@ -28,7 +28,6 @@ struct fsl_soc_die_attr {
static struct guts *guts; static struct guts *guts;
static struct soc_device_attribute soc_dev_attr; static struct soc_device_attribute soc_dev_attr;
static struct soc_device *soc_dev; static struct soc_device *soc_dev;
static struct device_node *root;
/* SoC die attribute definition for QorIQ platform */ /* SoC die attribute definition for QorIQ platform */
...@@ -138,7 +137,7 @@ static u32 fsl_guts_get_svr(void) ...@@ -138,7 +137,7 @@ static u32 fsl_guts_get_svr(void)
static int fsl_guts_probe(struct platform_device *pdev) static int fsl_guts_probe(struct platform_device *pdev)
{ {
struct device_node *np = pdev->dev.of_node; struct device_node *root, *np = pdev->dev.of_node;
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
const struct fsl_soc_die_attr *soc_die; const struct fsl_soc_die_attr *soc_die;
const char *machine; const char *machine;
...@@ -159,8 +158,14 @@ static int fsl_guts_probe(struct platform_device *pdev) ...@@ -159,8 +158,14 @@ static int fsl_guts_probe(struct platform_device *pdev)
root = of_find_node_by_path("/"); root = of_find_node_by_path("/");
if (of_property_read_string(root, "model", &machine)) if (of_property_read_string(root, "model", &machine))
of_property_read_string_index(root, "compatible", 0, &machine); of_property_read_string_index(root, "compatible", 0, &machine);
if (machine) if (machine) {
soc_dev_attr.machine = machine; soc_dev_attr.machine = devm_kstrdup(dev, machine, GFP_KERNEL);
if (!soc_dev_attr.machine) {
of_node_put(root);
return -ENOMEM;
}
}
of_node_put(root);
svr = fsl_guts_get_svr(); svr = fsl_guts_get_svr();
soc_die = fsl_soc_die_match(svr, fsl_soc_die); soc_die = fsl_soc_die_match(svr, fsl_soc_die);
...@@ -195,7 +200,6 @@ static int fsl_guts_probe(struct platform_device *pdev) ...@@ -195,7 +200,6 @@ static int fsl_guts_probe(struct platform_device *pdev)
static int fsl_guts_remove(struct platform_device *dev) static int fsl_guts_remove(struct platform_device *dev)
{ {
soc_device_unregister(soc_dev); soc_device_unregister(soc_dev);
of_node_put(root);
return 0; return 0;
} }
......
...@@ -147,7 +147,7 @@ EXPORT_SYMBOL(qe_issue_cmd); ...@@ -147,7 +147,7 @@ EXPORT_SYMBOL(qe_issue_cmd);
* memory mapped space. * memory mapped space.
* The BRG clock is the QE clock divided by 2. * The BRG clock is the QE clock divided by 2.
* It was set up long ago during the initial boot phase and is * It was set up long ago during the initial boot phase and is
* is given to us. * given to us.
* Baud rate clocks are zero-based in the driver code (as that maps * Baud rate clocks are zero-based in the driver code (as that maps
* to port numbers). Documentation uses 1-based numbering. * to port numbers). Documentation uses 1-based numbering.
*/ */
...@@ -421,7 +421,7 @@ static void qe_upload_microcode(const void *base, ...@@ -421,7 +421,7 @@ static void qe_upload_microcode(const void *base,
for (i = 0; i < be32_to_cpu(ucode->count); i++) for (i = 0; i < be32_to_cpu(ucode->count); i++)
iowrite32be(be32_to_cpu(code[i]), &qe_immr->iram.idata); iowrite32be(be32_to_cpu(code[i]), &qe_immr->iram.idata);
/* Set I-RAM Ready Register */ /* Set I-RAM Ready Register */
iowrite32be(QE_IRAM_READY, &qe_immr->iram.iready); iowrite32be(QE_IRAM_READY, &qe_immr->iram.iready);
} }
......
...@@ -35,6 +35,8 @@ int par_io_init(struct device_node *np) ...@@ -35,6 +35,8 @@ int par_io_init(struct device_node *np)
if (ret) if (ret)
return ret; return ret;
par_io = ioremap(res.start, resource_size(&res)); par_io = ioremap(res.start, resource_size(&res));
if (!par_io)
return -ENOMEM;
if (!of_property_read_u32(np, "num-ports", &num_ports)) if (!of_property_read_u32(np, "num-ports", &num_ports))
num_par_io_ports = num_ports; num_par_io_ports = num_ports;
......
...@@ -382,7 +382,8 @@ static int imx_pgc_power_down(struct generic_pm_domain *genpd) ...@@ -382,7 +382,8 @@ static int imx_pgc_power_down(struct generic_pm_domain *genpd)
return 0; return 0;
out_clk_disable: out_clk_disable:
clk_bulk_disable_unprepare(domain->num_clks, domain->clks); if (!domain->keep_clocks)
clk_bulk_disable_unprepare(domain->num_clks, domain->clks);
return ret; return ret;
} }
......
...@@ -869,8 +869,10 @@ static int optee_ffa_probe(struct ffa_device *ffa_dev) ...@@ -869,8 +869,10 @@ static int optee_ffa_probe(struct ffa_device *ffa_dev)
optee_supp_init(&optee->supp); optee_supp_init(&optee->supp);
ffa_dev_set_drvdata(ffa_dev, optee); ffa_dev_set_drvdata(ffa_dev, optee);
ctx = teedev_open(optee->teedev); ctx = teedev_open(optee->teedev);
if (IS_ERR(ctx)) if (IS_ERR(ctx)) {
rc = PTR_ERR(ctx);
goto err_rhashtable_free; goto err_rhashtable_free;
}
optee->ctx = ctx; optee->ctx = ctx;
rc = optee_notif_init(optee, OPTEE_DEFAULT_MAX_NOTIF_VALUE); rc = optee_notif_init(optee, OPTEE_DEFAULT_MAX_NOTIF_VALUE);
if (rc) if (rc)
......
...@@ -1417,8 +1417,10 @@ static int optee_probe(struct platform_device *pdev) ...@@ -1417,8 +1417,10 @@ static int optee_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, optee); platform_set_drvdata(pdev, optee);
ctx = teedev_open(optee->teedev); ctx = teedev_open(optee->teedev);
if (IS_ERR(ctx)) if (IS_ERR(ctx)) {
rc = PTR_ERR(ctx);
goto err_supp_uninit; goto err_supp_uninit;
}
optee->ctx = ctx; optee->ctx = ctx;
rc = optee_notif_init(optee, max_notif_value); rc = optee_notif_init(optee, max_notif_value);
if (rc) if (rc)
......
...@@ -7,7 +7,8 @@ ...@@ -7,7 +7,8 @@
#ifndef __FSL_DPAA2_FD_H #ifndef __FSL_DPAA2_FD_H
#define __FSL_DPAA2_FD_H #define __FSL_DPAA2_FD_H
#include <linux/kernel.h> #include <linux/byteorder/generic.h>
#include <linux/types.h>
/** /**
* DOC: DPAA2 FD - Frame Descriptor APIs for DPAA2 * DOC: DPAA2 FD - Frame Descriptor APIs for DPAA2
......
...@@ -13,7 +13,8 @@ ...@@ -13,7 +13,8 @@
#define _ASM_POWERPC_IMMAP_QE_H #define _ASM_POWERPC_IMMAP_QE_H
#ifdef __KERNEL__ #ifdef __KERNEL__
#include <linux/kernel.h> #include <linux/types.h>
#include <asm/io.h> #include <asm/io.h>
#define QE_IMMAP_SIZE (1024 * 1024) /* 1MB from 1MB+IMMR */ #define QE_IMMAP_SIZE (1024 * 1024) /* 1MB from 1MB+IMMR */
......
...@@ -10,8 +10,8 @@ ...@@ -10,8 +10,8 @@
#ifndef _QE_TDM_H_ #ifndef _QE_TDM_H_
#define _QE_TDM_H_ #define _QE_TDM_H_
#include <linux/kernel.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/types.h>
#include <soc/fsl/qe/immap_qe.h> #include <soc/fsl/qe/immap_qe.h>
#include <soc/fsl/qe/qe.h> #include <soc/fsl/qe/qe.h>
...@@ -19,6 +19,8 @@ ...@@ -19,6 +19,8 @@
#include <soc/fsl/qe/ucc.h> #include <soc/fsl/qe/ucc.h>
#include <soc/fsl/qe/ucc_fast.h> #include <soc/fsl/qe/ucc_fast.h>
struct device_node;
/* SI RAM entries */ /* SI RAM entries */
#define SIR_LAST 0x0001 #define SIR_LAST 0x0001
#define SIR_BYTE 0x0002 #define SIR_BYTE 0x0002
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
#ifndef __UCC_FAST_H__ #ifndef __UCC_FAST_H__
#define __UCC_FAST_H__ #define __UCC_FAST_H__
#include <linux/kernel.h> #include <linux/types.h>
#include <soc/fsl/qe/immap_qe.h> #include <soc/fsl/qe/immap_qe.h>
#include <soc/fsl/qe/qe.h> #include <soc/fsl/qe/qe.h>
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
#ifndef __UCC_SLOW_H__ #ifndef __UCC_SLOW_H__
#define __UCC_SLOW_H__ #define __UCC_SLOW_H__
#include <linux/kernel.h> #include <linux/types.h>
#include <soc/fsl/qe/immap_qe.h> #include <soc/fsl/qe/immap_qe.h>
#include <soc/fsl/qe/qe.h> #include <soc/fsl/qe/qe.h>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment