gem5 [DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
gem5::SparcISA Namespace Reference

Namespaces

namespace  float_reg
 
namespace  int_reg
 

Classes

class  BlockMem
 
class  BlockMemImm
 
class  BlockMemImmMicro
 
class  BlockMemMicro
 
class  Branch
 Base class for branch operations. More...
 
class  BranchDisp
 Base class for branch operations with an immediate displacement. More...
 
class  BranchImm13
 Base class for branches that use an immediate and a register to compute their displacements. More...
 
class  BranchNBits
 Base class for branches with n bit displacements. More...
 
class  BranchSplit
 Base class for 16bit split displacements. More...
 
class  CleanWindow
 
class  CpuMondo
 
class  DataAccessError
 
class  DataAccessException
 
class  DataAccessProtection
 
class  DataInvalidTSBEntry
 
class  DataRealTranslationMiss
 
class  Decoder
 
class  DevMondo
 
class  DivisionByZero
 
class  EmuLinux
 
class  EnumeratedFault
 
class  ExternallyInitiatedReset
 
class  FailUnimplemented
 Static instruction class for unimplemented instructions that cause simulator termination. More...
 
class  FastDataAccessMMUMiss
 
class  FastDataAccessProtection
 
class  FastInstructionAccessMMUMiss
 
class  FillNNormal
 
class  FillNOther
 
class  FpDisabled
 
class  FpExceptionIEEE754
 
class  FpExceptionOther
 
class  FpUnimpl
 
class  FsWorkload
 
class  HstickMatch
 
class  IllegalInstruction
 
class  InstructionAccessError
 
class  InstructionAccessException
 
class  InstructionBreakpoint
 
class  InstructionInvalidTSBEntry
 
class  InstructionRealTranslationMiss
 
class  InternalProcessorError
 
class  InterruptLevelN
 
class  Interrupts
 
class  InterruptVector
 
class  IntOp
 Base class for integer operations. More...
 
class  IntOpImm
 Base class for immediate integer operations. More...
 
class  IntOpImm10
 Base class for 10 bit immediate integer operations. More...
 
class  IntOpImm11
 Base class for 11 bit immediate integer operations. More...
 
class  IntOpImm13
 Base class for 13 bit immediate integer operations. More...
 
class  IntRegClassOps
 
class  ISA
 
class  LDDFMemAddressNotAligned
 
class  LDQFMemAddressNotAligned
 
class  Mem
 Base class for memory operations. More...
 
class  MemAddressNotAligned
 
class  MemImm
 Class for memory operations which use an immediate offset. More...
 
class  MMU
 
class  Nop
 Nop class. More...
 
class  PageTableEntry
 
class  PAWatchpoint
 
class  PowerOnReset
 
class  Priv
 Base class for privelege mode operations. More...
 
class  PrivilegedAction
 
class  PrivilegedOpcode
 
class  PrivImm
 Base class for privelege mode operations with immediates. More...
 
class  PrivReg
 
class  RdPriv
 
class  REDStateException
 
class  RemoteGDB
 
class  ResumableError
 
class  SetHi
 Base class for sethi. More...
 
class  SEWorkload
 
class  SoftwareInitiatedReset
 
class  SparcDelayedMicroInst
 
class  SparcFault
 
class  SparcFaultBase
 
class  SparcMacroInst
 
class  SparcMicroInst
 
class  SparcStaticInst
 Base class for all SPARC static instructions. More...
 
class  SpillNNormal
 
class  SpillNOther
 
class  StackTrace
 
class  STDFMemAddressNotAligned
 
class  StoreError
 
class  STQFMemAddressNotAligned
 
class  TagOverflow
 
class  TLB
 
struct  TlbEntry
 
class  TlbMap
 
struct  TlbRange
 
class  Trap
 Base class for trap instructions, or instructions that always fault. More...
 
class  TrapInstruction
 
class  TrapLevelZero
 
class  TteTag
 
class  Unknown
 Class for Unknown/Illegal instructions. More...
 
class  VAWatchpoint
 
class  VecDisabled
 
class  WarnUnimplemented
 Base class for unimplemented instructions that cause a warning to be printed (but do not terminate simulation). More...
 
class  WatchDogReset
 
class  WrPriv
 
class  WrPrivImm
 

Typedefs

typedef uint32_t TrapType
 
typedef uint32_t FaultPriority
 
typedef GenericISA::DelaySlotUPCState< 4 > PCState
 
typedef uint32_t MachInst
 
typedef uint64_t ExtMachInst
 

Enumerations

enum  ASI {
  ASI_IMPLICIT = 0x00 , ASI_NUCLEUS = 0x4 , ASI_N = 0x4 , ASI_NL = 0xC ,
  ASI_NUCLEUS_LITTLE = ASI_NL , ASI_AIUP = 0x10 , ASI_AS_IF_USER_PRIMARY = ASI_AIUP , ASI_AIUS = 0x11 ,
  ASI_AS_IF_USER_SECONDARY = ASI_AIUS , ASI_REAL = 0x14 , ASI_REAL_IO = 0x15 , ASI_BLK_AIUP = 0x16 ,
  ASI_BLOCK_AS_IF_USER_PRIMARY = ASI_BLK_AIUP , ASI_BLK_AIUS = 0x17 , ASI_BLOCK_AS_IF_USER_SECONDARY = ASI_BLK_AIUS , ASI_AIUP_L = 0x18 ,
  ASI_AS_IF_USER_PRIMARY_LITTLE = ASI_AIUP_L , ASI_AIUS_L = 0x19 , ASI_AS_IF_USER_SECONDARY_LITTLE = ASI_AIUS_L , ASI_REAL_L = 0x1C ,
  ASI_REAL_LITTLE = ASI_REAL_L , ASI_REAL_IO_L = 0x1D , ASI_REAL_IO_LITTLE = ASI_REAL_IO_L , ASI_BLK_AIUP_L = 0x1E ,
  ASI_BLOCK_AS_IF_USER_PRIMARY_LITTLE = ASI_BLK_AIUP_L , ASI_BLK_AIUS_L = 0x1F , ASI_BLOCK_AS_IF_USER_SECONDARY_LITTLE = ASI_BLK_AIUS_L , ASI_SCRATCHPAD = 0x20 ,
  ASI_MMU = 0x21 , ASI_LDTX_AIUP = 0x22 , ASI_LD_TWINX_AS_IF_USER_PRIMARY = ASI_LDTX_AIUP , ASI_LDTX_AIUS = 0x23 ,
  ASI_LD_TWINX_AS_IF_USER_SECONDARY = ASI_LDTX_AIUS , ASI_QUAD_LDD = 0x24 , ASI_QUEUE = 0x25 , ASI_QUAD_LDD_REAL = 0x26 ,
  ASI_LDTX_REAL = ASI_QUAD_LDD_REAL , ASI_LDTX_N = 0x27 , ASI_LD_TWINX_NUCLEUS = ASI_LDTX_N , ASI_ST_BLKINIT_NUCLEUS = ASI_LDTX_N ,
  ASI_STBI_N = ASI_LDTX_N , ASI_LDTX_AIUP_L = 0x2A , ASI_TWINX_AS_IF_USER_PRIMARY_LITTLE = ASI_LDTX_AIUP_L , ASI_ST_BLKINIT_AS_IF_USER_PRIMARY_LITTLE = ASI_LDTX_AIUP_L ,
  ASI_STBI_AIUP_L = ASI_LDTX_AIUP_L , ASI_LDTX_AIUS_L = 0x2B , ASI_LD_TWINX_AS_IF_USER_SECONDARY_LITTLE = ASI_LDTX_AIUS_L , ASI_ST_BLKINIT_AS_IF_USER_SECONDARY_LITTLE = ASI_LDTX_AIUS_L ,
  ASI_STBI_AIUS_L = ASI_LDTX_AIUS_L , ASI_LTX_L = 0x2C , ASI_TWINX_LITTLE = ASI_LTX_L , ASI_LDTX_REAL_L = 0x2E ,
  ASI_LD_TWINX_REAL_LITTLE = ASI_LDTX_REAL_L , ASI_LDTX_NL = 0x2F , ASI_LD_TWINX_NUCLEUS_LITTLE = ASI_LDTX_NL , ASI_DMMU_CTXT_ZERO_TSB_BASE_PS0 = 0x31 ,
  ASI_DMMU_CTXT_ZERO_TSB_BASE_PS1 = 0x32 , ASI_DMMU_CTXT_ZERO_CONFIG = 0x33 , ASI_IMMU_CTXT_ZERO_TSB_BASE_PS0 = 0x35 , ASI_IMMU_CTXT_ZERO_TSB_BASE_PS1 = 0x36 ,
  ASI_IMMU_CTXT_ZERO_CONFIG = 0x37 , ASI_DMMU_CTXT_NONZERO_TSB_BASE_PS0 = 0x39 , ASI_DMMU_CTXT_NONZERO_TSB_BASE_PS1 = 0x3A , ASI_DMMU_CTXT_NONZERO_CONFIG = 0x3B ,
  ASI_IMMU_CTXT_NONZERO_TSB_BASE_PS0 = 0x3D , ASI_IMMU_CTXT_NONZERO_TSB_BASE_PS1 = 0x3E , ASI_IMMU_CTXT_NONZERO_CONFIG = 0x3F , ASI_STREAM_MA = 0x40 ,
  ASI_CMT_SHARED = 0x41 , ASI_SPARC_BIST_CONTROL = 0x42 , ASI_INST_MASK_REG = 0x42 , ASI_LSU_DIAG_REG = 0x42 ,
  ASI_STM_CTL_REG = 0x44 , ASI_LSU_CONTROL_REG = 0x45 , ASI_DCACHE_DATA = 0x46 , ASI_DCACHE_TAG = 0x47 ,
  ASI_INTR_DISPATCH_STATUS = 0x48 , ASI_INTR_RECEIVE = 0x49 , ASI_UPA_CONFIG_REGISTER = 0x4A , ASI_SPARC_ERROR_EN_REG = 0x4B ,
  ASI_SPARC_ERROR_STATUS_REG = 0x4C , ASI_SPARC_ERROR_ADDRESS_REG = 0x4D , ASI_ECACHE_TAG_DATA = 0x4E , ASI_HYP_SCRATCHPAD = 0x4F ,
  ASI_IMMU = 0x50 , ASI_IMMU_TSB_PS0_PTR_REG = 0x51 , ASI_IMMU_TSB_PS1_PTR_REG = 0x52 , ASI_ITLB_DATA_IN_REG = 0x54 ,
  ASI_ITLB_DATA_ACCESS_REG = 0x55 , ASI_ITLB_TAG_READ_REG = 0x56 , ASI_IMMU_DEMAP = 0x57 , ASI_DMMU = 0x58 ,
  ASI_DMMU_TSB_PS0_PTR_REG = 0x59 , ASI_DMMU_TSB_PS1_PTR_REG = 0x5A , ASI_DMMU_TSB_DIRECT_PTR_REG = 0x5B , ASI_DTLB_DATA_IN_REG = 0x5C ,
  ASI_DTLB_DATA_ACCESS_REG = 0x5D , ASI_DTLB_TAG_READ_REG = 0x5E , ASI_DMMU_DEMAP = 0x5F , ASI_TLB_INVALIDATE_ALL = 0x60 ,
  ASI_CMT_PER_STRAND = 0x63 , ASI_ICACHE_INSTR = 0x66 , ASI_ICACHE_TAG = 0x67 , ASI_SWVR_INTR_RECEIVE = 0x72 ,
  ASI_SWVR_UDB_INTR_W = 0x73 , ASI_SWVR_UDB_INTR_R = 0x74 , ASI_P = 0x80 , ASI_PRIMARY = ASI_P ,
  ASI_S = 0x81 , ASI_SECONDARY = ASI_S , ASI_PNF = 0x82 , ASI_PRIMARY_NO_FAULT = ASI_PNF ,
  ASI_SNF = 0x83 , ASI_SECONDARY_NO_FAULT = ASI_SNF , ASI_PL = 0x88 , ASI_PRIMARY_LITTLE = ASI_PL ,
  ASI_SL = 0x89 , ASI_SECONDARY_LITTLE = ASI_SL , ASI_PNFL = 0x8A , ASI_PRIMARY_NO_FAULT_LITTLE = ASI_PNFL ,
  ASI_SNFL = 0x8B , ASI_SECONDARY_NO_FAULT_LITTLE = ASI_SNFL , ASI_PST8_P = 0xC0 , ASI_PST8_PRIMARY = ASI_PST8_P ,
  ASI_PST8_S = 0xC1 , ASI_PST8_SECONDARY = ASI_PST8_S , ASI_PST16_P = 0xC2 , ASI_PST16_PRIMARY = ASI_PST16_P ,
  ASI_PST16_S = 0xC3 , ASI_PST16_SECONDARY = ASI_PST16_S , ASI_PST32_P = 0xC4 , ASI_PST32_PRIMARY = ASI_PST32_P ,
  ASI_PST32_S = 0xC5 , ASI_PST32_SECONDARY = ASI_PST32_S , ASI_PST8_PL = 0xC8 , ASI_PST8_PRIMARY_LITTLE = ASI_PST8_PL ,
  ASI_PST8_SL = 0xC9 , ASI_PST8_SECONDARY_LITTLE = ASI_PST8_SL , ASI_PST16_PL = 0xCA , ASI_PST16_PRIMARY_LITTLE = ASI_PST16_PL ,
  ASI_PST16_SL = 0xCB , ASI_PST16_SECONDARY_LITTLE = ASI_PST16_SL , ASI_PST32_PL = 0xCC , ASI_PST32_PRIMARY_LITTLE = ASI_PST32_PL ,
  ASI_PST32_SL = 0xCD , ASI_PST32_SECONDARY_LITTLE = ASI_PST32_SL , ASI_FL8_P = 0xD0 , ASI_FL8_PRIMARY = ASI_FL8_P ,
  ASI_FL8_S = 0xD1 , ASI_FL8_SECONDARY = ASI_FL8_S , ASI_FL16_P = 0xD2 , ASI_FL16_PRIMARY = ASI_FL16_P ,
  ASI_FL16_S = 0xD3 , ASI_FL16_SECONDARY = ASI_FL16_S , ASI_FL8_PL = 0xD8 , ASI_FL8_PRIMARY_LITTLE = ASI_FL8_PL ,
  ASI_FL8_SL = 0xD9 , ASI_FL8_SECONDARY_LITTLE = ASI_FL8_SL , ASI_FL16_PL = 0xDA , ASI_FL16_PRIMARY_LITTLE = ASI_FL16_PL ,
  ASI_FL16_SL = 0xDB , ASI_FL16_SECONDARY_LITTLE = ASI_FL16_SL , ASI_LDTX_P = 0xE2 , ASI_LD_TWINX_PRIMARY = ASI_LDTX_P ,
  ASI_LDTX_S = 0xE3 , ASI_LD_TWINX_SECONDARY = ASI_LDTX_S , ASI_LDTX_PL = 0xEA , ASI_LD_TWINX_PRIMARY_LITTLE = ASI_LDTX_PL ,
  ASI_LDTX_SL = 0xEB , ASI_LD_TWINX_SECONDARY_LITTLE = ASI_LDTX_SL , ASI_BLK_P = 0xF0 , ASI_BLOCK_PRIMARY = ASI_BLK_P ,
  ASI_BLK_S = 0xF1 , ASI_BLOCK_SECONDARY = ASI_BLK_S , ASI_BLK_PL = 0xF8 , ASI_BLOCK_PRIMARY_LITTLE = ASI_BLK_PL ,
  ASI_BLK_SL = 0xF9 , ASI_BLOCK_SECONDARY_LITTLE = ASI_BLK_SL , MAX_ASI = 0xFF
}
 
enum  CondTest {
  Always =0x8 , Never =0x0 , NotEqual =0x9 , Equal =0x1 ,
  Greater =0xA , LessOrEqual =0x2 , GreaterOrEqual =0xB , Less =0x3 ,
  GreaterUnsigned =0xC , LessOrEqualUnsigned =0x4 , CarryClear =0xD , CarrySet =0x5 ,
  Positive =0xE , Negative =0x6 , OverflowClear =0xF , OverflowSet =0x7
}
 
enum  FpCondTest {
  FAlways =0x8 , FNever =0x0 , FUnordered =0x7 , FGreater =0x6 ,
  FUnorderedOrGreater =0x5 , FLess =0x4 , FUnorderedOrLess =0x3 , FLessOrGreater =0x2 ,
  FNotEqual =0x1 , FEqual =0x9 , FUnorderedOrEqual =0xA , FGreaterOrEqual =0xB ,
  FUnorderedOrGreaterOrEqual =0xC , FLessOrEqual =0xD , FUnorderedOrLessOrEqual =0xE , FOrdered =0xF
}
 
enum  InterruptTypes {
  IT_TRAP_LEVEL_ZERO , IT_HINTP , IT_INT_VEC , IT_CPU_MONDO ,
  IT_DEV_MONDO , IT_RES_ERROR , IT_SOFT_INT , NumInterruptTypes
}
 
enum  MiscRegIndex {
  MISCREG_ASI , MISCREG_TICK , MISCREG_FPRS , MISCREG_PCR ,
  MISCREG_PIC , MISCREG_GSR , MISCREG_SOFTINT_SET , MISCREG_SOFTINT_CLR ,
  MISCREG_SOFTINT , MISCREG_TICK_CMPR , MISCREG_STICK , MISCREG_STICK_CMPR ,
  MISCREG_TPC , MISCREG_TNPC , MISCREG_TSTATE , MISCREG_TT ,
  MISCREG_PRIVTICK , MISCREG_TBA , MISCREG_PSTATE , MISCREG_TL ,
  MISCREG_PIL , MISCREG_CWP , MISCREG_GL , MISCREG_HPSTATE ,
  MISCREG_HTSTATE , MISCREG_HINTP , MISCREG_HTBA , MISCREG_HVER ,
  MISCREG_STRAND_STS_REG , MISCREG_HSTICK_CMPR , MISCREG_FSR , MISCREG_MMU_P_CONTEXT ,
  MISCREG_MMU_S_CONTEXT , MISCREG_MMU_PART_ID , MISCREG_MMU_LSU_CTRL , MISCREG_SCRATCHPAD_R0 ,
  MISCREG_SCRATCHPAD_R1 , MISCREG_SCRATCHPAD_R2 , MISCREG_SCRATCHPAD_R3 , MISCREG_SCRATCHPAD_R4 ,
  MISCREG_SCRATCHPAD_R5 , MISCREG_SCRATCHPAD_R6 , MISCREG_SCRATCHPAD_R7 , MISCREG_QUEUE_CPU_MONDO_HEAD ,
  MISCREG_QUEUE_CPU_MONDO_TAIL , MISCREG_QUEUE_DEV_MONDO_HEAD , MISCREG_QUEUE_DEV_MONDO_TAIL , MISCREG_QUEUE_RES_ERROR_HEAD ,
  MISCREG_QUEUE_RES_ERROR_TAIL , MISCREG_QUEUE_NRES_ERROR_HEAD , MISCREG_QUEUE_NRES_ERROR_TAIL , MISCREG_TLB_DATA ,
  MISCREG_NUMMISCREGS
}
 

Functions

bool asiIsBlock (ASI asi)
 
bool asiIsPrimary (ASI asi)
 
bool asiIsSecondary (ASI asi)
 
bool asiIsNucleus (ASI asi)
 
bool asiIsAsIfUser (ASI asi)
 
bool asiIsIO (ASI asi)
 
bool asiIsReal (ASI asi)
 
bool asiIsLittle (ASI asi)
 
bool asiIsTwin (ASI asi)
 
bool asiIsPartialStore (ASI asi)
 
bool asiIsFloatingLoad (ASI asi)
 
bool asiIsNoFault (ASI asi)
 
bool asiIsScratchPad (ASI asi)
 
bool asiIsCmt (ASI asi)
 
bool asiIsQueue (ASI asi)
 
bool asiIsInterrupt (ASI asi)
 
bool asiIsMmu (ASI asi)
 
bool asiIsUnPriv (ASI asi)
 
bool asiIsPriv (ASI asi)
 
bool asiIsHPriv (ASI asi)
 
bool asiIsReg (ASI asi)
 
bool asiIsSparcError (ASI asi)
 
bool asiIsDtlb (ASI)
 
void enterREDState (ThreadContext *tc)
 This causes the thread context to enter RED state.
 
void doREDFault (ThreadContext *tc, TrapType tt)
 This sets everything up for a RED state trap except for actually jumping to the handler.
 
void doNormalFault (ThreadContext *tc, TrapType tt, bool gotoHpriv)
 This sets everything up for a normal trap except for actually jumping to the handler.
 
void getREDVector (RegVal TT, Addr &PC, Addr &NPC)
 
void getHyperVector (ThreadContext *tc, Addr &PC, Addr &NPC, RegVal TT)
 
void getPrivVector (ThreadContext *tc, Addr &PC, Addr &NPC, RegVal TT, RegVal TL)
 
static PSTATE buildPstateMask ()
 
static void copyMiscRegs (ThreadContext *src, ThreadContext *dest)
 
static SyscallReturn unameFunc (SyscallDesc *desc, ThreadContext *tc, VPtr< Linux::utsname > name)
 Target uname() handler.
 
static SyscallReturn getresuidFunc (SyscallDesc *desc, ThreadContext *tc, VPtr<> ruid, VPtr<> euid, VPtr<> suid)
 
constexpr RegClass floatRegClass (FloatRegClass, FloatRegClassName, float_reg::NumRegs, debug::FloatRegs)
 
 BitUnion64 (HPSTATE) Bitfield< 0 > tlz
 
 EndBitUnion (HPSTATE) BitUnion16(PSTATE) Bitfield< 1 > ie
 
 EndBitUnion (PSTATE) BitUnion8(CCR) SubBitUnion(xcc
 
 EndSubBitUnion (xcc) SubBitUnion(icc
 
 EndSubBitUnion (icc) EndBitUnion(CCR) struct STS
 
constexpr RegClass miscRegClass (MiscRegClass, MiscRegClassName, NumMiscRegs, debug::MiscRegs)
 

Variables

template<>
SparcFaultBase::FaultVals SparcFault< PowerOnReset >::vals ("power_on_reset", 0x001, 0, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< WatchDogReset >::vals ("watch_dog_reset", 0x002, 120, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< ExternallyInitiatedReset >::vals ("externally_initiated_reset", 0x003, 110, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< SoftwareInitiatedReset >::vals ("software_initiated_reset", 0x004, 130, {{SH, SH, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< REDStateException >::vals ("RED_state_exception", 0x005, 1, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< StoreError >::vals ("store_error", 0x007, 201, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InstructionAccessException >::vals ("instruction_access_exception", 0x008, 300, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InstructionAccessError >::vals ("instruction_access_error", 0x00A, 400, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< IllegalInstruction >::vals ("illegal_instruction", 0x010, 620, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< PrivilegedOpcode >::vals ("privileged_opcode", 0x011, 700, {{P, SH, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FpDisabled >::vals ("fp_disabled", 0x020, 800, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< VecDisabled >::vals ("fp_disabled", 0x020, 800, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FpExceptionIEEE754 >::vals ("fp_exception_ieee_754", 0x021, 1110, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FpExceptionOther >::vals ("fp_exception_other", 0x022, 1110, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< TagOverflow >::vals ("tag_overflow", 0x023, 1400, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< CleanWindow >::vals ("clean_window", 0x024, 1010, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DivisionByZero >::vals ("division_by_zero", 0x028, 1500, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InternalProcessorError >::vals ("internal_processor_error", 0x029, 4, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InstructionInvalidTSBEntry >::vals ("instruction_invalid_tsb_entry", 0x02A, 210, {{H, H, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DataInvalidTSBEntry >::vals ("data_invalid_tsb_entry", 0x02B, 1203, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DataAccessException >::vals ("data_access_exception", 0x030, 1201, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DataAccessError >::vals ("data_access_error", 0x032, 1210, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DataAccessProtection >::vals ("data_access_protection", 0x033, 1207, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< MemAddressNotAligned >::vals ("mem_address_not_aligned", 0x034, 1020, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< LDDFMemAddressNotAligned >::vals ("LDDF_mem_address_not_aligned", 0x035, 1010, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< STDFMemAddressNotAligned >::vals ("STDF_mem_address_not_aligned", 0x036, 1010, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< PrivilegedAction >::vals ("privileged_action", 0x037, 1110, {{H, H, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< LDQFMemAddressNotAligned >::vals ("LDQF_mem_address_not_aligned", 0x038, 1010, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< STQFMemAddressNotAligned >::vals ("STQF_mem_address_not_aligned", 0x039, 1010, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InstructionRealTranslationMiss >::vals ("instruction_real_translation_miss", 0x03E, 208, {{H, H, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DataRealTranslationMiss >::vals ("data_real_translation_miss", 0x03F, 1203, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InterruptLevelN >::vals ("interrupt_level_n", 0x040, 0, {{P, P, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< HstickMatch >::vals ("hstick_match", 0x05E, 1601, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< TrapLevelZero >::vals ("trap_level_zero", 0x05F, 202, {{H, H, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InterruptVector >::vals ("interrupt_vector", 0x060, 2630, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< PAWatchpoint >::vals ("PA_watchpoint", 0x061, 1209, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< VAWatchpoint >::vals ("VA_watchpoint", 0x062, 1120, {{P, P, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FastInstructionAccessMMUMiss >::vals ("fast_instruction_access_MMU_miss", 0x064, 208, {{H, H, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FastDataAccessMMUMiss >::vals ("fast_data_access_MMU_miss", 0x068, 1203, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FastDataAccessProtection >::vals ("fast_data_access_protection", 0x06C, 1207, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< InstructionBreakpoint >::vals ("instruction_break", 0x076, 610, {{H, H, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< CpuMondo >::vals ("cpu_mondo", 0x07C, 1608, {{P, P, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< DevMondo >::vals ("dev_mondo", 0x07D, 1611, {{P, P, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< ResumableError >::vals ("resume_error", 0x07E, 3330, {{P, P, SH}})
 
template<>
SparcFaultBase::FaultVals SparcFault< SpillNNormal >::vals ("spill_n_normal", 0x080, 900, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< SpillNOther >::vals ("spill_n_other", 0x0A0, 900, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FillNNormal >::vals ("fill_n_normal", 0x0C0, 900, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< FillNOther >::vals ("fill_n_other", 0x0E0, 900, {{P, P, H}})
 
template<>
SparcFaultBase::FaultVals SparcFault< TrapInstruction >::vals ("trap_instruction", 0x100, 1602, {{P, P, H}})
 
const int numFillInsts = 32
 
const int numSpillInsts = 32
 
const MachInst fillHandler64 [numFillInsts]
 
const MachInst fillHandler32 [numFillInsts]
 
const MachInst spillHandler64 [numSpillInsts]
 
const MachInst spillHandler32 [numSpillInsts]
 
const char * CondTestAbbrev []
 
static const PSTATE PstateMask = buildPstateMask()
 
const Addr PageShift = 13
 
const Addr PageBytes = 1ULL << PageShift
 
constexpr IntRegClassOps intRegClassOps
 
constexpr RegClass intRegClass
 
constexpr RegClass flatIntRegClass
 
constexpr auto & ReturnAddressReg = int_reg::I7
 
constexpr auto & ReturnValueReg = int_reg::O0
 
constexpr auto & StackPointerReg = int_reg::O6
 
constexpr auto & FramePointerReg = int_reg::I6
 
constexpr auto & SyscallPseudoReturnReg = int_reg::O1
 
Bitfield< 2 > hpriv
 
Bitfield< 5 > red
 
Bitfield< 10 > ibe
 
Bitfield< 11 > id
 
Bitfield< 2 > priv
 
Bitfield< 3 > am
 
Bitfield< 4 > pef
 
Bitfield< 7, 6 > mm
 
Bitfield< 8 > tle
 
Bitfield< 9 > cle
 
Bitfield< 10 > pid0
 
Bitfield< 11 > pid1
 
Bitfield< 7 > n
 
Bitfield< 6 > z
 
Bitfield< 5 > v
 
Bitfield< 4 > c
 
const int NumMiscRegs = MISCREG_NUMMISCREGS
 
const int MaxPTL = 2
 
const int MaxTL = 6
 
const int MaxGL = 3
 
const int MaxPGL = 2
 
const int NWindows = 8
 
const Addr StartVAddrHole = 0x0000800000000000ULL
 
const Addr EndVAddrHole = 0xFFFF7FFFFFFFFFFFULL
 
const Addr VAddrAMask = 0xFFFFFFFFULL
 
const Addr PAddrImplMask = 0x000000FFFFFFFFFFULL
 

Typedef Documentation

◆ ExtMachInst

typedef uint64_t gem5::SparcISA::ExtMachInst

Definition at line 42 of file types.hh.

◆ FaultPriority

Definition at line 45 of file faults.hh.

◆ MachInst

typedef uint32_t gem5::SparcISA::MachInst

Definition at line 41 of file types.hh.

◆ PCState

Definition at line 40 of file pcstate.hh.

◆ TrapType

typedef uint32_t gem5::SparcISA::TrapType

Definition at line 44 of file faults.hh.

Enumeration Type Documentation

◆ ASI

Enumerator
ASI_IMPLICIT 
ASI_NUCLEUS 
ASI_N 
ASI_NL 
ASI_NUCLEUS_LITTLE 
ASI_AIUP 
ASI_AS_IF_USER_PRIMARY 
ASI_AIUS 
ASI_AS_IF_USER_SECONDARY 
ASI_REAL 
ASI_REAL_IO 
ASI_BLK_AIUP 
ASI_BLOCK_AS_IF_USER_PRIMARY 
ASI_BLK_AIUS 
ASI_BLOCK_AS_IF_USER_SECONDARY 
ASI_AIUP_L 
ASI_AS_IF_USER_PRIMARY_LITTLE 
ASI_AIUS_L 
ASI_AS_IF_USER_SECONDARY_LITTLE 
ASI_REAL_L 
ASI_REAL_LITTLE 
ASI_REAL_IO_L 
ASI_REAL_IO_LITTLE 
ASI_BLK_AIUP_L 
ASI_BLOCK_AS_IF_USER_PRIMARY_LITTLE 
ASI_BLK_AIUS_L 
ASI_BLOCK_AS_IF_USER_SECONDARY_LITTLE 
ASI_SCRATCHPAD 
ASI_MMU 
ASI_LDTX_AIUP 
ASI_LD_TWINX_AS_IF_USER_PRIMARY 
ASI_LDTX_AIUS 
ASI_LD_TWINX_AS_IF_USER_SECONDARY 
ASI_QUAD_LDD 
ASI_QUEUE 
ASI_QUAD_LDD_REAL 
ASI_LDTX_REAL 
ASI_LDTX_N 
ASI_LD_TWINX_NUCLEUS 
ASI_ST_BLKINIT_NUCLEUS 
ASI_STBI_N 
ASI_LDTX_AIUP_L 
ASI_TWINX_AS_IF_USER_PRIMARY_LITTLE 
ASI_ST_BLKINIT_AS_IF_USER_PRIMARY_LITTLE 
ASI_STBI_AIUP_L 
ASI_LDTX_AIUS_L 
ASI_LD_TWINX_AS_IF_USER_SECONDARY_LITTLE 
ASI_ST_BLKINIT_AS_IF_USER_SECONDARY_LITTLE 
ASI_STBI_AIUS_L 
ASI_LTX_L 
ASI_TWINX_LITTLE 
ASI_LDTX_REAL_L 
ASI_LD_TWINX_REAL_LITTLE 
ASI_LDTX_NL 
ASI_LD_TWINX_NUCLEUS_LITTLE 
ASI_DMMU_CTXT_ZERO_TSB_BASE_PS0 
ASI_DMMU_CTXT_ZERO_TSB_BASE_PS1 
ASI_DMMU_CTXT_ZERO_CONFIG 
ASI_IMMU_CTXT_ZERO_TSB_BASE_PS0 
ASI_IMMU_CTXT_ZERO_TSB_BASE_PS1 
ASI_IMMU_CTXT_ZERO_CONFIG 
ASI_DMMU_CTXT_NONZERO_TSB_BASE_PS0 
ASI_DMMU_CTXT_NONZERO_TSB_BASE_PS1 
ASI_DMMU_CTXT_NONZERO_CONFIG 
ASI_IMMU_CTXT_NONZERO_TSB_BASE_PS0 
ASI_IMMU_CTXT_NONZERO_TSB_BASE_PS1 
ASI_IMMU_CTXT_NONZERO_CONFIG 
ASI_STREAM_MA 
ASI_CMT_SHARED 
ASI_SPARC_BIST_CONTROL 
ASI_INST_MASK_REG 
ASI_LSU_DIAG_REG 
ASI_STM_CTL_REG 
ASI_LSU_CONTROL_REG 
ASI_DCACHE_DATA 
ASI_DCACHE_TAG 
ASI_INTR_DISPATCH_STATUS 
ASI_INTR_RECEIVE 
ASI_UPA_CONFIG_REGISTER 
ASI_SPARC_ERROR_EN_REG 
ASI_SPARC_ERROR_STATUS_REG 
ASI_SPARC_ERROR_ADDRESS_REG 
ASI_ECACHE_TAG_DATA 
ASI_HYP_SCRATCHPAD 
ASI_IMMU 
ASI_IMMU_TSB_PS0_PTR_REG 
ASI_IMMU_TSB_PS1_PTR_REG 
ASI_ITLB_DATA_IN_REG 
ASI_ITLB_DATA_ACCESS_REG 
ASI_ITLB_TAG_READ_REG 
ASI_IMMU_DEMAP 
ASI_DMMU 
ASI_DMMU_TSB_PS0_PTR_REG 
ASI_DMMU_TSB_PS1_PTR_REG 
ASI_DMMU_TSB_DIRECT_PTR_REG 
ASI_DTLB_DATA_IN_REG 
ASI_DTLB_DATA_ACCESS_REG 
ASI_DTLB_TAG_READ_REG 
ASI_DMMU_DEMAP 
ASI_TLB_INVALIDATE_ALL 
ASI_CMT_PER_STRAND 
ASI_ICACHE_INSTR 
ASI_ICACHE_TAG 
ASI_SWVR_INTR_RECEIVE 
ASI_SWVR_UDB_INTR_W 
ASI_SWVR_UDB_INTR_R 
ASI_P 
ASI_PRIMARY 
ASI_S 
ASI_SECONDARY 
ASI_PNF 
ASI_PRIMARY_NO_FAULT 
ASI_SNF 
ASI_SECONDARY_NO_FAULT 
ASI_PL 
ASI_PRIMARY_LITTLE 
ASI_SL 
ASI_SECONDARY_LITTLE 
ASI_PNFL 
ASI_PRIMARY_NO_FAULT_LITTLE 
ASI_SNFL 
ASI_SECONDARY_NO_FAULT_LITTLE 
ASI_PST8_P 
ASI_PST8_PRIMARY 
ASI_PST8_S 
ASI_PST8_SECONDARY 
ASI_PST16_P 
ASI_PST16_PRIMARY 
ASI_PST16_S 
ASI_PST16_SECONDARY 
ASI_PST32_P 
ASI_PST32_PRIMARY 
ASI_PST32_S 
ASI_PST32_SECONDARY 
ASI_PST8_PL 
ASI_PST8_PRIMARY_LITTLE 
ASI_PST8_SL 
ASI_PST8_SECONDARY_LITTLE 
ASI_PST16_PL 
ASI_PST16_PRIMARY_LITTLE 
ASI_PST16_SL 
ASI_PST16_SECONDARY_LITTLE 
ASI_PST32_PL 
ASI_PST32_PRIMARY_LITTLE 
ASI_PST32_SL 
ASI_PST32_SECONDARY_LITTLE 
ASI_FL8_P 
ASI_FL8_PRIMARY 
ASI_FL8_S 
ASI_FL8_SECONDARY 
ASI_FL16_P 
ASI_FL16_PRIMARY 
ASI_FL16_S 
ASI_FL16_SECONDARY 
ASI_FL8_PL 
ASI_FL8_PRIMARY_LITTLE 
ASI_FL8_SL 
ASI_FL8_SECONDARY_LITTLE 
ASI_FL16_PL 
ASI_FL16_PRIMARY_LITTLE 
ASI_FL16_SL 
ASI_FL16_SECONDARY_LITTLE 
ASI_LDTX_P 
ASI_LD_TWINX_PRIMARY 
ASI_LDTX_S 
ASI_LD_TWINX_SECONDARY 
ASI_LDTX_PL 
ASI_LD_TWINX_PRIMARY_LITTLE 
ASI_LDTX_SL 
ASI_LD_TWINX_SECONDARY_LITTLE 
ASI_BLK_P 
ASI_BLOCK_PRIMARY 
ASI_BLK_S 
ASI_BLOCK_SECONDARY 
ASI_BLK_PL 
ASI_BLOCK_PRIMARY_LITTLE 
ASI_BLK_SL 
ASI_BLOCK_SECONDARY_LITTLE 
MAX_ASI 

Definition at line 38 of file asi.hh.

◆ CondTest

Enumerator
Always 
Never 
NotEqual 
Equal 
Greater 
LessOrEqual 
GreaterOrEqual 
Less 
GreaterUnsigned 
LessOrEqualUnsigned 
CarryClear 
CarrySet 
Positive 
Negative 
OverflowClear 
OverflowSet 

Definition at line 48 of file static_inst.hh.

◆ FpCondTest

Enumerator
FAlways 
FNever 
FUnordered 
FGreater 
FUnorderedOrGreater 
FLess 
FUnorderedOrLess 
FLessOrGreater 
FNotEqual 
FEqual 
FUnorderedOrEqual 
FGreaterOrEqual 
FUnorderedOrGreaterOrEqual 
FLessOrEqual 
FUnorderedOrLessOrEqual 
FOrdered 

Definition at line 70 of file static_inst.hh.

◆ InterruptTypes

Enumerator
IT_TRAP_LEVEL_ZERO 
IT_HINTP 
IT_INT_VEC 
IT_CPU_MONDO 
IT_DEV_MONDO 
IT_RES_ERROR 
IT_SOFT_INT 
NumInterruptTypes 

Definition at line 46 of file interrupts.hh.

◆ MiscRegIndex

Enumerator
MISCREG_ASI 

Ancillary State Registers.

MISCREG_TICK 
MISCREG_FPRS 
MISCREG_PCR 
MISCREG_PIC 
MISCREG_GSR 
MISCREG_SOFTINT_SET 
MISCREG_SOFTINT_CLR 
MISCREG_SOFTINT 
MISCREG_TICK_CMPR 
MISCREG_STICK 
MISCREG_STICK_CMPR 
MISCREG_TPC 

Privilged Registers.

MISCREG_TNPC 
MISCREG_TSTATE 
MISCREG_TT 
MISCREG_PRIVTICK 
MISCREG_TBA 
MISCREG_PSTATE 
MISCREG_TL 
MISCREG_PIL 
MISCREG_CWP 
MISCREG_GL 
MISCREG_HPSTATE 

Hyper privileged registers.

MISCREG_HTSTATE 
MISCREG_HINTP 
MISCREG_HTBA 
MISCREG_HVER 
MISCREG_STRAND_STS_REG 
MISCREG_HSTICK_CMPR 
MISCREG_FSR 

Floating Point Status Register.

MISCREG_MMU_P_CONTEXT 

MMU Internal Registers.

MISCREG_MMU_S_CONTEXT 
MISCREG_MMU_PART_ID 
MISCREG_MMU_LSU_CTRL 
MISCREG_SCRATCHPAD_R0 

Scratchpad regiscers.

MISCREG_SCRATCHPAD_R1 
MISCREG_SCRATCHPAD_R2 
MISCREG_SCRATCHPAD_R3 
MISCREG_SCRATCHPAD_R4 
MISCREG_SCRATCHPAD_R5 
MISCREG_SCRATCHPAD_R6 
MISCREG_SCRATCHPAD_R7 
MISCREG_QUEUE_CPU_MONDO_HEAD 
MISCREG_QUEUE_CPU_MONDO_TAIL 
MISCREG_QUEUE_DEV_MONDO_HEAD 
MISCREG_QUEUE_DEV_MONDO_TAIL 
MISCREG_QUEUE_RES_ERROR_HEAD 
MISCREG_QUEUE_RES_ERROR_TAIL 
MISCREG_QUEUE_NRES_ERROR_HEAD 
MISCREG_QUEUE_NRES_ERROR_TAIL 
MISCREG_TLB_DATA 
MISCREG_NUMMISCREGS 

Definition at line 42 of file misc.hh.

Function Documentation

◆ asiIsAsIfUser()

bool gem5::SparcISA::asiIsAsIfUser ( ASI asi)

◆ asiIsBlock()

bool gem5::SparcISA::asiIsBlock ( ASI asi)

◆ asiIsCmt()

bool gem5::SparcISA::asiIsCmt ( ASI asi)

Definition at line 249 of file asi.cc.

References ASI_CMT_PER_STRAND, and ASI_CMT_SHARED.

Referenced by asiIsReg().

◆ asiIsDtlb()

bool gem5::SparcISA::asiIsDtlb ( ASI )

◆ asiIsFloatingLoad()

bool gem5::SparcISA::asiIsFloatingLoad ( ASI asi)

Definition at line 220 of file asi.cc.

References ASI_FL16_P, ASI_FL16_PL, ASI_FL16_S, ASI_FL16_SL, ASI_FL8_P, ASI_FL8_PL, ASI_FL8_S, and ASI_FL8_SL.

◆ asiIsHPriv()

bool gem5::SparcISA::asiIsHPriv ( ASI asi)

Definition at line 298 of file asi.cc.

◆ asiIsInterrupt()

bool gem5::SparcISA::asiIsInterrupt ( ASI asi)

Definition at line 262 of file asi.cc.

References ASI_SWVR_INTR_RECEIVE, ASI_SWVR_UDB_INTR_R, and ASI_SWVR_UDB_INTR_W.

Referenced by asiIsReg().

◆ asiIsIO()

bool gem5::SparcISA::asiIsIO ( ASI asi)

Definition at line 135 of file asi.cc.

References ASI_REAL_IO, and ASI_REAL_IO_L.

◆ asiIsLittle()

◆ asiIsMmu()

◆ asiIsNoFault()

bool gem5::SparcISA::asiIsNoFault ( ASI asi)

Definition at line 233 of file asi.cc.

References ASI_PNF, ASI_PNFL, ASI_SNF, and ASI_SNFL.

◆ asiIsNucleus()

bool gem5::SparcISA::asiIsNucleus ( ASI asi)

Definition at line 109 of file asi.cc.

References ASI_LDTX_N, ASI_LDTX_NL, ASI_N, and ASI_NL.

◆ asiIsPartialStore()

bool gem5::SparcISA::asiIsPartialStore ( ASI asi)

◆ asiIsPrimary()

◆ asiIsPriv()

bool gem5::SparcISA::asiIsPriv ( ASI asi)

Definition at line 291 of file asi.cc.

◆ asiIsQueue()

bool gem5::SparcISA::asiIsQueue ( ASI asi)

Definition at line 256 of file asi.cc.

References ASI_QUEUE.

◆ asiIsReal()

bool gem5::SparcISA::asiIsReal ( ASI asi)

◆ asiIsReg()

bool gem5::SparcISA::asiIsReg ( ASI asi)

Definition at line 304 of file asi.cc.

References asiIsCmt(), asiIsInterrupt(), asiIsMmu(), asiIsScratchPad(), and asiIsSparcError().

◆ asiIsScratchPad()

bool gem5::SparcISA::asiIsScratchPad ( ASI asi)

Definition at line 242 of file asi.cc.

References ASI_HYP_SCRATCHPAD, and ASI_SCRATCHPAD.

Referenced by asiIsReg().

◆ asiIsSecondary()

◆ asiIsSparcError()

bool gem5::SparcISA::asiIsSparcError ( ASI asi)

Definition at line 312 of file asi.cc.

References ASI_SPARC_ERROR_EN_REG, and ASI_SPARC_ERROR_STATUS_REG.

Referenced by asiIsReg().

◆ asiIsTwin()

bool gem5::SparcISA::asiIsTwin ( ASI asi)

◆ asiIsUnPriv()

bool gem5::SparcISA::asiIsUnPriv ( ASI asi)

Definition at line 285 of file asi.cc.

◆ BitUnion64()

gem5::SparcISA::BitUnion64 ( HPSTATE )

◆ buildPstateMask()

static PSTATE gem5::SparcISA::buildPstateMask ( )
static

Definition at line 53 of file isa.cc.

References gem5::ArmISA::mask.

◆ copyMiscRegs()

◆ doNormalFault()

◆ doREDFault()

◆ EndBitUnion() [1/2]

gem5::SparcISA::EndBitUnion ( HPSTATE )

References gem5::MipsISA::ie.

Referenced by EndSubBitUnion().

◆ EndBitUnion() [2/2]

gem5::SparcISA::EndBitUnion ( PSTATE )

◆ EndSubBitUnion() [1/2]

gem5::SparcISA::EndSubBitUnion ( icc )

Definition at line 153 of file misc.hh.

References EndBitUnion(), and EndSubBitUnion().

◆ EndSubBitUnion() [2/2]

gem5::SparcISA::EndSubBitUnion ( xcc )

◆ enterREDState()

void gem5::SparcISA::enterREDState ( ThreadContext * tc)

This causes the thread context to enter RED state.

This causes the side effects which go with entering RED state because of a trap.

Definition at line 282 of file faults.cc.

References MISCREG_HPSTATE, MISCREG_PSTATE, gem5::ThreadContext::readMiscRegNoEffect(), and gem5::ThreadContext::setMiscReg().

Referenced by gem5::SparcISA::PowerOnReset::invoke(), and gem5::SparcISA::SparcFaultBase::invoke().

◆ floatRegClass()

◆ getHyperVector()

void gem5::SparcISA::getHyperVector ( ThreadContext * tc,
Addr & PC,
Addr & NPC,
RegVal TT )

◆ getPrivVector()

void gem5::SparcISA::getPrivVector ( ThreadContext * tc,
Addr & PC,
Addr & NPC,
RegVal TT,
RegVal TL )

◆ getREDVector()

void gem5::SparcISA::getREDVector ( RegVal TT,
Addr & PC,
Addr & NPC )

◆ getresuidFunc()

static SyscallReturn gem5::SparcISA::getresuidFunc ( SyscallDesc * desc,
ThreadContext * tc,
VPtr<> ruid,
VPtr<> euid,
VPtr<> suid )
static

◆ miscRegClass()

RegClass gem5::SparcISA::miscRegClass ( MiscRegClass ,
MiscRegClassName ,
NumMiscRegs ,
debug::MiscRegs  )
inlineconstexpr

◆ unameFunc()

static SyscallReturn gem5::SparcISA::unameFunc ( SyscallDesc * desc,
ThreadContext * tc,
VPtr< Linux::utsname > name )
static

Target uname() handler.

Definition at line 56 of file syscalls.cc.

References gem5::ThreadContext::getProcessPtr(), and name().

Variable Documentation

◆ am

◆ c

Bitfield< 0 > gem5::SparcISA::c

Definition at line 146 of file misc.hh.

Referenced by EndSubBitUnion(), and gem5::SparcISA::SparcStaticInst::passesCondition().

◆ cle

Bitfield<9> gem5::SparcISA::cle

Definition at line 136 of file misc.hh.

◆ CondTestAbbrev

const char * gem5::SparcISA::CondTestAbbrev
Initial value:

Definition at line 43 of file static_inst.cc.

◆ EndVAddrHole

const Addr gem5::SparcISA::EndVAddrHole = 0xFFFF7FFFFFFFFFFFULL

Definition at line 49 of file tlb.hh.

Referenced by gem5::SparcISA::TLB::validVirtualAddress().

◆ fillHandler32

const MachInst gem5::SparcISA::fillHandler32[numFillInsts]

Definition at line 81 of file handlers.hh.

Referenced by gem5::Sparc32Process::argsInit().

◆ fillHandler64

const MachInst gem5::SparcISA::fillHandler64[numFillInsts]

Definition at line 45 of file handlers.hh.

Referenced by gem5::Sparc64Process::argsInit().

◆ flatIntRegClass

RegClass gem5::SparcISA::flatIntRegClass
inlineconstexpr
Initial value:
=
constexpr char IntRegClassName[]
Definition reg_class.hh:75
@ IntRegClass
Integer register.
Definition reg_class.hh:61

Definition at line 83 of file int.hh.

Referenced by gem5::SparcISA::IntRegClassOps::flatten(), and gem5::SparcISA::ISA::ISA().

◆ FramePointerReg

auto & gem5::SparcISA::FramePointerReg = int_reg::I6

Definition at line 171 of file int.hh.

Referenced by gem5::SparcISA::SparcStaticInst::printReg().

◆ hpriv

Bitfield<2> gem5::SparcISA::hpriv

◆ ibe

Bitfield<10> gem5::SparcISA::ibe

Definition at line 125 of file misc.hh.

◆ id

Bitfield<11> gem5::SparcISA::id

Definition at line 126 of file misc.hh.

◆ intRegClass

◆ intRegClassOps

IntRegClassOps gem5::SparcISA::intRegClassOps
inlineconstexpr

Definition at line 76 of file int.hh.

◆ MaxGL

const int gem5::SparcISA::MaxGL = 3

◆ MaxPGL

const int gem5::SparcISA::MaxPGL = 2

Definition at line 41 of file sparc_traits.hh.

Referenced by doNormalFault().

◆ MaxPTL

const int gem5::SparcISA::MaxPTL = 2

Definition at line 38 of file sparc_traits.hh.

Referenced by gem5::SparcISA::SparcFaultBase::invoke().

◆ MaxTL

◆ mm

Bitfield<7, 6> gem5::SparcISA::mm

◆ n

◆ numFillInsts

const int gem5::SparcISA::numFillInsts = 32

◆ NumMiscRegs

const int gem5::SparcISA::NumMiscRegs = MISCREG_NUMMISCREGS

Definition at line 175 of file misc.hh.

Referenced by gem5::getMiscRegName(), and miscRegClass().

◆ numSpillInsts

const int gem5::SparcISA::numSpillInsts = 32

Definition at line 43 of file handlers.hh.

Referenced by gem5::Sparc32Process::argsInit(), and gem5::Sparc64Process::argsInit().

◆ NWindows

◆ PAddrImplMask

const Addr gem5::SparcISA::PAddrImplMask = 0x000000FFFFFFFFFFULL

Definition at line 51 of file tlb.hh.

◆ PageBytes

◆ PageShift

const Addr gem5::SparcISA::PageShift = 13

Definition at line 40 of file page_size.hh.

Referenced by gem5::SparcISA::EmuLinux::EmuLinux().

◆ pef

Bitfield<4> gem5::SparcISA::pef

Definition at line 133 of file misc.hh.

◆ pid0

Bitfield<10> gem5::SparcISA::pid0

Definition at line 137 of file misc.hh.

◆ pid1

Bitfield<11> gem5::SparcISA::pid1

Definition at line 138 of file misc.hh.

◆ priv

Bitfield<2> gem5::SparcISA::priv

◆ PstateMask

const PSTATE gem5::SparcISA::PstateMask = buildPstateMask()
static

◆ red

Bitfield<5> gem5::SparcISA::red

Definition at line 124 of file misc.hh.

Referenced by gem5::SparcISA::FastDataAccessMMUMiss::invoke(), TEST(), and TEST().

◆ ReturnAddressReg

auto& gem5::SparcISA::ReturnAddressReg = int_reg::I7
inlineconstexpr

Definition at line 168 of file int.hh.

◆ ReturnValueReg

◆ SparcFault< CleanWindow >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< CleanWindow >::vals ( "clean_window" ,
0x024 ,
1010 ,
{{P, P, H}}  )

Definition at line 306 of file faults.hh.

◆ SparcFault< CpuMondo >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< CpuMondo >::vals ( "cpu_mondo" ,
0x07C ,
1608 ,
{{P, P, SH}}  )

Definition at line 340 of file faults.hh.

◆ SparcFault< DataAccessError >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DataAccessError >::vals ( "data_access_error" ,
0x032 ,
1210 ,
{{H, H, H}}  )

Definition at line 313 of file faults.hh.

◆ SparcFault< DataAccessException >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DataAccessException >::vals ( "data_access_exception" ,
0x030 ,
1201 ,
{{H, H, H}}  )

Definition at line 312 of file faults.hh.

◆ SparcFault< DataAccessProtection >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DataAccessProtection >::vals ( "data_access_protection" ,
0x033 ,
1207 ,
{{H, H, H}}  )

Definition at line 314 of file faults.hh.

◆ SparcFault< DataInvalidTSBEntry >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DataInvalidTSBEntry >::vals ( "data_invalid_tsb_entry" ,
0x02B ,
1203 ,
{{H, H, H}}  )

Definition at line 311 of file faults.hh.

◆ SparcFault< DataRealTranslationMiss >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DataRealTranslationMiss >::vals ( "data_real_translation_miss" ,
0x03F ,
1203 ,
{{H, H, H}}  )

Definition at line 327 of file faults.hh.

◆ SparcFault< DevMondo >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DevMondo >::vals ( "dev_mondo" ,
0x07D ,
1611 ,
{{P, P, SH}}  )

Definition at line 341 of file faults.hh.

◆ SparcFault< DivisionByZero >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< DivisionByZero >::vals ( "division_by_zero" ,
0x028 ,
1500 ,
{{P, P, H}}  )

Definition at line 307 of file faults.hh.

◆ SparcFault< ExternallyInitiatedReset >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< ExternallyInitiatedReset >::vals ( "externally_initiated_reset" ,
0x003 ,
110 ,
{{H, H, H}}  )

Definition at line 292 of file faults.hh.

◆ SparcFault< FastDataAccessMMUMiss >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FastDataAccessMMUMiss >::vals ( "fast_data_access_MMU_miss" ,
0x068 ,
1203 ,
{{H, H, H}}  )

Definition at line 336 of file faults.hh.

◆ SparcFault< FastDataAccessProtection >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FastDataAccessProtection >::vals ( "fast_data_access_protection" ,
0x06C ,
1207 ,
{{H, H, H}}  )

Definition at line 338 of file faults.hh.

◆ SparcFault< FastInstructionAccessMMUMiss >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FastInstructionAccessMMUMiss >::vals ( "fast_instruction_access_MMU_miss" ,
0x064 ,
208 ,
{{H, H, SH}}  )

Definition at line 335 of file faults.hh.

◆ SparcFault< FillNNormal >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FillNNormal >::vals ( "fill_n_normal" ,
0x0C0 ,
900 ,
{{P, P, H}}  )

Definition at line 345 of file faults.hh.

◆ SparcFault< FillNOther >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FillNOther >::vals ( "fill_n_other" ,
0x0E0 ,
900 ,
{{P, P, H}}  )

Definition at line 346 of file faults.hh.

◆ SparcFault< FpDisabled >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FpDisabled >::vals ( "fp_disabled" ,
0x020 ,
800 ,
{{P, P, H}}  )

Definition at line 301 of file faults.hh.

◆ SparcFault< FpExceptionIEEE754 >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FpExceptionIEEE754 >::vals ( "fp_exception_ieee_754" ,
0x021 ,
1110 ,
{{P, P, H}}  )

Definition at line 303 of file faults.hh.

◆ SparcFault< FpExceptionOther >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< FpExceptionOther >::vals ( "fp_exception_other" ,
0x022 ,
1110 ,
{{P, P, H}}  )

Definition at line 304 of file faults.hh.

◆ SparcFault< HstickMatch >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< HstickMatch >::vals ( "hstick_match" ,
0x05E ,
1601 ,
{{H, H, H}}  )

Definition at line 329 of file faults.hh.

◆ SparcFault< IllegalInstruction >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< IllegalInstruction >::vals ( "illegal_instruction" ,
0x010 ,
620 ,
{{H, H, H}}  )

Definition at line 299 of file faults.hh.

◆ SparcFault< InstructionAccessError >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InstructionAccessError >::vals ( "instruction_access_error" ,
0x00A ,
400 ,
{{H, H, H}}  )

Definition at line 298 of file faults.hh.

◆ SparcFault< InstructionAccessException >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InstructionAccessException >::vals ( "instruction_access_exception" ,
0x008 ,
300 ,
{{H, H, H}}  )

Definition at line 297 of file faults.hh.

◆ SparcFault< InstructionBreakpoint >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InstructionBreakpoint >::vals ( "instruction_break" ,
0x076 ,
610 ,
{{H, H, H}}  )

Definition at line 339 of file faults.hh.

◆ SparcFault< InstructionInvalidTSBEntry >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InstructionInvalidTSBEntry >::vals ( "instruction_invalid_tsb_entry" ,
0x02A ,
210 ,
{{H, H, SH}}  )

Definition at line 310 of file faults.hh.

◆ SparcFault< InstructionRealTranslationMiss >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InstructionRealTranslationMiss >::vals ( "instruction_real_translation_miss" ,
0x03E ,
208 ,
{{H, H, SH}}  )

Definition at line 326 of file faults.hh.

◆ SparcFault< InternalProcessorError >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InternalProcessorError >::vals ( "internal_processor_error" ,
0x029 ,
4 ,
{{H, H, H}}  )

Definition at line 308 of file faults.hh.

◆ SparcFault< InterruptLevelN >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InterruptLevelN >::vals ( "interrupt_level_n" ,
0x040 ,
0 ,
{{P, P, SH}}  )

Definition at line 328 of file faults.hh.

◆ SparcFault< InterruptVector >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< InterruptVector >::vals ( "interrupt_vector" ,
0x060 ,
2630 ,
{{H, H, H}}  )

Definition at line 331 of file faults.hh.

◆ SparcFault< LDDFMemAddressNotAligned >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< LDDFMemAddressNotAligned >::vals ( "LDDF_mem_address_not_aligned" ,
0x035 ,
1010 ,
{{H, H, H}}  )

Definition at line 317 of file faults.hh.

◆ SparcFault< LDQFMemAddressNotAligned >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< LDQFMemAddressNotAligned >::vals ( "LDQF_mem_address_not_aligned" ,
0x038 ,
1010 ,
{{H, H, H}}  )

Definition at line 322 of file faults.hh.

◆ SparcFault< MemAddressNotAligned >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< MemAddressNotAligned >::vals ( "mem_address_not_aligned" ,
0x034 ,
1020 ,
{{H, H, H}}  )

Definition at line 315 of file faults.hh.

◆ SparcFault< PAWatchpoint >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< PAWatchpoint >::vals ( "PA_watchpoint" ,
0x061 ,
1209 ,
{{H, H, H}}  )

Definition at line 332 of file faults.hh.

◆ SparcFault< PowerOnReset >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< PowerOnReset >::vals ( "power_on_reset" ,
0x001 ,
0 ,
{{H, H, H}}  )

Definition at line 289 of file faults.hh.

◆ SparcFault< PrivilegedAction >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< PrivilegedAction >::vals ( "privileged_action" ,
0x037 ,
1110 ,
{{H, H, SH}}  )

Definition at line 320 of file faults.hh.

◆ SparcFault< PrivilegedOpcode >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< PrivilegedOpcode >::vals ( "privileged_opcode" ,
0x011 ,
700 ,
{{P, SH, SH}}  )

Definition at line 300 of file faults.hh.

◆ SparcFault< REDStateException >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< REDStateException >::vals ( "RED_state_exception" ,
0x005 ,
1 ,
{{H, H, H}}  )

Definition at line 294 of file faults.hh.

◆ SparcFault< ResumableError >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< ResumableError >::vals ( "resume_error" ,
0x07E ,
3330 ,
{{P, P, SH}}  )

Definition at line 342 of file faults.hh.

◆ SparcFault< SoftwareInitiatedReset >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< SoftwareInitiatedReset >::vals ( "software_initiated_reset" ,
0x004 ,
130 ,
{{SH, SH, H}}  )

Definition at line 293 of file faults.hh.

◆ SparcFault< SpillNNormal >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< SpillNNormal >::vals ( "spill_n_normal" ,
0x080 ,
900 ,
{{P, P, H}}  )

Definition at line 343 of file faults.hh.

◆ SparcFault< SpillNOther >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< SpillNOther >::vals ( "spill_n_other" ,
0x0A0 ,
900 ,
{{P, P, H}}  )

Definition at line 344 of file faults.hh.

◆ SparcFault< STDFMemAddressNotAligned >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< STDFMemAddressNotAligned >::vals ( "STDF_mem_address_not_aligned" ,
0x036 ,
1010 ,
{{H, H, H}}  )

Definition at line 319 of file faults.hh.

◆ SparcFault< StoreError >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< StoreError >::vals ( "store_error" ,
0x007 ,
201 ,
{{H, H, H}}  )

Definition at line 295 of file faults.hh.

◆ SparcFault< STQFMemAddressNotAligned >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< STQFMemAddressNotAligned >::vals ( "STQF_mem_address_not_aligned" ,
0x039 ,
1010 ,
{{H, H, H}}  )

Definition at line 324 of file faults.hh.

◆ SparcFault< TagOverflow >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< TagOverflow >::vals ( "tag_overflow" ,
0x023 ,
1400 ,
{{P, P, H}}  )

Definition at line 305 of file faults.hh.

◆ SparcFault< TrapInstruction >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< TrapInstruction >::vals ( "trap_instruction" ,
0x100 ,
1602 ,
{{P, P, H}}  )

Definition at line 347 of file faults.hh.

◆ SparcFault< TrapLevelZero >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< TrapLevelZero >::vals ( "trap_level_zero" ,
0x05F ,
202 ,
{{H, H, SH}}  )

Definition at line 330 of file faults.hh.

◆ SparcFault< VAWatchpoint >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< VAWatchpoint >::vals ( "VA_watchpoint" ,
0x062 ,
1120 ,
{{P, P, SH}}  )

Definition at line 333 of file faults.hh.

◆ SparcFault< VecDisabled >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< VecDisabled >::vals ( "fp_disabled" ,
0x020 ,
800 ,
{{P, P, H}}  )

Definition at line 302 of file faults.hh.

◆ SparcFault< WatchDogReset >::vals

template<>
SparcFaultBase::FaultVals gem5::SparcISA::SparcFault< WatchDogReset >::vals ( "watch_dog_reset" ,
0x002 ,
120 ,
{{H, H, H}}  )

Definition at line 290 of file faults.hh.

◆ spillHandler32

const MachInst gem5::SparcISA::spillHandler32[numSpillInsts]

Definition at line 153 of file handlers.hh.

Referenced by gem5::Sparc32Process::argsInit().

◆ spillHandler64

const MachInst gem5::SparcISA::spillHandler64[numSpillInsts]

Definition at line 117 of file handlers.hh.

Referenced by gem5::Sparc64Process::argsInit().

◆ StackPointerReg

auto & gem5::SparcISA::StackPointerReg = int_reg::O6

◆ StartVAddrHole

const Addr gem5::SparcISA::StartVAddrHole = 0x0000800000000000ULL

Definition at line 48 of file tlb.hh.

Referenced by gem5::SparcISA::TLB::validVirtualAddress().

◆ SyscallPseudoReturnReg

◆ tle

Bitfield<8> gem5::SparcISA::tle

Definition at line 135 of file misc.hh.

◆ v

Bitfield< 1 > gem5::SparcISA::v

Definition at line 145 of file misc.hh.

Referenced by EndSubBitUnion(), and gem5::SparcISA::SparcStaticInst::passesCondition().

◆ VAddrAMask

const Addr gem5::SparcISA::VAddrAMask = 0xFFFFFFFFULL

Definition at line 50 of file tlb.hh.

Referenced by gem5::SparcISA::TLB::translateFunctional().

◆ z

Bitfield< 2 > gem5::SparcISA::z

Definition at line 144 of file misc.hh.

Referenced by EndSubBitUnion(), and gem5::SparcISA::SparcStaticInst::passesCondition().


Generated on Mon May 26 2025 09:19:37 for gem5 by doxygen 1.13.2