gem5  v19.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Classes | Typedefs | Enumerations | Functions
HsailISA Namespace Reference

Classes

class  ArithInst
 
class  AtomicInst
 
class  AtomicInstBase
 
class  Barrier
 
class  BrDirectInst
 
class  BrIndirectInst
 
class  BrInstBase
 
class  BrnDirectInst
 
class  BrnIndirectInst
 
class  BrnInstBase
 
class  Call
 
class  CbrDirectInst
 
class  CbrIndirectInst
 
class  CbrInstBase
 
class  ClassInst
 
class  CmovInst
 
class  CmpInst
 
class  CmpInstBase
 
class  CommonInstBase
 
class  CvtInst
 
class  Decoder
 
class  ExtractInsertInst
 
class  GPUISA
 
class  HsailDataType
 
class  HsailGPUStaticInst
 
class  HsailOperandType
 
class  LdaInst
 
class  LdaInstBase
 
class  LdInst
 
class  LdInstBase
 
struct  MachInst
 
class  MemFence
 
class  MemInst
 
class  PopcountInst
 
class  Ret
 
class  ShiftInst
 
class  SpecialInst1Src
 
class  SpecialInst1SrcBase
 
class  SpecialInstNoSrc
 
class  SpecialInstNoSrcBase
 
class  SpecialInstNoSrcNoDest
 
class  StInst
 
class  StInstBase
 
class  Stub
 
class  ThreeNonUniformSourceInst
 
class  ThreeNonUniformSourceInstBase
 
class  TwoNonUniformSourceInst
 
class  TwoNonUniformSourceInstBase
 

Typedefs

typedef uint32_t RawMachInst
 
typedef HsailOperandType< CRegOperand, CRegOrImmOperandCRegOperandType
 
typedef HsailOperandType< SRegOperand, SRegOrImmOperandSRegOperandType
 
typedef HsailOperandType< DRegOperand, DRegOrImmOperandDRegOperandType
 
typedef HsailDataType< CRegOperandType, bool, Enums::M_U8, VT_32, 1 > B1
 
typedef HsailDataType< SRegOperandType, uint8_t, Enums::M_U8, VT_32, 1 > B8
 
typedef HsailDataType< SRegOperandType, uint16_t, Enums::M_U16, VT_32, 1 > B16
 
typedef HsailDataType< SRegOperandType, uint32_t, Enums::M_U32, VT_32, 1 > B32
 
typedef HsailDataType< DRegOperandType, uint64_t, Enums::M_U64, VT_64, 1 > B64
 
typedef HsailDataType< SRegOperandType, int8_t, Enums::M_S8, VT_32S8
 
typedef HsailDataType< SRegOperandType, int16_t, Enums::M_S16, VT_32S16
 
typedef HsailDataType< SRegOperandType, int32_t, Enums::M_S32, VT_32S32
 
typedef HsailDataType< DRegOperandType, int64_t, Enums::M_S64, VT_64S64
 
typedef HsailDataType< SRegOperandType, uint8_t, Enums::M_U8, VT_32U8
 
typedef HsailDataType< SRegOperandType, uint16_t, Enums::M_U16, VT_32U16
 
typedef HsailDataType< SRegOperandType, uint32_t, Enums::M_U32, VT_32U32
 
typedef HsailDataType< DRegOperandType, uint64_t, Enums::M_U64, VT_64U64
 
typedef HsailDataType< SRegOperandType, float, Enums::M_F32, VT_32F32
 
typedef HsailDataType< DRegOperandType, double, Enums::M_F64, VT_64F64
 

Enumerations

enum  {
  MAGIC_PRINT_WF_32 = 0, MAGIC_PRINT_WF_64, MAGIC_PRINT_LANE, MAGIC_PRINT_LANE_64,
  MAGIC_PRINT_WF_FLOAT, MAGIC_SIM_BREAK, MAGIC_PREF_SUM, MAGIC_REDUCTION,
  MAGIC_MASKLANE_LOWER, MAGIC_MASKLANE_UPPER, MAGIC_JOIN_WF_BAR, MAGIC_WAIT_WF_BAR,
  MAGIC_PANIC, MAGIC_ATOMIC_NR_ADD_GLOBAL_U32_REG, MAGIC_ATOMIC_NR_ADD_GROUP_U32_REG, MAGIC_LOAD_GLOBAL_U32_REG,
  MAGIC_XACT_CAS_LD, MAGIC_MOST_SIG_THD, MAGIC_MOST_SIG_BROADCAST, MAGIC_PRINT_WFID_32,
  MAGIC_PRINT_WFID_64
}
 

