xref: /aosp_15_r20/external/clang/test/CodeGen/arm-interrupt-attr.c (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -triple thumb-apple-darwin -target-abi aapcs -target-cpu cortex-m3 -emit-llvm -o - %s | FileCheck %s
2*67e74705SXin Li // RUN: %clang_cc1 -triple arm-apple-darwin -target-abi apcs-gnu -emit-llvm -o - %s | FileCheck %s --check-prefix=CHECK-APCS
3*67e74705SXin Li 
test_generic_interrupt()4*67e74705SXin Li __attribute__((interrupt)) void test_generic_interrupt() {
5*67e74705SXin Li   // CHECK: define arm_aapcscc void @test_generic_interrupt() [[GENERIC_ATTR:#[0-9]+]]
6*67e74705SXin Li 
7*67e74705SXin Li   // CHECK-APCS: define void @test_generic_interrupt() [[GENERIC_ATTR:#[0-9]+]]
8*67e74705SXin Li }
9*67e74705SXin Li 
test_irq_interrupt()10*67e74705SXin Li __attribute__((interrupt("IRQ"))) void test_irq_interrupt() {
11*67e74705SXin Li   // CHECK: define arm_aapcscc void @test_irq_interrupt() [[IRQ_ATTR:#[0-9]+]]
12*67e74705SXin Li }
13*67e74705SXin Li 
test_fiq_interrupt()14*67e74705SXin Li __attribute__((interrupt("FIQ"))) void test_fiq_interrupt() {
15*67e74705SXin Li   // CHECK: define arm_aapcscc void @test_fiq_interrupt() [[FIQ_ATTR:#[0-9]+]]
16*67e74705SXin Li }
17*67e74705SXin Li 
test_swi_interrupt()18*67e74705SXin Li __attribute__((interrupt("SWI"))) void test_swi_interrupt() {
19*67e74705SXin Li   // CHECK: define arm_aapcscc void @test_swi_interrupt() [[SWI_ATTR:#[0-9]+]]
20*67e74705SXin Li }
21*67e74705SXin Li 
test_abort_interrupt()22*67e74705SXin Li __attribute__((interrupt("ABORT"))) void test_abort_interrupt() {
23*67e74705SXin Li   // CHECK: define arm_aapcscc void @test_abort_interrupt() [[ABORT_ATTR:#[0-9]+]]
24*67e74705SXin Li }
25*67e74705SXin Li 
26*67e74705SXin Li 
test_undef_interrupt()27*67e74705SXin Li __attribute__((interrupt("UNDEF"))) void test_undef_interrupt() {
28*67e74705SXin Li   // CHECK: define arm_aapcscc void @test_undef_interrupt() [[UNDEF_ATTR:#[0-9]+]]
29*67e74705SXin Li }
30*67e74705SXin Li 
31*67e74705SXin Li // CHECK: attributes [[GENERIC_ATTR]] = { {{.*}} {{"interrupt"[^=]}}
32*67e74705SXin Li // CHECK: attributes [[IRQ_ATTR]] = { {{.*}} "interrupt"="IRQ"
33*67e74705SXin Li // CHECK: attributes [[FIQ_ATTR]] = { {{.*}} "interrupt"="FIQ"
34*67e74705SXin Li // CHECK: attributes [[SWI_ATTR]] = { {{.*}} "interrupt"="SWI"
35*67e74705SXin Li // CHECK: attributes [[ABORT_ATTR]] = { {{.*}} "interrupt"="ABORT"
36*67e74705SXin Li // CHECK: attributes [[UNDEF_ATTR]] = { {{.*}} "interrupt"="UNDEF"
37*67e74705SXin Li 
38*67e74705SXin Li // CHECK-APCS: attributes [[GENERIC_ATTR]] = { {{.*}} "interrupt"
39