| gem5 v23.0.0.1
    | 
Level 2 page table descriptor. More...
#include <table_walker.hh>
 
  
| Public Member Functions | |
| L2Descriptor () | |
| Default ctor. | |
| L2Descriptor (L1Descriptor &parent) | |
| uint64_t | getRawData () const override | 
| std::string | dbgHeader () const override | 
| TlbEntry::DomainType | domain () const override | 
| bool | secure (bool have_security, WalkerState *currState) const override | 
| uint8_t | offsetBits () const override | 
| bool | invalid () const | 
| Is the entry invalid. | |
| bool | large () const | 
| What is the size of the mapping? | |
| bool | xn () const override | 
| Is execution allowed on this mapping? | |
| bool | global (WalkerState *currState) const override | 
| Is the translation global (no asid used)? | |
| uint8_t | ap () const override | 
| Three bit access protection flags. | |
| uint8_t | texcb () const override | 
| Memory region attributes: ARM DDI 0406B: B3-32. | |
| Addr | pfn () const override | 
| Return the physical frame, bits shifted right. | |
| Addr | paddr (Addr va) const | 
| Return complete physical address given a VA. | |
| bool | shareable () const override | 
| If the section is shareable. | |
| void | setAp0 () | 
| Set access flag that this entry has been touched. | |
| bool | dirty () const | 
| This entry needs to be written back to memory. | |
|  Public Member Functions inherited from gem5::ArmISA::TableWalker::DescriptorBase | |
| DescriptorBase () | |
| virtual Addr | pfn () const =0 | 
| virtual TlbEntry::DomainType | domain () const =0 | 
| virtual bool | xn () const =0 | 
| virtual uint8_t | ap () const =0 | 
| virtual bool | global (WalkerState *currState) const =0 | 
| virtual uint8_t | offsetBits () const =0 | 
| virtual bool | secure (bool have_security, WalkerState *currState) const =0 | 
| virtual std::string | dbgHeader () const =0 | 
| virtual uint64_t | getRawData () const =0 | 
| virtual uint8_t | texcb () const | 
| virtual bool | shareable () const | 
| Public Attributes | |
| uint32_t | data | 
| The raw bits of the entry. | |
| L1Descriptor * | l1Parent | 
| bool | _dirty | 
| This entry has been modified (access flag set) and needs to be written back to memory. | |
|  Public Attributes inherited from gem5::ArmISA::TableWalker::DescriptorBase | |
| LookupLevel | lookupLevel | 
| Current lookup level for this descriptor. | |
Level 2 page table descriptor.
Definition at line 271 of file table_walker.hh.
| 
 | inline | 
Default ctor.
Definition at line 283 of file table_walker.hh.
References gem5::ArmISA::TableWalker::DescriptorBase::lookupLevel.
| 
 | inline | 
Definition at line 288 of file table_walker.hh.
References gem5::ArmISA::TableWalker::DescriptorBase::lookupLevel.
| 
 | inlineoverridevirtual | 
Three bit access protection flags.
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 354 of file table_walker.hh.
References gem5::bits(), and data.
Referenced by gem5::ArmISA::TableWalker::doL2Descriptor().
| 
 | inlineoverridevirtual | 
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 301 of file table_walker.hh.
| 
 | inline | 
This entry needs to be written back to memory.
Definition at line 404 of file table_walker.hh.
References _dirty.
| 
 | inlineoverridevirtual | 
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 307 of file table_walker.hh.
References gem5::ArmISA::TableWalker::L1Descriptor::domain(), and l1Parent.
| 
 | inlineoverridevirtual | 
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 295 of file table_walker.hh.
References data.
| 
 | inlineoverridevirtual | 
Is the translation global (no asid used)?
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 347 of file table_walker.hh.
References gem5::bits(), and data.
| 
 | inline | 
Is the entry invalid.
Definition at line 326 of file table_walker.hh.
References gem5::bits(), and data.
Referenced by gem5::ArmISA::TableWalker::doL2Descriptor().
| 
 | inline | 
What is the size of the mapping?
Definition at line 333 of file table_walker.hh.
References gem5::bits(), and data.
Referenced by offsetBits(), paddr(), pfn(), texcb(), and xn().
| 
 | inlineoverridevirtual | 
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 319 of file table_walker.hh.
References large().
Return complete physical address given a VA.
Definition at line 377 of file table_walker.hh.
References data, large(), gem5::mbits(), and gem5::ArmISA::va.
| 
 | inlineoverridevirtual | 
Return the physical frame, bits shifted right.
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 370 of file table_walker.hh.
References gem5::bits(), data, and large().
| 
 | inlineoverridevirtual | 
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 313 of file table_walker.hh.
References gem5::ArmISA::TableWalker::currState, l1Parent, and gem5::ArmISA::TableWalker::L1Descriptor::secure().
| 
 | inline | 
Set access flag that this entry has been touched.
Mark the entry as requiring a writeback, in the future.
Definition at line 396 of file table_walker.hh.
| 
 | inlineoverridevirtual | 
If the section is shareable.
See texcb() comment.
Reimplemented from gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 387 of file table_walker.hh.
References gem5::bits(), and data.
| 
 | inlineoverridevirtual | 
Memory region attributes: ARM DDI 0406B: B3-32.
Reimplemented from gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 361 of file table_walker.hh.
References gem5::bits(), data, and large().
| 
 | inlineoverridevirtual | 
Is execution allowed on this mapping?
Implements gem5::ArmISA::TableWalker::DescriptorBase.
Definition at line 340 of file table_walker.hh.
References gem5::bits(), data, and large().
| bool gem5::ArmISA::TableWalker::L2Descriptor::_dirty | 
This entry has been modified (access flag set) and needs to be written back to memory.
Definition at line 280 of file table_walker.hh.
| uint32_t gem5::ArmISA::TableWalker::L2Descriptor::data | 
The raw bits of the entry.
Definition at line 275 of file table_walker.hh.
Referenced by ap(), gem5::ArmISA::TableWalker::doL1Descriptor(), gem5::ArmISA::TableWalker::doL2Descriptor(), getRawData(), global(), invalid(), large(), paddr(), pfn(), setAp0(), shareable(), texcb(), and xn().
| L1Descriptor* gem5::ArmISA::TableWalker::L2Descriptor::l1Parent | 
Definition at line 276 of file table_walker.hh.