xref: /rk3399_ARM-atf/plat/arm/board/juno/juno_err.c (revision 09d40e0e08283a249e7dce0e106c07c5141f9b7e)
14da6f6cdSSathees Balya /*
24da6f6cdSSathees Balya  * Copyright (c) 2015-2018, ARM Limited and Contributors. All rights reserved.
34da6f6cdSSathees Balya  *
44da6f6cdSSathees Balya  * SPDX-License-Identifier: BSD-3-Clause
54da6f6cdSSathees Balya  */
64da6f6cdSSathees Balya 
74da6f6cdSSathees Balya #include <errno.h>
8*09d40e0eSAntonio Nino Diaz 
9*09d40e0eSAntonio Nino Diaz #include <arch_helpers.h>
10*09d40e0eSAntonio Nino Diaz #include <plat/common/platform.h>
11*09d40e0eSAntonio Nino Diaz 
124da6f6cdSSathees Balya #include <v2m_def.h>
134da6f6cdSSathees Balya 
144da6f6cdSSathees Balya /*
154da6f6cdSSathees Balya  * Juno error handler
164da6f6cdSSathees Balya  */
174da6f6cdSSathees Balya void __dead2 plat_arm_error_handler(int err)
184da6f6cdSSathees Balya {
194da6f6cdSSathees Balya 	uint32_t *flags_ptr = (uint32_t *)V2M_SYS_NVFLAGS_ADDR;
204da6f6cdSSathees Balya 
214da6f6cdSSathees Balya 	/* Propagate the err code in the NV-flags register */
224da6f6cdSSathees Balya 	*flags_ptr = err;
234da6f6cdSSathees Balya 
244da6f6cdSSathees Balya 	/* Loop until the watchdog resets the system */
254da6f6cdSSathees Balya 	for (;;)
264da6f6cdSSathees Balya 		wfi();
274da6f6cdSSathees Balya }
28