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