LLVM 22.0.0git
PostRASchedulerList.h
Go to the documentation of this file.
1//===- llvm/CodeGen/PostRASchedulerList.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#ifndef LLVM_CODEGEN_POSTRASCHEDULERLIST_H
10#define LLVM_CODEGEN_POSTRASCHEDULERLIST_H
11
13
14namespace llvm {
15
16class PostRASchedulerPass : public PassInfoMixin<PostRASchedulerPass> {
17 const TargetMachine *TM;
18
19public:
20 PostRASchedulerPass(const TargetMachine *TM) : TM(TM) {}
23
25 return MachineFunctionProperties().setNoVRegs();
26 }
27};
28
29} // namespace llvm
30
31#endif // LLVM_CODEGEN_POSTRASCHEDULERLIST_H
A container for analyses that lazily runs them and caches their results.
Definition: PassManager.h:255
Properties which a MachineFunction may have at a given point in time.
MachineFunctionProperties getRequiredProperties() const
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PostRASchedulerPass(const TargetMachine *TM)
A set of analyses that are preserved following a run of a transformation pass.
Definition: Analysis.h:112
Primary interface to the complete machine description for the target machine.
Definition: TargetMachine.h:83
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition: PassManager.h:70