1//============------------ BuiltinsLoongArchBase.def -------------*- C++ -*-==// 2// 3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4// See https://llvm.org/LICENSE.txt for license information. 5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6// 7//===----------------------------------------------------------------------===// 8// 9// This file defines the LoongArch-specific basic builtin function database. 10// Users of this file must define the BUILTIN macro to make use of this 11// information. 12// 13//===----------------------------------------------------------------------===// 14 15TARGET_BUILTIN(__builtin_loongarch_cacop_d, "vWiUWiWi", "nc", "64bit") 16TARGET_BUILTIN(__builtin_loongarch_cacop_w, "viUii", "nc", "32bit") 17TARGET_BUILTIN(__builtin_loongarch_dbar, "vIUi", "nc", "") 18TARGET_BUILTIN(__builtin_loongarch_ibar, "vIUi", "nc", "") 19TARGET_BUILTIN(__builtin_loongarch_movfcsr2gr, "UiIUi", "nc", "f") 20TARGET_BUILTIN(__builtin_loongarch_movgr2fcsr, "vIUiUi", "nc", "f") 21TARGET_BUILTIN(__builtin_loongarch_break, "vIUi", "nc", "") 22TARGET_BUILTIN(__builtin_loongarch_syscall, "vIUi", "nc", "") 23TARGET_BUILTIN(__builtin_loongarch_cpucfg, "UiUi", "nc", "") 24TARGET_BUILTIN(__builtin_loongarch_asrtle_d, "vWiWi", "nc", "64bit") 25TARGET_BUILTIN(__builtin_loongarch_asrtgt_d, "vWiWi", "nc", "64bit") 26 27TARGET_BUILTIN(__builtin_loongarch_crc_w_b_w, "iii", "nc", "64bit") 28TARGET_BUILTIN(__builtin_loongarch_crc_w_h_w, "iii", "nc", "64bit") 29TARGET_BUILTIN(__builtin_loongarch_crc_w_w_w, "iii", "nc", "64bit") 30TARGET_BUILTIN(__builtin_loongarch_crc_w_d_w, "iWii", "nc", "64bit") 31TARGET_BUILTIN(__builtin_loongarch_crcc_w_b_w, "iii", "nc", "64bit") 32TARGET_BUILTIN(__builtin_loongarch_crcc_w_h_w, "iii", "nc", "64bit") 33TARGET_BUILTIN(__builtin_loongarch_crcc_w_w_w, "iii", "nc", "64bit") 34TARGET_BUILTIN(__builtin_loongarch_crcc_w_d_w, "iWii", "nc", "64bit") 35 36TARGET_BUILTIN(__builtin_loongarch_csrrd_w, "UiIUi", "nc", "") 37TARGET_BUILTIN(__builtin_loongarch_csrrd_d, "UWiIUi", "nc", "64bit") 38TARGET_BUILTIN(__builtin_loongarch_csrwr_w, "UiUiIUi", "nc", "") 39TARGET_BUILTIN(__builtin_loongarch_csrwr_d, "UWiUWiIUi", "nc", "64bit") 40TARGET_BUILTIN(__builtin_loongarch_csrxchg_w, "UiUiUiIUi", "nc", "") 41TARGET_BUILTIN(__builtin_loongarch_csrxchg_d, "UWiUWiUWiIUi", "nc", "64bit") 42 43TARGET_BUILTIN(__builtin_loongarch_iocsrrd_b, "UiUi", "nc", "") 44TARGET_BUILTIN(__builtin_loongarch_iocsrrd_h, "UiUi", "nc", "") 45TARGET_BUILTIN(__builtin_loongarch_iocsrrd_w, "UiUi", "nc", "") 46TARGET_BUILTIN(__builtin_loongarch_iocsrrd_d, "UWiUi", "nc", "64bit") 47TARGET_BUILTIN(__builtin_loongarch_iocsrwr_b, "vUiUi", "nc", "") 48TARGET_BUILTIN(__builtin_loongarch_iocsrwr_h, "vUiUi", "nc", "") 49TARGET_BUILTIN(__builtin_loongarch_iocsrwr_w, "vUiUi", "nc", "") 50TARGET_BUILTIN(__builtin_loongarch_iocsrwr_d, "vUWiUi", "nc", "64bit") 51 52TARGET_BUILTIN(__builtin_loongarch_lddir_d, "WiWiIUWi", "nc", "64bit") 53TARGET_BUILTIN(__builtin_loongarch_ldpte_d, "vWiIUWi", "nc", "64bit") 54 55TARGET_BUILTIN(__builtin_loongarch_frecipe_s, "ff", "nc", "f,frecipe") 56TARGET_BUILTIN(__builtin_loongarch_frecipe_d, "dd", "nc", "d,frecipe") 57TARGET_BUILTIN(__builtin_loongarch_frsqrte_s, "ff", "nc", "f,frecipe") 58TARGET_BUILTIN(__builtin_loongarch_frsqrte_d, "dd", "nc", "d,frecipe") 59