llvm.org GIT mirror llvm / release_32 include / llvm / AddressingMode.h
release_32

Tree @release_32 (Download .tar.gz)

AddressingMode.h @release_32raw · history · blame

//===--------- llvm/AddressingMode.h - Addressing Mode    -------*- 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 addressing mode data structures which are shared
//  between LSR and a number of places in the codegen.
//
//===----------------------------------------------------------------------===//

#ifndef LLVM_ADDRESSING_MODE_H
#define LLVM_ADDRESSING_MODE_H

#include "llvm/Support/DataTypes.h"

namespace llvm {

class GlobalValue;

/// AddrMode - This represents an addressing mode of:
///    BaseGV + BaseOffs + BaseReg + Scale*ScaleReg
/// If BaseGV is null,  there is no BaseGV.
/// If BaseOffs is zero, there is no base offset.
/// If HasBaseReg is false, there is no base register.
/// If Scale is zero, there is no ScaleReg.  Scale of 1 indicates a reg with
/// no scale.
///
struct AddrMode {
  GlobalValue *BaseGV;
  int64_t      BaseOffs;
  bool         HasBaseReg;
  int64_t      Scale;
  AddrMode() : BaseGV(0), BaseOffs(0), HasBaseReg(false), Scale(0) {}
};

} // End llvm namespace

#endif