LLVM
8.0.1
|
#include "llvm/ADT/APFloat.h"
#include "llvm/ADT/APInt.h"
#include "llvm/ADT/bit.h"
#include "llvm/Support/ErrorHandling.h"
#include "llvm/Support/MathExtras.h"
#include <cassert>
Go to the source code of this file.
Namespaces | |
llvm | |
This class represents lattice values for constants. | |
llvm::ARM_AM | |
ARM_AM - ARM Addressing Mode Stuff. | |
Enumerations | |
enum | llvm::ARM_AM::ShiftOpc { llvm::ARM_AM::no_shift = 0, llvm::ARM_AM::asr, llvm::ARM_AM::lsl, llvm::ARM_AM::lsr, llvm::ARM_AM::ror, llvm::ARM_AM::rrx } |
enum | llvm::ARM_AM::AddrOpc { llvm::ARM_AM::sub = 0, llvm::ARM_AM::add } |
enum | llvm::ARM_AM::AMSubMode { llvm::ARM_AM::bad_am_submode = 0, llvm::ARM_AM::ia, llvm::ARM_AM::ib, llvm::ARM_AM::da, llvm::ARM_AM::db } |
Functions | |
const char * | llvm::ARM_AM::getAddrOpcStr (AddrOpc Op) |
const char * | llvm::ARM_AM::getShiftOpcStr (ShiftOpc Op) |
unsigned | llvm::ARM_AM::getShiftOpcEncoding (ShiftOpc Op) |
const char * | llvm::ARM_AM::getAMSubModeStr (AMSubMode Mode) |
unsigned | llvm::ARM_AM::rotr32 (unsigned Val, unsigned Amt) |
rotr32 - Rotate a 32-bit unsigned value right by a specified # bits. More... | |
unsigned | llvm::ARM_AM::rotl32 (unsigned Val, unsigned Amt) |
rotl32 - Rotate a 32-bit unsigned value left by a specified # bits. More... | |
unsigned | llvm::ARM_AM::getSORegOpc (ShiftOpc ShOp, unsigned Imm) |
unsigned | llvm::ARM_AM::getSORegOffset (unsigned Op) |
ShiftOpc | llvm::ARM_AM::getSORegShOp (unsigned Op) |
unsigned | llvm::ARM_AM::getSOImmValImm (unsigned Imm) |
getSOImmValImm - Given an encoded imm field for the reg/imm form, return the 8-bit imm value. More... | |
unsigned | llvm::ARM_AM::getSOImmValRot (unsigned Imm) |
getSOImmValRot - Given an encoded imm field for the reg/imm form, return the rotate amount. More... | |
unsigned | llvm::ARM_AM::getSOImmValRotate (unsigned Imm) |
getSOImmValRotate - Try to handle Imm with an immediate shifter operand, computing the rotate amount to use. More... | |
int | llvm::ARM_AM::getSOImmVal (unsigned Arg) |
getSOImmVal - Given a 32-bit immediate, if it is something that can fit into an shifter_operand immediate operand, return the 12-bit encoding for it. More... | |
bool | llvm::ARM_AM::isSOImmTwoPartVal (unsigned V) |
isSOImmTwoPartVal - Return true if the specified value can be obtained by or'ing together two SOImmVal's. More... | |
unsigned | llvm::ARM_AM::getSOImmTwoPartFirst (unsigned V) |
getSOImmTwoPartFirst - If V is a value that satisfies isSOImmTwoPartVal, return the first chunk of it. More... | |
unsigned | llvm::ARM_AM::getSOImmTwoPartSecond (unsigned V) |
getSOImmTwoPartSecond - If V is a value that satisfies isSOImmTwoPartVal, return the second chunk of it. More... | |
unsigned | llvm::ARM_AM::getThumbImmValShift (unsigned Imm) |
getThumbImmValShift - Try to handle Imm with a 8-bit immediate followed by a left shift. More... | |
bool | llvm::ARM_AM::isThumbImmShiftedVal (unsigned V) |
isThumbImmShiftedVal - Return true if the specified value can be obtained by left shifting a 8-bit immediate. More... | |
unsigned | llvm::ARM_AM::getThumbImm16ValShift (unsigned Imm) |
getThumbImm16ValShift - Try to handle Imm with a 16-bit immediate followed by a left shift. More... | |
bool | llvm::ARM_AM::isThumbImm16ShiftedVal (unsigned V) |
isThumbImm16ShiftedVal - Return true if the specified value can be obtained by left shifting a 16-bit immediate. More... | |
unsigned | llvm::ARM_AM::getThumbImmNonShiftedVal (unsigned V) |
getThumbImmNonShiftedVal - If V is a value that satisfies isThumbImmShiftedVal, return the non-shiftd value. More... | |
int | llvm::ARM_AM::getT2SOImmValSplatVal (unsigned V) |
getT2SOImmValSplat - Return the 12-bit encoded representation if the specified value can be obtained by splatting the low 8 bits into every other byte or every byte of a 32-bit value. More... | |
int | llvm::ARM_AM::getT2SOImmValRotateVal (unsigned V) |
getT2SOImmValRotateVal - Return the 12-bit encoded representation if the specified value is a rotated 8-bit value. More... | |
int | llvm::ARM_AM::getT2SOImmVal (unsigned Arg) |
getT2SOImmVal - Given a 32-bit immediate, if it is something that can fit into a Thumb-2 shifter_operand immediate operand, return the 12-bit encoding for it. More... | |
unsigned | llvm::ARM_AM::getT2SOImmValRotate (unsigned V) |
bool | llvm::ARM_AM::isT2SOImmTwoPartVal (unsigned Imm) |
unsigned | llvm::ARM_AM::getT2SOImmTwoPartFirst (unsigned Imm) |
unsigned | llvm::ARM_AM::getT2SOImmTwoPartSecond (unsigned Imm) |
unsigned | llvm::ARM_AM::getAM2Opc (AddrOpc Opc, unsigned Imm12, ShiftOpc SO, unsigned IdxMode=0) |
unsigned | llvm::ARM_AM::getAM2Offset (unsigned AM2Opc) |
AddrOpc | llvm::ARM_AM::getAM2Op (unsigned AM2Opc) |
ShiftOpc | llvm::ARM_AM::getAM2ShiftOpc (unsigned AM2Opc) |
unsigned | llvm::ARM_AM::getAM2IdxMode (unsigned AM2Opc) |
unsigned | llvm::ARM_AM::getAM3Opc (AddrOpc Opc, unsigned char Offset, unsigned IdxMode=0) |
getAM3Opc - This function encodes the addrmode3 opc field. More... | |
unsigned char | llvm::ARM_AM::getAM3Offset (unsigned AM3Opc) |
AddrOpc | llvm::ARM_AM::getAM3Op (unsigned AM3Opc) |
unsigned | llvm::ARM_AM::getAM3IdxMode (unsigned AM3Opc) |
AMSubMode | llvm::ARM_AM::getAM4SubMode (unsigned Mode) |
unsigned | llvm::ARM_AM::getAM4ModeImm (AMSubMode SubMode) |
unsigned | llvm::ARM_AM::getAM5Opc (AddrOpc Opc, unsigned char Offset) |
getAM5Opc - This function encodes the addrmode5 opc field. More... | |
unsigned char | llvm::ARM_AM::getAM5Offset (unsigned AM5Opc) |
AddrOpc | llvm::ARM_AM::getAM5Op (unsigned AM5Opc) |
unsigned | llvm::ARM_AM::getAM5FP16Opc (AddrOpc Opc, unsigned char Offset) |
getAM5FP16Opc - This function encodes the addrmode5fp16 opc field. More... | |
unsigned char | llvm::ARM_AM::getAM5FP16Offset (unsigned AM5Opc) |
AddrOpc | llvm::ARM_AM::getAM5FP16Op (unsigned AM5Opc) |
unsigned | llvm::ARM_AM::createNEONModImm (unsigned OpCmode, unsigned Val) |
unsigned | llvm::ARM_AM::getNEONModImmOpCmode (unsigned ModImm) |
unsigned | llvm::ARM_AM::getNEONModImmVal (unsigned ModImm) |
uint64_t | llvm::ARM_AM::decodeNEONModImm (unsigned ModImm, unsigned &EltBits) |
decodeNEONModImm - Decode a NEON modified immediate value into the element value and the element size in bits. More... | |
bool | llvm::ARM_AM::isNEONBytesplat (unsigned Value, unsigned Size) |
bool | llvm::ARM_AM::isNEONi16splat (unsigned Value) |
Checks if Value is a correct immediate for instructions like VBIC/VORR. More... | |
unsigned | llvm::ARM_AM::encodeNEONi16splat (unsigned Value) |
bool | llvm::ARM_AM::isNEONi32splat (unsigned Value) |
Checks if Value is a correct immediate for instructions like VBIC/VORR. More... | |
unsigned | llvm::ARM_AM::encodeNEONi32splat (unsigned Value) |
Encode NEON 32 bits Splat immediate for instructions like VBIC/VORR. More... | |
float | llvm::ARM_AM::getFPImmFloat (unsigned Imm) |
int | llvm::ARM_AM::getFP16Imm (const APInt &Imm) |
getFP16Imm - Return an 8-bit floating-point version of the 16-bit floating-point value. More... | |
int | llvm::ARM_AM::getFP16Imm (const APFloat &FPImm) |
int | llvm::ARM_AM::getFP32Imm (const APInt &Imm) |
getFP32Imm - Return an 8-bit floating-point version of the 32-bit floating-point value. More... | |
int | llvm::ARM_AM::getFP32Imm (const APFloat &FPImm) |
int | llvm::ARM_AM::getFP64Imm (const APInt &Imm) |
getFP64Imm - Return an 8-bit floating-point version of the 64-bit floating-point value. More... | |
int | llvm::ARM_AM::getFP64Imm (const APFloat &FPImm) |