view llvm/test/TableGen/GlobalISelEmitter-PR39045.td @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children 1f2b6ac9f198
line wrap: on
line source

// RUN: llvm-tblgen -gen-global-isel -I %p/../../include -I %p/Common  %s -o %t
// RUN: FileCheck %s < %t

// Both predicates should be tested
// CHECK-DAG: GIM_CheckCxxInsnPredicate, /*MI*/0, /*FnId*/GIPFP_MI_Predicate_pat_frag_b,
// CHECK-DAG: GIM_CheckCxxInsnPredicate, /*MI*/0, /*FnId*/GIPFP_MI_Predicate_pat_frag_a,

include "llvm/Target/Target.td"
include "GlobalISelEmitterCommon.td"


def pat_frag_a : PatFrag <(ops node:$ptr), (load node:$ptr), [{}]> {
   let PredicateCode = [{ return isInstA(MI); }];
   let GISelPredicateCode = [{ return isInstA(MI); }];
}

def pat_frag_b : PatFrag <(ops node:$ptr), (load node:$ptr), [{}]> {
   let PredicateCode = [{ return isInstB(MI); }];
   let GISelPredicateCode = [{ return isInstB(MI); }];
}

def inst_a : Instruction {
  let OutOperandList = (outs GPR32:$dst);
  let InOperandList = (ins GPR32:$src);
}
def inst_b : Instruction {
  let OutOperandList = (outs GPR32:$dst);
  let InOperandList = (ins GPR32:$src);
}

def : Pat <
  (pat_frag_a GPR32:$src),
  (inst_a GPR32:$src)
>;

def : Pat <
  (pat_frag_b GPR32:$src),
  (inst_b GPR32:$src)
>;