ARM: Clarifies creation of Linux and baremetal ARM systems.
makeArmSystem creates both bare-metal and Linux systems more cleanly. machine_type was never optional though listed as an optional argument; a system such as "RealView_PBX" must now be explicitly specified. Now that it is a required argument, the placement of the arguments has changed slightly requiring some changes to calls that create ARM systems.
This commit is contained in:
parent
e2a6275c03
commit
79dac89552
4 changed files with 18 additions and 14 deletions
|
@ -184,8 +184,9 @@ def makeSparcSystem(mem_mode, mdesc = None):
|
||||||
|
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def makeLinuxArmSystem(mem_mode, mdesc = None, bare_metal=False,
|
def makeArmSystem(mem_mode, machine_type, mdesc = None, bare_metal=False):
|
||||||
machine_type = None):
|
assert machine_type
|
||||||
|
|
||||||
if bare_metal:
|
if bare_metal:
|
||||||
self = ArmSystem()
|
self = ArmSystem()
|
||||||
else:
|
else:
|
||||||
|
@ -228,10 +229,15 @@ def makeLinuxArmSystem(mem_mode, mdesc = None, bare_metal=False,
|
||||||
print "Unknown Machine Type"
|
print "Unknown Machine Type"
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
if not bare_metal and machine_type:
|
if bare_metal:
|
||||||
self.machine_type = machine_type
|
# EOT character on UART will end the simulation
|
||||||
elif bare_metal:
|
|
||||||
self.realview.uart.end_on_eot = True
|
self.realview.uart.end_on_eot = True
|
||||||
|
else:
|
||||||
|
self.machine_type = machine_type
|
||||||
|
self.kernel = binary('vmlinux.arm')
|
||||||
|
self.boot_osflags = 'earlyprintk mem=128MB console=ttyAMA0' + \
|
||||||
|
' lpj=19988480 norandmaps slram=slram0,0x8000000,+0x8000000' + \
|
||||||
|
' mtdparts=slram0:- rw loglevel=8 root=/dev/mtdblock0'
|
||||||
|
|
||||||
self.realview.attachOnChipIO(self.membus)
|
self.realview.attachOnChipIO(self.membus)
|
||||||
self.realview.attachIO(self.iobus)
|
self.realview.attachIO(self.iobus)
|
||||||
|
@ -239,10 +245,6 @@ def makeLinuxArmSystem(mem_mode, mdesc = None, bare_metal=False,
|
||||||
self.intrctrl = IntrControl()
|
self.intrctrl = IntrControl()
|
||||||
self.terminal = Terminal()
|
self.terminal = Terminal()
|
||||||
self.vncserver = VncServer()
|
self.vncserver = VncServer()
|
||||||
self.kernel = binary('vmlinux.arm')
|
|
||||||
self.boot_osflags = 'earlyprintk mem=128MB console=ttyAMA0 lpj=19988480' + \
|
|
||||||
' norandmaps slram=slram0,0x8000000,+0x8000000' + \
|
|
||||||
' mtdparts=slram0:- rw loglevel=8 root=/dev/mtdblock0'
|
|
||||||
|
|
||||||
return self
|
return self
|
||||||
|
|
||||||
|
|
|
@ -134,8 +134,9 @@ elif buildEnv['TARGET_ISA'] == "x86":
|
||||||
test_sys = makeLinuxX86System(test_mem_mode, options.num_cpus, bm[0])
|
test_sys = makeLinuxX86System(test_mem_mode, options.num_cpus, bm[0])
|
||||||
setWorkCountOptions(test_sys, options)
|
setWorkCountOptions(test_sys, options)
|
||||||
elif buildEnv['TARGET_ISA'] == "arm":
|
elif buildEnv['TARGET_ISA'] == "arm":
|
||||||
test_sys = makeLinuxArmSystem(test_mem_mode, bm[0],
|
test_sys = makeArmSystem(test_mem_mode,
|
||||||
bare_metal=options.bare_metal, machine_type=options.machine_type)
|
options.machine_type, bm[0],
|
||||||
|
bare_metal=options.bare_metal)
|
||||||
else:
|
else:
|
||||||
fatal("incapable of building non-alpha or non-sparc full system!")
|
fatal("incapable of building non-alpha or non-sparc full system!")
|
||||||
|
|
||||||
|
@ -184,7 +185,8 @@ if len(bm) == 2:
|
||||||
elif buildEnv['TARGET_ISA'] == 'x86':
|
elif buildEnv['TARGET_ISA'] == 'x86':
|
||||||
drive_sys = makeX86System(drive_mem_mode, np, bm[1])
|
drive_sys = makeX86System(drive_mem_mode, np, bm[1])
|
||||||
elif buildEnv['TARGET_ISA'] == 'arm':
|
elif buildEnv['TARGET_ISA'] == 'arm':
|
||||||
drive_sys = makeLinuxArmSystem(drive_mem_mode, bm[1])
|
drive_sys = makeArmSystem(drive_mem_mode,
|
||||||
|
machine_options.machine_type, bm[1])
|
||||||
drive_sys.cpu = DriveCPUClass(cpu_id=0)
|
drive_sys.cpu = DriveCPUClass(cpu_id=0)
|
||||||
drive_sys.cpu.connectAllPorts(drive_sys.membus)
|
drive_sys.cpu.connectAllPorts(drive_sys.membus)
|
||||||
if options.fastmem:
|
if options.fastmem:
|
||||||
|
|
|
@ -68,7 +68,7 @@ class IOCache(BaseCache):
|
||||||
#cpu
|
#cpu
|
||||||
cpu = AtomicSimpleCPU(cpu_id=0)
|
cpu = AtomicSimpleCPU(cpu_id=0)
|
||||||
#the system
|
#the system
|
||||||
system = FSConfig.makeLinuxArmSystem('atomic', None, False, "RealView_PBX")
|
system = FSConfig.makeArmSystem('atomic', "RealView_PBX", None, False)
|
||||||
system.bridge.filter_ranges_a=[AddrRange(0, Addr.max)]
|
system.bridge.filter_ranges_a=[AddrRange(0, Addr.max)]
|
||||||
system.bridge.filter_ranges_b=[AddrRange(0, size='128MB')]
|
system.bridge.filter_ranges_b=[AddrRange(0, size='128MB')]
|
||||||
system.iocache = IOCache()
|
system.iocache = IOCache()
|
||||||
|
|
|
@ -69,7 +69,7 @@ class IOCache(BaseCache):
|
||||||
#cpu
|
#cpu
|
||||||
cpu = TimingSimpleCPU(cpu_id=0)
|
cpu = TimingSimpleCPU(cpu_id=0)
|
||||||
#the system
|
#the system
|
||||||
system = FSConfig.makeLinuxArmSystem('timing', None, False, "RealView_PBX")
|
system = FSConfig.makeArmSystem('timing', "RealView_PBX", None, False)
|
||||||
|
|
||||||
system.cpu = cpu
|
system.cpu = cpu
|
||||||
#create the l1/l2 bus
|
#create the l1/l2 bus
|
||||||
|
|
Loading…
Reference in a new issue