2015-07-24 15:37:48 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 ARM Limited
|
|
|
|
* Author: Dave Martin <Dave.Martin@arm.com>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ARCH_ARM64_ASM_BUG_H
|
|
|
|
#define _ARCH_ARM64_ASM_BUG_H
|
|
|
|
|
2016-02-23 07:56:45 +00:00
|
|
|
#include <asm/brk-imm.h>
|
2015-07-24 15:37:48 +00:00
|
|
|
|
|
|
|
#ifdef CONFIG_DEBUG_BUGVERBOSE
|
|
|
|
#define _BUGVERBOSE_LOCATION(file, line) __BUGVERBOSE_LOCATION(file, line)
|
|
|
|
#define __BUGVERBOSE_LOCATION(file, line) \
|
|
|
|
".pushsection .rodata.str,\"aMS\",@progbits,1\n" \
|
|
|
|
"2: .string \"" file "\"\n\t" \
|
|
|
|
".popsection\n\t" \
|
|
|
|
\
|
|
|
|
".long 2b - 0b\n\t" \
|
|
|
|
".short " #line "\n\t"
|
|
|
|
#else
|
|
|
|
#define _BUGVERBOSE_LOCATION(file, line)
|
|
|
|
#endif
|
|
|
|
|
2017-03-14 21:39:21 +00:00
|
|
|
#ifdef CONFIG_GENERIC_BUG
|
2015-07-24 15:37:48 +00:00
|
|
|
|
2017-03-14 21:39:21 +00:00
|
|
|
#define __BUG_ENTRY(flags) \
|
2017-07-15 05:10:58 +00:00
|
|
|
".pushsection __bug_table,\"aw\"\n\t" \
|
2015-07-24 15:37:48 +00:00
|
|
|
".align 2\n\t" \
|
|
|
|
"0: .long 1f - 0b\n\t" \
|
|
|
|
_BUGVERBOSE_LOCATION(__FILE__, __LINE__) \
|
|
|
|
".short " #flags "\n\t" \
|
|
|
|
".popsection\n" \
|
2017-03-14 21:39:21 +00:00
|
|
|
"1: "
|
|
|
|
#else
|
|
|
|
#define __BUG_ENTRY(flags) ""
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define __BUG_FLAGS(flags) \
|
|
|
|
asm volatile ( \
|
|
|
|
__BUG_ENTRY(flags) \
|
|
|
|
"brk %[imm]" :: [imm] "i" (BUG_BRK_IMM) \
|
|
|
|
);
|
2015-07-24 15:37:48 +00:00
|
|
|
|
2017-03-14 21:39:21 +00:00
|
|
|
|
|
|
|
#define BUG() do { \
|
|
|
|
__BUG_FLAGS(0); \
|
|
|
|
unreachable(); \
|
2015-07-24 15:37:48 +00:00
|
|
|
} while (0)
|
|
|
|
|
arm64 updates for 4.12:
- kdump support, including two necessary memblock additions:
memblock_clear_nomap() and memblock_cap_memory_range()
- ARMv8.3 HWCAP bits for JavaScript conversion instructions, complex
numbers and weaker release consistency
- arm64 ACPI platform MSI support
- arm perf updates: ACPI PMU support, L3 cache PMU in some Qualcomm
SoCs, Cortex-A53 L2 cache events and DTLB refills, MAINTAINERS update
for DT perf bindings
- architected timer errata framework (the arch/arm64 changes only)
- support for DMA_ATTR_FORCE_CONTIGUOUS in the arm64 iommu DMA API
- arm64 KVM refactoring to use common system register definitions
- remove support for ASID-tagged VIVT I-cache (no ARMv8 implementation
using it and deprecated in the architecture) together with some
I-cache handling clean-up
- PE/COFF EFI header clean-up/hardening
- define BUG() instruction without CONFIG_BUG
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1
iQIcBAABAgAGBQJZDKMoAAoJEGvWsS0AyF7xR+YP/0EMEz5MDfCv0PVYj7/AIa0G
Zphl7OhysIkeDAz7urXw9Jdl0NfORNIqmD1vZNVSc321IyNp56Od+kWd82lBrOWB
ad3nNT67pEmu0pAW7CO48ju3rTesEnEl3ra45E1tULeLihmv93jc4ZlfXgumlKq3
/GE84XJ5ZFmluuhq1zgNefeUtyl1tbxTxHJ74+INF7dTd/5sJcphpqS4Dzpb+msT
20WYliccQCBF9zBFUYHc2KjcXXKRQGxLulGS3MuoN2DLkD+U9YyR/OmA7SoXh2J2
WXC5b0x856xTQJFCJ39pb7rw5xHjt3l5zfU3VLSvqEVL/+asBqCcgGNtNUgOW1Es
dEHC6bc66Ley6mn7bbpFE3MK8D+K5q8HwMF6G5KDtIVB6DB/iQ6kzi5aXKoupxtb
1EuU4OW6cDhmOFQYjgIDofLgqbmVvJofdF6+NfxasfZmWrMgHzv0rYvaCDnAV/Tr
t7bhH7hf9/KcP/wpk86O2AMKKpgoNTqe1Qy8cWVFFLnut567Pb6zs/L3ZXfleoLv
t613yM8Zj2fE05ja8ylMDjaasidNpXGttb08/4kAn06Daaoueqla0jmduAhy4aaV
dQ3OFP9lJ5MFaFnMMTPfU3vtvNLMHuo9MZsYCrv5zCaNNs3lpAPUiPNh588ZscKa
sWx4PEiaCi+wcOsLsJvh
=SDkm
-----END PGP SIGNATURE-----
Merge tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux
Pull arm64 updates from Catalin Marinas:
- kdump support, including two necessary memblock additions:
memblock_clear_nomap() and memblock_cap_memory_range()
- ARMv8.3 HWCAP bits for JavaScript conversion instructions, complex
numbers and weaker release consistency
- arm64 ACPI platform MSI support
- arm perf updates: ACPI PMU support, L3 cache PMU in some Qualcomm
SoCs, Cortex-A53 L2 cache events and DTLB refills, MAINTAINERS update
for DT perf bindings
- architected timer errata framework (the arch/arm64 changes only)
- support for DMA_ATTR_FORCE_CONTIGUOUS in the arm64 iommu DMA API
- arm64 KVM refactoring to use common system register definitions
- remove support for ASID-tagged VIVT I-cache (no ARMv8 implementation
using it and deprecated in the architecture) together with some
I-cache handling clean-up
- PE/COFF EFI header clean-up/hardening
- define BUG() instruction without CONFIG_BUG
* tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: (92 commits)
arm64: Fix the DMA mmap and get_sgtable API with DMA_ATTR_FORCE_CONTIGUOUS
arm64: Print DT machine model in setup_machine_fdt()
arm64: pmu: Wire-up Cortex A53 L2 cache events and DTLB refills
arm64: module: split core and init PLT sections
arm64: pmuv3: handle pmuv3+
arm64: Add CNTFRQ_EL0 trap handler
arm64: Silence spurious kbuild warning on menuconfig
arm64: pmuv3: use arm_pmu ACPI framework
arm64: pmuv3: handle !PMUv3 when probing
drivers/perf: arm_pmu: add ACPI framework
arm64: add function to get a cpu's MADT GICC table
drivers/perf: arm_pmu: split out platform device probe logic
drivers/perf: arm_pmu: move irq request/free into probe
drivers/perf: arm_pmu: split cpu-local irq request/free
drivers/perf: arm_pmu: rename irq request/free functions
drivers/perf: arm_pmu: handle no platform_device
drivers/perf: arm_pmu: simplify cpu_pmu_request_irqs()
drivers/perf: arm_pmu: factor out pmu registration
drivers/perf: arm_pmu: fold init into alloc
drivers/perf: arm_pmu: define armpmu_init_fn
...
2017-05-05 19:11:37 +00:00
|
|
|
#define __WARN_FLAGS(flags) __BUG_FLAGS(BUGFLAG_WARNING|(flags))
|
2015-07-24 15:37:48 +00:00
|
|
|
|
2017-03-14 21:39:21 +00:00
|
|
|
#define HAVE_ARCH_BUG
|
2015-07-24 15:37:48 +00:00
|
|
|
|
|
|
|
#include <asm-generic/bug.h>
|
|
|
|
|
|
|
|
#endif /* ! _ARCH_ARM64_ASM_BUG_H */
|