| 123456789101112131415161718192021222324252627282930313233343536 |
- // RUN: llvm-tblgen -gen-intrinsic %s | FileCheck %s
- // XFAIL: vg_leak
- class IntrinsicProperty;
- class ValueType<int size, int value> {
- string Namespace = "MVT";
- int Size = size;
- int Value = value;
- }
- class LLVMType<ValueType vt> {
- ValueType VT = vt;
- }
- class Intrinsic<string name, list<LLVMType> param_types = []> {
- string LLVMName = name;
- bit isTarget = 0;
- string TargetPrefix = "";
- list<LLVMType> RetTypes = [];
- list<LLVMType> ParamTypes = param_types;
- list<IntrinsicProperty> Properties = [];
- }
- def iAny : ValueType<0, 254>;
- def llvm_anyint_ty : LLVMType<iAny>;
- // Make sure an intrinsic name that is a prefix of another is checked after the
- // other.
- // CHECK: if (NameR.startswith("oo.bar.")) return Intrinsic::foo_bar;
- // CHECK: if (NameR.startswith("oo.")) return Intrinsic::foo;
- def int_foo : Intrinsic<"llvm.foo", [llvm_anyint_ty]>;
- def int_foo_bar : Intrinsic<"llvm.foo.bar", [llvm_anyint_ty]>;
|