Home | History | Annotate | Download | only in TableGen
      1 // RUN: llvm-tblgen -gen-intrinsic %s | FileCheck %s
      2 
      3 class IntrinsicProperty;
      4 
      5 class ValueType<int size, int value> {
      6   string Namespace = "MVT";
      7   int Size = size;
      8   int Value = value;
      9 }
     10 
     11 class LLVMType<ValueType vt> {
     12   ValueType VT = vt;
     13 }
     14 
     15 class Intrinsic<string name, list<LLVMType> param_types = []> {
     16   string LLVMName = name;
     17   bit isTarget = 0;
     18   string TargetPrefix = "";
     19   list<LLVMType> RetTypes = [];
     20   list<LLVMType> ParamTypes = param_types;
     21   list<IntrinsicProperty> Properties = [];
     22 }
     23 
     24 def iAny : ValueType<0, 254>;
     25 def llvm_anyint_ty : LLVMType<iAny>;
     26 
     27 
     28 // Make sure an intrinsic name that is a prefix of another is checked after the
     29 // other.
     30 
     31 // CHECK: if (NameR.startswith("oo.bar.")) return Intrinsic::foo_bar;
     32 // CHECK: if (NameR.startswith("oo.")) return Intrinsic::foo;
     33 
     34 def int_foo : Intrinsic<"llvm.foo", [llvm_anyint_ty]>;
     35 def int_foo_bar : Intrinsic<"llvm.foo.bar", [llvm_anyint_ty]>;
     36