Go to the documentation of this file.
29 #ifndef __ARCH_RISCV_PMP_HH__
30 #define __ARCH_RISCV_PMP_HH__
37 #include "params/PMP.hh"
131 void pmpUpdateCfg(uint32_t pmp_index, uint8_t this_cfg);
197 #endif // __ARCH_RISCV_PMP_HH__
This class helps to implement RISCV's physical memory protection (pmp) primitive.
uint8_t pmpCfg
pmpcfg reg value for a pmp entry
PMP(const Params ¶ms)
bool shouldCheckPMP(RiscvISA::PrivilegeMode pmode, BaseMMU::Mode mode, ThreadContext *tc)
This function is called during a memory access to determine if the pmp table should be consulted for ...
void pmpUpdateRule(uint32_t pmp_index)
pmpUpdateRule updates the pmp rule for a given pmp entry depending on the value of pmpaddr and pmpcfg...
pmpAmatch
This enum is used for encoding of address matching mode of pmp address register, which is present in ...
ThreadContext is the external interface to all thread state for anything outside of the CPU.
std::shared_ptr< FaultBase > Fault
int numRules
variable to keep track of active number of rules any time
Addr rawAddr
raw addr in pmpaddr register for a pmp entry
const Params & params() const
Fault pmpCheck(const RequestPtr &req, BaseMMU::Mode mode, RiscvISA::PrivilegeMode pmode, ThreadContext *tc, Addr vaddr=0)
pmpCheck checks if a particular memory access is allowed based on the pmp rules.
std::shared_ptr< Request > RequestPtr
AddrRange pmpAddr
addr range corresponding to a single pmp entry
Fault createAddrfault(Addr vaddr, BaseMMU::Mode mode)
createAddrfault creates an address fault if the pmp checks fail to pass for a given access.
Abstract superclass for simulation objects.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const uint8_t PMP_EXEC
pmpcfg address range execute permission mask
void pmpUpdateAddr(uint32_t pmp_index, Addr this_addr)
pmpUpdateAddr updates the pmpaddr for a pmp entry and calls pmpUpdateRule to update the rule of corre...
const uint8_t PMP_WRITE
pmpcfg address range write permission mask
AddrRange pmpDecodeNapot(Addr pmpaddr)
This function decodes a pmpaddr register value into an address range when A field of pmpcfg register ...
uint8_t pmpGetAField(uint8_t cfg)
pmpGetAField extracts the A field (address matching mode) from an input pmpcfg register
const uint8_t PMP_LOCK
pmpcfg address range locked mask
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
void pmpUpdateCfg(uint32_t pmp_index, uint8_t this_cfg)
pmpUpdateCfg updates the pmpcfg for a pmp entry and calls pmpUpdateRule to update the rule of corresp...
const uint8_t PMP_READ
pmpcfg address range read permission mask
int pmpEntries
maximum number of entries in the pmp table
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::vector< PmpEntry > pmpTable
a table of pmp entries
Generated on Tue Sep 7 2021 14:53:42 for gem5 by doxygen 1.8.17