Commit e44b59cd authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'arm-fixes-5.8-1' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc

Pull ARM SoC fixes from Arnd Bergmann:
 "Here are a couple of bug fixes, mostly for devicetree files

  NXP i.MX:
   - Use correct voltage on some i.MX8M board device trees to avoid
     hardware damage
   - Code fixes for a compiler warning and incorrect reference counting,
     both harmless.
   - Fix the i.MX8M SoC driver to correctly identify imx8mp
   - Fix watchdog configuration in imx6ul-kontron device tree.

  Broadcom:
   - A small regression fix for the Raspberry-Pi firmware driver
   - A Kconfig change to use the correct timer driver on Northstar
   - A DT fix for the Luxul XWC-2000 machine
   - Two more DT fixes for NSP SoCs

  STmicroelectronics STI
   - Revert one broken patch for L2 cache configuration

  ARM Versatile Express:
   - Fix a regression by reverting a broken DT cleanup

  TEE drivers:
   - MAINTAINERS: change tee mailing list"

* tag 'arm-fixes-5.8-1' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc:
  Revert "ARM: sti: Implement dummy L2 cache's write_sec"
  soc: imx8m: fix build warning
  ARM: imx6: add missing put_device() call in imx6q_suspend_init()
  ARM: imx5: add missing put_device() call in imx_suspend_alloc_ocram()
  soc: imx8m: Correct i.MX8MP UID fuse offset
  ARM: dts: imx6ul-kontron: Change WDOG_ANY signal from push-pull to open-drain
  ARM: dts: imx6ul-kontron: Move watchdog from Kontron i.MX6UL/ULL board to SoM
  arm64: dts: imx8mm-beacon: Fix voltages on LDO1 and LDO2
  arm64: dts: imx8mn-ddr4-evk: correct ldo1/ldo2 voltage range
  arm64: dts: imx8mm-evk: correct ldo1/ldo2 voltage range
  ARM: dts: NSP: Correct FA2 mailbox node
  ARM: bcm2835: Fix integer overflow in rpi_firmware_print_firmware_revision()
  MAINTAINERS: change tee mailing list
  ARM: dts: NSP: Disable PL330 by default, add dma-coherent property
  ARM: bcm: Select ARM_TIMER_SP804 for ARCH_BCM_NSP
  ARM: dts: BCM5301X: Add missing memory "device_type" for Luxul XWC-2000
  arm: dts: vexpress: Move mcc node back into motherboard node
