Commit ec351c8f authored by Linus Torvalds's avatar Linus Torvalds

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

Pull ARM SoC fixes from Arnd Bergmann:
 "A couple of platforms get a lone dts fix each:

   - SoCFPGA: Fix incorrect I2C property for SCL signal

   - Renesas: Fix interrupt names for MTU3 channels on RZ/G2L and
     RZ/V2L.

   - Juno/Vexpress: remove a dangling symlink

   - at91: sam9x60 SoC detection compatible strings

   - nspire: Fix arm primecell compatible string

  On the NXP i.MX platform, there multiple issues that get addressed:

   - A couple of ARM DTS fixes for i.MX6SLL usbphy and supported CPU
     frequency of sk-imx53 board

   - Add missing pull-up for imx8mn-var-som onboard PHY reset pinmux

   - A couple of imx8mm-venice fixes from Tim Harvey to diable
     disp_blk_ctrl

   - A couple of phycore-imx8mm fixes from Yashwanth Varakala to correct
     VPU label and gpio-line-names

   - Fix imx8mp-blk-ctrl driver to register HSIO PLL clock as
     bus_power_dev child, so that runtime PM can translate into the
     necessary GPC power domain action

  On the driver side, there are two fixes for tegra memory controller
  drivers addressing regressions from the merge window, a couple of
  minor correctness fixes for SCMI and SMCCC firmware, as well as a
  build fix for an lcd backlight driver"

* tag 'soc-fixes-6.5-2' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc: (22 commits)
  backlight: corgi_lcd: fix missing prototype
  memory: tegra: make icc_set_bw return zero if BWMGR not supported
  arm64: dts: renesas: rzg2l: Update overfow/underflow IRQ names for MTU3 channels
  dt-bindings: serial: atmel,at91-usart: update compatible for sam9x60
  ARM: dts: at91: sam9x60: fix the SOC detection
  ARM: dts: nspire: Fix arm primecell compatible string
  firmware: arm_scmi: Fix chan_free cleanup on SMC
  firmware: arm_scmi: Drop OF node reference in the transport channel setup
  soc: imx: imx8mp-blk-ctrl: register HSIO PLL clock as bus_power_dev child
  ARM: dts: nxp/imx: limit sk-imx53 supported frequencies
  firmware: arm_scmi: Fix signed error return values handling
  firmware: smccc: Fix use of uninitialised results structure
  arm64: dts: freescale: Fix VPU G2 clock
  arm64: dts: imx8mn-var-som: add missing pull-up for onboard PHY reset pinmux
  arm64: dts: phycore-imx8mm: Correction in gpio-line-names
  arm64: dts: phycore-imx8mm: Label typo-fix of VPU
  ARM: dts: nxp/imx6sll: fix wrong property name in usbphy node
  arm64: dts: imx8mm-venice-gw7904: disable disp_blk_ctrl
  arm64: dts: imx8mm-venice-gw7903: disable disp_blk_ctrl
  arm64: dts: arm: Remove the dangling vexpress-v2m-rs1.dtsi symlink
  ...
