1 //===-- AMDGPUInstructions.td - TODO: Add brief description -------===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // TODO: Add full description
12 //===----------------------------------------------------------------------===//
14 include "AMDGPUInstrEnums.td"
16 class AMDGPUInst <dag outs, dag ins, string asm, list<dag> pattern> : Instruction {
17 field bits<16> AMDILOp = 0;
18 field bits<3> Gen = 0;
19 field bit PreloadReg = 0;
21 let Namespace = "AMDIL";
22 let OutOperandList = outs;
23 let InOperandList = ins;
25 let Pattern = pattern;
26 let TSFlags{32} = PreloadReg;
27 let TSFlags{42-40} = Gen;
28 let TSFlags{63-48} = AMDILOp;
31 class AMDGPUShaderInst <dag outs, dag ins, string asm, list<dag> pattern>
32 : AMDGPUInst<outs, ins, asm, pattern> {
34 field bits<32> Inst = 0xffffffff;
38 let isCodeGenOnly = 1 in {
40 def EXPORT_REG : AMDGPUShaderInst <
44 [(int_AMDGPU_export_reg GPRF32:$src)]
47 def LOAD_INPUT : AMDGPUShaderInst <
50 "LOAD_INPUT $dst, $src",
55 def MASK_WRITE : AMDGPUShaderInst <
62 def RESERVE_REG : AMDGPUShaderInst <
65 "RESERVE_REG $dst, $src",
66 [(set GPRF32:$dst, (int_AMDGPU_reserve_reg imm:$src))]> {
70 def STORE_OUTPUT: AMDGPUShaderInst <
72 (ins GPRF32:$src0, i32imm:$src1),
73 "STORE_OUTPUT $dst, $src0, $src1",
74 [(set GPRF32:$dst, (int_AMDGPU_store_output GPRF32:$src0, imm:$src1))]
78 /* Generic helper patterns for intrinsics */
79 /* -------------------------------------- */
81 class POW_Common <AMDGPUInst log_ieee, AMDGPUInst exp_ieee, AMDGPUInst mul,
82 RegisterClass rc> : Pat <
83 (int_AMDGPU_pow rc:$src0, rc:$src1),
84 (exp_ieee (mul rc:$src1, (log_ieee rc:$src0)))
87 /* Other helper patterns */
88 /* --------------------- */
90 /* Extract element pattern */
91 class Extract_Element <ValueType sub_type, ValueType vec_type,
92 RegisterClass vec_class, int sub_idx,
93 SubRegIndex sub_reg>: Pat<
94 (sub_type (vector_extract (vec_type vec_class:$src), sub_idx)),
95 (EXTRACT_SUBREG vec_class:$src, sub_reg)
98 /* Insert element pattern */
99 class Insert_Element <ValueType elem_type, ValueType vec_type,
100 RegisterClass elem_class, RegisterClass vec_class,
101 int sub_idx, SubRegIndex sub_reg> : Pat <
103 (vec_type (vector_insert (vec_type vec_class:$vec),
104 (elem_type elem_class:$elem), sub_idx)),
105 (INSERT_SUBREG vec_class:$vec, elem_class:$elem, sub_reg)
108 include "R600Instructions.td"
110 include "SIInstrInfo.td"