Compiler projects using llvm
// 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, 57, 0