LLVM 17.0.0git
ARC.h
Go to the documentation of this file.
1//===- ARC.h - Top-level interface for ARC representation -------*- 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// This file contains the entry points for global functions defined in the LLVM
10// ARC back-end.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_LIB_TARGET_ARC_ARC_H
15#define LLVM_LIB_TARGET_ARC_ARC_H
16
19
20namespace llvm {
21
22class ARCTargetMachine;
23class FunctionPass;
24class PassRegistry;
25
26FunctionPass *createARCISelDag(ARCTargetMachine &TM,
27 CodeGenOpt::Level OptLevel);
28FunctionPass *createARCExpandPseudosPass();
29FunctionPass *createARCOptAddrMode();
30FunctionPass *createARCBranchFinalizePass();
32
33} // end namespace llvm
34
35#endif // LLVM_LIB_TARGET_ARC_ARC_H
const char LLVMTargetMachineRef TM
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...
Definition: PassRegistry.h:37
Level
Code generation optimization level.
Definition: CodeGen.h:57
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
FunctionPass * createARCISelDag(ARCTargetMachine &TM, CodeGenOpt::Level OptLevel)
This pass converts a legalized DAG into a ARC-specific DAG, ready for instruction scheduling.
FunctionPass * createARCExpandPseudosPass()
void initializeARCDAGToDAGISelPass(PassRegistry &)
FunctionPass * createARCOptAddrMode()
FunctionPass * createARCBranchFinalizePass()