config: Move the memory instantiation outside FSConfig

This patch moves the instantiation of the memory controller outside
FSConfig and instead relies on the mem_ranges to pass the information
to the caller (e.g. fs.py or one of the regression scripts). The main
motivation for this change is to expose the structural composition of
the memory system and allow more tuning and configuration without
adding a large number of options to the makeSystem functions.

The patch updates the relevant example scripts to maintain the current
functionality. As the order that ports are connected to the memory bus
changes (in certain regresisons), some bus stats are shuffled
around. For example, what used to be layer 0 is now layer 1.

Going forward, options will be added to support the addition of
multi-channel memory controllers.
This commit is contained in:
Andreas Hansson 2013-08-19 03:52:27 -04:00
parent d5593f3c75
commit a8480fe1c3
43 changed files with 137 additions and 96 deletions

View file

@ -55,7 +55,7 @@ class MemBus(CoherentBus):
default = Self.badaddr_responder.pio default = Self.badaddr_responder.pio
def makeLinuxAlphaSystem(mem_mode, MemClass, mdesc = None): def makeLinuxAlphaSystem(mem_mode, mdesc = None):
IO_address_space_base = 0x80000000000 IO_address_space_base = 0x80000000000
class BaseTsunami(Tsunami): class BaseTsunami(Tsunami):
ethernet = NSGigE(pci_bus=0, pci_dev=1, pci_func=0) ethernet = NSGigE(pci_bus=0, pci_dev=1, pci_func=0)
@ -73,11 +73,9 @@ def makeLinuxAlphaSystem(mem_mode, MemClass, mdesc = None):
# base address (including the PCI config space) # base address (including the PCI config space)
self.bridge = Bridge(delay='50ns', self.bridge = Bridge(delay='50ns',
ranges = [AddrRange(IO_address_space_base, Addr.max)]) ranges = [AddrRange(IO_address_space_base, Addr.max)])
self.physmem = MemClass(range = AddrRange(mdesc.mem())) self.mem_ranges = [AddrRange(mdesc.mem())]
self.mem_ranges = [self.physmem.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
self.physmem.port = self.membus.master
self.disk0 = CowIdeDisk(driveID='master') self.disk0 = CowIdeDisk(driveID='master')
self.disk2 = CowIdeDisk(driveID='master') self.disk2 = CowIdeDisk(driveID='master')
self.disk0.childImage(mdesc.disk()) self.disk0.childImage(mdesc.disk())
@ -104,15 +102,13 @@ def makeLinuxAlphaSystem(mem_mode, MemClass, mdesc = None):
return self return self
def makeLinuxAlphaRubySystem(mem_mode, MemClass, mdesc = None): def makeLinuxAlphaRubySystem(mem_mode, mdesc = None):
class BaseTsunami(Tsunami): class BaseTsunami(Tsunami):
ethernet = NSGigE(pci_bus=0, pci_dev=1, pci_func=0) ethernet = NSGigE(pci_bus=0, pci_dev=1, pci_func=0)
ide = IdeController(disks=[Parent.disk0, Parent.disk2], ide = IdeController(disks=[Parent.disk0, Parent.disk2],
pci_func=0, pci_dev=0, pci_bus=0) pci_func=0, pci_dev=0, pci_bus=0)
self = LinuxAlphaSystem()
physmem = MemClass(range = AddrRange(mdesc.mem())) self.mem_ranges = [AddrRange(mdesc.mem())]
self = LinuxAlphaSystem(physmem = physmem)
self.mem_ranges = [self.physmem.range]
if not mdesc: if not mdesc:
# generic system # generic system
mdesc = SysConfig() mdesc = SysConfig()
@ -121,13 +117,6 @@ def makeLinuxAlphaRubySystem(mem_mode, MemClass, mdesc = None):
# Create pio bus to connect all device pio ports to rubymem's pio port # Create pio bus to connect all device pio ports to rubymem's pio port
self.piobus = NoncoherentBus() self.piobus = NoncoherentBus()
#
# Pio functional accesses from devices need direct access to memory
# RubyPort currently does support functional accesses. Therefore provide
# the piobus a direct connection to physical memory
#
self.piobus.master = physmem.port
self.disk0 = CowIdeDisk(driveID='master') self.disk0 = CowIdeDisk(driveID='master')
self.disk2 = CowIdeDisk(driveID='master') self.disk2 = CowIdeDisk(driveID='master')
self.disk0.childImage(mdesc.disk()) self.disk0.childImage(mdesc.disk())
@ -157,7 +146,7 @@ def makeLinuxAlphaRubySystem(mem_mode, MemClass, mdesc = None):
return self return self
def makeSparcSystem(mem_mode, MemClass, mdesc = None): def makeSparcSystem(mem_mode, mdesc = None):
# Constants from iob.cc and uart8250.cc # Constants from iob.cc and uart8250.cc
iob_man_addr = 0x9800000000 iob_man_addr = 0x9800000000
uart_pio_size = 8 uart_pio_size = 8
@ -180,13 +169,10 @@ 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.mem_ranges = [AddrRange(Addr('1MB'), size = '64MB'),
self.physmem2 = MemClass(range = AddrRange(Addr('2GB'), size ='256MB')) AddrRange(Addr('2GB'), size ='256MB')]
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
self.physmem.port = self.membus.master
self.physmem2.port = self.membus.master
self.rom.port = self.membus.master self.rom.port = self.membus.master
self.nvram.port = self.membus.master self.nvram.port = self.membus.master
self.hypervisor_desc.port = self.membus.master self.hypervisor_desc.port = self.membus.master
@ -225,7 +211,7 @@ def makeSparcSystem(mem_mode, MemClass, mdesc = None):
return self return self
def makeArmSystem(mem_mode, machine_type, MemClass, mdesc = None, def makeArmSystem(mem_mode, machine_type, mdesc = None,
dtb_filename = None, bare_metal=False): dtb_filename = None, bare_metal=False):
assert machine_type assert machine_type
@ -273,8 +259,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.mem_ranges = [AddrRange(mdesc.mem())]
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')
if dtb_filename is not None: if dtb_filename is not None:
@ -288,11 +273,8 @@ def makeArmSystem(mem_mode, machine_type, MemClass, mdesc = None,
boot_flags = 'earlyprintk console=ttyAMA0 lpj=19988480 norandmaps ' + \ boot_flags = 'earlyprintk console=ttyAMA0 lpj=19988480 norandmaps ' + \
'rw loglevel=8 mem=%s root=/dev/sda1' % mdesc.mem() 'rw loglevel=8 mem=%s root=/dev/sda1' % mdesc.mem()
self.mem_ranges = [AddrRange(self.realview.mem_start_addr,
self.physmem = MemClass(range = AddrRange(self.realview.mem_start_addr, size = mdesc.mem())]
size = mdesc.mem()),
conf_table_reported = True)
self.mem_ranges = [self.physmem.range]
self.realview.setupBootLoader(self.membus, self, binary) self.realview.setupBootLoader(self.membus, self, binary)
self.gic_cpu_addr = self.realview.gic.cpu_addr self.gic_cpu_addr = self.realview.gic.cpu_addr
self.flags_addr = self.realview.realview_io.pio_addr + 0x30 self.flags_addr = self.realview.realview_io.pio_addr + 0x30
@ -300,8 +282,6 @@ def makeArmSystem(mem_mode, machine_type, MemClass, mdesc = None,
if mdesc.disk().lower().count('android'): if mdesc.disk().lower().count('android'):
boot_flags += " init=/init " boot_flags += " init=/init "
self.boot_osflags = boot_flags self.boot_osflags = boot_flags
self.physmem.port = self.membus.master
self.realview.attachOnChipIO(self.membus, self.bridge) self.realview.attachOnChipIO(self.membus, self.bridge)
self.realview.attachIO(self.iobus) self.realview.attachIO(self.iobus)
self.intrctrl = IntrControl() self.intrctrl = IntrControl()
@ -313,7 +293,7 @@ def makeArmSystem(mem_mode, machine_type, MemClass, mdesc = None,
return self return self
def makeLinuxMipsSystem(mem_mode, MemClass, mdesc = None): def makeLinuxMipsSystem(mem_mode, mdesc = None):
class BaseMalta(Malta): class BaseMalta(Malta):
ethernet = NSGigE(pci_bus=0, pci_dev=1, pci_func=0) ethernet = NSGigE(pci_bus=0, pci_dev=1, pci_func=0)
ide = IdeController(disks=[Parent.disk0, Parent.disk2], ide = IdeController(disks=[Parent.disk0, Parent.disk2],
@ -327,11 +307,9 @@ def makeLinuxMipsSystem(mem_mode, MemClass, mdesc = None):
self.iobus = NoncoherentBus() self.iobus = NoncoherentBus()
self.membus = MemBus() self.membus = MemBus()
self.bridge = Bridge(delay='50ns') self.bridge = Bridge(delay='50ns')
self.physmem = MemClass(range = AddrRange('1GB')) self.mem_ranges = [AddrRange('1GB')]
self.mem_ranges = [self.physmem.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
self.physmem.port = self.membus.master
self.disk0 = CowIdeDisk(driveID='master') self.disk0 = CowIdeDisk(driveID='master')
self.disk2 = CowIdeDisk(driveID='master') self.disk2 = CowIdeDisk(driveID='master')
self.disk0.childImage(mdesc.disk()) self.disk0.childImage(mdesc.disk())
@ -369,7 +347,6 @@ def connectX86ClassicSystem(x86_sys, numCPUs):
APIC_range_size = 1 << 12; APIC_range_size = 1 << 12;
x86_sys.membus = MemBus() x86_sys.membus = MemBus()
x86_sys.physmem.port = x86_sys.membus.master
# North Bridge # North Bridge
x86_sys.iobus = NoncoherentBus() x86_sys.iobus = NoncoherentBus()
@ -409,19 +386,13 @@ def connectX86RubySystem(x86_sys):
# North Bridge # North Bridge
x86_sys.piobus = NoncoherentBus() x86_sys.piobus = NoncoherentBus()
#
# Pio functional accesses from devices need direct access to memory
# RubyPort currently does support functional accesses. Therefore provide
# the piobus a direct connection to physical memory
#
x86_sys.piobus.master = x86_sys.physmem.port
# add the ide to the list of dma devices that later need to attach to # add the ide to the list of dma devices that later need to attach to
# dma controllers # dma controllers
x86_sys._dma_ports = [x86_sys.pc.south_bridge.ide.dma] x86_sys._dma_ports = [x86_sys.pc.south_bridge.ide.dma]
x86_sys.pc.attachIO(x86_sys.piobus, x86_sys._dma_ports) x86_sys.pc.attachIO(x86_sys.piobus, x86_sys._dma_ports)
def makeX86System(mem_mode, MemClass, numCPUs = 1, mdesc = None, self = None, def makeX86System(mem_mode, numCPUs = 1, mdesc = None, self = None,
Ruby = False): Ruby = False):
if self == None: if self == None:
self = X86System() self = X86System()
@ -434,8 +405,7 @@ def makeX86System(mem_mode, MemClass, numCPUs = 1, mdesc = None, self = None,
self.mem_mode = mem_mode self.mem_mode = mem_mode
# Physical memory # Physical memory
self.physmem = MemClass(range = AddrRange(mdesc.mem())) self.mem_ranges = [AddrRange(mdesc.mem())]
self.mem_ranges = [self.physmem.range]
# Platform # Platform
self.pc = Pc() self.pc = Pc()
@ -518,17 +488,16 @@ def makeX86System(mem_mode, MemClass, numCPUs = 1, mdesc = None, self = None,
self.intel_mp_table.base_entries = base_entries self.intel_mp_table.base_entries = base_entries
self.intel_mp_table.ext_entries = ext_entries self.intel_mp_table.ext_entries = ext_entries
def makeLinuxX86System(mem_mode, MemClass, numCPUs = 1, mdesc = None, def makeLinuxX86System(mem_mode, numCPUs = 1, mdesc = None,
Ruby = False): Ruby = False):
self = LinuxX86System() self = LinuxX86System()
# Build up the x86 system and then specialize it for Linux # Build up the x86 system and then specialize it for Linux
makeX86System(mem_mode, MemClass, numCPUs, mdesc, self, Ruby) makeX86System(mem_mode, numCPUs, mdesc, self, Ruby)
# We assume below that there's at least 1MB of memory. We'll require 2 # We assume below that there's at least 1MB of memory. We'll require 2
# just to avoid corner cases. # just to avoid corner cases.
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), self.mem_ranges))
self.memories.unproxy(self)))
assert(phys_mem_size >= 0x200000) assert(phys_mem_size >= 0x200000)
self.e820_table.entries = \ self.e820_table.entries = \

View file

@ -102,17 +102,16 @@ else:
np = options.num_cpus np = options.num_cpus
if buildEnv['TARGET_ISA'] == "alpha": if buildEnv['TARGET_ISA'] == "alpha":
test_sys = makeLinuxAlphaSystem(test_mem_mode, TestMemClass, bm[0]) test_sys = makeLinuxAlphaSystem(test_mem_mode, bm[0])
elif buildEnv['TARGET_ISA'] == "mips": elif buildEnv['TARGET_ISA'] == "mips":
test_sys = makeLinuxMipsSystem(test_mem_mode, TestMemClass, bm[0]) test_sys = makeLinuxMipsSystem(test_mem_mode, bm[0])
elif buildEnv['TARGET_ISA'] == "sparc": elif buildEnv['TARGET_ISA'] == "sparc":
test_sys = makeSparcSystem(test_mem_mode, TestMemClass, bm[0]) test_sys = makeSparcSystem(test_mem_mode, bm[0])
elif buildEnv['TARGET_ISA'] == "x86": elif buildEnv['TARGET_ISA'] == "x86":
test_sys = makeLinuxX86System(test_mem_mode, TestMemClass, test_sys = makeLinuxX86System(test_mem_mode, options.num_cpus, bm[0])
options.num_cpus, bm[0])
elif buildEnv['TARGET_ISA'] == "arm": elif buildEnv['TARGET_ISA'] == "arm":
test_sys = makeArmSystem(test_mem_mode, options.machine_type, test_sys = makeArmSystem(test_mem_mode, options.machine_type, bm[0],
TestMemClass, bm[0], options.dtb_filename, options.dtb_filename,
bare_metal=options.bare_metal) bare_metal=options.bare_metal)
else: else:
fatal("Incapable of building %s full system!", buildEnv['TARGET_ISA']) fatal("Incapable of building %s full system!", buildEnv['TARGET_ISA'])
@ -164,18 +163,24 @@ for i in xrange(np):
CacheConfig.config_cache(options, test_sys) CacheConfig.config_cache(options, test_sys)
# Create the appropriate memory controllers and connect them to the
# memory bus
test_sys.mem_ctrls = [TestMemClass(range = r, conf_table_reported = True)
for r in test_sys.mem_ranges]
for i in xrange(len(test_sys.mem_ctrls)):
test_sys.mem_ctrls[i].port = test_sys.membus.master
if len(bm) == 2: if len(bm) == 2:
if buildEnv['TARGET_ISA'] == 'alpha': if buildEnv['TARGET_ISA'] == 'alpha':
drive_sys = makeLinuxAlphaSystem(drive_mem_mode, DriveMemClass, bm[1]) drive_sys = makeLinuxAlphaSystem(drive_mem_mode, bm[1])
elif buildEnv['TARGET_ISA'] == 'mips': elif buildEnv['TARGET_ISA'] == 'mips':
drive_sys = makeLinuxMipsSystem(drive_mem_mode, DriveMemClass, bm[1]) drive_sys = makeLinuxMipsSystem(drive_mem_mode, bm[1])
elif buildEnv['TARGET_ISA'] == 'sparc': elif buildEnv['TARGET_ISA'] == 'sparc':
drive_sys = makeSparcSystem(drive_mem_mode, DriveMemClass, bm[1]) drive_sys = makeSparcSystem(drive_mem_mode, bm[1])
elif buildEnv['TARGET_ISA'] == 'x86': elif buildEnv['TARGET_ISA'] == 'x86':
drive_sys = makeX86System(drive_mem_mode, DriveMemClass, np, bm[1]) drive_sys = makeX86System(drive_mem_mode, np, bm[1])
elif buildEnv['TARGET_ISA'] == 'arm': elif buildEnv['TARGET_ISA'] == 'arm':
drive_sys = makeArmSystem(drive_mem_mode, options.machine_type, drive_sys = makeArmSystem(drive_mem_mode, options.machine_type, bm[1])
DriveMemClass, bm[1])
# Create a source clock for the system and set the clock period # Create a source clock for the system and set the clock period
drive_sys.clk_domain = SrcClockDomain(clock = options.sys_clock) drive_sys.clk_domain = SrcClockDomain(clock = options.sys_clock)
@ -201,6 +206,13 @@ if len(bm) == 2:
drive_sys.iobridge.slave = drive_sys.iobus.master drive_sys.iobridge.slave = drive_sys.iobus.master
drive_sys.iobridge.master = drive_sys.membus.slave drive_sys.iobridge.master = drive_sys.membus.slave
# Create the appropriate memory controllers and connect them to the
# memory bus
drive_sys.mem_ctrls = [DriveMemClass(range = r, conf_table_reported = True)
for r in drive_sys.mem_ranges]
for i in xrange(len(drive_sys.mem_ctrls)):
drive_sys.mem_ctrls[i].port = drive_sys.membus.master
drive_sys.init_param = options.init_param drive_sys.init_param = options.init_param
root = makeDualRoot(True, test_sys, drive_sys, options.etherdump) root = makeDualRoot(True, test_sys, drive_sys, options.etherdump)
elif len(bm) == 1: elif len(bm) == 1:

View file

@ -83,10 +83,9 @@ if not (options.cpu_type == "detailed" or options.cpu_type == "timing"):
TestMemClass = Simulation.setMemClass(options) TestMemClass = Simulation.setMemClass(options)
if buildEnv['TARGET_ISA'] == "alpha": if buildEnv['TARGET_ISA'] == "alpha":
system = makeLinuxAlphaRubySystem(test_mem_mode, TestMemClass, bm[0]) system = makeLinuxAlphaRubySystem(test_mem_mode, bm[0])
elif buildEnv['TARGET_ISA'] == "x86": elif buildEnv['TARGET_ISA'] == "x86":
system = makeLinuxX86System(test_mem_mode, TestMemClass, system = makeLinuxX86System(test_mem_mode, options.num_cpus, bm[0], True)
options.num_cpus, bm[0], True)
Simulation.setWorkCountOptions(system, options) Simulation.setWorkCountOptions(system, options)
else: else:
fatal("incapable of building non-alpha or non-x86 full system!") fatal("incapable of building non-alpha or non-x86 full system!")
@ -127,5 +126,13 @@ for (i, cpu) in enumerate(system.cpu):
system.ruby._cpu_ruby_ports[i].access_phys_mem = True system.ruby._cpu_ruby_ports[i].access_phys_mem = True
# Create the appropriate memory controllers and connect them to the
# PIO bus
system.mem_ctrls = [TestMemClass(range = r,
conf_table_reported = True)
for r in system.mem_ranges]
for i in xrange(len(system.physmem)):
system.mem_ctrls[i].port = system.piobus.master
root = Root(full_system = True, system = system) root = Root(full_system = True, system = system)
Simulation.run(options, root, system, FutureClass) Simulation.run(options, root, system, FutureClass)

View file

@ -140,8 +140,7 @@ def create_system(options, system, piobus, dma_ports, ruby_system):
cntrl_count += 1 cntrl_count += 1
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(phys_mem_size % options.num_dirs == 0) assert(phys_mem_size % options.num_dirs == 0)
mem_module_size = phys_mem_size / options.num_dirs mem_module_size = phys_mem_size / options.num_dirs

View file

@ -105,8 +105,7 @@ def create_system(options, system, piobus, dma_ports, ruby_system):
cntrl_count += 1 cntrl_count += 1
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(phys_mem_size % options.num_dirs == 0) assert(phys_mem_size % options.num_dirs == 0)
mem_module_size = phys_mem_size / options.num_dirs mem_module_size = phys_mem_size / options.num_dirs

View file

@ -135,8 +135,7 @@ def create_system(options, system, piobus, dma_ports, ruby_system):
cntrl_count += 1 cntrl_count += 1
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(phys_mem_size % options.num_dirs == 0) assert(phys_mem_size % options.num_dirs == 0)
mem_module_size = phys_mem_size / options.num_dirs mem_module_size = phys_mem_size / options.num_dirs

View file

@ -156,8 +156,7 @@ def create_system(options, system, piobus, dma_ports, ruby_system):
cntrl_count += 1 cntrl_count += 1
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(phys_mem_size % options.num_dirs == 0) assert(phys_mem_size % options.num_dirs == 0)
mem_module_size = phys_mem_size / options.num_dirs mem_module_size = phys_mem_size / options.num_dirs

View file

@ -131,8 +131,7 @@ def create_system(options, system, piobus, dma_ports, ruby_system):
cntrl_count += 1 cntrl_count += 1
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(phys_mem_size % options.num_dirs == 0) assert(phys_mem_size % options.num_dirs == 0)
mem_module_size = phys_mem_size / options.num_dirs mem_module_size = phys_mem_size / options.num_dirs

View file

@ -103,8 +103,7 @@ def create_system(options, system, piobus, dma_ports, ruby_system):
cntrl_count += 1 cntrl_count += 1
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(phys_mem_size % options.num_dirs == 0) assert(phys_mem_size % options.num_dirs == 0)
mem_module_size = phys_mem_size / options.num_dirs mem_module_size = phys_mem_size / options.num_dirs

View file

@ -183,8 +183,7 @@ def create_system(options, system, piobus = None, dma_ports = []):
total_mem_size.value += dir_cntrl.directory.size.value total_mem_size.value += dir_cntrl.directory.size.value
dir_cntrl.directory.numa_high_bit = numa_bit dir_cntrl.directory.numa_high_bit = numa_bit
phys_mem_size = sum(map(lambda mem: mem.range.size(), phys_mem_size = sum(map(lambda r: r.size(), system.mem_ranges))
system.memories.unproxy(system)))
assert(total_mem_size.value == phys_mem_size) assert(total_mem_size.value == phys_mem_size)
ruby_profiler = RubyProfiler(ruby_system = ruby, ruby_profiler = RubyProfiler(ruby_system = ruby,

View file

@ -59,7 +59,7 @@ class LinuxAlphaSystemBuilder(object):
pass pass
def create_system(self): def create_system(self):
system = FSConfig.makeLinuxAlphaSystem(self.mem_mode, DDR3_1600_x64) system = FSConfig.makeLinuxAlphaSystem(self.mem_mode)
self.init_system(system) self.init_system(system)
return system return system

View file

@ -60,9 +60,7 @@ class LinuxArmSystemBuilder(object):
def create_system(self): def create_system(self):
system = FSConfig.makeArmSystem(self.mem_mode, system = FSConfig.makeArmSystem(self.mem_mode,
self.machine_type, self.machine_type, None, False)
DDR3_1600_x64,
None, False)
# We typically want the simulator to panic if the kernel # We typically want the simulator to panic if the kernel
# panics or oopses. This prevents the simulator from running # panics or oopses. This prevents the simulator from running

View file

@ -221,6 +221,14 @@ class BaseFSSystem(BaseSystem):
def init_system(self, system): def init_system(self, system):
BaseSystem.init_system(self, system) BaseSystem.init_system(self, system)
# create the memory controllers and connect them, stick with
# the physmem name to avoid bumping all the reference stats
system.physmem = [self.mem_class(range = r,
conf_table_reported = True)
for r in system.mem_ranges]
for i in xrange(len(system.physmem)):
system.physmem[i].port = system.membus.master
# create the iocache, which by default runs at the system clock # create the iocache, which by default runs at the system clock
system.iocache = IOCache(addr_ranges=system.mem_ranges) system.iocache = IOCache(addr_ranges=system.mem_ranges)
system.iocache.cpu_side = system.iobus.master system.iocache.cpu_side = system.iobus.master

View file

@ -91,6 +91,8 @@ system.cpu_clk_domain = SrcClockDomain(clock = '2GHz')
for cpu in cpus: for cpu in cpus:
cpu.clk_domain = system.cpu_clk_domain cpu.clk_domain = system.cpu_clk_domain
system.mem_ranges = AddrRange('256MB')
Ruby.create_system(options, system) Ruby.create_system(options, system)
# Create a separate clock domain for Ruby # Create a separate clock domain for Ruby

View file

@ -39,4 +39,5 @@ from m5.objects import *
from x86_generic import * from x86_generic import *
root = LinuxX86FSSystemUniprocessor(mem_mode='timing', root = LinuxX86FSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=DerivO3CPU).create_root() cpu_class=DerivO3CPU).create_root()

View file

@ -39,4 +39,5 @@ from m5.objects import *
from x86_generic import * from x86_generic import *
root = LinuxX86FSSystemUniprocessor(mem_mode='atomic', root = LinuxX86FSSystemUniprocessor(mem_mode='atomic',
mem_class=DDR3_1600_x64,
cpu_class=AtomicSimpleCPU).create_root() cpu_class=AtomicSimpleCPU).create_root()

View file

@ -55,7 +55,7 @@ options.num_cpus = 2
#the system #the system
mdesc = SysConfig(disk = 'linux-x86.img') mdesc = SysConfig(disk = 'linux-x86.img')
system = FSConfig.makeLinuxX86System('timing', DDR3_1600_x64, options.num_cpus, system = FSConfig.makeLinuxX86System('timing', options.num_cpus,
mdesc=mdesc, Ruby=True) mdesc=mdesc, Ruby=True)
system.kernel = FSConfig.binary('x86_64-vmlinux-2.6.22.9.smp') system.kernel = FSConfig.binary('x86_64-vmlinux-2.6.22.9.smp')
@ -84,5 +84,11 @@ for (i, cpu) in enumerate(system.cpu):
# Set access_phys_mem to True for ruby port # Set access_phys_mem to True for ruby port
system.ruby._cpu_ruby_ports[i].access_phys_mem = True system.ruby._cpu_ruby_ports[i].access_phys_mem = True
system.physmem = [DDR3_1600_x64(range = r,
conf_table_reported = True)
for r in system.mem_ranges]
for i in xrange(len(system.physmem)):
system.physmem[i].port = system.piobus.master
root = Root(full_system = True, system = system) root = Root(full_system = True, system = system)
m5.ticks.setGlobalFrequency('1THz') m5.ticks.setGlobalFrequency('1THz')

View file

@ -39,5 +39,6 @@ from m5.objects import *
from x86_generic import * from x86_generic import *
root = LinuxX86FSSystemUniprocessor(mem_mode='timing', root = LinuxX86FSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=TimingSimpleCPU).create_root() cpu_class=TimingSimpleCPU).create_root()

View file

@ -42,6 +42,7 @@ from x86_generic import *
import switcheroo import switcheroo
root = LinuxX86FSSwitcheroo( root = LinuxX86FSSwitcheroo(
mem_class=DDR3_1600_x64,
cpu_classes=(AtomicSimpleCPU, TimingSimpleCPU, DerivO3CPU) cpu_classes=(AtomicSimpleCPU, TimingSimpleCPU, DerivO3CPU)
).create_root() ).create_root()

View file

@ -39,5 +39,6 @@ from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystemUniprocessor(mem_mode='timing', root = LinuxArmFSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=DerivO3CPU, cpu_class=DerivO3CPU,
checker=True).create_root() checker=True).create_root()

View file

@ -38,5 +38,7 @@
from m5.objects import * from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystem(mem_mode='timing', cpu_class=DerivO3CPU, root = LinuxArmFSSystem(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=DerivO3CPU,
num_cpus=2).create_root() num_cpus=2).create_root()

View file

@ -39,4 +39,5 @@ from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystemUniprocessor(mem_mode='timing', root = LinuxArmFSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=DerivO3CPU).create_root() cpu_class=DerivO3CPU).create_root()

View file

@ -38,5 +38,7 @@
from m5.objects import * from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystem(mem_mode='atomic', cpu_class=AtomicSimpleCPU, root = LinuxArmFSSystem(mem_mode='atomic',
mem_class=DDR3_1600_x64,
cpu_class=AtomicSimpleCPU,
num_cpus=2).create_root() num_cpus=2).create_root()

View file

@ -39,5 +39,6 @@ from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystemUniprocessor(mem_mode='atomic', root = LinuxArmFSSystemUniprocessor(mem_mode='atomic',
mem_class=DDR3_1600_x64,
cpu_class=AtomicSimpleCPU).create_root() cpu_class=AtomicSimpleCPU).create_root()

View file

@ -38,5 +38,7 @@
from m5.objects import * from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystem(mem_mode='timing', cpu_class=TimingSimpleCPU, root = LinuxArmFSSystem(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=TimingSimpleCPU,
num_cpus=2).create_root() num_cpus=2).create_root()

View file

@ -39,4 +39,5 @@ from m5.objects import *
from arm_generic import * from arm_generic import *
root = LinuxArmFSSystemUniprocessor(mem_mode='timing', root = LinuxArmFSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=TimingSimpleCPU).create_root() cpu_class=TimingSimpleCPU).create_root()

View file

@ -40,6 +40,7 @@ from arm_generic import *
import switcheroo import switcheroo
root = LinuxArmFSSwitcheroo( root = LinuxArmFSSwitcheroo(
mem_class=DDR3_1600_x64,
cpu_classes=(AtomicSimpleCPU, AtomicSimpleCPU) cpu_classes=(AtomicSimpleCPU, AtomicSimpleCPU)
).create_root() ).create_root()

View file

@ -40,6 +40,7 @@ from arm_generic import *
import switcheroo import switcheroo
root = LinuxArmFSSwitcheroo( root = LinuxArmFSSwitcheroo(
mem_class=DDR3_1600_x64,
cpu_classes=(AtomicSimpleCPU, TimingSimpleCPU, DerivO3CPU) cpu_classes=(AtomicSimpleCPU, TimingSimpleCPU, DerivO3CPU)
).create_root() ).create_root()

View file

@ -40,6 +40,7 @@ from arm_generic import *
import switcheroo import switcheroo
root = LinuxArmFSSwitcheroo( root = LinuxArmFSSwitcheroo(
mem_class=DDR3_1600_x64,
cpu_classes=(DerivO3CPU, DerivO3CPU) cpu_classes=(DerivO3CPU, DerivO3CPU)
).create_root() ).create_root()

View file

@ -40,6 +40,7 @@ from arm_generic import *
import switcheroo import switcheroo
root = LinuxArmFSSwitcheroo( root = LinuxArmFSSwitcheroo(
mem_class=DDR3_1600_x64,
cpu_classes=(TimingSimpleCPU, TimingSimpleCPU) cpu_classes=(TimingSimpleCPU, TimingSimpleCPU)
).create_root() ).create_root()

View file

@ -80,6 +80,8 @@ tester = RubyTester(check_flush = check_flush, checks_to_complete = 100,
system = System(tester = tester, physmem = SimpleMemory(null = True), system = System(tester = tester, physmem = SimpleMemory(null = True),
clk_domain = SrcClockDomain(clock = options.sys_clock)) clk_domain = SrcClockDomain(clock = options.sys_clock))
system.mem_ranges = AddrRange('256MB')
Ruby.create_system(options, system) Ruby.create_system(options, system)
# Create a separate clock domain for Ruby # Create a separate clock domain for Ruby

View file

@ -74,6 +74,8 @@ system = System(cpu = cpu, physmem = SimpleMemory(null = True),
# CPUs frequency # CPUs frequency
system.cpu.clk_domain = SrcClockDomain(clock = '2GHz') system.cpu.clk_domain = SrcClockDomain(clock = '2GHz')
system.mem_ranges = AddrRange('256MB')
Ruby.create_system(options, system) Ruby.create_system(options, system)
# Create a separate clock for Ruby # Create a separate clock for Ruby

View file

@ -31,7 +31,7 @@ from m5.objects import *
m5.util.addToPath('../configs/common') m5.util.addToPath('../configs/common')
import FSConfig import FSConfig
system = FSConfig.makeSparcSystem('atomic', SimpleMemory) system = FSConfig.makeSparcSystem('atomic')
system.clk_domain = SrcClockDomain(clock = '1GHz') system.clk_domain = SrcClockDomain(clock = '1GHz')
system.cpu_clk_domain = SrcClockDomain(clock = '1GHz') system.cpu_clk_domain = SrcClockDomain(clock = '1GHz')
cpu = AtomicSimpleCPU(cpu_id=0, clk_domain = system.cpu_clk_domain) cpu = AtomicSimpleCPU(cpu_id=0, clk_domain = system.cpu_clk_domain)
@ -40,6 +40,14 @@ system.cpu = cpu
cpu.createInterruptController() cpu.createInterruptController()
cpu.connectAllPorts(system.membus) cpu.connectAllPorts(system.membus)
# create the memory controllers and connect them, stick with
# the physmem name to avoid bumping all the reference stats
system.physmem = [SimpleMemory(range = r,
conf_table_reported = True)
for r in system.mem_ranges]
for i in xrange(len(system.physmem)):
system.physmem[i].port = system.membus.master
root = Root(full_system=True, system=system) root = Root(full_system=True, system=system)
m5.ticks.setGlobalFrequency('2GHz') m5.ticks.setGlobalFrequency('2GHz')

View file

@ -39,4 +39,5 @@ from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystemUniprocessor(mem_mode='timing', root = LinuxAlphaFSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=InOrderCPU).create_root() cpu_class=InOrderCPU).create_root()

View file

@ -38,5 +38,7 @@
from m5.objects import * from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystem(mem_mode='timing', cpu_class=DerivO3CPU, root = LinuxAlphaFSSystem(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=DerivO3CPU,
num_cpus=2).create_root() num_cpus=2).create_root()

View file

@ -39,4 +39,5 @@ from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystemUniprocessor(mem_mode='timing', root = LinuxAlphaFSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=DerivO3CPU).create_root() cpu_class=DerivO3CPU).create_root()

View file

@ -38,5 +38,7 @@
from m5.objects import * from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystem(mem_mode='atomic', cpu_class=AtomicSimpleCPU, root = LinuxAlphaFSSystem(mem_mode='atomic',
mem_class=DDR3_1600_x64,
cpu_class=AtomicSimpleCPU,
num_cpus=2).create_root() num_cpus=2).create_root()

View file

@ -39,4 +39,5 @@ from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystemUniprocessor(mem_mode='atomic', root = LinuxAlphaFSSystemUniprocessor(mem_mode='atomic',
mem_class=DDR3_1600_x64,
cpu_class=AtomicSimpleCPU).create_root() cpu_class=AtomicSimpleCPU).create_root()

View file

@ -38,5 +38,7 @@
from m5.objects import * from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystem(mem_mode='timing', cpu_class=TimingSimpleCPU, root = LinuxAlphaFSSystem(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=TimingSimpleCPU,
num_cpus=2).create_root() num_cpus=2).create_root()

View file

@ -39,4 +39,5 @@ from m5.objects import *
from alpha_generic import * from alpha_generic import *
root = LinuxAlphaFSSystemUniprocessor(mem_mode='timing', root = LinuxAlphaFSSystemUniprocessor(mem_mode='timing',
mem_class=DDR3_1600_x64,
cpu_class=TimingSimpleCPU).create_root() cpu_class=TimingSimpleCPU).create_root()

View file

@ -40,6 +40,7 @@ from alpha_generic import *
import switcheroo import switcheroo
root = LinuxAlphaFSSwitcheroo( root = LinuxAlphaFSSwitcheroo(
mem_class=DDR3_1600_x64,
cpu_classes=(AtomicSimpleCPU, TimingSimpleCPU, DerivO3CPU) cpu_classes=(AtomicSimpleCPU, TimingSimpleCPU, DerivO3CPU)
).create_root() ).create_root()

View file

@ -32,8 +32,8 @@ m5.util.addToPath('../configs/common')
from FSConfig import * from FSConfig import *
from Benchmarks import * from Benchmarks import *
test_sys = makeLinuxAlphaSystem('atomic', SimpleMemory, test_sys = makeLinuxAlphaSystem('atomic',
SysConfig('netperf-stream-client.rcS')) SysConfig('netperf-stream-client.rcS'))
# Create the system clock domain # Create the system clock domain
test_sys.clk_domain = SrcClockDomain(clock = '1GHz') test_sys.clk_domain = SrcClockDomain(clock = '1GHz')
@ -57,7 +57,10 @@ test_sys.iobridge = Bridge(delay='50ns', ranges = test_sys.mem_ranges)
test_sys.iobridge.slave = test_sys.iobus.master test_sys.iobridge.slave = test_sys.iobus.master
test_sys.iobridge.master = test_sys.membus.slave test_sys.iobridge.master = test_sys.membus.slave
drive_sys = makeLinuxAlphaSystem('atomic', SimpleMemory, test_sys.physmem = SimpleMemory(range = test_sys.mem_ranges[0])
test_sys.physmem.port = test_sys.membus.master
drive_sys = makeLinuxAlphaSystem('atomic',
SysConfig('netperf-server.rcS')) SysConfig('netperf-server.rcS'))
# Create the system clock domain # Create the system clock domain
drive_sys.clk_domain = SrcClockDomain(clock = '1GHz') drive_sys.clk_domain = SrcClockDomain(clock = '1GHz')
@ -77,6 +80,9 @@ drive_sys.iobridge = Bridge(delay='50ns', ranges = drive_sys.mem_ranges)
drive_sys.iobridge.slave = drive_sys.iobus.master drive_sys.iobridge.slave = drive_sys.iobus.master
drive_sys.iobridge.master = drive_sys.membus.slave drive_sys.iobridge.master = drive_sys.membus.slave
drive_sys.physmem = SimpleMemory(range = drive_sys.mem_ranges[0])
drive_sys.physmem.port = drive_sys.membus.master
root = makeDualRoot(True, test_sys, drive_sys, "ethertrace") root = makeDualRoot(True, test_sys, drive_sys, "ethertrace")
maxtick = 199999999 maxtick = 199999999

View file

@ -58,7 +58,6 @@ class LinuxX86SystemBuilder(object):
def create_system(self): def create_system(self):
mdesc = SysConfig(disk = 'linux-x86.img') mdesc = SysConfig(disk = 'linux-x86.img')
system = FSConfig.makeLinuxX86System(self.mem_mode, system = FSConfig.makeLinuxX86System(self.mem_mode,
DDR3_1600_x64,
numCPUs=self.num_cpus, numCPUs=self.num_cpus,
mdesc=mdesc) mdesc=mdesc)
system.kernel = FSConfig.binary('x86_64-vmlinux-2.6.22.9') system.kernel = FSConfig.binary('x86_64-vmlinux-2.6.22.9')