/* * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #include #include #include #include #define TEGRA186_SMMU_CTX_SIZE 0x420 .globl tegra186_cpu_reset_handler /* CPU reset handler routine */ func tegra186_cpu_reset_handler _align=4 /* * The TZRAM loses state during System Suspend. We use this * information to decide if the reset handler is running after a * System Suspend. Resume from system suspend requires restoring * the entire state from TZDRAM to TZRAM. */ mov x0, #BL31_BASE ldr x0, [x0] cbnz x0, boot_cpu /* resume from system suspend */ mov x0, #BL31_BASE adr x1, __tegra186_cpu_reset_handler_end adr x2, __tegra186_cpu_reset_handler_data ldr x2, [x2, #8] /* memcpy16 */ m_loop16: cmp x2, #16 b.lt m_loop1 ldp x3, x4, [x1], #16 stp x3, x4, [x0], #16 sub x2, x2, #16 b m_loop16 /* copy byte per byte */ m_loop1: cbz x2, boot_cpu ldrb w3, [x1], #1 strb w3, [x0], #1 subs x2, x2, #1 b.ne m_loop1 boot_cpu: adr x0, __tegra186_cpu_reset_handler_data ldr x0, [x0] br x0 endfunc tegra186_cpu_reset_handler /* * Tegra186 reset data (offset 0x0 - 0x430) * * 0x000: secure world's entrypoint * 0x008: BL31 size (RO + RW) * 0x00C: SMMU context start * 0x42C: SMMU context end */ .align 4 .type __tegra186_cpu_reset_handler_data, %object .globl __tegra186_cpu_reset_handler_data __tegra186_cpu_reset_handler_data: .quad tegra_secure_entrypoint .quad __BL31_END__ - BL31_BASE .align 4 .globl __tegra186_smmu_context __tegra186_smmu_context: .rept TEGRA186_SMMU_CTX_SIZE .quad 0 .endr .size __tegra186_cpu_reset_handler_data, \ . - __tegra186_cpu_reset_handler_data .align 4 .globl __tegra186_cpu_reset_handler_end __tegra186_cpu_reset_handler_end: .globl tegra186_get_cpu_reset_handler_size .globl tegra186_get_cpu_reset_handler_base .globl tegra186_get_smmu_ctx_offset /* return size of the CPU reset handler */ func tegra186_get_cpu_reset_handler_size adr x0, __tegra186_cpu_reset_handler_end adr x1, tegra186_cpu_reset_handler sub x0, x0, x1 ret endfunc tegra186_get_cpu_reset_handler_size /* return the start address of the CPU reset handler */ func tegra186_get_cpu_reset_handler_base adr x0, tegra186_cpu_reset_handler ret endfunc tegra186_get_cpu_reset_handler_base /* return the size of the SMMU context */ func tegra186_get_smmu_ctx_offset adr x0, __tegra186_smmu_context adr x1, tegra186_cpu_reset_handler sub x0, x0, x1 ret endfunc tegra186_get_smmu_ctx_offset