//===--------- 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