
Register assembly printer passes in the pass registry. This makes it possible to use `llc -start-before=<target>-asm-printer ...` in tests. Adds a `char &ID` parameter to the AssemblyPrinter constructor to allow targets to use the `INITIALIZE_PASS` macros and register the pass in the pass registry. This currently has a default parameter so it won't break any targets that have not been updated.
70 lines
2.7 KiB
C++
70 lines
2.7 KiB
C++
//===-- Mips.h - Top-level interface for Mips representation ----*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains the entry points for global functions defined in
|
|
// the LLVM Mips back-end.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_LIB_TARGET_MIPS_MIPS_H
|
|
#define LLVM_LIB_TARGET_MIPS_MIPS_H
|
|
|
|
#include "MCTargetDesc/MipsMCTargetDesc.h"
|
|
#include "llvm/Target/TargetMachine.h"
|
|
|
|
#define IsMFLOMFHI(instr) \
|
|
(instr == Mips::MFLO || instr == Mips::MFLO64 || instr == Mips::MFHI || \
|
|
instr == Mips::MFHI64)
|
|
#define IsDIVMULT(instr) \
|
|
(instr == Mips::SDIV || instr == Mips::PseudoSDIV || instr == Mips::DSDIV || \
|
|
instr == Mips::PseudoDSDIV || instr == Mips::UDIV || \
|
|
instr == Mips::PseudoUDIV || instr == Mips::DUDIV || \
|
|
instr == Mips::PseudoDUDIV || instr == Mips::MULT || \
|
|
instr == Mips::PseudoMULT || instr == Mips::DMULT || \
|
|
instr == Mips::PseudoDMULT)
|
|
|
|
namespace llvm {
|
|
class FunctionPass;
|
|
class InstructionSelector;
|
|
class MipsRegisterBankInfo;
|
|
class MipsSubtarget;
|
|
class MipsTargetMachine;
|
|
class MipsTargetMachine;
|
|
class ModulePass;
|
|
class PassRegistry;
|
|
|
|
ModulePass *createMipsOs16Pass();
|
|
ModulePass *createMips16HardFloatPass();
|
|
|
|
FunctionPass *createMipsModuleISelDagPass();
|
|
FunctionPass *createMipsOptimizePICCallPass();
|
|
FunctionPass *createMipsDelaySlotFillerPass();
|
|
FunctionPass *createMipsBranchExpansion();
|
|
FunctionPass *createMipsConstantIslandPass();
|
|
FunctionPass *createMicroMipsSizeReducePass();
|
|
FunctionPass *createMipsExpandPseudoPass();
|
|
FunctionPass *createMipsPreLegalizeCombiner();
|
|
FunctionPass *createMipsPostLegalizeCombiner(bool IsOptNone);
|
|
FunctionPass *createMipsMulMulBugPass();
|
|
|
|
InstructionSelector *
|
|
createMipsInstructionSelector(const MipsTargetMachine &, const MipsSubtarget &,
|
|
const MipsRegisterBankInfo &);
|
|
|
|
void initializeMicroMipsSizeReducePass(PassRegistry &);
|
|
void initializeMipsAsmPrinterPass(PassRegistry &);
|
|
void initializeMipsBranchExpansionPass(PassRegistry &);
|
|
void initializeMipsDAGToDAGISelLegacyPass(PassRegistry &);
|
|
void initializeMipsDelaySlotFillerPass(PassRegistry &);
|
|
void initializeMipsMulMulBugFixPass(PassRegistry &);
|
|
void initializeMipsPostLegalizerCombinerPass(PassRegistry &);
|
|
void initializeMipsPreLegalizerCombinerPass(PassRegistry &);
|
|
} // namespace llvm
|
|
|
|
#endif
|