From e3d96aa889680469be44bb9cd59d3db837cb4dc4 Mon Sep 17 00:00:00 2001 From: Steve Reinhardt Date: Fri, 10 Mar 2006 10:01:29 -0500 Subject: Compiles now (with CPU_MODELS=SimpleCPU), but hangs on execution. configs/test/test.py: Move test binary out of m5-test, don't depend on m5-test/Benchmarks. python/m5/objects/System.py: Split out full-system-only parameters (lost in merge). sim/system.cc: Need to be able to instantiate System directly in SE mode (lost in merge). sim/system.hh: A few more functions here are FS-only. configs/test/hello: Add in binary. --HG-- rename : configs/test.py => configs/test/test.py extra : convert_revision : 4051b18772e0a0dcb97eb591d4373683be9f4395 --- configs/test.py | 8 -------- configs/test/hello | Bin 0 -> 312176 bytes configs/test/test.py | 10 ++++++++++ python/m5/objects/System.py | 17 +++++++++-------- sim/system.cc | 30 ++++++++++++++++++++++++++++++ sim/system.hh | 2 +- 6 files changed, 50 insertions(+), 17 deletions(-) delete mode 100644 configs/test.py create mode 100755 configs/test/hello create mode 100644 configs/test/test.py diff --git a/configs/test.py b/configs/test.py deleted file mode 100644 index ea0e63a61..000000000 --- a/configs/test.py +++ /dev/null @@ -1,8 +0,0 @@ -from m5 import * -AddToPath('/z/stever/bk/m5-test') -import Benchmarks - -mem = PhysicalMemory() -cpu = SimpleCPU(workload=Benchmarks.HelloWorld(), mem=mem) -system = System(physmem=mem, cpu=cpu) -root = Root(system=system) diff --git a/configs/test/hello b/configs/test/hello new file mode 100755 index 000000000..59c0d195c Binary files /dev/null and b/configs/test/hello differ diff --git a/configs/test/test.py b/configs/test/test.py new file mode 100644 index 000000000..0982ba4f2 --- /dev/null +++ b/configs/test/test.py @@ -0,0 +1,10 @@ +from m5 import * + +class HelloWorld(LiveProcess): + executable = '../configs/test/hello' + cmd = 'hello' + +mem = PhysicalMemory() +cpu = SimpleCPU(workload=HelloWorld(), mem=mem) +system = System(physmem=mem, cpu=cpu) +root = Root(system=system) diff --git a/python/m5/objects/System.py b/python/m5/objects/System.py index 5925cadf5..2959c1d1a 100644 --- a/python/m5/objects/System.py +++ b/python/m5/objects/System.py @@ -2,15 +2,16 @@ from m5 import * class System(SimObject): type = 'System' - boot_cpu_frequency = Param.Frequency(Self.cpu[0].clock.frequency, - "boot processor frequency") - memctrl = Param.MemoryController(Parent.any, "memory controller") physmem = Param.PhysicalMemory(Parent.any, "phsyical memory") - init_param = Param.UInt64(0, "numerical value to pass into simulator") - bin = Param.Bool(False, "is this system binned") - binned_fns = VectorParam.String([], "functions broken down and binned") - kernel = Param.String("file that contains the kernel code") - readfile = Param.String("", "file to read startup script from") + if build_env['FULL_SYSTEM']: + boot_cpu_frequency = Param.Frequency(Self.cpu[0].clock.frequency, + "boot processor frequency") + memctrl = Param.MemoryController(Parent.any, "memory controller") + init_param = Param.UInt64(0, "numerical value to pass into simulator") + bin = Param.Bool(False, "is this system binned") + binned_fns = VectorParam.String([], "functions broken down and binned") + kernel = Param.String("file that contains the kernel code") + readfile = Param.String("", "file to read startup script from") class AlphaSystem(System): type = 'AlphaSystem' diff --git a/sim/system.cc b/sim/system.cc index f1d0579d7..05b41e32b 100644 --- a/sim/system.cc +++ b/sim/system.cc @@ -217,5 +217,35 @@ printSystems() System::printSystems(); } +#if FULL_SYSTEM + +// In full system mode, only derived classes (e.g. AlphaLinuxSystem) +// can be created directly. + DEFINE_SIM_OBJECT_CLASS_NAME("System", System) +#else + +BEGIN_DECLARE_SIM_OBJECT_PARAMS(System) + + SimObjectParam physmem; + +END_DECLARE_SIM_OBJECT_PARAMS(System) + +BEGIN_INIT_SIM_OBJECT_PARAMS(System) + + INIT_PARAM(physmem, "physical memory") + +END_INIT_SIM_OBJECT_PARAMS(System) + +CREATE_SIM_OBJECT(System) +{ + System::Params *p = new System::Params; + p->name = getInstanceName(); + p->physmem = physmem; + return new System(p); +} + +REGISTER_SIM_OBJECT("System", System) + +#endif diff --git a/sim/system.hh b/sim/system.hh index cbe876c42..0d5b40e3d 100644 --- a/sim/system.hh +++ b/sim/system.hh @@ -101,6 +101,7 @@ class System : public SimObject protected: +#if FULL_SYSTEM /** * Fix up an address used to match PCs for hooking simulator * events on to target function executions. See comment in @@ -125,7 +126,6 @@ class System : public SimObject return NULL; } -#if FULL_SYSTEM /** Add a function-based event to kernel code. */ template T *System::addKernelFuncEvent(const char *lbl) -- cgit v1.2.3