fvp: Disable SYSTEM_SUSPEND when ARM_BL31_IN_DRAM
authorAntonio Nino Diaz <antonio.ninodiaz@arm.com>
Wed, 22 Nov 2017 12:00:44 +0000 (12:00 +0000)
committerAntonio Nino Diaz <antonio.ninodiaz@arm.com>
Wed, 6 Dec 2017 09:52:01 +0000 (09:52 +0000)
After returning from SYSTEM_SUSPEND state, BL31 reconfigures the
TrustZone Controller during the boot sequence. If BL31 is placed in
TZC-secured DRAM, it will try to change the permissions of the memory it
is being executed from, causing an exception.

The solution is to disable SYSTEM_SUSPEND when the Trusted Firmware has
been compiled with ``ARM_BL31_IN_DRAM=1``.

Change-Id: I96dc50decaacd469327c6b591d07964726e58db4
Signed-off-by: Antonio Nino Diaz <antonio.ninodiaz@arm.com>
plat/arm/board/fvp/fvp_pm.c

index 13bd8f2377ae9242598bef556f1ab8f0fa034df2..72845843d86e827c4fb987c92925aa577e1cae70 100644 (file)
@@ -402,12 +402,20 @@ plat_psci_ops_t plat_arm_psci_pm_ops = {
        .validate_ns_entrypoint = arm_validate_psci_entrypoint,
        .translate_power_state_by_mpidr = fvp_translate_power_state_by_mpidr,
        .get_node_hw_state = fvp_node_hw_state,
+#if !ARM_BL31_IN_DRAM
+       /*
+        * The TrustZone Controller is set up during the warmboot sequence after
+        * resuming the CPU from a SYSTEM_SUSPEND. If BL31 is located in SRAM
+        * this is  not a problem but, if it is in TZC-secured DRAM, it tries to
+        * reconfigure the same memory it is running on, causing an exception.
+        */
        .get_sys_suspend_power_state = fvp_get_sys_suspend_power_state,
-/*
- * mem_protect is not supported in RESET_TO_BL31 and RESET_TO_SP_MIN,
- * as that would require mapping in all of NS DRAM into BL31 or BL32.
- */
+#endif
 #if !RESET_TO_BL31 && !RESET_TO_SP_MIN
+       /*
+        * mem_protect is not supported in RESET_TO_BL31 and RESET_TO_SP_MIN,
+        * as that would require mapping in all of NS DRAM into BL31 or BL32.
+        */
        .mem_protect_chk        = arm_psci_mem_protect_chk,
        .read_mem_protect       = arm_psci_read_mem_protect,
        .write_mem_protect      = arm_nor_psci_write_mem_protect,