parents a4e98a30 d21afb09
...@@ -16,13 +16,15 @@ properties: ...@@ -16,13 +16,15 @@ properties:
- enum: - enum:
- atmel,at91rm9200-usart - atmel,at91rm9200-usart
- atmel,at91sam9260-usart - atmel,at91sam9260-usart
- microchip,sam9x60-usart
- items: - items:
- const: atmel,at91rm9200-dbgu - const: atmel,at91rm9200-dbgu
- const: atmel,at91rm9200-usart - const: atmel,at91rm9200-usart
- items: - items:
- const: atmel,at91sam9260-dbgu - const: atmel,at91sam9260-dbgu
- const: atmel,at91sam9260-usart - const: atmel,at91sam9260-usart
- items:
- const: microchip,sam9x60-usart
- const: atmel,at91sam9260-usart
- items: - items:
- const: microchip,sam9x60-dbgu - const: microchip,sam9x60-dbgu
- const: microchip,sam9x60-usart - const: microchip,sam9x60-usart
......
...@@ -172,7 +172,7 @@ flx4: flexcom@f0000000 { ...@@ -172,7 +172,7 @@ flx4: flexcom@f0000000 {
status = "disabled"; status = "disabled";
uart4: serial@200 { uart4: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <13 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <13 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -240,7 +240,7 @@ flx5: flexcom@f0004000 { ...@@ -240,7 +240,7 @@ flx5: flexcom@f0004000 {
status = "disabled"; status = "disabled";
uart5: serial@200 { uart5: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
atmel,usart-mode = <AT91_USART_MODE_SERIAL>; atmel,usart-mode = <AT91_USART_MODE_SERIAL>;
interrupts = <14 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <14 IRQ_TYPE_LEVEL_HIGH 7>;
...@@ -370,7 +370,7 @@ flx11: flexcom@f0020000 { ...@@ -370,7 +370,7 @@ flx11: flexcom@f0020000 {
status = "disabled"; status = "disabled";
uart11: serial@200 { uart11: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <32 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <32 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -419,7 +419,7 @@ flx12: flexcom@f0024000 { ...@@ -419,7 +419,7 @@ flx12: flexcom@f0024000 {
status = "disabled"; status = "disabled";
uart12: serial@200 { uart12: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <33 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <33 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -576,7 +576,7 @@ flx6: flexcom@f8010000 { ...@@ -576,7 +576,7 @@ flx6: flexcom@f8010000 {
status = "disabled"; status = "disabled";
uart6: serial@200 { uart6: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <9 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <9 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -625,7 +625,7 @@ flx7: flexcom@f8014000 { ...@@ -625,7 +625,7 @@ flx7: flexcom@f8014000 {
status = "disabled"; status = "disabled";
uart7: serial@200 { uart7: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <10 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <10 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -674,7 +674,7 @@ flx8: flexcom@f8018000 { ...@@ -674,7 +674,7 @@ flx8: flexcom@f8018000 {
status = "disabled"; status = "disabled";
uart8: serial@200 { uart8: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <11 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <11 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -723,7 +723,7 @@ flx0: flexcom@f801c000 { ...@@ -723,7 +723,7 @@ flx0: flexcom@f801c000 {
status = "disabled"; status = "disabled";
uart0: serial@200 { uart0: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <5 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <5 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -791,7 +791,7 @@ flx1: flexcom@f8020000 { ...@@ -791,7 +791,7 @@ flx1: flexcom@f8020000 {
status = "disabled"; status = "disabled";
uart1: serial@200 { uart1: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <6 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <6 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -859,7 +859,7 @@ flx2: flexcom@f8024000 { ...@@ -859,7 +859,7 @@ flx2: flexcom@f8024000 {
status = "disabled"; status = "disabled";
uart2: serial@200 { uart2: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <7 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <7 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -927,7 +927,7 @@ flx3: flexcom@f8028000 { ...@@ -927,7 +927,7 @@ flx3: flexcom@f8028000 {
status = "disabled"; status = "disabled";
uart3: serial@200 { uart3: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <8 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <8 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -1050,7 +1050,7 @@ flx9: flexcom@f8040000 { ...@@ -1050,7 +1050,7 @@ flx9: flexcom@f8040000 {
status = "disabled"; status = "disabled";
uart9: serial@200 { uart9: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <15 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <15 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
...@@ -1099,7 +1099,7 @@ flx10: flexcom@f8044000 { ...@@ -1099,7 +1099,7 @@ flx10: flexcom@f8044000 {
status = "disabled"; status = "disabled";
uart10: serial@200 { uart10: serial@200 {
compatible = "microchip,sam9x60-dbgu", "microchip,sam9x60-usart", "atmel,at91sam9260-dbgu", "atmel,at91sam9260-usart"; compatible = "microchip,sam9x60-usart", "atmel,at91sam9260-usart";
reg = <0x200 0x200>; reg = <0x200 0x200>;
interrupts = <16 IRQ_TYPE_LEVEL_HIGH 7>; interrupts = <16 IRQ_TYPE_LEVEL_HIGH 7>;
dmas = <&dma0 dmas = <&dma0
......
...@@ -161,7 +161,7 @@ timer1: timer@900d0000 { ...@@ -161,7 +161,7 @@ timer1: timer@900d0000 {
}; };
watchdog: watchdog@90060000 { watchdog: watchdog@90060000 {
compatible = "arm,amba-primecell"; compatible = "arm,primecell";
reg = <0x90060000 0x1000>; reg = <0x90060000 0x1000>;
interrupts = <3>; interrupts = <3>;
}; };
......
...@@ -60,6 +60,16 @@ &can1 { ...@@ -60,6 +60,16 @@ &can1 {
status = "okay"; status = "okay";
}; };
&cpu0 {
/* CPU rated to 800 MHz, not the default 1.2GHz. */
operating-points = <
/* kHz uV */
166666 850000
400000 900000
800000 1050000
>;
};
&ecspi1 { &ecspi1 {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_ecspi1>; pinctrl-0 = <&pinctrl_ecspi1>;
......
...@@ -552,7 +552,7 @@ usbphy2: usb-phy@20ca000 { ...@@ -552,7 +552,7 @@ usbphy2: usb-phy@20ca000 {
reg = <0x020ca000 0x1000>; reg = <0x020ca000 0x1000>;
interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&clks IMX6SLL_CLK_USBPHY2>; clocks = <&clks IMX6SLL_CLK_USBPHY2>;
phy-reg_3p0-supply = <&reg_3p0>; phy-3p0-supply = <&reg_3p0>;
fsl,anatop = <&anatop>; fsl,anatop = <&anatop>;
}; };
......
...@@ -105,5 +105,4 @@ void sharpsl_pm_led(int val); ...@@ -105,5 +105,4 @@ void sharpsl_pm_led(int val);
#define MAX1111_ACIN_VOLT 6u #define MAX1111_ACIN_VOLT 6u
int sharpsl_pm_pxa_read_max1111(int channel); int sharpsl_pm_pxa_read_max1111(int channel);
void corgi_lcd_limit_intensity(int limit);
#endif #endif
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/apm-emulation.h> #include <linux/apm-emulation.h>
#include <linux/spi/corgi_lcd.h>
#include <asm/irq.h> #include <asm/irq.h>
#include <asm/mach-types.h> #include <asm/mach-types.h>
......
...@@ -145,7 +145,7 @@ &i2c1 { ...@@ -145,7 +145,7 @@ &i2c1 {
status = "okay"; status = "okay";
clock-frequency = <100000>; clock-frequency = <100000>;
i2c-sda-falling-time-ns = <890>; /* hcnt */ i2c-sda-falling-time-ns = <890>; /* hcnt */
i2c-sdl-falling-time-ns = <890>; /* lcnt */ i2c-scl-falling-time-ns = <890>; /* lcnt */
pinctrl-names = "default", "gpio"; pinctrl-names = "default", "gpio";
pinctrl-0 = <&i2c1_pmx_func>; pinctrl-0 = <&i2c1_pmx_func>;
......
...@@ -141,7 +141,7 @@ &i2c2 { ...@@ -141,7 +141,7 @@ &i2c2 {
status = "okay"; status = "okay";
clock-frequency = <100000>; clock-frequency = <100000>;
i2c-sda-falling-time-ns = <890>; /* hcnt */ i2c-sda-falling-time-ns = <890>; /* hcnt */
i2c-sdl-falling-time-ns = <890>; /* lcnt */ i2c-scl-falling-time-ns = <890>; /* lcnt */
adc@14 { adc@14 {
compatible = "lltc,ltc2497"; compatible = "lltc,ltc2497";
......
../../../../arm/boot/dts/vexpress-v2m-rs1.dtsi
\ No newline at end of file
...@@ -141,7 +141,7 @@ can0: can@0 { ...@@ -141,7 +141,7 @@ can0: can@0 {
}; };
&gpio1 { &gpio1 {
gpio-line-names = "nINT_ETHPHY", "LED_RED", "WDOG_INT", "X_RTC_INT", gpio-line-names = "", "LED_RED", "WDOG_INT", "X_RTC_INT",
"", "", "", "RESET_ETHPHY", "", "", "", "RESET_ETHPHY",
"CAN_nINT", "CAN_EN", "nENABLE_FLATLINK", "", "CAN_nINT", "CAN_EN", "nENABLE_FLATLINK", "",
"USB_OTG_VBUS_EN", "", "LED_GREEN", "LED_BLUE"; "USB_OTG_VBUS_EN", "", "LED_GREEN", "LED_BLUE";
......
...@@ -111,7 +111,7 @@ som_flash: flash@0 { ...@@ -111,7 +111,7 @@ som_flash: flash@0 {
}; };
&gpio1 { &gpio1 {
gpio-line-names = "nINT_ETHPHY", "", "WDOG_INT", "X_RTC_INT", gpio-line-names = "", "", "WDOG_INT", "X_RTC_INT",
"", "", "", "RESET_ETHPHY", "", "", "", "RESET_ETHPHY",
"", "", "nENABLE_FLATLINK"; "", "", "nENABLE_FLATLINK";
}; };
...@@ -210,7 +210,7 @@ regulator-state-mem { ...@@ -210,7 +210,7 @@ regulator-state-mem {
}; };
}; };
reg_vdd_gpu: buck3 { reg_vdd_vpu: buck3 {
regulator-always-on; regulator-always-on;
regulator-boot-on; regulator-boot-on;
regulator-max-microvolt = <1000000>; regulator-max-microvolt = <1000000>;
......
...@@ -567,6 +567,10 @@ &pcie0 { ...@@ -567,6 +567,10 @@ &pcie0 {
status = "okay"; status = "okay";
}; };
&disp_blk_ctrl {
status = "disabled";
};
&pgc_mipi { &pgc_mipi {
status = "disabled"; status = "disabled";
}; };
......
...@@ -628,6 +628,10 @@ &pcie0 { ...@@ -628,6 +628,10 @@ &pcie0 {
status = "okay"; status = "okay";
}; };
&disp_blk_ctrl {
status = "disabled";
};
&pgc_mipi { &pgc_mipi {
status = "disabled"; status = "disabled";
}; };
......
...@@ -358,7 +358,7 @@ MX8MN_IOMUXC_ENET_TXC_ENET1_RGMII_TXC 0x1f ...@@ -358,7 +358,7 @@ MX8MN_IOMUXC_ENET_TXC_ENET1_RGMII_TXC 0x1f
MX8MN_IOMUXC_ENET_RXC_ENET1_RGMII_RXC 0x91 MX8MN_IOMUXC_ENET_RXC_ENET1_RGMII_RXC 0x91
MX8MN_IOMUXC_ENET_RX_CTL_ENET1_RGMII_RX_CTL 0x91 MX8MN_IOMUXC_ENET_RX_CTL_ENET1_RGMII_RX_CTL 0x91
MX8MN_IOMUXC_ENET_TX_CTL_ENET1_RGMII_TX_CTL 0x1f MX8MN_IOMUXC_ENET_TX_CTL_ENET1_RGMII_TX_CTL 0x1f
MX8MN_IOMUXC_GPIO1_IO09_GPIO1_IO9 0x19 MX8MN_IOMUXC_GPIO1_IO09_GPIO1_IO9 0x159
>; >;
}; };
......
...@@ -772,7 +772,7 @@ pgc_vpu: power-domain@6 { ...@@ -772,7 +772,7 @@ pgc_vpu: power-domain@6 {
<&clk IMX8MQ_SYS1_PLL_800M>, <&clk IMX8MQ_SYS1_PLL_800M>,
<&clk IMX8MQ_VPU_PLL>; <&clk IMX8MQ_VPU_PLL>;
assigned-clock-rates = <600000000>, assigned-clock-rates = <600000000>,
<600000000>, <300000000>,
<800000000>, <800000000>,
<0>; <0>;
}; };
......
...@@ -223,20 +223,20 @@ mtu3: timer@10001200 { ...@@ -223,20 +223,20 @@ mtu3: timer@10001200 {
<GIC_SPI 212 IRQ_TYPE_EDGE_RISING>, <GIC_SPI 212 IRQ_TYPE_EDGE_RISING>,
<GIC_SPI 213 IRQ_TYPE_EDGE_RISING>; <GIC_SPI 213 IRQ_TYPE_EDGE_RISING>;
interrupt-names = "tgia0", "tgib0", "tgic0", "tgid0", interrupt-names = "tgia0", "tgib0", "tgic0", "tgid0",
"tgiv0", "tgie0", "tgif0", "tciv0", "tgie0", "tgif0",
"tgia1", "tgib1", "tgiv1", "tgiu1", "tgia1", "tgib1", "tciv1", "tciu1",
"tgia2", "tgib2", "tgiv2", "tgiu2", "tgia2", "tgib2", "tciv2", "tciu2",
"tgia3", "tgib3", "tgic3", "tgid3", "tgia3", "tgib3", "tgic3", "tgid3",
"tgiv3", "tciv3",
"tgia4", "tgib4", "tgic4", "tgid4", "tgia4", "tgib4", "tgic4", "tgid4",
"tgiv4", "tciv4",
"tgiu5", "tgiv5", "tgiw5", "tgiu5", "tgiv5", "tgiw5",
"tgia6", "tgib6", "tgic6", "tgid6", "tgia6", "tgib6", "tgic6", "tgid6",
"tgiv6", "tciv6",
"tgia7", "tgib7", "tgic7", "tgid7", "tgia7", "tgib7", "tgic7", "tgid7",
"tgiv7", "tciv7",
"tgia8", "tgib8", "tgic8", "tgid8", "tgia8", "tgib8", "tgic8", "tgid8",
"tgiv8", "tgiu8"; "tciv8", "tciu8";
clocks = <&cpg CPG_MOD R9A07G044_MTU_X_MCK_MTU3>; clocks = <&cpg CPG_MOD R9A07G044_MTU_X_MCK_MTU3>;
power-domains = <&cpg>; power-domains = <&cpg>;
resets = <&cpg R9A07G044_MTU_X_PRESET_MTU3>; resets = <&cpg R9A07G044_MTU_X_PRESET_MTU3>;
......
...@@ -223,20 +223,20 @@ mtu3: timer@10001200 { ...@@ -223,20 +223,20 @@ mtu3: timer@10001200 {
<GIC_SPI 212 IRQ_TYPE_EDGE_RISING>, <GIC_SPI 212 IRQ_TYPE_EDGE_RISING>,
<GIC_SPI 213 IRQ_TYPE_EDGE_RISING>; <GIC_SPI 213 IRQ_TYPE_EDGE_RISING>;
interrupt-names = "tgia0", "tgib0", "tgic0", "tgid0", interrupt-names = "tgia0", "tgib0", "tgic0", "tgid0",
"tgiv0", "tgie0", "tgif0", "tciv0", "tgie0", "tgif0",
"tgia1", "tgib1", "tgiv1", "tgiu1", "tgia1", "tgib1", "tciv1", "tciu1",
"tgia2", "tgib2", "tgiv2", "tgiu2", "tgia2", "tgib2", "tciv2", "tciu2",
"tgia3", "tgib3", "tgic3", "tgid3", "tgia3", "tgib3", "tgic3", "tgid3",
"tgiv3", "tciv3",
"tgia4", "tgib4", "tgic4", "tgid4", "tgia4", "tgib4", "tgic4", "tgid4",
"tgiv4", "tciv4",
"tgiu5", "tgiv5", "tgiw5", "tgiu5", "tgiv5", "tgiw5",
"tgia6", "tgib6", "tgic6", "tgid6", "tgia6", "tgib6", "tgic6", "tgid6",
"tgiv6", "tciv6",
"tgia7", "tgib7", "tgic7", "tgid7", "tgia7", "tgib7", "tgic7", "tgid7",
"tgiv7", "tciv7",
"tgia8", "tgib8", "tgic8", "tgid8", "tgia8", "tgib8", "tgic8", "tgid8",
"tgiv8", "tgiu8"; "tciv8", "tciu8";
clocks = <&cpg CPG_MOD R9A07G054_MTU_X_MCK_MTU3>; clocks = <&cpg CPG_MOD R9A07G054_MTU_X_MCK_MTU3>;
power-domains = <&cpg>; power-domains = <&cpg>;
resets = <&cpg R9A07G054_MTU_X_PRESET_MTU3>; resets = <&cpg R9A07G054_MTU_X_PRESET_MTU3>;
......
...@@ -166,8 +166,10 @@ static int mailbox_chan_setup(struct scmi_chan_info *cinfo, struct device *dev, ...@@ -166,8 +166,10 @@ static int mailbox_chan_setup(struct scmi_chan_info *cinfo, struct device *dev,
return -ENOMEM; return -ENOMEM;
shmem = of_parse_phandle(cdev->of_node, "shmem", idx); shmem = of_parse_phandle(cdev->of_node, "shmem", idx);
if (!of_device_is_compatible(shmem, "arm,scmi-shmem")) if (!of_device_is_compatible(shmem, "arm,scmi-shmem")) {
of_node_put(shmem);
return -ENXIO; return -ENXIO;
}
ret = of_address_to_resource(shmem, 0, &res); ret = of_address_to_resource(shmem, 0, &res);
of_node_put(shmem); of_node_put(shmem);
......
...@@ -818,10 +818,13 @@ static ssize_t scmi_dbg_raw_mode_common_write(struct file *filp, ...@@ -818,10 +818,13 @@ static ssize_t scmi_dbg_raw_mode_common_write(struct file *filp,
* before sending it with a single RAW xfer. * before sending it with a single RAW xfer.
*/ */
if (rd->tx_size < rd->tx_req_size) { if (rd->tx_size < rd->tx_req_size) {
size_t cnt; ssize_t cnt;
cnt = simple_write_to_buffer(rd->tx.buf, rd->tx.len, ppos, cnt = simple_write_to_buffer(rd->tx.buf, rd->tx.len, ppos,
buf, count); buf, count);
if (cnt < 0)
return cnt;
rd->tx_size += cnt; rd->tx_size += cnt;
if (cnt < count) if (cnt < count)
return cnt; return cnt;
......
...@@ -40,6 +40,7 @@ ...@@ -40,6 +40,7 @@
/** /**
* struct scmi_smc - Structure representing a SCMI smc transport * struct scmi_smc - Structure representing a SCMI smc transport
* *
* @irq: An optional IRQ for completion
* @cinfo: SCMI channel info * @cinfo: SCMI channel info
* @shmem: Transmit/Receive shared memory area * @shmem: Transmit/Receive shared memory area
* @shmem_lock: Lock to protect access to Tx/Rx shared memory area. * @shmem_lock: Lock to protect access to Tx/Rx shared memory area.
...@@ -52,6 +53,7 @@ ...@@ -52,6 +53,7 @@
*/ */
struct scmi_smc { struct scmi_smc {
int irq;
struct scmi_chan_info *cinfo; struct scmi_chan_info *cinfo;
struct scmi_shared_mem __iomem *shmem; struct scmi_shared_mem __iomem *shmem;
/* Protect access to shmem area */ /* Protect access to shmem area */
...@@ -127,7 +129,7 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev, ...@@ -127,7 +129,7 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev,
struct resource res; struct resource res;
struct device_node *np; struct device_node *np;
u32 func_id; u32 func_id;
int ret, irq; int ret;
if (!tx) if (!tx)
return -ENODEV; return -ENODEV;
...@@ -137,8 +139,10 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev, ...@@ -137,8 +139,10 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev,
return -ENOMEM; return -ENOMEM;
np = of_parse_phandle(cdev->of_node, "shmem", 0); np = of_parse_phandle(cdev->of_node, "shmem", 0);
if (!of_device_is_compatible(np, "arm,scmi-shmem")) if (!of_device_is_compatible(np, "arm,scmi-shmem")) {
of_node_put(np);
return -ENXIO; return -ENXIO;
}
ret = of_address_to_resource(np, 0, &res); ret = of_address_to_resource(np, 0, &res);
of_node_put(np); of_node_put(np);
...@@ -167,11 +171,10 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev, ...@@ -167,11 +171,10 @@ static int smc_chan_setup(struct scmi_chan_info *cinfo, struct device *dev,
* completion of a message is signaled by an interrupt rather than by * completion of a message is signaled by an interrupt rather than by
* the return of the SMC call. * the return of the SMC call.
*/ */
irq = of_irq_get_byname(cdev->of_node, "a2p"); scmi_info->irq = of_irq_get_byname(cdev->of_node, "a2p");
if (irq > 0) { if (scmi_info->irq > 0) {
ret = devm_request_irq(dev, irq, smc_msg_done_isr, ret = request_irq(scmi_info->irq, smc_msg_done_isr,
IRQF_NO_SUSPEND, IRQF_NO_SUSPEND, dev_name(dev), scmi_info);
dev_name(dev), scmi_info);
if (ret) { if (ret) {
dev_err(dev, "failed to setup SCMI smc irq\n"); dev_err(dev, "failed to setup SCMI smc irq\n");
return ret; return ret;
...@@ -193,6 +196,10 @@ static int smc_chan_free(int id, void *p, void *data) ...@@ -193,6 +196,10 @@ static int smc_chan_free(int id, void *p, void *data)
struct scmi_chan_info *cinfo = p; struct scmi_chan_info *cinfo = p;
struct scmi_smc *scmi_info = cinfo->transport_info; struct scmi_smc *scmi_info = cinfo->transport_info;
/* Ignore any possible further reception on the IRQ path */
if (scmi_info->irq > 0)
free_irq(scmi_info->irq, scmi_info);
cinfo->transport_info = NULL; cinfo->transport_info = NULL;
scmi_info->cinfo = NULL; scmi_info->cinfo = NULL;
......
...@@ -34,7 +34,6 @@ static struct soc_device_attribute *soc_dev_attr; ...@@ -34,7 +34,6 @@ static struct soc_device_attribute *soc_dev_attr;
static int __init smccc_soc_init(void) static int __init smccc_soc_init(void)
{ {
struct arm_smccc_res res;
int soc_id_rev, soc_id_version; int soc_id_rev, soc_id_version;
static char soc_id_str[20], soc_id_rev_str[12]; static char soc_id_str[20], soc_id_rev_str[12];
static char soc_id_jep106_id_str[12]; static char soc_id_jep106_id_str[12];
...@@ -49,13 +48,13 @@ static int __init smccc_soc_init(void) ...@@ -49,13 +48,13 @@ static int __init smccc_soc_init(void)
} }
if (soc_id_version < 0) { if (soc_id_version < 0) {
pr_err("ARCH_SOC_ID(0) returned error: %lx\n", res.a0); pr_err("Invalid SoC Version: %x\n", soc_id_version);
return -EINVAL; return -EINVAL;
} }
soc_id_rev = arm_smccc_get_soc_id_revision(); soc_id_rev = arm_smccc_get_soc_id_revision();
if (soc_id_rev < 0) { if (soc_id_rev < 0) {
pr_err("ARCH_SOC_ID(1) returned error: %lx\n", res.a0); pr_err("Invalid SoC Revision: %x\n", soc_id_rev);
return -EINVAL; return -EINVAL;
} }
......
...@@ -755,6 +755,43 @@ const char *const tegra_mc_error_names[8] = { ...@@ -755,6 +755,43 @@ const char *const tegra_mc_error_names[8] = {
[6] = "SMMU translation error", [6] = "SMMU translation error",
}; };
struct icc_node *tegra_mc_icc_xlate(struct of_phandle_args *spec, void *data)
{
struct tegra_mc *mc = icc_provider_to_tegra_mc(data);
struct icc_node *node;
list_for_each_entry(node, &mc->provider.nodes, node_list) {
if (node->id == spec->args[0])
return node;
}
/*
* If a client driver calls devm_of_icc_get() before the MC driver
* is probed, then return EPROBE_DEFER to the client driver.
*/
return ERR_PTR(-EPROBE_DEFER);
}
static int tegra_mc_icc_get(struct icc_node *node, u32 *average, u32 *peak)
{
*average = 0;
*peak = 0;
return 0;
}
static int tegra_mc_icc_set(struct icc_node *src, struct icc_node *dst)
{
return 0;
}
const struct tegra_mc_icc_ops tegra_mc_icc_ops = {
.xlate = tegra_mc_icc_xlate,
.aggregate = icc_std_aggregate,
.get_bw = tegra_mc_icc_get,
.set = tegra_mc_icc_set,
};
/* /*
* Memory Controller (MC) has few Memory Clients that are issuing memory * Memory Controller (MC) has few Memory Clients that are issuing memory
* bandwidth allocation requests to the MC interconnect provider. The MC * bandwidth allocation requests to the MC interconnect provider. The MC
......
...@@ -1355,6 +1355,7 @@ const struct tegra_mc_soc tegra194_mc_soc = { ...@@ -1355,6 +1355,7 @@ const struct tegra_mc_soc tegra194_mc_soc = {
MC_INT_SECURITY_VIOLATION | MC_INT_DECERR_EMEM, MC_INT_SECURITY_VIOLATION | MC_INT_DECERR_EMEM,
.has_addr_hi_reg = true, .has_addr_hi_reg = true,
.ops = &tegra186_mc_ops, .ops = &tegra186_mc_ops,
.icc_ops = &tegra_mc_icc_ops,
.ch_intmask = 0x00000f00, .ch_intmask = 0x00000f00,
.global_intstatus_channel_shift = 8, .global_intstatus_channel_shift = 8,
}; };
...@@ -827,7 +827,7 @@ static int tegra234_mc_icc_set(struct icc_node *src, struct icc_node *dst) ...@@ -827,7 +827,7 @@ static int tegra234_mc_icc_set(struct icc_node *src, struct icc_node *dst)
return 0; return 0;
if (!mc->bwmgr_mrq_supported) if (!mc->bwmgr_mrq_supported)
return -EINVAL; return 0;
if (!mc->bpmp) { if (!mc->bpmp) {
dev_err(mc->dev, "BPMP reference NULL\n"); dev_err(mc->dev, "BPMP reference NULL\n");
...@@ -874,7 +874,7 @@ static int tegra234_mc_icc_aggregate(struct icc_node *node, u32 tag, u32 avg_bw, ...@@ -874,7 +874,7 @@ static int tegra234_mc_icc_aggregate(struct icc_node *node, u32 tag, u32 avg_bw,
struct tegra_mc *mc = icc_provider_to_tegra_mc(p); struct tegra_mc *mc = icc_provider_to_tegra_mc(p);
if (!mc->bwmgr_mrq_supported) if (!mc->bwmgr_mrq_supported)
return -EINVAL; return 0;
if (node->id == TEGRA_ICC_MC_CPU_CLUSTER0 || if (node->id == TEGRA_ICC_MC_CPU_CLUSTER0 ||
node->id == TEGRA_ICC_MC_CPU_CLUSTER1 || node->id == TEGRA_ICC_MC_CPU_CLUSTER1 ||
...@@ -889,27 +889,6 @@ static int tegra234_mc_icc_aggregate(struct icc_node *node, u32 tag, u32 avg_bw, ...@@ -889,27 +889,6 @@ static int tegra234_mc_icc_aggregate(struct icc_node *node, u32 tag, u32 avg_bw,
return 0; return 0;
} }
static struct icc_node*
tegra234_mc_of_icc_xlate(struct of_phandle_args *spec, void *data)
{
struct tegra_mc *mc = icc_provider_to_tegra_mc(data);
unsigned int cl_id = spec->args[0];
struct icc_node *node;
list_for_each_entry(node, &mc->provider.nodes, node_list) {
if (node->id != cl_id)
continue;
return node;
}
/*
* If a client driver calls devm_of_icc_get() before the MC driver
* is probed, then return EPROBE_DEFER to the client driver.
*/
return ERR_PTR(-EPROBE_DEFER);
}
static int tegra234_mc_icc_get_init_bw(struct icc_node *node, u32 *avg, u32 *peak) static int tegra234_mc_icc_get_init_bw(struct icc_node *node, u32 *avg, u32 *peak)
{ {
*avg = 0; *avg = 0;
...@@ -919,7 +898,7 @@ static int tegra234_mc_icc_get_init_bw(struct icc_node *node, u32 *avg, u32 *pea ...@@ -919,7 +898,7 @@ static int tegra234_mc_icc_get_init_bw(struct icc_node *node, u32 *avg, u32 *pea
} }
static const struct tegra_mc_icc_ops tegra234_mc_icc_ops = { static const struct tegra_mc_icc_ops tegra234_mc_icc_ops = {
.xlate = tegra234_mc_of_icc_xlate, .xlate = tegra_mc_icc_xlate,
.aggregate = tegra234_mc_icc_aggregate, .aggregate = tegra234_mc_icc_aggregate,
.get_bw = tegra234_mc_icc_get_init_bw, .get_bw = tegra234_mc_icc_get_init_bw,
.set = tegra234_mc_icc_set, .set = tegra234_mc_icc_set,
......
...@@ -164,7 +164,7 @@ static int imx8mp_hsio_blk_ctrl_probe(struct imx8mp_blk_ctrl *bc) ...@@ -164,7 +164,7 @@ static int imx8mp_hsio_blk_ctrl_probe(struct imx8mp_blk_ctrl *bc)
clk_hsio_pll->hw.init = &init; clk_hsio_pll->hw.init = &init;
hw = &clk_hsio_pll->hw; hw = &clk_hsio_pll->hw;
ret = devm_clk_hw_register(bc->dev, hw); ret = devm_clk_hw_register(bc->bus_power_dev, hw);
if (ret) if (ret)
return ret; return ret;
......
...@@ -15,4 +15,6 @@ struct corgi_lcd_platform_data { ...@@ -15,4 +15,6 @@ struct corgi_lcd_platform_data {
void (*kick_battery)(void); void (*kick_battery)(void);
}; };
void corgi_lcd_limit_intensity(int limit);
#endif /* __LINUX_SPI_CORGI_LCD_H */ #endif /* __LINUX_SPI_CORGI_LCD_H */
...@@ -175,6 +175,9 @@ struct tegra_mc_icc_ops { ...@@ -175,6 +175,9 @@ struct tegra_mc_icc_ops {
int (*get_bw)(struct icc_node *node, u32 *avg, u32 *peak); int (*get_bw)(struct icc_node *node, u32 *avg, u32 *peak);
}; };
struct icc_node *tegra_mc_icc_xlate(struct of_phandle_args *spec, void *data);
extern const struct tegra_mc_icc_ops tegra_mc_icc_ops;
struct tegra_mc_ops { struct tegra_mc_ops {
/* /*
* @probe: Callback to set up SoC-specific bits of the memory controller. This is called * @probe: Callback to set up SoC-specific bits of the memory controller. This is called
......
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