assert.c 852 Bytes
Newer Older
1
/*
2
 * Copyright (c) 2013-2018, ARM Limited and Contributors. All rights reserved.
3
 *
dp-arm's avatar
dp-arm committed
4
 * SPDX-License-Identifier: BSD-3-Clause
5
6
 */

7
#include <assert.h>
8
#include <cdefs.h>
9
#include <console.h>
10
#include <debug.h>
11
#include <platform.h>
12

13
/*
14
15
16
 * Only print the output if PLAT_LOG_LEVEL_ASSERT is higher or equal to
 * LOG_LEVEL_INFO, which is the default value for builds with DEBUG=1.
 */
17

18
19
20
#if PLAT_LOG_LEVEL_ASSERT >= LOG_LEVEL_VERBOSE
void __assert(const char *file, unsigned int line, const char *assertion)
{
21
	tf_printf("ASSERT: %s:%d:%s\n", file, line, assertion);
22
	console_flush();
23
	plat_panic_handler();
24
}
25
26
27
#elif PLAT_LOG_LEVEL_ASSERT >= LOG_LEVEL_INFO
void __assert(const char *file, unsigned int line)
{
28
	tf_printf("ASSERT: %s:%d\n", file, line);
29
30
31
32
33
34
35
36
37
	console_flush();
	plat_panic_handler();
}
#else
void __assert(void)
{
	plat_panic_handler();
}
#endif