| // RUN: not llvm-tblgen -I %p/../../../include -gen-global-isel-combiner \ |
| // RUN: -combiners=MyCombiner %s 2>&1| \ |
| // RUN: FileCheck %s -implicit-check-not=error: |
| |
| include "llvm/Target/Target.td" |
| include "llvm/Target/GlobalISel/Combine.td" |
| |
| def MyTargetISA : InstrInfo; |
| def MyTarget : Target { let InstructionSet = MyTargetISA; } |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: 'G_BUILD_VECTOR': GIVariadic can only be used on the last operand |
| def VariadicNotLastInList : GICombineRule< |
| (defs root:$dst), |
| (match (G_BUILD_VECTOR $dst, $a, GIVariadic<>:$b, $c)), |
| (apply (G_ANYEXT $dst, $a))>; |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: 'G_IMPLICIT_DEF': GIVariadic cannot be used on defs |
| def VariadicAsDef : GICombineRule< |
| (defs root:$dst), |
| (match (G_IMPLICIT_DEF GIVariadic<1>:$dst)), |
| (apply [{ APPLY }])>; |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: conflicting types for operand 'args': 'GIVariadic<2,4>' vs 'GIVariadic<3,6>' |
| def ConflictingInference : GICombineRule< |
| (defs root:$dst), |
| (match (G_BUILD_VECTOR $dst, GIVariadic<2, 4>:$args)), |
| (apply (G_MERGE_VALUES $dst, GIVariadic<3, 6>:$args))>; |
| |
| // CHECK: :[[@LINE+2]]:{{[0-9]+}}: error: cannot parse operand type: minimum number of arguments must be greater than zero in GIVariadic |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Failed to parse pattern: '(G_BUILD_VECTOR ?:$dst, anonymous_{{[0-9]+}}:$a)' |
| def InvalidBounds0 : GICombineRule< |
| (defs root:$dst), |
| (match (G_BUILD_VECTOR $dst, GIVariadic<0>:$a)), |
| (apply [{ APPLY }])>; |
| |
| // CHECK: :[[@LINE+2]]:{{[0-9]+}}: error: cannot parse operand type: maximum number of arguments (1) must be zero, or greater than the minimum number of arguments (1) in GIVariadic |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Failed to parse pattern: '(G_BUILD_VECTOR ?:$dst, anonymous_{{[0-9]+}}:$a)' |
| def InvalidBounds1 : GICombineRule< |
| (defs root:$dst), |
| (match (G_BUILD_VECTOR $dst, GIVariadic<1,1>:$a)), |
| (apply [{ APPLY }])>; |
| |
| // CHECK: :[[@LINE+2]]:{{[0-9]+}}: error: each instance of a GIVariadic operand must have a unique name within the match patterns |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: note: 'c' is used multiple times |
| def VariadicTypeTestEqOp : GICombineRule< |
| (defs root:$a), |
| (match (G_MERGE_VALUES $b, $c), |
| (G_BUILD_VECTOR $a, $b, GIVariadic<2, 4>:$c)), |
| (apply (G_MERGE_VALUES $a, $c))>; |
| |
| // TODO: We could support this if needed |
| |
| // CHECK: :[[@LINE+3]]:{{[0-9]+}}: error: GISpecialType is not supported in GICombinePatFrag |
| // CHECK: :[[@LINE+2]]:{{[0-9]+}}: note: operand 1 of '__PFWithVariadic_alt0_pattern_0' has type 'GIVariadic<1,0 |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Could not parse GICombinePatFrag 'PFWithVariadic' |
| def PFWithVariadic: GICombinePatFrag< |
| (outs $dst), (ins), |
| [(pattern (G_ANYEXT $dst, GIVariadic<>:$b))]>; |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Failed to parse pattern: '(PFWithVariadic ?:$dst)' |
| def UseInPF: GICombineRule< |
| (defs root:$dst), |
| (match (PFWithVariadic $dst)), |
| (apply (G_ANYEXT $dst, (i32 0)))>; |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: cannot use a GIVariadic operand on non-variadic instruction 'G_MUL' |
| def NotVariadicInstMatch : GICombineRule< |
| (defs root:$a), |
| (match (G_MUL $a, $c, GIVariadic<2, 4>:$b)), |
| (apply (G_MERGE_VALUES $a, $b, $c))>; |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: cannot use a GIVariadic operand on non-variadic instruction 'G_MUL' |
| def NotVariadicInstApply : GICombineRule< |
| (defs root:$a), |
| (match (G_BUILD_VECTOR $a, GIVariadic<2, 4>:$b)), |
| (apply (G_MUL $a, $b, $c))>; |
| |
| // CHECK: :[[@LINE+1]]:{{[0-9]+}}: error: Failed to parse one or more rules |
| def MyCombiner: GICombiner<"GenMyCombiner", [ |
| VariadicNotLastInList, |
| VariadicAsDef, |
| ConflictingInference, |
| InvalidBounds0, |
| InvalidBounds1, |
| VariadicTypeTestEqOp, |
| UseInPF, |
| NotVariadicInstMatch, |
| NotVariadicInstApply |
| ]>; |