LLVM 20.0.0git
GIMatchTableExecutor.h
Go to the documentation of this file.
1//===- llvm/CodeGen/GlobalISel/GIMatchTableExecutor.h -----------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9/// \file This file declares the GIMatchTableExecutor API, the opcodes supported
10/// by the match table, and some associated data structures used by the
11/// executor's implementation (see `GIMatchTableExecutorImpl.h`).
12//
13//===----------------------------------------------------------------------===//
14
15#ifndef LLVM_CODEGEN_GLOBALISEL_GIMATCHTABLEEXECUTOR_H
16#define LLVM_CODEGEN_GLOBALISEL_GIMATCHTABLEEXECUTOR_H
17
18#include "llvm/ADT/ArrayRef.h"
19#include "llvm/ADT/Bitset.h"
20#include "llvm/ADT/DenseMap.h"
26#include "llvm/IR/Function.h"
27#include <bitset>
28#include <cstddef>
29#include <cstdint>
30#include <functional>
31#include <initializer_list>
32#include <optional>
33#include <vector>
34
35namespace llvm {
36
37class BlockFrequencyInfo;
38class CodeGenCoverage;
39class MachineBasicBlock;
40class ProfileSummaryInfo;
41class APInt;
42class APFloat;
43class GISelKnownBits;
44class MachineInstr;
45class MachineIRBuilder;
46class MachineInstrBuilder;
47class MachineFunction;
48class MachineOperand;
49class MachineRegisterInfo;
50class RegisterBankInfo;
51class TargetInstrInfo;
52class TargetRegisterInfo;
53
54enum {
57};
58
59/// The MatchTable is encoded as an array of bytes.
60/// Thus, opcodes are expected to be <255.
61///
62/// Operands can be variable-sized, their size is always after their name
63/// in the docs, e.g. "Foo(4)" means that "Foo" takes 4 entries in the table,
64/// so 4 bytes. "Foo()"
65///
66/// As a general rule of thumb:
67/// - Instruction & Operand IDs are ULEB128
68/// - LLT IDs are 1 byte
69/// - Predicates and target opcodes, register and register class IDs are 2
70/// bytes.
71/// - Indexes into the table are 4 bytes.
72/// - Inline constants are 8 bytes
73///
74/// Design notes:
75/// - Inst/Op IDs have to be LEB128 because some targets generate
76/// extremely long patterns which need more than 255 temporaries.
77/// We could just use 2 bytes everytime, but then some targets like
78/// X86/AMDGPU that have no need for it will pay the price all the time.
79enum {
80 /// Begin a try-block to attempt a match and jump to OnFail if it is
81 /// unsuccessful.
82 /// - OnFail(4) - The MatchTable entry at which to resume if the match fails.
83 ///
84 /// FIXME: This ought to take an argument indicating the number of try-blocks
85 /// to exit on failure. It's usually one but the last match attempt of
86 /// a block will need more. The (implemented) alternative is to tack a
87 /// GIM_Reject on the end of each try-block which is simpler but
88 /// requires an extra opcode and iteration in the interpreter on each
89 /// failed match.
91
92 /// Switch over the opcode on the specified instruction
93 /// - InsnID(ULEB128) - Instruction ID
94 /// - LowerBound(2) - numerically minimum opcode supported
95 /// - UpperBound(2) - numerically maximum + 1 opcode supported
96 /// - Default(4) - failure jump target
97 /// - JumpTable(4)... - (UpperBound - LowerBound) (at least 2) jump targets
99
100 /// Switch over the LLT on the specified instruction operand
101 /// - InsnID(ULEB128) - Instruction ID
102 /// - OpIdx(ULEB128) - Operand index
103 /// - LowerBound(2) - numerically minimum Type ID supported
104 /// - UpperBound(2) - numerically maximum + 1 Type ID supported
105 /// - Default(4) - failure jump target
106 /// - JumpTable(4)... - (UpperBound - LowerBound) (at least 2) jump targets
108
109 /// Record the specified instruction.
110 /// The IgnoreCopies variant ignores COPY instructions.
111 /// - NewInsnID(ULEB128) - Instruction ID to define
112 /// - InsnID(ULEB128) - Instruction ID
113 /// - OpIdx(ULEB128) - Operand index
116
117 /// Check the feature bits
118 /// Feature(2) - Expected features
120
121 /// Check the opcode on the specified instruction
122 /// - InsnID(ULEB128) - Instruction ID
123 /// - Opc(2) - Expected opcode
125
126 /// Check the opcode on the specified instruction, checking 2 acceptable
127 /// alternatives.
128 /// - InsnID(ULEB128) - Instruction ID
129 /// - Opc(2) - Expected opcode
130 /// - Opc(2) - Alternative expected opcode
132
133 /// Check the instruction has the right number of operands
134 /// - InsnID(ULEB128) - Instruction ID
135 /// - Ops(ULEB128) - Expected number of operands
137
138 /// Check the instruction has a number of operands <= or >= than given number.
139 /// - InsnID(ULEB128) - Instruction ID
140 /// - Ops(ULEB128) - Number of operands
143
144 /// Check an immediate predicate on the specified instruction
145 /// - InsnID(ULEB128) - Instruction ID
146 /// - Pred(2) - The predicate to test
148 /// Check an immediate predicate on the specified instruction via an APInt.
149 /// - InsnID(ULEB128) - Instruction ID
150 /// - Pred(2) - The predicate to test
152 /// Check a floating point immediate predicate on the specified instruction.
153 /// - InsnID(ULEB128) - Instruction ID
154 /// - Pred(2) - The predicate to test
156 /// Check an immediate predicate on the specified instruction
157 /// - InsnID(ULEB128) - Instruction ID
158 /// - OpIdx(ULEB128) - Operand index
159 /// - Pred(2) - The predicate to test
161
162 /// Check a memory operation has the specified atomic ordering.
163 /// - InsnID(ULEB128) - Instruction ID
164 /// - Ordering(ULEB128) - The AtomicOrdering value
168
169 /// Check the size of the memory access for the given machine memory operand.
170 /// - InsnID(ULEB128) - Instruction ID
171 /// - MMOIdx(ULEB128) - MMO index
172 /// - Size(4) - The size in bytes of the memory access
174
175 /// Check the address space of the memory access for the given machine memory
176 /// operand.
177 /// - InsnID(ULEB128) - Instruction ID
178 /// - MMOIdx(ULEB128) - MMO index
179 /// - NumAddrSpace(1) - Number of valid address spaces
180 /// - AddrSpaceN(ULEB128) - An allowed space of the memory access
181 /// - AddrSpaceN+1 ...
183
184 /// Check the minimum alignment of the memory access for the given machine
185 /// memory operand.
186 /// - InsnID(ULEB128) - Instruction ID
187 /// - MMOIdx(ULEB128) - MMO index
188 /// - MinAlign(1) - Minimum acceptable alignment
190
191 /// Check the size of the memory access for the given machine memory operand
192 /// against the size of an operand.
193 /// - InsnID(ULEB128) - Instruction ID
194 /// - MMOIdx(ULEB128) - MMO index
195 /// - OpIdx(ULEB128) - The operand index to compare the MMO against
199
200 /// Check if this is a vector that can be treated as a vector splat
201 /// constant. This is valid for both G_BUILD_VECTOR as well as
202 /// G_BUILD_VECTOR_TRUNC. For AllOnes refers to individual bits, so a -1
203 /// element.
204 /// - InsnID(ULEB128) - Instruction ID
207
208 /// Check a trivial predicate which takes no arguments.
209 /// This can be used by executors to implement custom flags that don't fit in
210 /// target features.
211 /// - Pred(2) - Predicate ID to check.
213
214 /// Check a generic C++ instruction predicate
215 /// - InsnID(ULEB128) - Instruction ID
216 /// - PredicateID(2) - The ID of the predicate function to call
218
219 /// Check if there's no use of the first result.
220 /// - InsnID(ULEB128) - Instruction ID
222
223 /// Check if there's one use of the first result.
224 /// - InsnID(ULEB128) - Instruction ID
226
227 /// Check the type for the specified operand
228 /// - InsnID(ULEB128) - Instruction ID
229 /// - OpIdx(ULEB128) - Operand index
230 /// - Ty(1) - Expected type
232 /// GIM_CheckType but InsnID is omitted and defaults to zero.
234
235 /// Check the type of a pointer to any address space.
236 /// - InsnID(ULEB128) - Instruction ID
237 /// - OpIdx(ULEB128) - Operand index
238 /// - SizeInBits(ULEB128) - The size of the pointer value in bits.
240
241 /// Check the register bank for the specified operand
242 /// - InsnID(ULEB128) - Instruction ID
243 /// - OpIdx(ULEB128) - Operand index
244 /// - RC(2) - Expected register bank (specified as a register class)
246 /// GIM_CheckRegBankForClass but InsnID is omitted and defaults to zero.
248
249 /// Check the operand matches a complex predicate
250 /// - InsnID(ULEB128) - Instruction ID
251 /// - OpIdx(ULEB128) - Operand index
252 /// - RendererID(2) - The renderer to hold the result
253 /// - Pred(2) - Complex predicate ID
255
256 /// Check the operand is a specific integer
257 /// - InsnID(ULEB128) - Instruction ID
258 /// - OpIdx(ULEB128) - Operand index
259 /// - Val(8) Expected integer
261
262 /// Check the operand is a specific 8-bit signed integer
263 /// - InsnID(ULEB128) - Instruction ID
264 /// - OpIdx(ULEB128) - Operand index
265 /// - Val(1) Expected integer
267
268 /// Check the operand is a specific literal integer (i.e. MO.isImm() or
269 /// MO.isCImm() is true).
270 /// - InsnID(ULEB128) - Instruction ID
271 /// - OpIdx(ULEB128) - Operand index
272 /// - Val(8) - Expected integer
274
275 /// Check the operand is a specific intrinsic ID
276 /// - InsnID(ULEB128) - Instruction ID
277 /// - OpIdx(ULEB128) - Operand index
278 /// - IID(2) - Expected Intrinsic ID
280
281 /// Check the operand is a specific predicate
282 /// - InsnID(ULEB128) - Instruction ID
283 /// - OpIdx(ULEB128) - Operand index
284 /// - Pred(2) - Expected predicate
286
287 /// Check the specified operand is an MBB
288 /// - InsnID(ULEB128) - Instruction ID
289 /// - OpIdx(ULEB128) - Operand index
291
292 /// Check the specified operand is an Imm
293 /// - InsnID(ULEB128) - Instruction ID
294 /// - OpIdx(ULEB128) - Operand index
296
297 /// Checks if the matched instructions numbered [1, 1+N) can
298 /// be folded into the root (inst 0).
299 /// - Num(1)
301
302 /// Check the specified operands are identical.
303 /// The IgnoreCopies variant looks through COPY instructions before
304 /// comparing the operands.
305 /// The "All" variants check all operands starting from the index.
306 /// - InsnID(ULEB128) - Instruction ID
307 /// - OpIdx(ULEB128) - Operand index
308 /// - OtherInsnID(ULEB128) - Other instruction ID
309 /// - OtherOpIdx(ULEB128) - Other operand index
314
315 /// Check we can replace all uses of a register with another.
316 /// - OldInsnID(ULEB128)
317 /// - OldOpIdx(ULEB128)
318 /// - NewInsnID(ULEB128)
319 /// - NewOpIdx(ULEB128)
321
322 /// Check that a matched instruction has, or doesn't have a MIFlag.
323 ///
324 /// - InsnID(ULEB128) - Instruction to check.
325 /// - Flags(4) - (can be one or more flags OR'd together)
328
329 /// Predicates with 'let PredicateCodeUsesOperands = 1' need to examine some
330 /// named operands that will be recorded in RecordedOperands. Names of these
331 /// operands are referenced in predicate argument list. Emitter determines
332 /// StoreIdx(corresponds to the order in which names appear in argument list).
333 /// - InsnID(ULEB128) - Instruction ID
334 /// - OpIdx(ULEB128) - Operand index
335 /// - StoreIdx(ULEB128) - Store location in RecordedOperands.
337
338 /// Records an operand's register type into the set of temporary types.
339 /// - InsnID(ULEB128) - Instruction ID
340 /// - OpIdx(ULEB128) - Operand index
341 /// - TempTypeIdx(1) - Temp Type Index, always negative.
343
344 /// Fail the current try-block, or completely fail to match if there is no
345 /// current try-block.
347
348 //=== Renderers ===
349
350 /// Mutate an instruction
351 /// - NewInsnID(ULEB128) - Instruction ID to define
352 /// - OldInsnID(ULEB128) - Instruction ID to mutate
353 /// - NewOpcode(2) - The new opcode to use
355
356 /// Build a new instruction
357 /// - InsnID(ULEB128) - Instruction ID to define
358 /// - Opcode(2) - The new opcode to use
360 /// GIR_BuildMI but InsnID is omitted and defaults to zero.
362
363 /// Builds a constant and stores its result in a TempReg.
364 /// - TempRegID(ULEB128) - Temp Register to define.
365 /// - Imm(8) - The immediate to add
367
368 /// Copy an operand to the specified instruction
369 /// - NewInsnID(ULEB128) - Instruction ID to modify
370 /// - OldInsnID(ULEB128) - Instruction ID to copy from
371 /// - OpIdx(ULEB128) - The operand to copy
373 /// GIR_Copy but with both New/OldInsnIDs omitted and defaulting to zero.
375
376 /// Copies all operand starting from OpIdx in OldInsnID into the new
377 /// instruction NewInsnID.
378 /// - NewInsnID(ULEB128) - Instruction ID to modify
379 /// - OldInsnID(ULEB128) - Instruction ID to copy from
380 /// - OpIdx(ULEB128) - The first operand to copy
382
383 /// Copy an operand to the specified instruction or add a zero register if the
384 /// operand is a zero immediate.
385 /// - NewInsnID(ULEB128) - Instruction ID to modify
386 /// - OldInsnID(ULEB128) - Instruction ID to copy from
387 /// - OpIdx(ULEB128) - The operand to copy
388 /// - ZeroReg(2) - The zero register to use
390 /// Copy an operand to the specified instruction
391 /// - NewInsnID(ULEB128) - Instruction ID to modify
392 /// - OldInsnID(ULEB128) - Instruction ID to copy from
393 /// - OpIdx(ULEB128) - The operand to copy
394 /// - SubRegIdx(2) - The subregister to copy
396
397 /// Add an implicit register def to the specified instruction
398 /// - InsnID(ULEB128) - Instruction ID to modify
399 /// - RegNum(2) - The register to add
400 /// - Flags(2) - Register Flags
402 /// Add an implicit register use to the specified instruction
403 /// - InsnID(ULEB128) - Instruction ID to modify
404 /// - RegNum(2) - The register to add
406 /// Add an register to the specified instruction
407 /// - InsnID(ULEB128) - Instruction ID to modify
408 /// - RegNum(2) - The register to add
409 /// - Flags(2) - Register Flags
411
412 /// Adds an intrinsic ID to the specified instruction.
413 /// - InsnID(ULEB128) - Instruction ID to modify
414 /// - IID(2) - Intrinsic ID
416
417 /// Marks the implicit def of a register as dead.
418 /// - InsnID(ULEB128) - Instruction ID to modify
419 /// - OpIdx(ULEB128) - The implicit def operand index
420 ///
421 /// OpIdx starts at 0 for the first implicit def.
423
424 /// Set or unset a MIFlag on an instruction.
425 ///
426 /// - InsnID(ULEB128) - Instruction to modify.
427 /// - Flags(4) - (can be one or more flags OR'd together)
430
431 /// Copy the MIFlags of a matched instruction into an
432 /// output instruction. The flags are OR'd together.
433 ///
434 /// - InsnID(ULEB128) - Instruction to modify.
435 /// - OldInsnID(ULEB128) - Matched instruction to copy flags from.
437
438 /// Add a temporary register to the specified instruction
439 /// - InsnID(ULEB128) - Instruction ID to modify
440 /// - TempRegID(ULEB128) - The temporary register ID to add
441 /// - TempRegFlags(2) - The register flags to set
443
444 /// Add a temporary register to the specified instruction without
445 /// setting any flags.
446 /// - InsnID(ULEB128) - Instruction ID to modify
447 /// - TempRegID(ULEB128) - The temporary register ID to add
449
450 /// Add a temporary register to the specified instruction
451 /// - InsnID(ULEB128) - Instruction ID to modify
452 /// - TempRegID(ULEB128) - The temporary register ID to add
453 /// - TempRegFlags(2) - The register flags to set
454 /// - SubRegIndex(2) - The subregister index to set
456
457 /// Add an immediate to the specified instruction
458 /// - InsnID(ULEB128) - Instruction ID to modify
459 /// - Imm(8) - The immediate to add
461
462 /// Add signed 8 bit immediate to the specified instruction
463 /// - InsnID(ULEB128) - Instruction ID to modify
464 /// - Imm(1) - The immediate to add
466
467 /// Add an CImm to the specified instruction
468 /// - InsnID(ULEB128) - Instruction ID to modify
469 /// - Ty(1) - Type of the constant immediate.
470 /// - Imm(8) - The immediate to add
472
473 /// Render complex operands to the specified instruction
474 /// - InsnID(ULEB128) - Instruction ID to modify
475 /// - RendererID(2) - The renderer to call
477 /// Render sub-operands of complex operands to the specified instruction
478 /// - InsnID(ULEB128) - Instruction ID to modify
479 /// - RendererID(2) - The renderer to call
480 /// - RenderOpID(ULEB128) - The suboperand to render.
482 /// Render subregisters of suboperands of complex operands to the
483 /// specified instruction
484 /// - InsnID(ULEB128) - Instruction ID to modify
485 /// - RendererID(2) - The renderer to call
486 /// - RenderOpID(ULEB128) - The suboperand to render
487 /// - SubRegIdx(2) - The subregister to extract
489
490 /// Render operands to the specified instruction using a custom function
491 /// - InsnID(ULEB128) - Instruction ID to modify
492 /// - OldInsnID(ULEB128) - Instruction ID to get the matched operand from
493 /// - RendererFnID(2) - Custom renderer function to call
495
496 /// Calls a C++ function that concludes the current match.
497 /// The C++ function is free to return false and reject the match, or
498 /// return true and mutate the instruction(s) (or do nothing, even).
499 /// - FnID(2) - The function to call.
501
502 /// Render operands to the specified instruction using a custom function,
503 /// reading from a specific operand.
504 /// - InsnID(ULEB128) - Instruction ID to modify
505 /// - OldInsnID(ULEB128) - Instruction ID to get the matched operand from
506 /// - OpIdx(ULEB128) - Operand index in OldInsnID the render function should
507 /// read
508 /// from..
509 /// - RendererFnID(2) - Custom renderer function to call
511
512 /// Render a G_CONSTANT operator as a sign-extended immediate.
513 /// - NewInsnID(ULEB128) - Instruction ID to modify
514 /// - OldInsnID(ULEB128) - Instruction ID to copy from
515 /// The operand index is implicitly 1.
517
518 /// Render a G_FCONSTANT operator as a sign-extended immediate.
519 /// - NewInsnID(ULEB128) - Instruction ID to modify
520 /// - OldInsnID(ULEB128) - Instruction ID to copy from
521 /// The operand index is implicitly 1.
523
524 /// Constrain an instruction operand to a register class.
525 /// - InsnID(ULEB128) - Instruction ID to modify
526 /// - OpIdx(ULEB128) - Operand index
527 /// - RCEnum(2) - Register class enumeration value
529
530 /// Constrain an instructions operands according to the instruction
531 /// description.
532 /// - InsnID(ULEB128) - Instruction ID to modify
534 /// GIR_ConstrainSelectedInstOperands but InsnID is omitted and defaults to
535 /// zero.
537
538 /// Merge all memory operands into instruction.
539 /// - InsnID(ULEB128) - Instruction ID to modify
540 /// - NumInsnID(1) - Number of instruction IDs following this argument
541 /// - MergeInsnID(ULEB128)... - One or more Instruction ID to merge into the
542 /// result.
544
545 /// Erase from parent.
546 /// - InsnID(ULEB128) - Instruction ID to erase
548
549 /// Combines both a GIR_EraseFromParent 0 + GIR_Done
551
552 /// Create a new temporary register that's not constrained.
553 /// - TempRegID(ULEB128) - The temporary register ID to initialize.
554 /// - Ty(1) - Expected type
556
557 /// Replaces all references to a register from an instruction
558 /// with another register from another instruction.
559 /// - OldInsnID(ULEB128)
560 /// - OldOpIdx(ULEB128)
561 /// - NewInsnID(ULEB128)
562 /// - NewOpIdx(ULEB128)
564
565 /// Replaces all references to a register with a temporary register.
566 /// - OldInsnID(ULEB128)
567 /// - OldOpIdx(ULEB128)
568 /// - TempRegIdx(ULEB128)
570
571 /// A successful emission
573
574 /// Increment the rule coverage counter.
575 /// - RuleID(4) - The ID of the rule that was covered.
577
578 /// Keeping track of the number of the GI opcodes. Must be the last entry.
580};
581
582/// Provides the logic to execute GlobalISel match tables, which are used by the
583/// instruction selector and instruction combiners as their engine to match and
584/// apply MIR patterns.
586public:
587 virtual ~GIMatchTableExecutor() = default;
588
590 GISelKnownBits *KB = nullptr;
591 MachineFunction *MF = nullptr;
594 // For some predicates, we need to track the current MBB.
596
598
599 /// Setup per-MF executor state.
601 CodeGenCoverage *covinfo = nullptr,
602 ProfileSummaryInfo *psi = nullptr,
603 BlockFrequencyInfo *bfi = nullptr) {
604 CoverageInfo = covinfo;
605 KB = kb;
606 MF = &mf;
607 PSI = psi;
608 BFI = bfi;
609 CurMBB = nullptr;
611 }
612
613protected:
615 std::optional<SmallVector<std::function<void(MachineInstrBuilder &)>, 4>>;
618
620 std::vector<ComplexRendererFns::value_type> Renderers;
623 /// Named operands that predicate with 'let PredicateCodeUsesOperands = 1'
624 /// referenced in its argument list. Operands are inserted at index set by
625 /// emitter, it corresponds to the order in which names appear in argument
626 /// list. Currently such predicates don't have more then 3 arguments.
627 std::array<const MachineOperand *, 3> RecordedOperands;
628
629 /// Types extracted from an instruction's operand.
630 /// Whenever a type index is negative, we look here instead.
632
633 MatcherState(unsigned MaxRenderers);
634 };
635
637 const auto &F = MF->getFunction();
638 return F.hasOptSize() || F.hasMinSize() ||
640 }
641
642public:
643 template <class PredicateBitset, class ComplexMatcherMemFn,
644 class CustomRendererFn>
645 struct ExecInfoTy {
646 ExecInfoTy(const LLT *TypeObjects, size_t NumTypeObjects,
647 const PredicateBitset *FeatureBitsets,
648 const ComplexMatcherMemFn *ComplexPredicates,
649 const CustomRendererFn *CustomRenderers)
653
654 for (size_t I = 0; I < NumTypeObjects; ++I)
656 }
658 const PredicateBitset *FeatureBitsets;
659 const ComplexMatcherMemFn *ComplexPredicates;
660 const CustomRendererFn *CustomRenderers;
661
663 };
664
665protected:
667
668 /// Execute a given matcher table and return true if the match was successful
669 /// and false otherwise.
670 template <class TgtExecutor, class PredicateBitset, class ComplexMatcherMemFn,
671 class CustomRendererFn>
672 bool executeMatchTable(TgtExecutor &Exec, MatcherState &State,
673 const ExecInfoTy<PredicateBitset, ComplexMatcherMemFn,
674 CustomRendererFn> &ExecInfo,
675 MachineIRBuilder &Builder, const uint8_t *MatchTable,
677 const TargetRegisterInfo &TRI,
678 const RegisterBankInfo &RBI,
679 const PredicateBitset &AvailableFeatures,
681
682 virtual const uint8_t *getMatchTable() const {
683 llvm_unreachable("Should have been overridden by tablegen if used");
684 }
685
686 virtual bool testImmPredicate_I64(unsigned, int64_t) const {
688 "Subclasses must override this with a tablegen-erated function");
689 }
690 virtual bool testImmPredicate_APInt(unsigned, const APInt &) const {
692 "Subclasses must override this with a tablegen-erated function");
693 }
694 virtual bool testImmPredicate_APFloat(unsigned, const APFloat &) const {
696 "Subclasses must override this with a tablegen-erated function");
697 }
698 virtual bool testMIPredicate_MI(unsigned, const MachineInstr &,
699 const MatcherState &State) const {
701 "Subclasses must override this with a tablegen-erated function");
702 }
703
704 virtual bool testSimplePredicate(unsigned) const {
705 llvm_unreachable("Subclass does not implement testSimplePredicate!");
706 }
707
708 virtual bool runCustomAction(unsigned, const MatcherState &State,
709 NewMIVector &OutMIs) const {
710 llvm_unreachable("Subclass does not implement runCustomAction!");
711 }
712
713 bool isOperandImmEqual(const MachineOperand &MO, int64_t Value,
715 bool Splat = false) const;
716
717 /// Return true if the specified operand is a G_PTR_ADD with a G_CONSTANT on
718 /// the right-hand side. GlobalISel's separation of pointer and integer types
719 /// means that we don't need to worry about G_OR with equivalent semantics.
721 const MachineRegisterInfo &MRI) const;
722
723 /// Return true if MI can obviously be folded into IntoMI.
724 /// MI and IntoMI do not need to be in the same basic blocks, but MI must
725 /// preceed IntoMI.
727
728 template <typename Ty> static Ty readBytesAs(const uint8_t *MatchTable) {
729 Ty Ret;
730 memcpy(&Ret, MatchTable, sizeof(Ret));
731 return Ret;
732 }
733
735 unsigned FirstVarOp) {
736 auto Operands = drop_begin(MI.operands(), FirstVarOp);
737 return {Operands.begin(), Operands.end()};
738 }
739
740public:
741 // Faster ULEB128 decoder tailored for the Match Table Executor.
742 //
743 // - Arguments are fixed to avoid mid-function checks.
744 // - Unchecked execution, assumes no error.
745 // - Fast common case handling (1 byte values).
748 uint64_t &CurrentIdx) {
749 uint64_t Value = MatchTable[CurrentIdx++];
750 if (LLVM_UNLIKELY(Value >= 128)) {
751 Value &= 0x7f;
752 unsigned Shift = 7;
753 do {
754 uint64_t Slice = MatchTable[CurrentIdx] & 0x7f;
755 Value += Slice << Shift;
756 Shift += 7;
757 } while (MatchTable[CurrentIdx++] >= 128);
758 }
759 return Value;
760 }
761};
762
763} // end namespace llvm
764
765#endif // LLVM_CODEGEN_GLOBALISEL_GIMATCHTABLEEXECUTOR_H
unsigned const MachineRegisterInfo * MRI
#define LLVM_UNLIKELY(EXPR)
Definition: Compiler.h:241
#define LLVM_ATTRIBUTE_ALWAYS_INLINE
LLVM_ATTRIBUTE_ALWAYS_INLINE - On compilers where we have a directive to do so, mark a method "always...
Definition: Compiler.h:261
#define LLVM_ATTRIBUTE_RESTRICT
LLVM_ATTRIBUTE_RESTRICT - Annotates a pointer to tell the compiler that it is not aliased in the curr...
Definition: Compiler.h:286
This file defines the DenseMap class.
const HexagonInstrInfo * TII
IRTranslator LLVM IR MI
Implement a low-level type suitable for MachineInstr level instruction selection.
#define F(x, y, z)
Definition: MD5.cpp:55
#define I(x, y, z)
Definition: MD5.cpp:58
mir Rename Register Operands
unsigned const TargetRegisterInfo * TRI
This file defines the SmallVector class.
Class for arbitrary precision integers.
Definition: APInt.h:78
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
Provides the logic to execute GlobalISel match tables, which are used by the instruction selector and...
virtual bool testSimplePredicate(unsigned) const
bool executeMatchTable(TgtExecutor &Exec, MatcherState &State, const ExecInfoTy< PredicateBitset, ComplexMatcherMemFn, CustomRendererFn > &ExecInfo, MachineIRBuilder &Builder, const uint8_t *MatchTable, const TargetInstrInfo &TII, MachineRegisterInfo &MRI, const TargetRegisterInfo &TRI, const RegisterBankInfo &RBI, const PredicateBitset &AvailableFeatures, CodeGenCoverage *CoverageInfo) const
Execute a given matcher table and return true if the match was successful and false otherwise.
virtual bool testImmPredicate_APFloat(unsigned, const APFloat &) const
virtual const uint8_t * getMatchTable() const
virtual bool testImmPredicate_APInt(unsigned, const APInt &) const
virtual bool testMIPredicate_MI(unsigned, const MachineInstr &, const MatcherState &State) const
bool isBaseWithConstantOffset(const MachineOperand &Root, const MachineRegisterInfo &MRI) const
Return true if the specified operand is a G_PTR_ADD with a G_CONSTANT on the right-hand side.
virtual bool testImmPredicate_I64(unsigned, int64_t) const
static Ty readBytesAs(const uint8_t *MatchTable)
std::optional< SmallVector< std::function< void(MachineInstrBuilder &)>, 4 > > ComplexRendererFns
bool shouldOptForSize(const MachineFunction *MF) const
static LLVM_ATTRIBUTE_ALWAYS_INLINE uint64_t fastDecodeULEB128(const uint8_t *LLVM_ATTRIBUTE_RESTRICT MatchTable, uint64_t &CurrentIdx)
bool isOperandImmEqual(const MachineOperand &MO, int64_t Value, const MachineRegisterInfo &MRI, bool Splat=false) const
virtual ~GIMatchTableExecutor()=default
virtual void setupMF(MachineFunction &mf, GISelKnownBits *kb, CodeGenCoverage *covinfo=nullptr, ProfileSummaryInfo *psi=nullptr, BlockFrequencyInfo *bfi=nullptr)
Setup per-MF executor state.
bool isObviouslySafeToFold(MachineInstr &MI, MachineInstr &IntoMI) const
Return true if MI can obviously be folded into IntoMI.
virtual bool runCustomAction(unsigned, const MatcherState &State, NewMIVector &OutMIs) const
static ArrayRef< MachineOperand > getRemainingOperands(const MachineInstr &MI, unsigned FirstVarOp)
virtual void setupGeneratedPerFunctionState(MachineFunction &MF)=0
Function & getFunction()
Return the LLVM function that this machine code represents.
Helper class to build MachineInstr.
Representation of each machine instruction.
Definition: MachineInstr.h:69
MachineOperand class - Representation of each machine instruction operand.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
Analysis providing profile information.
Holds all the information related to register banks.
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Definition: SmallVector.h:1210
TargetInstrInfo - Interface to description of machine instruction set.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
LLVM Value Representation.
Definition: Value.h:74
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
Definition: STLExtras.h:329
@ GIR_AddIntrinsicID
Adds an intrinsic ID to the specified instruction.
@ GIR_ComplexRenderer
Render complex operands to the specified instruction.
@ GIR_ReplaceRegWithTempReg
Replaces all references to a register with a temporary register.
@ GIR_ComplexSubOperandRenderer
Render sub-operands of complex operands to the specified instruction.
@ GIR_MakeTempReg
Create a new temporary register that's not constrained.
@ GIM_CheckMemorySizeEqualTo
Check the size of the memory access for the given machine memory operand.
@ GIM_RootCheckType
GIM_CheckType but InsnID is omitted and defaults to zero.
@ GIM_RootCheckRegBankForClass
GIM_CheckRegBankForClass but InsnID is omitted and defaults to zero.
@ GIR_Done
A successful emission.
@ GIM_RecordNamedOperand
Predicates with 'let PredicateCodeUsesOperands = 1' need to examine some named operands that will be ...
@ GIM_Try
Begin a try-block to attempt a match and jump to OnFail if it is unsuccessful.
@ GIR_RootConstrainSelectedInstOperands
GIR_ConstrainSelectedInstOperands but InsnID is omitted and defaults to zero.
@ GIM_CheckIsBuildVectorAllOnes
Check if this is a vector that can be treated as a vector splat constant.
@ GIM_CheckNumOperands
Check the instruction has the right number of operands.
@ GIR_AddCImm
Add an CImm to the specified instruction.
@ GIR_ConstrainOperandRC
Constrain an instruction operand to a register class.
@ GIM_CheckI64ImmPredicate
Check an immediate predicate on the specified instruction.
@ GIR_AddImplicitDef
Add an implicit register def to the specified instruction.
@ GIM_CheckAPIntImmPredicate
Check an immediate predicate on the specified instruction via an APInt.
@ GIM_CheckHasNoUse
Check if there's no use of the first result.
@ GIM_CheckPointerToAny
Check the type of a pointer to any address space.
@ GIM_CheckMemorySizeEqualToLLT
Check the size of the memory access for the given machine memory operand against the size of an opera...
@ GIM_CheckComplexPattern
Check the operand matches a complex predicate.
@ GIR_CopyConstantAsSImm
Render a G_CONSTANT operator as a sign-extended immediate.
@ GIR_EraseFromParent
Erase from parent.
@ GIM_SwitchType
Switch over the LLT on the specified instruction operand.
@ GIR_CopySubReg
Copy an operand to the specified instruction.
@ GIR_MutateOpcode
Mutate an instruction.
@ GIM_CheckIsBuildVectorAllZeros
@ GIM_CheckAtomicOrderingOrStrongerThan
@ GIR_AddRegister
Add an register to the specified instruction.
@ GIR_AddTempSubRegister
Add a temporary register to the specified instruction.
@ GIM_CheckIsSafeToFold
Checks if the matched instructions numbered [1, 1+N) can be folded into the root (inst 0).
@ GIM_CheckOpcode
Check the opcode on the specified instruction.
@ GIR_ReplaceReg
Replaces all references to a register from an instruction with another register from another instruct...
@ GIM_SwitchOpcode
Switch over the opcode on the specified instruction.
@ GIM_CheckAPFloatImmPredicate
Check a floating point immediate predicate on the specified instruction.
@ GIM_CheckAllSameOperandIgnoreCopies
@ GIM_Reject
Fail the current try-block, or completely fail to match if there is no current try-block.
@ GIR_AddSimpleTempRegister
Add a temporary register to the specified instruction without setting any flags.
@ GIR_AddTempRegister
Add a temporary register to the specified instruction.
@ GIR_Copy
Copy an operand to the specified instruction.
@ GIR_AddImm
Add an immediate to the specified instruction.
@ GIR_CopyFConstantAsFPImm
Render a G_FCONSTANT operator as a sign-extended immediate.
@ GIU_NumOpcodes
Keeping track of the number of the GI opcodes. Must be the last entry.
@ GIR_CopyRemaining
Copies all operand starting from OpIdx in OldInsnID into the new instruction NewInsnID.
@ GIM_MIFlags
Check that a matched instruction has, or doesn't have a MIFlag.
@ GIR_CopyOrAddZeroReg
Copy an operand to the specified instruction or add a zero register if the operand is a zero immediat...
@ GIM_CheckMemoryAlignment
Check the minimum alignment of the memory access for the given machine memory operand.
@ GIM_CheckIsSameOperand
Check the specified operands are identical.
@ GIR_AddImm8
Add signed 8 bit immediate to the specified instruction.
@ GIM_CheckIsSameOperandIgnoreCopies
@ GIM_CheckIsMBB
Check the specified operand is an MBB.
@ GIM_CheckNumOperandsLE
Check the instruction has a number of operands <= or >= than given number.
@ GIM_CheckMemorySizeGreaterThanLLT
@ GIM_CheckRegBankForClass
Check the register bank for the specified operand.
@ GIM_CheckNumOperandsGE
@ GIM_CheckLiteralInt
Check the operand is a specific literal integer (i.e.
@ GIM_CheckMemorySizeLessThanLLT
@ GIM_RecordRegType
Records an operand's register type into the set of temporary types.
@ GIM_CheckHasOneUse
Check if there's one use of the first result.
@ GIM_CheckAllSameOperand
@ GIR_EraseRootFromParent_Done
Combines both a GIR_EraseFromParent 0 + GIR_Done.
@ GIR_CopyMIFlags
Copy the MIFlags of a matched instruction into an output instruction.
@ GIR_DoneWithCustomAction
Calls a C++ function that concludes the current match.
@ GIR_BuildMI
Build a new instruction.
@ GIM_RecordInsn
Record the specified instruction.
@ GIM_CheckIsImm
Check the specified operand is an Imm.
@ GIR_BuildRootMI
GIR_BuildMI but InsnID is omitted and defaults to zero.
@ GIM_CheckFeatures
Check the feature bits Feature(2) - Expected features.
@ GIM_CheckCanReplaceReg
Check we can replace all uses of a register with another.
@ GIM_CheckMemoryAddressSpace
Check the address space of the memory access for the given machine memory operand.
@ GIR_CustomRenderer
Render operands to the specified instruction using a custom function.
@ GIM_CheckAtomicOrdering
Check a memory operation has the specified atomic ordering.
@ GIM_CheckType
Check the type for the specified operand.
@ GIM_CheckConstantInt8
Check the operand is a specific 8-bit signed integer.
@ GIM_CheckCmpPredicate
Check the operand is a specific predicate.
@ GIM_CheckOpcodeIsEither
Check the opcode on the specified instruction, checking 2 acceptable alternatives.
@ GIR_SetImplicitDefDead
Marks the implicit def of a register as dead.
@ GIR_BuildConstant
Builds a constant and stores its result in a TempReg.
@ GIR_AddImplicitUse
Add an implicit register use to the specified instruction.
@ GIR_Coverage
Increment the rule coverage counter.
@ GIR_MergeMemOperands
Merge all memory operands into instruction.
@ GIM_CheckImmOperandPredicate
Check an immediate predicate on the specified instruction.
@ GIM_CheckAtomicOrderingWeakerThan
@ GIR_SetMIFlags
Set or unset a MIFlag on an instruction.
@ GIM_CheckIntrinsicID
Check the operand is a specific intrinsic ID.
@ GIM_CheckConstantInt
Check the operand is a specific integer.
@ GIR_RootToRootCopy
GIR_Copy but with both New/OldInsnIDs omitted and defaulting to zero.
@ GIR_ComplexSubOperandSubRegRenderer
Render subregisters of suboperands of complex operands to the specified instruction.
@ GIM_RecordInsnIgnoreCopies
@ GIR_CustomOperandRenderer
Render operands to the specified instruction using a custom function, reading from a specific operand...
@ GIR_ConstrainSelectedInstOperands
Constrain an instructions operands according to the instruction description.
@ GIM_CheckCxxInsnPredicate
Check a generic C++ instruction predicate.
@ GIM_CheckSimplePredicate
Check a trivial predicate which takes no arguments.
@ GICXXCustomAction_Invalid
bool shouldOptForSize(const MachineBasicBlock &MBB, ProfileSummaryInfo *PSI, BlockFrequencyInfo *BFI)
Returns true if the given block should be optimized for size.
Definition: Utils.cpp:1637
ExecInfoTy(const LLT *TypeObjects, size_t NumTypeObjects, const PredicateBitset *FeatureBitsets, const ComplexMatcherMemFn *ComplexPredicates, const CustomRendererFn *CustomRenderers)
SmallDenseMap< LLT, unsigned, 64 > TypeIDMap
const ComplexMatcherMemFn * ComplexPredicates
std::array< const MachineOperand *, 3 > RecordedOperands
Named operands that predicate with 'let PredicateCodeUsesOperands = 1' referenced in its argument lis...
SmallVector< LLT, 4 > RecordedTypes
Types extracted from an instruction's operand.
DenseMap< unsigned, unsigned > TempRegisters
std::vector< ComplexRendererFns::value_type > Renderers