//===- IntrinsicsRISCV.td - Defines RISCV intrinsics -------*- tablegen -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file defines all of the RISCV-specific intrinsics. // //===----------------------------------------------------------------------===// let TargetPrefix = "riscv" in { //===----------------------------------------------------------------------===// // Atomics class MaskedAtomicRMW32Intrinsic : Intrinsic<[llvm_i32_ty], [llvm_anyptr_ty, llvm_i32_ty, llvm_i32_ty, llvm_i32_ty], [IntrArgMemOnly, NoCapture<0>, ImmArg<3>]>; class MaskedAtomicRMW32WithSextIntrinsic : Intrinsic<[llvm_i32_ty], [llvm_anyptr_ty, llvm_i32_ty, llvm_i32_ty, llvm_i32_ty, llvm_i32_ty], [IntrArgMemOnly, NoCapture<0>, ImmArg<4>]>; def int_riscv_masked_atomicrmw_xchg_i32 : MaskedAtomicRMW32Intrinsic; def int_riscv_masked_atomicrmw_add_i32 : MaskedAtomicRMW32Intrinsic; def int_riscv_masked_atomicrmw_sub_i32 : MaskedAtomicRMW32Intrinsic; def int_riscv_masked_atomicrmw_nand_i32 : MaskedAtomicRMW32Intrinsic; def int_riscv_masked_atomicrmw_max_i32 : MaskedAtomicRMW32WithSextIntrinsic; def int_riscv_masked_atomicrmw_min_i32 : MaskedAtomicRMW32WithSextIntrinsic; def int_riscv_masked_atomicrmw_umax_i32 : MaskedAtomicRMW32Intrinsic; def int_riscv_masked_atomicrmw_umin_i32 : MaskedAtomicRMW32Intrinsic; def int_riscv_masked_cmpxchg_i32 : Intrinsic<[llvm_i32_ty], [llvm_anyptr_ty, llvm_i32_ty, llvm_i32_ty, llvm_i32_ty, llvm_i32_ty], [IntrArgMemOnly, NoCapture<0>, ImmArg<4>]>; class MaskedAtomicRMW64Intrinsic : Intrinsic<[llvm_i64_ty], [llvm_anyptr_ty, llvm_i64_ty, llvm_i64_ty, llvm_i64_ty], [IntrArgMemOnly, NoCapture<0>, ImmArg<3>]>; class MaskedAtomicRMW64WithSextIntrinsic : Intrinsic<[llvm_i64_ty], [llvm_anyptr_ty, llvm_i64_ty, llvm_i64_ty, llvm_i64_ty, llvm_i64_ty], [IntrArgMemOnly, NoCapture<0>, ImmArg<4>]>; def int_riscv_masked_atomicrmw_xchg_i64 : MaskedAtomicRMW64Intrinsic; def int_riscv_masked_atomicrmw_add_i64 : MaskedAtomicRMW64Intrinsic; def int_riscv_masked_atomicrmw_sub_i64 : MaskedAtomicRMW64Intrinsic; def int_riscv_masked_atomicrmw_nand_i64 : MaskedAtomicRMW64Intrinsic; def int_riscv_masked_atomicrmw_max_i64 : MaskedAtomicRMW64WithSextIntrinsic; def int_riscv_masked_atomicrmw_min_i64 : MaskedAtomicRMW64WithSextIntrinsic; def int_riscv_masked_atomicrmw_umax_i64 : MaskedAtomicRMW64Intrinsic; def int_riscv_masked_atomicrmw_umin_i64 : MaskedAtomicRMW64Intrinsic; def int_riscv_masked_cmpxchg_i64 : Intrinsic<[llvm_i64_ty], [llvm_anyptr_ty, llvm_i64_ty, llvm_i64_ty, llvm_i64_ty, llvm_i64_ty], [IntrArgMemOnly, NoCapture<0>, ImmArg<4>]>; } // TargetPrefix = "riscv"