builtins-ppc.c
1.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// REQUIRES: powerpc-registered-target
// RUN: %clang_cc1 -triple powerpc-unknown-unknown -emit-llvm %s -o - | FileCheck %s
void test_eh_return_data_regno()
{
volatile int res;
res = __builtin_eh_return_data_regno(0); // CHECK: store volatile i32 3
res = __builtin_eh_return_data_regno(1); // CHECK: store volatile i32 4
}
// CHECK-LABEL: define i64 @test_builtin_ppc_get_timebase
long long test_builtin_ppc_get_timebase() {
// CHECK: call i64 @llvm.readcyclecounter()
return __builtin_ppc_get_timebase();
}
void test_builtin_ppc_setrnd() {
volatile double res;
volatile int x = 100;
// CHECK: call double @llvm.ppc.setrnd(i32 2)
res = __builtin_setrnd(2);
// CHECK: call double @llvm.ppc.setrnd(i32 100)
res = __builtin_setrnd(100);
// CHECK: call double @llvm.ppc.setrnd(i32 %2)
res = __builtin_setrnd(x);
}
void test_builtin_ppc_flm() {
volatile double res;
// CHECK: call double @llvm.ppc.readflm()
res = __builtin_readflm();
// CHECK: call double @llvm.ppc.setflm(double %1)
res = __builtin_setflm(res);
}