assert.c 1 KB
Newer Older
1
/*
2
 * Copyright (c) 2013-2019, 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 <stdio.h>
10

11
12
13
14
#include <common/debug.h>
#include <drivers/console.h>
#include <plat/common/platform.h>

15
/*
16
17
18
 * 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.
 */
19

20
#if PLAT_LOG_LEVEL_ASSERT >= LOG_LEVEL_VERBOSE
21
22
void __dead2 __assert(const char *file, unsigned int line,
		      const char *assertion)
23
{
24
	printf("ASSERT: %s:%d:%s\n", file, line, assertion);
25
26
	backtrace("assert");
	(void)console_flush();
27
	plat_panic_handler();
28
}
29
#elif PLAT_LOG_LEVEL_ASSERT >= LOG_LEVEL_INFO
30
void __dead2 __assert(const char *file, unsigned int line)
31
{
32
	printf("ASSERT: %s:%d\n", file, line);
33
34
	backtrace("assert");
	(void)console_flush();
35
36
37
	plat_panic_handler();
}
#else
38
void __dead2 __assert(void)
39
{
40
41
	backtrace("assert");
	(void)console_flush();
42
43
44
	plat_panic_handler();
}
#endif