Use a computed mask to mask out the fetch address and not a hard coded one.

--HG--
extra : convert_revision : c22907bed4b83f0dff51d2283dafe4f76fa9e94a
This commit is contained in:
Gabe Black 2007-04-11 14:16:54 +00:00
parent 54abc8b337
commit c382bdf93d

View file

@ -335,7 +335,11 @@ BaseSimpleCPU::setupFetchRequest(Request *req)
thread->readNextPC());
#endif
req->setVirt(0, thread->readPC() & ~3, sizeof(MachInst), 0,
// This will generate a mask which aligns the pc on MachInst size
// boundaries. It won't work for non-power-of-two sized MachInsts, but
// it will work better than a hard coded mask.
const Addr PCMask = ~(sizeof(MachInst) - 1);
req->setVirt(0, thread->readPC() & PCMask, sizeof(MachInst), 0,
thread->readPC());
Fault fault = thread->translateInstReq(req);