llvm.org GIT mirror llvm / release_1 lib / Target / X86 / X86RegisterInfo.h
release_1

Tree @release_1 (Download .tar.gz)

X86RegisterInfo.h @release_1raw · history · blame

//===- X86RegisterInfo.h - X86 Register Information Impl --------*- C++ -*-===//
// 
//                     The LLVM Compiler Infrastructure
//
// This file was developed by the LLVM research group and is distributed under
// the University of Illinois Open Source License. See LICENSE.TXT for details.
// 
//===----------------------------------------------------------------------===//
//
// This file contains the X86 implementation of the MRegisterInfo class.
//
//===----------------------------------------------------------------------===//

#ifndef X86REGISTERINFO_H
#define X86REGISTERINFO_H

#include "llvm/Target/MRegisterInfo.h"

class Type;

#include "X86GenRegisterInfo.h.inc"

struct X86RegisterInfo : public X86GenRegisterInfo {
  X86RegisterInfo();
  const TargetRegisterClass* getRegClassForType(const Type* Ty) const;

  /// Code Generation virtual methods...
  void storeRegToStackSlot(MachineBasicBlock &MBB,
			   MachineBasicBlock::iterator &MBBI,
			   unsigned SrcReg, int FrameIndex,
			   const TargetRegisterClass *RC) const;

  void loadRegFromStackSlot(MachineBasicBlock &MBB,
			    MachineBasicBlock::iterator &MBBI,
			    unsigned DestReg, int FrameIndex,
			    const TargetRegisterClass *RC) const;
  
  void copyRegToReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator &MBBI,
		   unsigned DestReg, unsigned SrcReg,
		   const TargetRegisterClass *RC) const;

  void eliminateCallFramePseudoInstr(MachineFunction &MF,
				     MachineBasicBlock &MBB,
				     MachineBasicBlock::iterator &I) const;

  void eliminateFrameIndex(MachineFunction &MF,
			   MachineBasicBlock::iterator &II) const;

  void processFunctionBeforeFrameFinalized(MachineFunction &MF) const;

  void emitPrologue(MachineFunction &MF) const;
  void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const;
};

#endif