parents 668f532d 42d3f7e8
...@@ -12695,13 +12695,13 @@ F: arch/mips/boot/dts/ralink/omega2p.dts ...@@ -12695,13 +12695,13 @@ F: arch/mips/boot/dts/ralink/omega2p.dts
OP-TEE DRIVER OP-TEE DRIVER
M: Jens Wiklander <jens.wiklander@linaro.org> M: Jens Wiklander <jens.wiklander@linaro.org>
L: tee-dev@lists.linaro.org L: op-tee@lists.trustedfirmware.org
S: Maintained S: Maintained
F: drivers/tee/optee/ F: drivers/tee/optee/
OP-TEE RANDOM NUMBER GENERATOR (RNG) DRIVER OP-TEE RANDOM NUMBER GENERATOR (RNG) DRIVER
M: Sumit Garg <sumit.garg@linaro.org> M: Sumit Garg <sumit.garg@linaro.org>
L: tee-dev@lists.linaro.org L: op-tee@lists.trustedfirmware.org
S: Maintained S: Maintained
F: drivers/char/hw_random/optee-rng.c F: drivers/char/hw_random/optee-rng.c
...@@ -16774,7 +16774,7 @@ F: include/media/i2c/tw9910.h ...@@ -16774,7 +16774,7 @@ F: include/media/i2c/tw9910.h
TEE SUBSYSTEM TEE SUBSYSTEM
M: Jens Wiklander <jens.wiklander@linaro.org> M: Jens Wiklander <jens.wiklander@linaro.org>
L: tee-dev@lists.linaro.org L: op-tee@lists.trustedfirmware.org
S: Maintained S: Maintained
F: Documentation/tee.txt F: Documentation/tee.txt
F: drivers/tee/ F: drivers/tee/
......
...@@ -200,7 +200,7 @@ uart1: serial@400 { ...@@ -200,7 +200,7 @@ uart1: serial@400 {
status = "disabled"; status = "disabled";
}; };
dma@20000 { dma: dma@20000 {
compatible = "arm,pl330", "arm,primecell"; compatible = "arm,pl330", "arm,primecell";
reg = <0x20000 0x1000>; reg = <0x20000 0x1000>;
interrupts = <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>, interrupts = <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>,
...@@ -215,6 +215,8 @@ dma@20000 { ...@@ -215,6 +215,8 @@ dma@20000 {
clocks = <&iprocslow>; clocks = <&iprocslow>;
clock-names = "apb_pclk"; clock-names = "apb_pclk";
#dma-cells = <1>; #dma-cells = <1>;
dma-coherent;
status = "disabled";
}; };
sdio: sdhci@21000 { sdio: sdhci@21000 {
...@@ -257,10 +259,10 @@ amac2: ethernet@24000 { ...@@ -257,10 +259,10 @@ amac2: ethernet@24000 {
status = "disabled"; status = "disabled";
}; };
mailbox: mailbox@25000 { mailbox: mailbox@25c00 {
compatible = "brcm,iproc-fa2-mbox"; compatible = "brcm,iproc-fa2-mbox";
reg = <0x25000 0x445>; reg = <0x25c00 0x400>;
interrupts = <GIC_SPI 150 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>;
#mbox-cells = <1>; #mbox-cells = <1>;
brcm,rx-status-len = <32>; brcm,rx-status-len = <32>;
brcm,use-bcm-hdr; brcm,use-bcm-hdr;
......
...@@ -17,6 +17,7 @@ chosen { ...@@ -17,6 +17,7 @@ chosen {
}; };
memory { memory {
device_type = "memory";
reg = <0x00000000 0x08000000 reg = <0x00000000 0x08000000
0x88000000 0x18000000>; 0x88000000 0x18000000>;
}; };
......
...@@ -58,6 +58,10 @@ gpio-restart { ...@@ -58,6 +58,10 @@ gpio-restart {
/* USB 3 support needed to be complete */ /* USB 3 support needed to be complete */
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -58,6 +58,10 @@ gpio-restart { ...@@ -58,6 +58,10 @@ gpio-restart {
/* USB 3 support needed to be complete */ /* USB 3 support needed to be complete */
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -58,6 +58,10 @@ gpio-restart { ...@@ -58,6 +58,10 @@ gpio-restart {
/* XHCI support needed to be complete */ /* XHCI support needed to be complete */
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -58,6 +58,10 @@ gpio-restart { ...@@ -58,6 +58,10 @@ gpio-restart {
/* USB 3 and SLIC support needed to be complete */ /* USB 3 and SLIC support needed to be complete */
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -58,6 +58,10 @@ gpio-restart { ...@@ -58,6 +58,10 @@ gpio-restart {
/* USB 3 and SLIC support needed to be complete */ /* USB 3 and SLIC support needed to be complete */
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -69,6 +69,10 @@ &i2c0 { ...@@ -69,6 +69,10 @@ &i2c0 {
status = "okay"; status = "okay";
}; };
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -48,6 +48,10 @@ memory@60000000 { ...@@ -48,6 +48,10 @@ memory@60000000 {
}; };
}; };
&dma {
status = "okay";
};
&amac0 { &amac0 {
status = "okay"; status = "okay";
}; };
......
...@@ -232,13 +232,6 @@ &usdhc2 { ...@@ -232,13 +232,6 @@ &usdhc2 {
status = "okay"; status = "okay";
}; };
&wdog1 {
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_wdog>;
fsl,ext-reset-output;
status = "okay";
};
&iomuxc { &iomuxc {
pinctrl-0 = <&pinctrl_reset_out &pinctrl_gpio>; pinctrl-0 = <&pinctrl_reset_out &pinctrl_gpio>;
...@@ -409,10 +402,4 @@ MX6UL_PAD_NAND_DATA02__USDHC2_DATA2 0x170f9 ...@@ -409,10 +402,4 @@ MX6UL_PAD_NAND_DATA02__USDHC2_DATA2 0x170f9
MX6UL_PAD_NAND_DATA03__USDHC2_DATA3 0x170f9 MX6UL_PAD_NAND_DATA03__USDHC2_DATA3 0x170f9
>; >;
}; };
pinctrl_wdog: wdoggrp {
fsl,pins = <
MX6UL_PAD_GPIO1_IO09__WDOG1_WDOG_ANY 0x30b0
>;
};
}; };
...@@ -57,6 +57,13 @@ &qspi { ...@@ -57,6 +57,13 @@ &qspi {
status = "okay"; status = "okay";
}; };
&wdog1 {
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_wdog>;
fsl,ext-reset-output;
status = "okay";
};
&iomuxc { &iomuxc {
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_reset_out>; pinctrl-0 = <&pinctrl_reset_out>;
...@@ -106,4 +113,10 @@ pinctrl_reset_out: rstoutgrp { ...@@ -106,4 +113,10 @@ pinctrl_reset_out: rstoutgrp {
MX6UL_PAD_SNVS_TAMPER9__GPIO5_IO09 0x1b0b0 MX6UL_PAD_SNVS_TAMPER9__GPIO5_IO09 0x1b0b0
>; >;
}; };
pinctrl_wdog: wdoggrp {
fsl,pins = <
MX6UL_PAD_GPIO1_IO09__WDOG1_WDOG_ANY 0x18b0
>;
};
}; };
...@@ -100,79 +100,6 @@ led-8 { ...@@ -100,79 +100,6 @@ led-8 {
}; };
}; };
mcc {
compatible = "arm,vexpress,config-bus";
arm,vexpress,config-bridge = <&v2m_sysreg>;
oscclk0 {
/* MCC static memory clock */
compatible = "arm,vexpress-osc";
arm,vexpress-sysreg,func = <1 0>;
freq-range = <25000000 60000000>;
#clock-cells = <0>;
clock-output-names = "v2m:oscclk0";
};
v2m_oscclk1: oscclk1 {
/* CLCD clock */
compatible = "arm,vexpress-osc";
arm,vexpress-sysreg,func = <1 1>;
freq-range = <23750000 65000000>;
#clock-cells = <0>;
clock-output-names = "v2m:oscclk1";
};
v2m_oscclk2: oscclk2 {
/* IO FPGA peripheral clock */
compatible = "arm,vexpress-osc";
arm,vexpress-sysreg,func = <1 2>;
freq-range = <24000000 24000000>;
#clock-cells = <0>;
clock-output-names = "v2m:oscclk2";
};
volt-vio {
/* Logic level voltage */
compatible = "arm,vexpress-volt";
arm,vexpress-sysreg,func = <2 0>;
regulator-name = "VIO";
regulator-always-on;
label = "VIO";
};
temp-mcc {
/* MCC internal operating temperature */
compatible = "arm,vexpress-temp";
arm,vexpress-sysreg,func = <4 0>;
label = "MCC";
};
reset {
compatible = "arm,vexpress-reset";
arm,vexpress-sysreg,func = <5 0>;
};
muxfpga {
compatible = "arm,vexpress-muxfpga";
arm,vexpress-sysreg,func = <7 0>;
};
shutdown {
compatible = "arm,vexpress-shutdown";
arm,vexpress-sysreg,func = <8 0>;
};
reboot {
compatible = "arm,vexpress-reboot";
arm,vexpress-sysreg,func = <9 0>;
};
dvimode {
compatible = "arm,vexpress-dvimode";
arm,vexpress-sysreg,func = <11 0>;
};
};
bus@8000000 { bus@8000000 {
motherboard-bus { motherboard-bus {
model = "V2M-P1"; model = "V2M-P1";
...@@ -435,6 +362,79 @@ clcd_pads: endpoint { ...@@ -435,6 +362,79 @@ clcd_pads: endpoint {
}; };
}; };
}; };
mcc {
compatible = "arm,vexpress,config-bus";
arm,vexpress,config-bridge = <&v2m_sysreg>;
oscclk0 {
/* MCC static memory clock */
compatible = "arm,vexpress-osc";
arm,vexpress-sysreg,func = <1 0>;
freq-range = <25000000 60000000>;
#clock-cells = <0>;
clock-output-names = "v2m:oscclk0";
};
v2m_oscclk1: oscclk1 {
/* CLCD clock */
compatible = "arm,vexpress-osc";
arm,vexpress-sysreg,func = <1 1>;
freq-range = <23750000 65000000>;
#clock-cells = <0>;
clock-output-names = "v2m:oscclk1";
};
v2m_oscclk2: oscclk2 {
/* IO FPGA peripheral clock */
compatible = "arm,vexpress-osc";
arm,vexpress-sysreg,func = <1 2>;
freq-range = <24000000 24000000>;
#clock-cells = <0>;
clock-output-names = "v2m:oscclk2";
};
volt-vio {
/* Logic level voltage */
compatible = "arm,vexpress-volt";
arm,vexpress-sysreg,func = <2 0>;
regulator-name = "VIO";
regulator-always-on;
label = "VIO";
};
temp-mcc {
/* MCC internal operating temperature */
compatible = "arm,vexpress-temp";
arm,vexpress-sysreg,func = <4 0>;
label = "MCC";
};
reset {
compatible = "arm,vexpress-reset";
arm,vexpress-sysreg,func = <5 0>;
};
muxfpga {
compatible = "arm,vexpress-muxfpga";
arm,vexpress-sysreg,func = <7 0>;
};
shutdown {
compatible = "arm,vexpress-shutdown";
arm,vexpress-sysreg,func = <8 0>;
};
reboot {
compatible = "arm,vexpress-reboot";
arm,vexpress-sysreg,func = <9 0>;
};
dvimode {
compatible = "arm,vexpress-dvimode";
arm,vexpress-sysreg,func = <11 0>;
};
};
}; };
}; };
}; };
......
...@@ -53,6 +53,7 @@ config ARCH_BCM_NSP ...@@ -53,6 +53,7 @@ config ARCH_BCM_NSP
select ARM_ERRATA_754322 select ARM_ERRATA_754322
select ARM_ERRATA_775420 select ARM_ERRATA_775420
select ARM_ERRATA_764369 if SMP select ARM_ERRATA_764369 if SMP
select ARM_TIMER_SP804
select THERMAL select THERMAL
select THERMAL_OF select THERMAL_OF
help help
......
...@@ -295,14 +295,14 @@ static int __init imx_suspend_alloc_ocram( ...@@ -295,14 +295,14 @@ static int __init imx_suspend_alloc_ocram(
if (!ocram_pool) { if (!ocram_pool) {
pr_warn("%s: ocram pool unavailable!\n", __func__); pr_warn("%s: ocram pool unavailable!\n", __func__);
ret = -ENODEV; ret = -ENODEV;
goto put_node; goto put_device;
} }
ocram_base = gen_pool_alloc(ocram_pool, size); ocram_base = gen_pool_alloc(ocram_pool, size);
if (!ocram_base) { if (!ocram_base) {
pr_warn("%s: unable to alloc ocram!\n", __func__); pr_warn("%s: unable to alloc ocram!\n", __func__);
ret = -ENOMEM; ret = -ENOMEM;
goto put_node; goto put_device;
} }
phys = gen_pool_virt_to_phys(ocram_pool, ocram_base); phys = gen_pool_virt_to_phys(ocram_pool, ocram_base);
...@@ -312,6 +312,8 @@ static int __init imx_suspend_alloc_ocram( ...@@ -312,6 +312,8 @@ static int __init imx_suspend_alloc_ocram(
if (virt_out) if (virt_out)
*virt_out = virt; *virt_out = virt;
put_device:
put_device(&pdev->dev);
put_node: put_node:
of_node_put(node); of_node_put(node);
......
...@@ -493,14 +493,14 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata) ...@@ -493,14 +493,14 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata)
if (!ocram_pool) { if (!ocram_pool) {
pr_warn("%s: ocram pool unavailable!\n", __func__); pr_warn("%s: ocram pool unavailable!\n", __func__);
ret = -ENODEV; ret = -ENODEV;
goto put_node; goto put_device;
} }
ocram_base = gen_pool_alloc(ocram_pool, MX6Q_SUSPEND_OCRAM_SIZE); ocram_base = gen_pool_alloc(ocram_pool, MX6Q_SUSPEND_OCRAM_SIZE);
if (!ocram_base) { if (!ocram_base) {
pr_warn("%s: unable to alloc ocram!\n", __func__); pr_warn("%s: unable to alloc ocram!\n", __func__);
ret = -ENOMEM; ret = -ENOMEM;
goto put_node; goto put_device;
} }
ocram_pbase = gen_pool_virt_to_phys(ocram_pool, ocram_base); ocram_pbase = gen_pool_virt_to_phys(ocram_pool, ocram_base);
...@@ -523,7 +523,7 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata) ...@@ -523,7 +523,7 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata)
ret = imx6_pm_get_base(&pm_info->mmdc_base, socdata->mmdc_compat); ret = imx6_pm_get_base(&pm_info->mmdc_base, socdata->mmdc_compat);
if (ret) { if (ret) {
pr_warn("%s: failed to get mmdc base %d!\n", __func__, ret); pr_warn("%s: failed to get mmdc base %d!\n", __func__, ret);
goto put_node; goto put_device;
} }
ret = imx6_pm_get_base(&pm_info->src_base, socdata->src_compat); ret = imx6_pm_get_base(&pm_info->src_base, socdata->src_compat);
...@@ -570,7 +570,7 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata) ...@@ -570,7 +570,7 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata)
&imx6_suspend, &imx6_suspend,
MX6Q_SUSPEND_OCRAM_SIZE - sizeof(*pm_info)); MX6Q_SUSPEND_OCRAM_SIZE - sizeof(*pm_info));
goto put_node; goto put_device;
pl310_cache_map_failed: pl310_cache_map_failed:
iounmap(pm_info->gpc_base.vbase); iounmap(pm_info->gpc_base.vbase);
...@@ -580,6 +580,8 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata) ...@@ -580,6 +580,8 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata)
iounmap(pm_info->src_base.vbase); iounmap(pm_info->src_base.vbase);
src_map_failed: src_map_failed:
iounmap(pm_info->mmdc_base.vbase); iounmap(pm_info->mmdc_base.vbase);
put_device:
put_device(&pdev->dev);
put_node: put_node:
of_node_put(node); of_node_put(node);
......
...@@ -20,14 +20,6 @@ static const char *const stih41x_dt_match[] __initconst = { ...@@ -20,14 +20,6 @@ static const char *const stih41x_dt_match[] __initconst = {
NULL NULL
}; };
static void sti_l2_write_sec(unsigned long val, unsigned reg)
{
/*
* We can't write to secure registers as we are in non-secure
* mode, until we have some SMI service available.
*/
}
DT_MACHINE_START(STM, "STi SoC with Flattened Device Tree") DT_MACHINE_START(STM, "STi SoC with Flattened Device Tree")
.dt_compat = stih41x_dt_match, .dt_compat = stih41x_dt_match,
.l2c_aux_val = L2C_AUX_CTRL_SHARED_OVERRIDE | .l2c_aux_val = L2C_AUX_CTRL_SHARED_OVERRIDE |
...@@ -36,5 +28,4 @@ DT_MACHINE_START(STM, "STi SoC with Flattened Device Tree") ...@@ -36,5 +28,4 @@ DT_MACHINE_START(STM, "STi SoC with Flattened Device Tree")
L2C_AUX_CTRL_WAY_SIZE(4), L2C_AUX_CTRL_WAY_SIZE(4),
.l2c_aux_mask = 0xc0000fff, .l2c_aux_mask = 0xc0000fff,
.smp = smp_ops(sti_smp_ops), .smp = smp_ops(sti_smp_ops),
.l2c_write_sec = sti_l2_write_sec,
MACHINE_END MACHINE_END
...@@ -136,7 +136,7 @@ buck6_reg: BUCK6 { ...@@ -136,7 +136,7 @@ buck6_reg: BUCK6 {
ldo1_reg: LDO1 { ldo1_reg: LDO1 {
regulator-name = "LDO1"; regulator-name = "LDO1";
regulator-min-microvolt = <3000000>; regulator-min-microvolt = <1600000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
regulator-boot-on; regulator-boot-on;
regulator-always-on; regulator-always-on;
...@@ -144,7 +144,7 @@ ldo1_reg: LDO1 { ...@@ -144,7 +144,7 @@ ldo1_reg: LDO1 {
ldo2_reg: LDO2 { ldo2_reg: LDO2 {
regulator-name = "LDO2"; regulator-name = "LDO2";
regulator-min-microvolt = <900000>; regulator-min-microvolt = <800000>;
regulator-max-microvolt = <900000>; regulator-max-microvolt = <900000>;
regulator-boot-on; regulator-boot-on;
regulator-always-on; regulator-always-on;
......
...@@ -208,7 +208,7 @@ buck6_reg: BUCK6 { ...@@ -208,7 +208,7 @@ buck6_reg: BUCK6 {
ldo1_reg: LDO1 { ldo1_reg: LDO1 {
regulator-name = "LDO1"; regulator-name = "LDO1";
regulator-min-microvolt = <3000000>; regulator-min-microvolt = <1600000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
regulator-boot-on; regulator-boot-on;
regulator-always-on; regulator-always-on;
...@@ -216,7 +216,7 @@ ldo1_reg: LDO1 { ...@@ -216,7 +216,7 @@ ldo1_reg: LDO1 {
ldo2_reg: LDO2 { ldo2_reg: LDO2 {
regulator-name = "LDO2"; regulator-name = "LDO2";
regulator-min-microvolt = <900000>; regulator-min-microvolt = <800000>;
regulator-max-microvolt = <900000>; regulator-max-microvolt = <900000>;
regulator-boot-on; regulator-boot-on;
regulator-always-on; regulator-always-on;
......
...@@ -113,7 +113,7 @@ buck6_reg: BUCK6 { ...@@ -113,7 +113,7 @@ buck6_reg: BUCK6 {
ldo1_reg: LDO1 { ldo1_reg: LDO1 {
regulator-name = "LDO1"; regulator-name = "LDO1";
regulator-min-microvolt = <3000000>; regulator-min-microvolt = <1600000>;
regulator-max-microvolt = <3300000>; regulator-max-microvolt = <3300000>;
regulator-boot-on; regulator-boot-on;
regulator-always-on; regulator-always-on;
...@@ -121,7 +121,7 @@ ldo1_reg: LDO1 { ...@@ -121,7 +121,7 @@ ldo1_reg: LDO1 {
ldo2_reg: LDO2 { ldo2_reg: LDO2 {
regulator-name = "LDO2"; regulator-name = "LDO2";
regulator-min-microvolt = <900000>; regulator-min-microvolt = <800000>;
regulator-max-microvolt = <900000>; regulator-max-microvolt = <900000>;
regulator-boot-on; regulator-boot-on;
regulator-always-on; regulator-always-on;
......
...@@ -181,6 +181,7 @@ EXPORT_SYMBOL_GPL(rpi_firmware_property); ...@@ -181,6 +181,7 @@ EXPORT_SYMBOL_GPL(rpi_firmware_property);
static void static void
rpi_firmware_print_firmware_revision(struct rpi_firmware *fw) rpi_firmware_print_firmware_revision(struct rpi_firmware *fw)
{ {
time64_t date_and_time;
u32 packet; u32 packet;
int ret = rpi_firmware_property(fw, int ret = rpi_firmware_property(fw,
RPI_FIRMWARE_GET_FIRMWARE_REVISION, RPI_FIRMWARE_GET_FIRMWARE_REVISION,
...@@ -189,7 +190,9 @@ rpi_firmware_print_firmware_revision(struct rpi_firmware *fw) ...@@ -189,7 +190,9 @@ rpi_firmware_print_firmware_revision(struct rpi_firmware *fw)
if (ret) if (ret)
return; return;
dev_info(fw->cl.dev, "Attached to firmware from %ptT\n", &packet); /* This is not compatible with y2038 */
date_and_time = packet;
dev_info(fw->cl.dev, "Attached to firmware from %ptT\n", &date_and_time);
} }
static void static void
......
...@@ -22,6 +22,8 @@ ...@@ -22,6 +22,8 @@
#define OCOTP_UID_LOW 0x410 #define OCOTP_UID_LOW 0x410
#define OCOTP_UID_HIGH 0x420 #define OCOTP_UID_HIGH 0x420
#define IMX8MP_OCOTP_UID_OFFSET 0x10
/* Same as ANADIG_DIGPROG_IMX7D */ /* Same as ANADIG_DIGPROG_IMX7D */
#define ANADIG_DIGPROG_IMX8MM 0x800 #define ANADIG_DIGPROG_IMX8MM 0x800
...@@ -87,6 +89,8 @@ static void __init imx8mm_soc_uid(void) ...@@ -87,6 +89,8 @@ static void __init imx8mm_soc_uid(void)
{ {
void __iomem *ocotp_base; void __iomem *ocotp_base;
struct device_node *np; struct device_node *np;
u32 offset = of_machine_is_compatible("fsl,imx8mp") ?
IMX8MP_OCOTP_UID_OFFSET : 0;
np = of_find_compatible_node(NULL, NULL, "fsl,imx8mm-ocotp"); np = of_find_compatible_node(NULL, NULL, "fsl,imx8mm-ocotp");
if (!np) if (!np)
...@@ -95,9 +99,9 @@ static void __init imx8mm_soc_uid(void) ...@@ -95,9 +99,9 @@ static void __init imx8mm_soc_uid(void)
ocotp_base = of_iomap(np, 0); ocotp_base = of_iomap(np, 0);
WARN_ON(!ocotp_base); WARN_ON(!ocotp_base);
soc_uid = readl_relaxed(ocotp_base + OCOTP_UID_HIGH); soc_uid = readl_relaxed(ocotp_base + OCOTP_UID_HIGH + offset);
soc_uid <<= 32; soc_uid <<= 32;
soc_uid |= readl_relaxed(ocotp_base + OCOTP_UID_LOW); soc_uid |= readl_relaxed(ocotp_base + OCOTP_UID_LOW + offset);
iounmap(ocotp_base); iounmap(ocotp_base);
of_node_put(np); of_node_put(np);
...@@ -146,7 +150,7 @@ static const struct imx8_soc_data imx8mp_soc_data = { ...@@ -146,7 +150,7 @@ static const struct imx8_soc_data imx8mp_soc_data = {
.soc_revision = imx8mm_soc_revision, .soc_revision = imx8mm_soc_revision,
}; };
static const struct of_device_id imx8_soc_match[] = { static __maybe_unused const struct of_device_id imx8_soc_match[] = {
{ .compatible = "fsl,imx8mq", .data = &imx8mq_soc_data, }, { .compatible = "fsl,imx8mq", .data = &imx8mq_soc_data, },
{ .compatible = "fsl,imx8mm", .data = &imx8mm_soc_data, }, { .compatible = "fsl,imx8mm", .data = &imx8mm_soc_data, },
{ .compatible = "fsl,imx8mn", .data = &imx8mn_soc_data, }, { .compatible = "fsl,imx8mn", .data = &imx8mn_soc_data, },
......
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