2016-03-08 01:19:15 +08:00
|
|
|
// REQUIRES: sparc-registered-target
|
2022-04-07 18:03:55 +08:00
|
|
|
// RUN: %clang_cc1 -no-opaque-pointers -triple sparc-unknown-unknown -emit-llvm %s -o - | FileCheck %s
|
|
|
|
// RUN: %clang_cc1 -no-opaque-pointers -triple sparc64-unknown-unknown -emit-llvm %s -o - | FileCheck -check-prefix CHECK-V9 %s
|
2016-03-08 01:19:15 +08:00
|
|
|
|
|
|
|
void test_eh_return_data_regno(void)
|
|
|
|
{
|
|
|
|
volatile int res;
|
[clang][Sparc] Fix __builtin_extract_return_addr etc.
While investigating the failures of `symbolize_pc.cpp` and
`symbolize_pc_inline.cpp` on SPARC (both Solaris and Linux), I noticed that
`__builtin_extract_return_addr` is a no-op in `clang` on all targets, while
`gcc` has non-default implementations for arm, mips, s390, and sparc.
This patch provides the SPARC implementation. For background see
`SparcISelLowering.cpp` (`SparcTargetLowering::LowerReturn_32`), the SPARC
psABI p.3-12, `%i7` and p.3-16/17, and SCD 2.4.1, p.3P-10, `%i7` and
p.3P-15.
Tested (after enabling the `sanitizer_common` tests on SPARC) on
`sparcv9-sun-solaris2.11`.
Differential Revision: https://reviews.llvm.org/D91607
2022-02-03 02:20:02 +08:00
|
|
|
res = __builtin_eh_return_data_regno(0); // CHECK,CHECKV9: store volatile i32 24
|
|
|
|
res = __builtin_eh_return_data_regno(1); // CHECK,CHECKV9: store volatile i32 25
|
|
|
|
}
|
|
|
|
|
|
|
|
void *test_extract_return_address(void)
|
|
|
|
{
|
|
|
|
// CHECK,CHECKV9: getelementptr i8, i8* %0, i32 8
|
|
|
|
return __builtin_extract_return_addr(__builtin_return_address(0));
|
|
|
|
}
|
|
|
|
|
|
|
|
struct s {
|
|
|
|
void *p;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct s test_extract_struct_return_address(void)
|
|
|
|
{
|
|
|
|
struct s s;
|
|
|
|
// CHECK: getelementptr i8, i8* %0, i32 12
|
|
|
|
// CHECK-V9: getelementptr i8, i8* %0, i32 8
|
|
|
|
s.p = __builtin_extract_return_addr(__builtin_return_address(0));
|
|
|
|
return s;
|
2016-03-08 01:19:15 +08:00
|
|
|
}
|