1*91f16700Schasinglulu/* 2*91f16700Schasinglulu * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved. 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu#ifndef ASSERT_MACROS_S 7*91f16700Schasinglulu#define ASSERT_MACROS_S 8*91f16700Schasinglulu 9*91f16700Schasinglulu /* 10*91f16700Schasinglulu * Assembler macro to enable asm_assert. We assume that the stack is 11*91f16700Schasinglulu * initialized prior to invoking this macro. 12*91f16700Schasinglulu */ 13*91f16700Schasinglulu#define ASM_ASSERT(_cc) \ 14*91f16700Schasinglulu.ifndef .L_assert_filename ;\ 15*91f16700Schasinglulu .pushsection .rodata.str1.1, "aS" ;\ 16*91f16700Schasinglulu .L_assert_filename: ;\ 17*91f16700Schasinglulu .string __FILE__ ;\ 18*91f16700Schasinglulu .popsection ;\ 19*91f16700Schasinglulu.endif ;\ 20*91f16700Schasinglulu b##_cc 300f ;\ 21*91f16700Schasinglulu ldr r0, =.L_assert_filename ;\ 22*91f16700Schasinglulu ldr r1, =__LINE__ ;\ 23*91f16700Schasinglulu b asm_assert;\ 24*91f16700Schasinglulu300: 25*91f16700Schasinglulu 26*91f16700Schasinglulu#endif /* ASSERT_MACROS_S */ 27