mem: Avoid explicitly zeroing the memory backing store
This patch removes the explicit memset as it is redundant and causes the simulator to touch the entire space, forcing the host system to allocate the pages. Anonymous pages are mapped on the first access, and the page-fault handler is responsible for zeroing them. Thus, the pages are still zeroed, but we avoid touching the entire allocated space which enables us to use much larger memory sizes as long as not all the memory is actually used.
This commit is contained in:
parent
cc8911261e
commit
88aa7755f4
5 changed files with 6 additions and 37 deletions
|
@ -180,10 +180,8 @@ def makeSparcSystem(mem_mode, MemClass, mdesc = None):
|
||||||
self.t1000 = T1000()
|
self.t1000 = T1000()
|
||||||
self.t1000.attachOnChipIO(self.membus)
|
self.t1000.attachOnChipIO(self.membus)
|
||||||
self.t1000.attachIO(self.iobus)
|
self.t1000.attachIO(self.iobus)
|
||||||
self.physmem = MemClass(range = AddrRange(Addr('1MB'), size = '64MB'),
|
self.physmem = MemClass(range = AddrRange(Addr('1MB'), size = '64MB'))
|
||||||
zero = True)
|
self.physmem2 = MemClass(range = AddrRange(Addr('2GB'), size ='256MB'))
|
||||||
self.physmem2 = MemClass(range = AddrRange(Addr('2GB'), size ='256MB'),
|
|
||||||
zero = True)
|
|
||||||
self.mem_ranges = [self.physmem.range, self.physmem2.range]
|
self.mem_ranges = [self.physmem.range, self.physmem2.range]
|
||||||
self.bridge.master = self.iobus.slave
|
self.bridge.master = self.iobus.slave
|
||||||
self.bridge.slave = self.membus.master
|
self.bridge.slave = self.membus.master
|
||||||
|
@ -275,8 +273,7 @@ def makeArmSystem(mem_mode, machine_type, MemClass, mdesc = None,
|
||||||
if bare_metal:
|
if bare_metal:
|
||||||
# EOT character on UART will end the simulation
|
# EOT character on UART will end the simulation
|
||||||
self.realview.uart.end_on_eot = True
|
self.realview.uart.end_on_eot = True
|
||||||
self.physmem = MemClass(range = AddrRange(Addr(mdesc.mem())),
|
self.physmem = MemClass(range = AddrRange(Addr(mdesc.mem())))
|
||||||
zero = True)
|
|
||||||
self.mem_ranges = [self.physmem.range]
|
self.mem_ranges = [self.physmem.range]
|
||||||
else:
|
else:
|
||||||
self.kernel = binary('vmlinux.arm.smp.fb.2.6.38.8')
|
self.kernel = binary('vmlinux.arm.smp.fb.2.6.38.8')
|
||||||
|
|
|
@ -162,8 +162,7 @@ class RealView(Platform):
|
||||||
|
|
||||||
def setupBootLoader(self, mem_bus, cur_sys, loc):
|
def setupBootLoader(self, mem_bus, cur_sys, loc):
|
||||||
self.nvmem = SimpleMemory(range = AddrRange(Addr('2GB'),
|
self.nvmem = SimpleMemory(range = AddrRange(Addr('2GB'),
|
||||||
size = '64MB'),
|
size = '64MB'))
|
||||||
zero = True)
|
|
||||||
self.nvmem.port = mem_bus.master
|
self.nvmem.port = mem_bus.master
|
||||||
cur_sys.boot_loader = loc('boot.arm')
|
cur_sys.boot_loader = loc('boot.arm')
|
||||||
|
|
||||||
|
@ -360,8 +359,7 @@ class VExpress_EMM(RealView):
|
||||||
InterruptLine=2, InterruptPin=2)
|
InterruptLine=2, InterruptPin=2)
|
||||||
|
|
||||||
|
|
||||||
vram = SimpleMemory(range = AddrRange(0x18000000, size='32MB'),
|
vram = SimpleMemory(range = AddrRange(0x18000000, size='32MB'))
|
||||||
zero = True)
|
|
||||||
rtc = PL031(pio_addr=0x1C170000, int_num=36)
|
rtc = PL031(pio_addr=0x1C170000, int_num=36)
|
||||||
|
|
||||||
l2x0_fake = IsaFake(pio_addr=0x2C100000, pio_size=0xfff)
|
l2x0_fake = IsaFake(pio_addr=0x2C100000, pio_size=0xfff)
|
||||||
|
@ -376,8 +374,7 @@ class VExpress_EMM(RealView):
|
||||||
mmc_fake = AmbaFake(pio_addr=0x1c050000)
|
mmc_fake = AmbaFake(pio_addr=0x1c050000)
|
||||||
|
|
||||||
def setupBootLoader(self, mem_bus, cur_sys, loc):
|
def setupBootLoader(self, mem_bus, cur_sys, loc):
|
||||||
self.nvmem = SimpleMemory(range = AddrRange(0, size = '64MB'),
|
self.nvmem = SimpleMemory(range = AddrRange(0, size = '64MB'))
|
||||||
zero = True)
|
|
||||||
self.nvmem.port = mem_bus.master
|
self.nvmem.port = mem_bus.master
|
||||||
cur_sys.boot_loader = loc('boot_emm.arm')
|
cur_sys.boot_loader = loc('boot_emm.arm')
|
||||||
cur_sys.atags_addr = 0x80000100
|
cur_sys.atags_addr = 0x80000100
|
||||||
|
|
|
@ -48,7 +48,6 @@ class AbstractMemory(MemObject):
|
||||||
cxx_header = "mem/abstract_mem.hh"
|
cxx_header = "mem/abstract_mem.hh"
|
||||||
range = Param.AddrRange(AddrRange('128MB'), "Address range")
|
range = Param.AddrRange(AddrRange('128MB'), "Address range")
|
||||||
null = Param.Bool(False, "Do not store data, always return zero")
|
null = Param.Bool(False, "Do not store data, always return zero")
|
||||||
zero = Param.Bool(False, "Initialize memory with zeros")
|
|
||||||
|
|
||||||
# All memories are passed to the global physical memory, and
|
# All memories are passed to the global physical memory, and
|
||||||
# certain memories may be excluded from the global address map,
|
# certain memories may be excluded from the global address map,
|
||||||
|
|
|
@ -202,13 +202,6 @@ class AbstractMemory : public MemObject
|
||||||
*/
|
*/
|
||||||
bool isNull() const { return params()->null; }
|
bool isNull() const { return params()->null; }
|
||||||
|
|
||||||
/**
|
|
||||||
* See if this memory should be initialized to zero or not.
|
|
||||||
*
|
|
||||||
* @return true if zero
|
|
||||||
*/
|
|
||||||
bool initToZero() const { return params()->zero; }
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the host memory backing store to be used by this memory
|
* Set the host memory backing store to be used by this memory
|
||||||
* controller.
|
* controller.
|
||||||
|
|
|
@ -162,10 +162,6 @@ PhysicalMemory::createBackingStore(AddrRange range,
|
||||||
// it appropriately
|
// it appropriately
|
||||||
backingStore.push_back(make_pair(range, pmem));
|
backingStore.push_back(make_pair(range, pmem));
|
||||||
|
|
||||||
// count how many of the memories are to be zero initialized so we
|
|
||||||
// can see if some but not all have this parameter set
|
|
||||||
uint32_t init_to_zero = 0;
|
|
||||||
|
|
||||||
// point the memories to their backing store, and if requested,
|
// point the memories to their backing store, and if requested,
|
||||||
// initialize the memory range to 0
|
// initialize the memory range to 0
|
||||||
for (vector<AbstractMemory*>::const_iterator m = _memories.begin();
|
for (vector<AbstractMemory*>::const_iterator m = _memories.begin();
|
||||||
|
@ -173,19 +169,6 @@ PhysicalMemory::createBackingStore(AddrRange range,
|
||||||
DPRINTF(BusAddrRanges, "Mapping memory %s to backing store\n",
|
DPRINTF(BusAddrRanges, "Mapping memory %s to backing store\n",
|
||||||
(*m)->name());
|
(*m)->name());
|
||||||
(*m)->setBackingStore(pmem);
|
(*m)->setBackingStore(pmem);
|
||||||
|
|
||||||
// if it should be zero, then go and make it so
|
|
||||||
if ((*m)->initToZero()) {
|
|
||||||
++init_to_zero;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (init_to_zero != 0) {
|
|
||||||
if (init_to_zero != _memories.size())
|
|
||||||
fatal("Some, but not all memories in range %s are set zero\n",
|
|
||||||
range.to_string());
|
|
||||||
|
|
||||||
memset(pmem, 0, range.size());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue