blob: 0ca9947ebb1ea53ae918e451129761208c7af884 [file] [edit]
// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py
// RUN: %clang_cc1 -triple riscv32 -target-feature +xandesperf -emit-llvm %s -o - \
// RUN: -disable-O0-optnone | opt -S -passes=mem2reg \
// RUN: | FileCheck %s
#include <stdint.h>
#include <riscv_nds.h>
// CHECK-LABEL: @test_ffb(
// CHECK-NEXT: entry:
// CHECK-NEXT: [[TMP0:%.*]] = call i32 @llvm.riscv.nds.ffb.i32(i32 [[A:%.*]], i32 [[B:%.*]])
// CHECK-NEXT: ret i32 [[TMP0]]
//
int32_t test_ffb(uint32_t a, uint32_t b) {
return __riscv_nds_ffb_32(a, b);
}
// CHECK-LABEL: @test_ffzmism(
// CHECK-NEXT: entry:
// CHECK-NEXT: [[TMP0:%.*]] = call i32 @llvm.riscv.nds.ffzmism.i32(i32 [[A:%.*]], i32 [[B:%.*]])
// CHECK-NEXT: ret i32 [[TMP0]]
//
int32_t test_ffzmism(uint32_t a, uint32_t b) {
return __riscv_nds_ffzmism_32(a, b);
}
// CHECK-LABEL: @test_ffmism(
// CHECK-NEXT: entry:
// CHECK-NEXT: [[TMP0:%.*]] = call i32 @llvm.riscv.nds.ffmism.i32(i32 [[A:%.*]], i32 [[B:%.*]])
// CHECK-NEXT: ret i32 [[TMP0]]
//
int32_t test_ffmism(uint32_t a, uint32_t b) {
return __riscv_nds_ffmism_32(a, b);
}
// CHECK-LABEL: @test_flmism(
// CHECK-NEXT: entry:
// CHECK-NEXT: [[TMP0:%.*]] = call i32 @llvm.riscv.nds.flmism.i32(i32 [[A:%.*]], i32 [[B:%.*]])
// CHECK-NEXT: ret i32 [[TMP0]]
//
int32_t test_flmism(uint32_t a, uint32_t b) {
return __riscv_nds_flmism_32(a, b);
}