memory access (I think because we're deallocating our one and only
CpuRequest object).
base/loader/aout_object.cc:
base/loader/ecoff_object.cc:
base/loader/elf_object.cc:
Add flag to force allocation of new pages on data writes.
cpu/simple/cpu.cc:
Several minor fixes.
Switch to atomic mode for now.
mem/physical.hh:
Don't copy the packet to the response event, just keep a reference
to the original.
mem/translating_port.cc:
mem/translating_port.hh:
Add parameter to writeBlobFunctional() to force allocation of
unallocated pages on writes.
--HG--
extra : convert_revision :
05cb31c7b0047b492dcfa0d12ddee690ef762b44
// Since we don't really have an MMU and all memory is
// zero-filled, there's no need to set up the BSS segment.
if (text.size != 0)
- memPort->writeBlobFunctional(textAddr, fileData + N_TXTOFF(*execHdr), text.size);
+ memPort->writeBlobFunctional(textAddr, fileData + N_TXTOFF(*execHdr),
+ text.size, true);
if (data.size != 0)
- memPort->writeBlobFunctional(dataAddr, fileData + N_DATOFF(*execHdr), data.size);
+ memPort->writeBlobFunctional(dataAddr, fileData + N_DATOFF(*execHdr),
+ data.size, true);
return true;
}
// Since we don't really have an MMU and all memory is
// zero-filled, there's no need to set up the BSS segment.
- memPort->writeBlobFunctional(textAddr, fileData + ECOFF_TXTOFF(execHdr), text.size);
- memPort->writeBlobFunctional(dataAddr, fileData + ECOFF_DATOFF(execHdr), data.size);
+ memPort->writeBlobFunctional(textAddr, fileData + ECOFF_TXTOFF(execHdr),
+ text.size, true);
+ memPort->writeBlobFunctional(dataAddr, fileData + ECOFF_DATOFF(execHdr),
+ data.size, true);
return true;
}
// Since we don't really have an MMU and all memory is
// zero-filled, there's no need to set up the BSS segment.
if (text.size != 0)
- memPort->writeBlobFunctional(textAddr, fileTextBits, text.size);
+ memPort->writeBlobFunctional(textAddr, fileTextBits, text.size, true);
if (data.size != 0)
- memPort->writeBlobFunctional(dataAddr, fileDataBits, data.size);
+ memPort->writeBlobFunctional(dataAddr, fileDataBits, data.size, true);
return true;
}
void
SimpleCPU::sendIcacheRequest()
{
-#if 1
+#if 0
bool success = icachePort.sendTiming(*pkt);
unscheduleTickEvent();
_status = IcacheWaitResponse;
}
#else
- Tick latency = icachePort.sendAtomic(pkt);
+ Tick latency = icachePort.sendAtomic(*pkt);
unscheduleTickEvent();
scheduleTickEvent(latency);
{
unscheduleTickEvent();
-#if 1
+#if 0
bool success = dcachePort.sendTiming(*pkt);
lastDcacheStall = curTick;
_status = DcacheWaitResponse;
}
#else
- Tick latency = dcachePort.sendAtomic(pkt);
+ Tick latency = dcachePort.sendAtomic(*pkt);
scheduleTickEvent(latency);
/* memReq->reset(xc->regs.pc & ~3, sizeof(uint32_t),
IFETCH_FLAGS(xc->regs.pc));
*/
-//NEED NEW TRANSLATION HERE
+
fault = xc->translateInstReq(req);
if (fault == No_Fault) {
pkt->addr = req->paddr;
pkt->size = sizeof(MachInst);
pkt->req = req;
+ pkt->data = (uint8_t *)&inst;
sendIcacheRequest();
+ return;
/* fault = xc->mem->read(memReq, inst);
if (icacheInterface && fault == No_Fault) {
struct MemResponseEvent : public Event
{
- Packet pkt;
+ Packet &pkt;
MemoryPort *memoryPort;
MemResponseEvent(Packet &pkt, MemoryPort *memoryPort);
for (ChunkGenerator gen(addr, size, VMPageSize); !gen.done(); gen.next()) {
- if (!pTable->translate(gen.addr(),paddr))
- return Machine_Check_Fault;
+ if (!pTable->translate(gen.addr(),paddr))
+ return Machine_Check_Fault;
- port->readBlobFunctional(paddr, p + prevSize, gen.size());
- prevSize += gen.size();
+ port->readBlobFunctional(paddr, p + prevSize, gen.size());
+ prevSize += gen.size();
}
return No_Fault;
}
Fault
-TranslatingPort::writeBlobFunctional(Addr addr, uint8_t *p, int size)
+TranslatingPort::writeBlobFunctional(Addr addr, uint8_t *p, int size,
+ bool alloc)
{
Addr paddr;
int prevSize = 0;
for (ChunkGenerator gen(addr, size, VMPageSize); !gen.done(); gen.next()) {
- if (!pTable->translate(gen.addr(),paddr))
- return Machine_Check_Fault;
-
- port->writeBlobFunctional(paddr, p + prevSize, gen.size());
- prevSize += gen.size();
+ if (!pTable->translate(gen.addr(), paddr)) {
+ if (alloc) {
+ pTable->allocate(roundDown(gen.addr(), VMPageSize),
+ VMPageSize);
+ pTable->translate(gen.addr(), paddr);
+ } else {
+ return Machine_Check_Fault;
+ }
+ }
+
+ port->writeBlobFunctional(paddr, p + prevSize, gen.size());
+ prevSize += gen.size();
}
return No_Fault;
public:
Fault readBlobFunctional(Addr addr, uint8_t *p, int size);
- Fault writeBlobFunctional(Addr addr, uint8_t *p, int size);
+ Fault writeBlobFunctional(Addr addr, uint8_t *p, int size,
+ bool alloc = false);
// Fault memsetBlobFunctional(Addr addr, uint8_t val, int size);
Fault writeStringFunctional(Addr addr, const char *str);
Fault readStringFunctional(std::string &str, Addr addr);