summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnson Huang <Anson.Huang@nxp.com>2018-07-12 11:04:15 +0800
committerAnson Huang <Anson.Huang@nxp.com>2018-07-12 11:05:21 +0800
commit351e3731cacf9c36f94a80e0bee6af021bed7faf (patch)
tree4bceb8feea92d02e2d6a133012b6c3c795f1c959
parent8972694e931df4622cb5844c96ecdd0fe5941235 (diff)
imx: imx8qx: add system reset support
Add system reset support for i.MX8QX, when Linux kernel issues "reboot" command, TF-A will send command to inform system controller to reset whole board according to board design, tested on i.MX8QX MEK board. Signed-off-by: Anson Huang <Anson.Huang@nxp.com>
-rw-r--r--plat/imx/common/imx8_psci.c7
-rw-r--r--plat/imx/common/include/plat_imx8.h1
-rw-r--r--plat/imx/imx8qx/imx8qx_psci.c1
3 files changed, 9 insertions, 0 deletions
diff --git a/plat/imx/common/imx8_psci.c b/plat/imx/common/imx8_psci.c
index 0b0dcb57..37eda3e6 100644
--- a/plat/imx/common/imx8_psci.c
+++ b/plat/imx/common/imx8_psci.c
@@ -19,4 +19,11 @@ void __dead2 imx_system_off(void)
panic();
}
+void __dead2 imx_system_reset(void)
+{
+ sc_pm_reset(ipc_handle, SC_PM_RESET_TYPE_BOARD);
+ wfi();
+ ERROR("system reset failed.\n");
+ panic();
+}
diff --git a/plat/imx/common/include/plat_imx8.h b/plat/imx/common/include/plat_imx8.h
index 640d60e7..3b5f4ec6 100644
--- a/plat/imx/common/include/plat_imx8.h
+++ b/plat/imx/common/include/plat_imx8.h
@@ -18,4 +18,5 @@ void plat_gic_cpuif_disable(void);
void plat_gic_pcpu_init(void);
void __dead2 imx_system_off(void);
+void __dead2 imx_system_reset(void);
#endif /*__PLAT_IMX8_H__ */
diff --git a/plat/imx/imx8qx/imx8qx_psci.c b/plat/imx/imx8qx/imx8qx_psci.c
index 1e8f7fa4..80f747b1 100644
--- a/plat/imx/imx8qx/imx8qx_psci.c
+++ b/plat/imx/imx8qx/imx8qx_psci.c
@@ -65,6 +65,7 @@ static const plat_psci_ops_t imx_plat_psci_ops = {
.pwr_domain_on_finish = imx_pwr_domain_on_finish,
.validate_ns_entrypoint = imx_validate_ns_entrypoint,
.system_off = imx_system_off,
+ .system_reset = imx_system_reset,
};
int plat_setup_psci_ops(uintptr_t sec_entrypoint,