summaryrefslogtreecommitdiff
path: root/test/Sema/riscv-interrupt-attr.cpp
blob: a01999b3a1071982da5d5c1d059ec4a2ff14360f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// RUN: %clang_cc1 -x c++ -triple riscv32-unknown-elf -emit-llvm  -DCHECK_IR < %s | FileCheck %s
// RUN: %clang_cc1 -x c++ -triple riscv64-unknown-elf -emit-llvm  -DCHECK_IR < %s | FileCheck %s
// RUN: %clang_cc1 %s -triple riscv32-unknown-elf -verify -fsyntax-only
// RUN: %clang_cc1 %s -triple riscv64-unknown-elf -verify -fsyntax-only

#if defined(CHECK_IR)
// CHECK-LABEL: @_Z11foo_defaultv() #0
// CHECK: ret void
[[gnu::interrupt]] void foo_default() {}
// CHECK: attributes #0
// CHECK: "interrupt"="machine"
#else
[[gnu::interrupt]] [[gnu::interrupt]] void foo1() {} // expected-warning {{repeated RISC-V 'interrupt' attribute}} \
                                                     // expected-note {{repeated RISC-V 'interrupt' attribute is here}}
[[gnu::interrupt]] void foo2() {}
#endif