File: builtins-ppc.c

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (90 lines) | stat: -rw-r--r-- 3,136 bytes parent folder | download | duplicates (8)
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// REQUIRES: powerpc-registered-target
// RUN: %clang_cc1 -triple powerpc-unknown-unknown -emit-llvm %s -o - \
// RUN:   | FileCheck %s
// RUN: %clang_cc1 -triple powerpc-unknown-unknown -emit-llvm %s -o - \
// RUN:   -target-cpu pwr9 | FileCheck %s --check-prefixes=P9,CHECK

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

  // CHECK: call double @llvm.ppc.setrnd(i32 %4)
  res = __builtin_ppc_set_fpscr_rn(x);
}

void test_builtin_ppc_flm() {
  volatile double res;
  // CHECK: call double @llvm.ppc.readflm()
  res = __builtin_readflm();

  // CHECK: call double @llvm.ppc.readflm()
  res = __builtin_ppc_mffs();

  // CHECK: call double @llvm.ppc.setflm(double %2)
  res = __builtin_setflm(res);

#ifdef _ARCH_PWR9
  // P9: call double @llvm.ppc.mffsl()
  res = __builtin_ppc_mffsl();
#endif
}

double test_builtin_unpack_ldbl(long double x) {
  // CHECK: call double @llvm.ppc.unpack.longdouble(ppc_fp128 %0, i32 1)
  return __builtin_unpack_longdouble(x, 1);
}

long double test_builtin_pack_ldbl(double x, double y) {
  // CHECK: call ppc_fp128 @llvm.ppc.pack.longdouble(double %0, double %1)
  return __builtin_pack_longdouble(x, y);
}

void test_builtin_ppc_maxminfe(long double a, long double b, long double c,
                               long double d) {
  volatile long double res;
  // CHECK: call ppc_fp128 (ppc_fp128, ppc_fp128, ppc_fp128, ...) @llvm.ppc.maxfe(ppc_fp128 %0, ppc_fp128 %1, ppc_fp128 %2, ppc_fp128 %3)
  res = __builtin_ppc_maxfe(a, b, c, d);

  // CHECK: call ppc_fp128 (ppc_fp128, ppc_fp128, ppc_fp128, ...) @llvm.ppc.minfe(ppc_fp128 %5, ppc_fp128 %6, ppc_fp128 %7, ppc_fp128 %8)
  res = __builtin_ppc_minfe(a, b, c, d);
}

void test_builtin_ppc_maxminfl(double a, double b, double c, double d) {
  volatile double res;
  // CHECK: call double (double, double, double, ...) @llvm.ppc.maxfl(double %0, double %1, double %2, double %3)
  res = __builtin_ppc_maxfl(a, b, c, d);

  // CHECK: call double (double, double, double, ...) @llvm.ppc.minfl(double %5, double %6, double %7, double %8)
  res = __builtin_ppc_minfl(a, b, c, d);
}

void test_builtin_ppc_maxminfs(float a, float b, float c, float d) {
  volatile float res;
  // CHECK: call float (float, float, float, ...) @llvm.ppc.maxfs(float %0, float %1, float %2, float %3)
  res = __builtin_ppc_maxfs(a, b, c, d);

  // CHECK: call float (float, float, float, ...) @llvm.ppc.minfs(float %5, float %6, float %7, float %8)
  res = __builtin_ppc_minfs(a, b, c, d);
}