trait UpdateCsrFilesFun extends AnyRef
- Alphabetic
- By Inheritance
- UpdateCsrFilesFun
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Value Members
- final def !=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def ##: Int
- Definition Classes
- AnyRef → Any
- final def ==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- def clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @native() @HotSpotIntrinsicCandidate()
- final def eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- def equals(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef → Any
- final def getClass(): Class[_ <: AnyRef]
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
- def hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
- final def isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- final def ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- final def notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
- final def notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
- final def synchronized[T0](arg0: => T0): T0
- Definition Classes
- AnyRef
- def toString(): String
- Definition Classes
- AnyRef → Any
- def update_DMode(in: CMMState_Bundle): Bool
- def update_csrfiles(in: CMMState_Bundle): CSR_Bundle
- def update_dcsr(in: CMMState_Bundle): DcsrBundle
- def update_dpc(in: CMMState_Bundle): UInt
- def update_dscratch0(in: CMMState_Bundle): UInt
- def update_dscratch1(in: CMMState_Bundle): UInt
- def update_dscratch2(in: CMMState_Bundle): UInt
- def update_fcsr(in: CMMState_Bundle): FCSRBundle
- def update_marchid(in: CMMState_Bundle): UInt
- def update_mcause(in: CMMState_Bundle): CauseBundle
Machine Cause Register
Machine Cause Register
when a ***trap*** is taken into ***M-mode***, Indicating the event that caused the trap
- def update_mcounteren(in: CMMState_Bundle): CounterenBundle
Machine Counter-Enable Register -- mcounteren
- def update_mcountinhibit(in: CMMState_Bundle): UInt
when set, the counter will not increase, all hard-wire to 0 in this version
- def update_mcycle(in: CMMState_Bundle): UInt
Hardware Performance Monitor -- mcycle
Hardware Performance Monitor -- mcycle
- returns
the number of clock cycles executed by the processor core
- def update_medeleg(in: CMMState_Bundle): UInt
Machine Trap Delegation Register
Machine Trap Delegation Register
By default, the exception will be handled in M-mode, when the bits set, it's handled in S-mode
- def update_mepc(in: CMMState_Bundle): UInt
Machine Exception Program Counter
Machine Exception Program Counter
- Note
hold all valid virtual addresses when a ***trap*** is taken into ***M-mode***, update to the ***virtual address*** that was interrupted or encountered the exception
,we are only considering 2 condition: 1) 1 trap outsize the DMode; 2) trap inside the DMode; we will not consider normal trap + step, for step-interrupt has one cycle latency
- def update_mhartid(in: CMMState_Bundle): UInt
- def update_mhpmcounter(in: CMMState_Bundle): Vec[UInt]
Hardware Performance Monitor -- mhpmcounter 3~31
- def update_mhpmevent(in: CMMState_Bundle): Vec[UInt]
- def update_mideleg(in: CMMState_Bundle): UInt
Machine Trap Delegation Register
Machine Trap Delegation Register
By default, the interrupt will be handled in M-mode, when the bits set, it's handled in S-mode
- def update_mie(in: CMMState_Bundle): MSIntBundle
Machine Interrupt Registers
- def update_mimpid(in: CMMState_Bundle): UInt
- def update_minstret(in: CMMState_Bundle): UInt
Hardware Performance Monitor -- minstret
Hardware Performance Monitor -- minstret
- returns
the number of instructions the hart has retired
- def update_mip(in: CMMState_Bundle): MSIntBundle
Machine Interrupt Registers
Machine Interrupt Registers
- Note
implemented in read-only mode
- def update_misa(in: CMMState_Bundle): UInt
Machine ISA register
Machine ISA register
- Note
U(20): User mode implement S(18): Supervisor mode implemented N(13): User-level interrupts supported
,M(12): Integer Multiply/Divide extension I(8): RV64I base ISA C(2): Compressed extension
- def update_mscratch(in: CMMState_Bundle): UInt
Machine Scratch Register -- mscratch
Machine Scratch Register -- mscratch
it's used to hold a pointer to a M-mode hart-local context space and swapped with a user register upon entry to an M-mode trap handler
- def update_mstatus(in: CMMState_Bundle): MStatusBundle
- def update_mtinst(in: CMMState_Bundle): UInt
- def update_mtval(in: CMMState_Bundle): UInt
Machine Trap Value Register
Machine Trap Value Register
When a trap is taken into ***M-mode***, update to ***virtual address*** or ***faulting instruction***
- def update_mtval2(in: CMMState_Bundle): UInt
- def update_mtvec(in: CMMState_Bundle): TVecBundle
Machine Trap-Vector Base-Address Register holds trap vector configuration, consisting of a vector of a vector base address and a bector mode
- def update_mvendorid(in: CMMState_Bundle): UInt
- def update_pmpaddr(in: CMMState_Bundle): Vec[UInt]
- def update_pmpcfg(in: CMMState_Bundle): Vec[Vec[PmpcfgBundle]]
- def update_priv_lvl(in: CMMState_Bundle): UInt
- def update_satp(in: CMMState_Bundle): SatpBundle
Supervisor Address protection and translation Register -- satp
- def update_scause(in: CMMState_Bundle): CauseBundle
Supervisor Cause Register -- scause
Supervisor Cause Register -- scause
when a trap is taken into S-mode, scause is written with a code indicating the event that cause the trap
- def update_scounteren(in: CMMState_Bundle): CounterenBundle
Supervisor Timers and Performance Counters -- Counter-Enable Register -- scounteren
Supervisor Timers and Performance Counters -- Counter-Enable Register -- scounteren
- Note
controls the availability of the hardware performance monitoring counters to U-mode
- def update_sepc(in: CMMState_Bundle): UInt
Supervisor Exception Program Counter -- sepc
Supervisor Exception Program Counter -- sepc
hold virtual addresses: when a trap is taken into S-mode, sepc is written with the virtual address of the instruction that was interrupted or that encountered the exception
- def update_sscratch(in: CMMState_Bundle): UInt
Supervisor Scratch Register -- sscratch
Supervisor Scratch Register -- sscratch
- Note
used to hold a pointer to the hart-local supervisor context while the hart is executing user code
- def update_stval(in: CMMState_Bundle): UInt
Supervisor Trap Value Register -- stval
Supervisor Trap Value Register -- stval
when a trap is taken into S-mode, stval is written with exception-specific information to assist softwave in handling the trap
- def update_stvec(in: CMMState_Bundle): TVecBundle
Supervisor Trap Vector Base Address Register --stvec
Supervisor Trap Vector Base Address Register --stvec
- Note
holdstrap vector configuration
- def update_tdata1(in: CMMState_Bundle): UInt
- def update_tdata2(in: CMMState_Bundle): UInt
- def update_tdata3(in: CMMState_Bundle): UInt
- def update_tselect(in: CMMState_Bundle): UInt
- def update_vConfig(in: CMMState_Bundle): VConfigBundle
- def update_vcsr(in: CMMState_Bundle): VCSRBundle
- def update_vlenb(in: CMMState_Bundle): UInt
- def update_vstart(in: CMMState_Bundle): UInt
- final def wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException]) @native()
- final def wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
Deprecated Value Members
- def finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable]) @Deprecated
- Deprecated