| // 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); |
| } |