58 lines
1.5 KiB
TableGen
58 lines
1.5 KiB
TableGen
|
// RUN: llvm-tblgen -gen-intrinsic-impl %s | FileCheck %s
|
||
|
|
||
|
// This test is validating that it an Intrinsic with an LLVMPointerType to
|
||
|
// llvm_any_ty still properly work after r363233. That patch rewrote the
|
||
|
// substitution handling code in the Intrinsic Emitter, and didn't consider this
|
||
|
// case, so TableGen would hit an assertion in EncodeFixedType that was checking
|
||
|
// to ensure that the substitution being processed was correctly replaced.
|
||
|
|
||
|
class IntrinsicProperty<bit is_default = 0> {
|
||
|
bit IsDefault = is_default;
|
||
|
}
|
||
|
|
||
|
class SDNodeProperty;
|
||
|
|
||
|
class ValueType<int size, int value> {
|
||
|
string Namespace = "MVT";
|
||
|
int Size = size;
|
||
|
int Value = value;
|
||
|
}
|
||
|
|
||
|
def iPTR : ValueType<0 , 254>;
|
||
|
def Any : ValueType<0 , 255>;
|
||
|
|
||
|
class LLVMType<ValueType vt> {
|
||
|
ValueType VT = vt;
|
||
|
int isAny = 0;
|
||
|
}
|
||
|
|
||
|
|
||
|
class Intrinsic<list<LLVMType> ret_types> {
|
||
|
string LLVMName = "";
|
||
|
string TargetPrefix = ""; // Set to a prefix for target-specific intrinsics.
|
||
|
list<LLVMType> RetTypes = ret_types;
|
||
|
list<LLVMType> ParamTypes = [];
|
||
|
list<IntrinsicProperty> IntrProperties = [];
|
||
|
list<SDNodeProperty> Properties = [];
|
||
|
bit isTarget = 0;
|
||
|
bit DisableDefaultAttributes = 1;
|
||
|
}
|
||
|
|
||
|
class LLVMQualPointerType<LLVMType elty>
|
||
|
: LLVMType<iPTR>{
|
||
|
LLVMType ElTy = elty;
|
||
|
int AddrSpace = 0;
|
||
|
}
|
||
|
|
||
|
class LLVMPointerType<LLVMType elty>
|
||
|
: LLVMQualPointerType<elty>;
|
||
|
|
||
|
let isAny = 1 in {
|
||
|
def llvm_any_ty : LLVMType<Any>;
|
||
|
}
|
||
|
def i8 : ValueType<8, 3>;
|
||
|
def llvm_i8_ty : LLVMType<i8>;
|
||
|
|
||
|
def int_has_ptr_to_any : Intrinsic<[LLVMPointerType<llvm_any_ty>, llvm_i8_ty]>;
|
||
|
// CHECK: /* 0 */ 21, 14, 15, 0, 2, 0
|