mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-13 22:58:50 +00:00
58b914129e
Author: milena.vujosevic.janicic Reviewers: sdardis The patch extends size reduction pass for MicroMIPS. It introduces reduction of two instructions into one instruction: Two SW instructions are transformed into one SWP instrucition. Two LW instructions are transformed into one LWP instrucition. Differential Revision: https://reviews.llvm.org/D39115 llvm-svn: 334595
51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
//===-- Mips.h - Top-level interface for Mips representation ----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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"
|
|
|
|
namespace llvm {
|
|
class MipsTargetMachine;
|
|
class ModulePass;
|
|
class FunctionPass;
|
|
class MipsRegisterBankInfo;
|
|
class MipsSubtarget;
|
|
class MipsTargetMachine;
|
|
class InstructionSelector;
|
|
class PassRegistry;
|
|
|
|
ModulePass *createMipsOs16Pass();
|
|
ModulePass *createMips16HardFloatPass();
|
|
|
|
FunctionPass *createMipsModuleISelDagPass();
|
|
FunctionPass *createMipsOptimizePICCallPass();
|
|
FunctionPass *createMipsDelaySlotFillerPass();
|
|
FunctionPass *createMipsBranchExpansion();
|
|
FunctionPass *createMipsConstantIslandPass();
|
|
FunctionPass *createMicroMipsSizeReducePass();
|
|
|
|
InstructionSelector *createMipsInstructionSelector(const MipsTargetMachine &,
|
|
MipsSubtarget &,
|
|
MipsRegisterBankInfo &);
|
|
|
|
void initializeMipsDelaySlotFillerPass(PassRegistry &);
|
|
void initializeMipsBranchExpansionPass(PassRegistry &);
|
|
void initializeMicroMipsSizeReducePass(PassRegistry &);
|
|
} // end namespace llvm;
|
|
|
|
#endif
|