mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-27 16:06:05 +00:00
52 lines
3.5 KiB
C
52 lines
3.5 KiB
C
![]() |
// RUN: %clang_cc1 -triple riscv32-unknown-elf -target-feature +experimental-xqciint -emit-llvm -DCHECK_IR < %s| FileCheck %s
|
||
|
// RUN: %clang_cc1 %s -triple riscv32-unknown-elf -target-feature +experimental-xqciint -verify=enabled,both -fsyntax-only
|
||
|
// RUN: %clang_cc1 %s -triple riscv32-unknown-elf -verify=disabled,both -fsyntax-only
|
||
|
// RUN: %clang_cc1 %s -triple riscv32-unknown-elf -target-feature -experimental-xqciint -verify=disabled,both -fsyntax-only
|
||
|
// RUN: %clang_cc1 %s -triple riscv64-unknown-elf -verify=disabled,both -fsyntax-only -DRV64
|
||
|
|
||
|
#if defined(CHECK_IR)
|
||
|
// Test for QCI extension's interrupt attribute support
|
||
|
// CHECK-LABEL: @foo_nest_interrupt() #0
|
||
|
// CHECK: ret void
|
||
|
__attribute__((interrupt("qci-nest")))
|
||
|
void foo_nest_interrupt(void) {}
|
||
|
|
||
|
// CHECK-LABEL: @foo_nonnest_interrupt() #1
|
||
|
// CHECK: ret void
|
||
|
__attribute__((interrupt("qci-nonest")))
|
||
|
void foo_nonnest_interrupt(void) {}
|
||
|
|
||
|
// CHECK: attributes #0
|
||
|
// CHECK: "interrupt"="qci-nest"
|
||
|
// CHECK: attributes #1
|
||
|
// CHECK: "interrupt"="qci-nonest"
|
||
|
#else
|
||
|
// Test for QCI extension's interrupt attribute support
|
||
|
__attribute__((interrupt("qci-est"))) void foo_nest1(void) {} // both-warning {{'interrupt' attribute argument not supported: qci-est}}
|
||
|
__attribute__((interrupt("qci-noest"))) void foo_nonest1(void) {} // both-warning {{'interrupt' attribute argument not supported: qci-noest}}
|
||
|
__attribute__((interrupt(1))) void foo_nest2(void) {} // both-error {{expected string literal as argument of 'interrupt' attribute}}
|
||
|
__attribute__((interrupt("qci-nest", "qci-nonest"))) void foo1(void) {} // both-error {{'interrupt' attribute takes no more than 1 argument}}
|
||
|
__attribute__((interrupt("qci-nonest", "qci-nest"))) void foo2(void) {} // both-error {{'interrupt' attribute takes no more than 1 argument}}
|
||
|
__attribute__((interrupt("", "qci-nonest"))) void foo3(void) {} // both-error {{'interrupt' attribute takes no more than 1 argument}}
|
||
|
__attribute__((interrupt("", "qci-nest"))) void foo4(void) {} // both-error {{'interrupt' attribute takes no more than 1 argument}}
|
||
|
__attribute__((interrupt("qci-nonest", 1))) void foo5(void) {} // both-error {{'interrupt' attribute takes no more than 1 argument}}
|
||
|
__attribute__((interrupt("qci-nest", 1))) void foo6(void) {} // both-error {{'interrupt' attribute takes no more than 1 argument}}
|
||
|
|
||
|
__attribute__((interrupt("qci-nest"))) void foo_nest(void) {} // disabled-error {{RISC-V interrupt attribute 'qci-nest' requires extension 'Xqciint'}}
|
||
|
__attribute__((interrupt("qci-nonest"))) void foo_nonest(void) {} // disabled-error {{RISC-V interrupt attribute 'qci-nonest' requires extension 'Xqciint'}}
|
||
|
|
||
|
// This tests the errors for the qci interrupts when using
|
||
|
// `__attribute__((target(...)))` - but they fail on RV64, because you cannot
|
||
|
// enable xqciint on rv64.
|
||
|
#if __riscv_xlen == 32
|
||
|
__attribute__((target("arch=+xqciint"))) __attribute__((interrupt("qci-nest"))) void foo_nest_xqciint(void) {}
|
||
|
__attribute__((target("arch=+xqciint"))) __attribute__((interrupt("qci-nonest"))) void foo_nonest_xqciint(void) {}
|
||
|
|
||
|
// The attribute order is important, the interrupt attribute must come after the
|
||
|
// target attribute
|
||
|
__attribute__((interrupt("qci-nest"))) __attribute__((target("arch=+xqciint"))) void foo_nest_xqciint2(void) {} // disabled-error {{RISC-V interrupt attribute 'qci-nest' requires extension 'Xqciint'}}
|
||
|
__attribute__((interrupt("qci-nonest"))) __attribute__((target("arch=+xqciint"))) void foo_nonest_xqciint2(void) {} // disabled-error {{RISC-V interrupt attribute 'qci-nonest' requires extension 'Xqciint'}}
|
||
|
#endif
|
||
|
|
||
|
#endif
|