38#ifndef __ARCH_ARM_TLBI_HH__
39#define __ARCH_ARM_TLBI_HH__
250 :
TLBIASID(_targetEL, _secure, _asid)
265 :
TLBIASID(_targetEL, _secure, _asid)
280 :
TLBIOp(_targetEL, false)
305 Addr _addr,
bool last_level)
324 Addr _addr, uint16_t _asid,
bool last_level)
344 Addr _addr, uint16_t _asid)
345 :
TLBIMVA(_targetEL, _secure, _addr, _asid, false)
360 Addr _addr, uint16_t _asid)
361 :
TLBIMVA(_targetEL, _secure, _addr, _asid, false)
385 panic(
"This shouldn't be called\n");
DTLBIALL(ExceptionLevel _targetEL, bool _secure)
void operator()(ThreadContext *tc) override
void broadcast(ThreadContext *tc)=delete
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
Data TLB Invalidate by ASID match.
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
DTLBIASID(ExceptionLevel _targetEL, bool _secure, uint16_t _asid)
void broadcast(ThreadContext *tc)=delete
Data TLB Invalidate by VA.
void broadcast(ThreadContext *tc)=delete
DTLBIMVA(ExceptionLevel _targetEL, bool _secure, Addr _addr, uint16_t _asid)
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
Instruction TLB Invalidate All.
ITLBIALL(ExceptionLevel _targetEL, bool _secure)
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
void operator()(ThreadContext *tc) override
void broadcast(ThreadContext *tc)=delete
Instruction TLB Invalidate by ASID match.
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
void broadcast(ThreadContext *tc)=delete
ITLBIASID(ExceptionLevel _targetEL, bool _secure, uint16_t _asid)
Instruction TLB Invalidate by VA.
void operator()(ThreadContext *tc) override
ITLBIMVA(ExceptionLevel _targetEL, bool _secure, Addr _addr, uint16_t _asid)
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
void broadcast(ThreadContext *tc)=delete
Implementaton of AArch64 TLBI ALLE(1,2,3)(IS) instructions.
TLBIALLEL(ExceptionLevel _targetEL, bool _secure)
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
bool stage2Flush() const override
Return true if the TLBI op needs to flush stage2 entries, Defaulting to false in the TLBIOp abstract ...
TLBIALLEL makeStage2() const
TLB Invalidate All, Non-Secure.
TLBIALLN makeStage2() const
bool stage2Flush() const override
Return true if the TLBI op needs to flush stage2 entries, Defaulting to false in the TLBIOp abstract ...
TLBIALLN(ExceptionLevel _targetEL)
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
bool stage2Flush() const override
Return true if the TLBI op needs to flush stage2 entries, Defaulting to false in the TLBIOp abstract ...
TLBIALL makeStage2() const
void operator()(ThreadContext *tc) override
TLBIALL(ExceptionLevel _targetEL, bool _secure)
TLB Invalidate by ASID match.
void operator()(ThreadContext *tc) override
TLBIASID(ExceptionLevel _targetEL, bool _secure, uint16_t _asid)
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
TLB Invalidate by Intermediate Physical Address.
TLBIMVAA makeStage2() const
TLBIIPA is basically a TLBIMVAA for stage2 TLBs.
TLBIIPA(ExceptionLevel _targetEL, bool _secure, Addr _addr, bool last_level)
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
bool stage1Flush() const override
Return true if the TLBI op needs to flush stage1 entries, Defaulting to true in the TLBIOp abstract c...
TLB Invalidate by VA, All ASID.
TLBIMVAA(ExceptionLevel _targetEL, bool _secure, Addr _addr, bool last_level)
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
void operator()(ThreadContext *tc) override
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
TLBIMVA(ExceptionLevel _targetEL, bool _secure, Addr _addr, uint16_t _asid, bool last_level)
void operator()(ThreadContext *tc) override
void broadcast(ThreadContext *tc)
Broadcast the TLB Invalidate operation to all TLBs in the Arm system.
virtual bool stage1Flush() const
Return true if the TLBI op needs to flush stage1 entries, Defaulting to true in the TLBIOp abstract c...
virtual bool match(TlbEntry *entry, vmid_t curr_vmid) const =0
virtual bool stage2Flush() const
Return true if the TLBI op needs to flush stage2 entries, Defaulting to false in the TLBIOp abstract ...
TLBIOp(ExceptionLevel _targetEL, bool _secure)
virtual void operator()(ThreadContext *tc)
Implementaton of AArch64 TLBI VMALLE1(IS)/VMALLS112E1(IS) instructions.
TLBIVMALL(ExceptionLevel _targetEL, bool _secure, bool _stage2)
TLBIVMALL makeStage2() const
bool match(TlbEntry *entry, vmid_t curr_vmid) const override
void operator()(ThreadContext *tc) override
bool stage2Flush() const override
Return true if the TLBI op needs to flush stage2 entries, Defaulting to false in the TLBIOp abstract ...
ThreadContext is the external interface to all thread state for anything outside of the CPU.
virtual System * getSystemPtr()=0
#define panic(...)
This implements a cprintf based panic() function.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.