arm: Don't consult the TLB test iface for functional translations
Don't consult the TLB test interface for PA's returned by functional translations by the AT instruction. We implement this by chaning the ISA code to synthesize 0-length functional reads for the TLB lookup. The TLB then bypasses the final PA check in the tester if the size is zero. Change-Id: I2487b7f829cea88c37e229e9fc7a4543aced961b Signed-off-by: Andreas Sandberg <andreas.sandberg@arm.com> Reviewed-by: Curtis Dunham <curtis.dunham@arm.com>
This commit is contained in:
parent
30cae3c213
commit
f471cc22f0
2 changed files with 3 additions and 3 deletions
|
@ -1520,7 +1520,7 @@ ISA::setMiscReg(int misc_reg, const MiscReg &val, ThreadContext *tc)
|
||||||
// can't be an atomic translation because that causes problems
|
// can't be an atomic translation because that causes problems
|
||||||
// with unexpected atomic snoop requests.
|
// with unexpected atomic snoop requests.
|
||||||
warn("Translating via MISCREG(%d) in functional mode! Fix Me!\n", misc_reg);
|
warn("Translating via MISCREG(%d) in functional mode! Fix Me!\n", misc_reg);
|
||||||
Request req(0, val, 1, flags, Request::funcMasterId,
|
Request req(0, val, 0, flags, Request::funcMasterId,
|
||||||
tc->pcState().pc(), tc->contextId());
|
tc->pcState().pc(), tc->contextId());
|
||||||
fault = tc->getDTBPtr()->translateFunctional(&req, tc, mode, tranType);
|
fault = tc->getDTBPtr()->translateFunctional(&req, tc, mode, tranType);
|
||||||
TTBCR ttbcr = readMiscRegNoEffect(MISCREG_TTBCR);
|
TTBCR ttbcr = readMiscRegNoEffect(MISCREG_TTBCR);
|
||||||
|
@ -1765,7 +1765,7 @@ ISA::setMiscReg(int misc_reg, const MiscReg &val, ThreadContext *tc)
|
||||||
// can't be an atomic translation because that causes problems
|
// can't be an atomic translation because that causes problems
|
||||||
// with unexpected atomic snoop requests.
|
// with unexpected atomic snoop requests.
|
||||||
warn("Translating via MISCREG(%d) in functional mode! Fix Me!\n", misc_reg);
|
warn("Translating via MISCREG(%d) in functional mode! Fix Me!\n", misc_reg);
|
||||||
req->setVirt(0, val, 1, flags, Request::funcMasterId,
|
req->setVirt(0, val, 0, flags, Request::funcMasterId,
|
||||||
tc->pcState().pc());
|
tc->pcState().pc());
|
||||||
req->setContext(tc->contextId());
|
req->setContext(tc->contextId());
|
||||||
fault = tc->getDTBPtr()->translateFunctional(req, tc, mode,
|
fault = tc->getDTBPtr()->translateFunctional(req, tc, mode,
|
||||||
|
|
|
@ -1423,7 +1423,7 @@ TLB::setTestInterface(SimObject *_ti)
|
||||||
Fault
|
Fault
|
||||||
TLB::testTranslation(RequestPtr req, Mode mode, TlbEntry::DomainType domain)
|
TLB::testTranslation(RequestPtr req, Mode mode, TlbEntry::DomainType domain)
|
||||||
{
|
{
|
||||||
if (!test) {
|
if (!test || !req->hasSize() || req->getSize() == 0) {
|
||||||
return NoFault;
|
return NoFault;
|
||||||
} else {
|
} else {
|
||||||
return test->translationCheck(req, isPriv, mode, domain);
|
return test->translationCheck(req, isPriv, mode, domain);
|
||||||
|
|
Loading…
Reference in a new issue