blob: 366448eb0fb7ad093d1e85eec0e84126cb32aa3d [file] [log] [blame]
Dave P Martin9fb74102015-07-24 16:37:48 +01001/*
2 * Copyright (C) 2015 ARM Limited
3 * Author: Dave Martin <Dave.Martin@arm.com>
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18#ifndef _ARCH_ARM64_ASM_BUG_H
19#define _ARCH_ARM64_ASM_BUG_H
20
Ard Biesheuvelf98deee2016-02-23 08:56:45 +010021#include <asm/brk-imm.h>
Dave P Martin9fb74102015-07-24 16:37:48 +010022
Dave P Martin9fb74102015-07-24 16:37:48 +010023#ifdef CONFIG_DEBUG_BUGVERBOSE
24#define _BUGVERBOSE_LOCATION(file, line) __BUGVERBOSE_LOCATION(file, line)
25#define __BUGVERBOSE_LOCATION(file, line) \
26 ".pushsection .rodata.str,\"aMS\",@progbits,1\n" \
27 "2: .string \"" file "\"\n\t" \
28 ".popsection\n\t" \
29 \
30 ".long 2b - 0b\n\t" \
31 ".short " #line "\n\t"
32#else
33#define _BUGVERBOSE_LOCATION(file, line)
34#endif
35
Arnd Bergmannf13d52c2017-03-14 22:39:21 +010036#ifdef CONFIG_GENERIC_BUG
Dave P Martin9fb74102015-07-24 16:37:48 +010037
Arnd Bergmannf13d52c2017-03-14 22:39:21 +010038#define __BUG_ENTRY(flags) \
Dave P Martin9fb74102015-07-24 16:37:48 +010039 ".pushsection __bug_table,\"a\"\n\t" \
40 ".align 2\n\t" \
41 "0: .long 1f - 0b\n\t" \
42_BUGVERBOSE_LOCATION(__FILE__, __LINE__) \
43 ".short " #flags "\n\t" \
44 ".popsection\n" \
Arnd Bergmannf13d52c2017-03-14 22:39:21 +010045 "1: "
46#else
47#define __BUG_ENTRY(flags) ""
48#endif
Dave P Martin9fb74102015-07-24 16:37:48 +010049
Arnd Bergmannf13d52c2017-03-14 22:39:21 +010050#define __BUG_FLAGS(flags) \
51 asm volatile ( \
52 __BUG_ENTRY(flags) \
53 "brk %[imm]" :: [imm] "i" (BUG_BRK_IMM) \
54 );
55
56
57#define BUG() do { \
58 __BUG_FLAGS(0); \
59 unreachable(); \
Dave P Martin9fb74102015-07-24 16:37:48 +010060} while (0)
61
Linus Torvaldsab182e62017-05-05 12:11:37 -070062#define __WARN_FLAGS(flags) __BUG_FLAGS(BUGFLAG_WARNING|(flags))
Dave P Martin9fb74102015-07-24 16:37:48 +010063
Arnd Bergmannf13d52c2017-03-14 22:39:21 +010064#define HAVE_ARCH_BUG
Dave P Martin9fb74102015-07-24 16:37:48 +010065
66#include <asm-generic/bug.h>
67
68#endif /* ! _ARCH_ARM64_ASM_BUG_H */