
This commit moves RISC-V to auto-generate its target-specific SDNode types. The biggest change is that SDNodes can now be validated against their expected type profiles, and that we don't need to edit several different files when declaring a new one. This takes Sergei's work in #119709 and "finishes" it - by moving the final five RISCVISD opcodes into tablegen (including defining their types), and by ensuring the tablegen has expected closing scope comments. Co-authored-by: Sergei Barannikov <barannikov88@gmail.com>
53 lines
2.5 KiB
TableGen
53 lines
2.5 KiB
TableGen
//===-- RISCVInstrInfoZicond.td ----------------------------*- 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 describes the RISC-V instructions from the standard Integer
|
|
// Conditional operations extension (Zicond).
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// RISC-V specific DAG Nodes.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Branchless select operations, matching the semantics of the instructions
|
|
// defined in Zicond or XVentanaCondOps
|
|
def riscv_czero_eqz : RVSDNode<"CZERO_EQZ", SDTIntBinOp>; // vt.maskc for XVentanaCondOps.
|
|
def riscv_czero_nez : RVSDNode<"CZERO_NEZ", SDTIntBinOp>; // vt.maskcn for XVentanaCondOps.
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Instructions
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
let Predicates = [HasStdExtZicond] in {
|
|
def CZERO_EQZ : ALU_rr<0b0000111, 0b101, "czero.eqz">,
|
|
Sched<[WriteIALU, ReadIALU, ReadIALU]>;
|
|
def CZERO_NEZ : ALU_rr<0b0000111, 0b111, "czero.nez">,
|
|
Sched<[WriteIALU, ReadIALU, ReadIALU]>;
|
|
} // Predicates = [HasStdExtZicond]
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Pseudo-instructions and codegen patterns
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
let Predicates = [HasStdExtZicond] in {
|
|
def : Pat<(XLenVT (riscv_czero_eqz GPR:$rs1, GPR:$rc)),
|
|
(CZERO_EQZ GPR:$rs1, GPR:$rc)>;
|
|
def : Pat<(XLenVT (riscv_czero_nez GPR:$rs1, GPR:$rc)),
|
|
(CZERO_NEZ GPR:$rs1, GPR:$rc)>;
|
|
|
|
def : Pat<(XLenVT (riscv_czero_eqz GPR:$rs1, (riscv_setne (XLenVT GPR:$rc)))),
|
|
(CZERO_EQZ GPR:$rs1, GPR:$rc)>;
|
|
def : Pat<(XLenVT (riscv_czero_eqz GPR:$rs1, (riscv_seteq (XLenVT GPR:$rc)))),
|
|
(CZERO_NEZ GPR:$rs1, GPR:$rc)>;
|
|
def : Pat<(XLenVT (riscv_czero_nez GPR:$rs1, (riscv_setne (XLenVT GPR:$rc)))),
|
|
(CZERO_NEZ GPR:$rs1, GPR:$rc)>;
|
|
def : Pat<(XLenVT (riscv_czero_nez GPR:$rs1, (riscv_seteq (XLenVT GPR:$rc)))),
|
|
(CZERO_EQZ GPR:$rs1, GPR:$rc)>;
|
|
} // Predicates = [HasStdExtZicond]
|