| // 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 |