Functions

GPUStaticInstdecodeBrn (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
GPUStaticInstdecodeCbr (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
GPUStaticInstdecodeBr (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename T >
bool fpclassify (T src0, uint32_t src1)
 
template<typename T >
bool compare (T src0, T src1, Brig::BrigCompareOperation cmpOp)
 
template<typename T >
int32_t firstbit (T src0)
 
const char * cmpOpToString (Brig::BrigCompareOperation cmpOp)
 
template<typename T >
heynot (T arg)
 
template<>
bool heynot< bool > (bool arg)
 
const char * atomicOpToString (BrigAtomicOperation brigOp)
 
template<typename DataType >
GPUStaticInstdecodeLda (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename MemDT , typename DestDT >
GPUStaticInstdecodeLd2 (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename MemDT >
GPUStaticInstdecodeLd (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename DataType , typename SrcDataType >
GPUStaticInstdecodeSt (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename DataType , typename AddrOperandType , int NumSrcOperands>
GPUStaticInstconstructAtomic (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename DataType , int NumSrcOperands>
GPUStaticInstdecodeAtomicHelper (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename DataType >
GPUStaticInstdecodeAtomic (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
template<typename DataType >
GPUStaticInstdecodeAtomicNoRet (const Brig::BrigInstBase *ib, const BrigObject *obj)
 
static Addr calcPrivAddr (Addr addr, Wavefront *w, int lane, GPUStaticInst *i)
 

Typedef Documentation

◆ B1

typedef HsailDataType<CRegOperandType, bool, Enums::M_U8, VT_32, 1> HsailISA::B1

Definition at line 76 of file decl.hh.

◆ B16

typedef HsailDataType<SRegOperandType, uint16_t, Enums::M_U16, VT_32, 1> HsailISA::B16

Definition at line 80 of file decl.hh.

◆ B32

typedef HsailDataType<SRegOperandType, uint32_t, Enums::M_U32, VT_32, 1> HsailISA::B32

Definition at line 83 of file decl.hh.

◆ B64

typedef HsailDataType<DRegOperandType, uint64_t, Enums::M_U64, VT_64, 1> HsailISA::B64

Definition at line 86 of file decl.hh.

◆ B8

typedef HsailDataType<SRegOperandType, uint8_t, Enums::M_U8, VT_32, 1> HsailISA::B8

Definition at line 77 of file decl.hh.

◆ CRegOperandType

Definition at line 57 of file decl.hh.

◆ DRegOperandType

Definition at line 59 of file decl.hh.

◆ F32

typedef HsailDataType<SRegOperandType, float, Enums::M_F32, VT_32> HsailISA::F32

Definition at line 98 of file decl.hh.

◆ F64

typedef HsailDataType<DRegOperandType, double, Enums::M_F64, VT_64> HsailISA::F64

Definition at line 99 of file decl.hh.

◆ RawMachInst

typedef uint32_t HsailISA::RawMachInst

Definition at line 54 of file gpu_types.hh.

◆ S16

typedef HsailDataType<SRegOperandType, int16_t, Enums::M_S16, VT_32> HsailISA::S16

Definition at line 89 of file decl.hh.

◆ S32

typedef HsailDataType<SRegOperandType, int32_t, Enums::M_S32, VT_32> HsailISA::S32

Definition at line 90 of file decl.hh.

◆ S64

typedef HsailDataType<DRegOperandType, int64_t, Enums::M_S64, VT_64> HsailISA::S64

Definition at line 91 of file decl.hh.

◆ S8

typedef HsailDataType<SRegOperandType, int8_t, Enums::M_S8, VT_32> HsailISA::S8

Definition at line 88 of file decl.hh.

◆ SRegOperandType

Definition at line 58 of file decl.hh.

◆ U16

typedef HsailDataType<SRegOperandType, uint16_t, Enums::M_U16, VT_32> HsailISA::U16

Definition at line 94 of file decl.hh.

◆ U32

typedef HsailDataType<SRegOperandType, uint32_t, Enums::M_U32, VT_32> HsailISA::U32

Definition at line 95 of file decl.hh.

◆ U64

typedef HsailDataType<DRegOperandType, uint64_t, Enums::M_U64, VT_64> HsailISA::U64

Definition at line 96 of file decl.hh.

◆ U8

typedef HsailDataType<SRegOperandType, uint8_t, Enums::M_U8, VT_32> HsailISA::U8

Definition at line 93 of file decl.hh.

Enumeration Type Documentation

◆ anonymous enum

anonymous enum
Enumerator
MAGIC_PRINT_WF_32 
MAGIC_PRINT_WF_64 
MAGIC_PRINT_LANE 
MAGIC_PRINT_LANE_64 
MAGIC_PRINT_WF_FLOAT 
MAGIC_SIM_BREAK 
MAGIC_PREF_SUM 
MAGIC_REDUCTION 
MAGIC_MASKLANE_LOWER 
MAGIC_MASKLANE_UPPER 
MAGIC_JOIN_WF_BAR 
MAGIC_WAIT_WF_BAR 
MAGIC_PANIC 
MAGIC_ATOMIC_NR_ADD_GLOBAL_U32_REG 
MAGIC_ATOMIC_NR_ADD_GROUP_U32_REG 
MAGIC_LOAD_GLOBAL_U32_REG 
MAGIC_XACT_CAS_LD 
MAGIC_MOST_SIG_THD 
MAGIC_MOST_SIG_BROADCAST 
MAGIC_PRINT_WFID_32 
MAGIC_PRINT_WFID_64 

Definition at line 54 of file pseudo_inst.cc.

Function Documentation

◆ atomicOpToString()

const char * HsailISA::atomicOpToString ( BrigAtomicOperation  brigOp)

◆ calcPrivAddr()

static Addr HsailISA::calcPrivAddr ( Addr  addr,
Wavefront w,
int  lane,
GPUStaticInst i 
)
static

◆ cmpOpToString()

const char * HsailISA::cmpOpToString ( Brig::BrigCompareOperation  cmpOp)

◆ compare()

template<typename T >
bool HsailISA::compare ( src0,
src1,
Brig::BrigCompareOperation  cmpOp 
)

◆ constructAtomic()

template<typename DataType , typename AddrOperandType , int NumSrcOperands>
GPUStaticInst* HsailISA::constructAtomic ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeAtomic()

template<typename DataType >
GPUStaticInst* HsailISA::decodeAtomic ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

Definition at line 1753 of file mem.hh.

References ArmISA::at, Brig::BrigInstAtomic::atomicOperation, and Brig::BRIG_ATOMIC_CAS.

◆ decodeAtomicHelper()

template<typename DataType , int NumSrcOperands>
GPUStaticInst* HsailISA::decodeAtomicHelper ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeAtomicNoRet()

template<typename DataType >
GPUStaticInst* HsailISA::decodeAtomicNoRet ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

Definition at line 1766 of file mem.hh.

References ArmISA::at, Brig::BrigInstAtomic::atomicOperation, and Brig::BRIG_ATOMIC_CAS.

◆ decodeBr()

GPUStaticInst * HsailISA::decodeBr ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeBrn()

GPUStaticInst * HsailISA::decodeBrn ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeCbr()

GPUStaticInst * HsailISA::decodeCbr ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeLd()

template<typename MemDT >
GPUStaticInst* HsailISA::decodeLd ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeLd2()

template<typename MemDT , typename DestDT >
GPUStaticInst* HsailISA::decodeLd2 ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeLda()

template<typename DataType >
GPUStaticInst* HsailISA::decodeLda ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ decodeSt()

template<typename DataType , typename SrcDataType >
GPUStaticInst* HsailISA::decodeSt ( const Brig::BrigInstBase ib,
const BrigObject obj 
)

◆ firstbit()

template<typename T >
int32_t HsailISA::firstbit ( src0)

Definition at line 648 of file decl.hh.

References cmpOpToString().

◆ fpclassify()

template<typename T >
bool HsailISA::fpclassify ( src0,
uint32_t  src1 
)

◆ heynot()

template<typename T >
T HsailISA::heynot ( arg)

Definition at line 1273 of file decl.hh.

◆ heynot< bool >()

template<>
bool HsailISA::heynot< bool > ( bool  arg)
inline

Generated on Fri Feb 28 2020 16:27:21 for gem5 by doxygen 1.8.13