Compiler projects using llvm
// RUN: %clang_cc1 -ffreestanding %s -triple=i686-- -target-feature +rdpru -emit-llvm -o - -Wall -Werror | FileCheck %s
// RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-- -target-feature +rdpru -emit-llvm -o - -Wall -Werror | FileCheck %s
// RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-- -target-cpu znver2 -emit-llvm -o - -Wall -Werror | FileCheck %s

#include <x86intrin.h>

// NOTE: This should correspond to the tests in llvm/test/CodeGen/X86/rdpru.ll

unsigned long long test_rdpru(int regid) {
  // CHECK-LABEL: test_rdpru
  // CHECK: [[RESULT:%.*]] = call i64 @llvm.x86.rdpru(i32 %{{.*}})
  // CHECK-NEXT: ret i64 [[RESULT]]
  return __rdpru(regid);
}

unsigned long long test_mperf() {
  // CHECK-LABEL: test_mperf
  // CHECK: [[RESULT:%.*]] = call i64 @llvm.x86.rdpru(i32 0)
  // CHECK-NEXT: ret i64 [[RESULT]]
  return __mperf();
}

unsigned long long test_aperf() {
  // CHECK-LABEL: test_aperf
  // CHECK: [[RESULT:%.*]] = call i64 @llvm.x86.rdpru(i32 1)
  // CHECK-NEXT: ret i64 [[RESULT]]
  return __aperf();
}

void test_direct_calls_to_builtin_rdpru(int regid) {
  // CHECK: call i64 @llvm.x86.rdpru(i32 0)
  // CHECK: call i64 @llvm.x86.rdpru(i32 1)
  // CHECK: call i64 @llvm.x86.rdpru(i32 %{{.*}})
  (void) __builtin_ia32_rdpru(0);
  (void) __builtin_ia32_rdpru(1);
  (void) __builtin_ia32_rdpru(regid);
}