Separate the stuff for SimObject from SimObject builder.
This makes testing a bit easier. arch/alpha/alpha_memory.cc: cpu/intr_control.cc: cpu/memtest/memtest.cc: cpu/simple_cpu/simple_cpu.cc: dev/alpha_console.cc: dev/console.cc: dev/disk_image.cc: dev/etherbus.cc: dev/etherdump.cc: dev/etherlink.cc: dev/ethertap.cc: dev/simple_disk.cc: kern/tru64/tru64_system.cc: sim/main.cc: sim/prog.cc: Need to include builder.hh sort #includes sim/sim_object.cc: sim/sim_object.hh: Separate the SimObjectBuilder stuff into its own file --HG-- extra : convert_revision : e8395e0cc6ae1f180f9cd6f100795a1ac44aeed5
This commit is contained in:
parent
4963dbf9a9
commit
e0b065ff7c
19 changed files with 511 additions and 435 deletions
|
@ -30,12 +30,13 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "targetarch/alpha_memory.hh"
|
|
||||||
#include "targetarch/ev5.hh"
|
|
||||||
#include "cpu/exec_context.hh"
|
|
||||||
#include "base/trace.hh"
|
|
||||||
#include "base/inifile.hh"
|
#include "base/inifile.hh"
|
||||||
#include "base/str.hh"
|
#include "base/str.hh"
|
||||||
|
#include "base/trace.hh"
|
||||||
|
#include "cpu/exec_context.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "targetarch/alpha_memory.hh"
|
||||||
|
#include "targetarch/ev5.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
|
|
||||||
#include "cpu/base_cpu.hh"
|
#include "cpu/base_cpu.hh"
|
||||||
#include "cpu/intr_control.hh"
|
#include "cpu/intr_control.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
#include "sim/sim_object.hh"
|
#include "sim/sim_object.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
|
@ -33,13 +33,13 @@
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "cpu/memtest/memtest.hh"
|
|
||||||
#include "base/misc.hh"
|
#include "base/misc.hh"
|
||||||
#include "sim/sim_events.hh"
|
|
||||||
#include "mem/functional_mem/main_memory.hh"
|
|
||||||
#include "mem/cache/base_cache.hh"
|
|
||||||
|
|
||||||
#include "base/statistics.hh"
|
#include "base/statistics.hh"
|
||||||
|
#include "cpu/memtest/memtest.hh"
|
||||||
|
#include "mem/cache/base_cache.hh"
|
||||||
|
#include "mem/functional_mem/main_memory.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "sim/sim_events.hh"
|
||||||
#include "sim/sim_stats.hh"
|
#include "sim/sim_stats.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
|
@ -26,59 +26,52 @@
|
||||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
|
#include <cstdio>
|
||||||
|
#include <cstdlib>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
#include <list>
|
#include <list>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <math.h>
|
|
||||||
|
|
||||||
#include "sim/host.hh"
|
|
||||||
#include "base/cprintf.hh"
|
#include "base/cprintf.hh"
|
||||||
#include "base/misc.hh"
|
|
||||||
#include "cpu/full_cpu/smt.hh"
|
|
||||||
|
|
||||||
#include "sim/annotation.hh"
|
|
||||||
#include "cpu/exec_context.hh"
|
|
||||||
#include "cpu/base_cpu.hh"
|
|
||||||
#include "sim/debug.hh"
|
|
||||||
#include "cpu/simple_cpu/simple_cpu.hh"
|
|
||||||
#include "base/inifile.hh"
|
#include "base/inifile.hh"
|
||||||
#include "mem/mem_interface.hh"
|
#include "base/loader/symtab.hh"
|
||||||
#include "mem/base_mem.hh"
|
#include "base/misc.hh"
|
||||||
#include "cpu/static_inst.hh"
|
|
||||||
|
|
||||||
#ifdef FULL_SYSTEM
|
|
||||||
#include "mem/functional_mem/memory_control.hh"
|
|
||||||
#include "mem/functional_mem/physical_memory.hh"
|
|
||||||
#include "targetarch/alpha_memory.hh"
|
|
||||||
#include "sim/system.hh"
|
|
||||||
#else // !FULL_SYSTEM
|
|
||||||
#include "mem/functional_mem/functional_memory.hh"
|
|
||||||
#include "sim/prog.hh"
|
|
||||||
#include "eio/eio.hh"
|
|
||||||
#endif // FULL_SYSTEM
|
|
||||||
|
|
||||||
#include "cpu/exetrace.hh"
|
|
||||||
#include "base/trace.hh"
|
|
||||||
#include "sim/sim_events.hh"
|
|
||||||
#include "base/pollevent.hh"
|
#include "base/pollevent.hh"
|
||||||
|
#include "base/range.hh"
|
||||||
|
#include "base/trace.hh"
|
||||||
|
#include "cpu/base_cpu.hh"
|
||||||
|
#include "cpu/exec_context.hh"
|
||||||
|
#include "cpu/exetrace.hh"
|
||||||
|
#include "cpu/full_cpu/smt.hh"
|
||||||
|
#include "cpu/simple_cpu/simple_cpu.hh"
|
||||||
|
#include "cpu/static_inst.hh"
|
||||||
|
#include "mem/base_mem.hh"
|
||||||
|
#include "mem/mem_interface.hh"
|
||||||
|
#include "sim/annotation.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "sim/debug.hh"
|
||||||
|
#include "sim/host.hh"
|
||||||
|
#include "sim/sim_events.hh"
|
||||||
#include "sim/sim_object.hh"
|
#include "sim/sim_object.hh"
|
||||||
#include "sim/sim_stats.hh"
|
#include "sim/sim_stats.hh"
|
||||||
|
|
||||||
#include "base/range.hh"
|
|
||||||
#include "base/loader/symtab.hh"
|
|
||||||
|
|
||||||
#ifdef FULL_SYSTEM
|
#ifdef FULL_SYSTEM
|
||||||
#include "targetarch/vtophys.hh"
|
|
||||||
#include "dev/pciareg.h"
|
|
||||||
#include "base/remote_gdb.hh"
|
#include "base/remote_gdb.hh"
|
||||||
#include "dev/alpha_access.h"
|
#include "dev/alpha_access.h"
|
||||||
#endif
|
#include "dev/pciareg.h"
|
||||||
|
#include "mem/functional_mem/memory_control.hh"
|
||||||
|
#include "mem/functional_mem/physical_memory.hh"
|
||||||
|
#include "sim/system.hh"
|
||||||
|
#include "targetarch/alpha_memory.hh"
|
||||||
|
#include "targetarch/vtophys.hh"
|
||||||
|
#else // !FULL_SYSTEM
|
||||||
|
#include "eio/eio.hh"
|
||||||
|
#include "mem/functional_mem/functional_memory.hh"
|
||||||
|
#include "sim/prog.hh"
|
||||||
|
#endif // FULL_SYSTEM
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -30,22 +30,22 @@
|
||||||
* System Console Definition
|
* System Console Definition
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <cstddef>
|
||||||
#include <stdio.h>
|
#include <cstdio>
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "dev/alpha_console.hh"
|
|
||||||
#include "cpu/base_cpu.hh"
|
|
||||||
#include "dev/console.hh"
|
|
||||||
#include "cpu/exec_context.hh"
|
|
||||||
#include "mem/functional_mem/memory_control.hh"
|
|
||||||
#include "dev/simple_disk.hh"
|
|
||||||
#include "dev/tlaser_clock.hh"
|
|
||||||
#include "sim/system.hh"
|
|
||||||
#include "base/trace.hh"
|
|
||||||
#include "base/inifile.hh"
|
#include "base/inifile.hh"
|
||||||
#include "base/str.hh" // for to_number()
|
#include "base/str.hh" // for to_number()
|
||||||
|
#include "base/trace.hh"
|
||||||
|
#include "cpu/base_cpu.hh"
|
||||||
|
#include "cpu/exec_context.hh"
|
||||||
|
#include "dev/alpha_console.hh"
|
||||||
|
#include "dev/console.hh"
|
||||||
|
#include "dev/simple_disk.hh"
|
||||||
|
#include "dev/tlaser_clock.hh"
|
||||||
|
#include "mem/functional_mem/memory_control.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "sim/system.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -43,12 +43,12 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "base/misc.hh"
|
#include "base/misc.hh"
|
||||||
#include "targetarch/ev5.hh"
|
|
||||||
|
|
||||||
#include "dev/console.hh"
|
|
||||||
#include "base/socket.hh"
|
#include "base/socket.hh"
|
||||||
#include "base/trace.hh"
|
#include "base/trace.hh"
|
||||||
|
#include "dev/console.hh"
|
||||||
#include "mem/functional_mem/memory_control.hh"
|
#include "mem/functional_mem/memory_control.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "targetarch/ev5.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -33,18 +33,19 @@
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/uio.h>
|
#include <sys/uio.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
|
#include <cstring>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "dev/disk_image.hh"
|
#include "base/callback.hh"
|
||||||
#include "base/misc.hh"
|
#include "base/misc.hh"
|
||||||
#include "base/trace.hh"
|
#include "base/trace.hh"
|
||||||
|
#include "dev/disk_image.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
#include "sim/sim_exit.hh"
|
#include "sim/sim_exit.hh"
|
||||||
#include "base/callback.hh"
|
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -30,17 +30,17 @@
|
||||||
* Device module for modelling an ethernet hub
|
* Device module for modelling an ethernet hub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
#include <deque>
|
#include <deque>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <math.h>
|
#include "base/trace.hh"
|
||||||
|
|
||||||
#include "dev/etherbus.hh"
|
#include "dev/etherbus.hh"
|
||||||
#include "dev/etherdump.hh"
|
#include "dev/etherdump.hh"
|
||||||
#include "dev/etherint.hh"
|
#include "dev/etherint.hh"
|
||||||
#include "dev/etherpkt.hh"
|
#include "dev/etherpkt.hh"
|
||||||
#include "base/trace.hh"
|
#include "sim/builder.hh"
|
||||||
#include "sim/universe.hh"
|
#include "sim/universe.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
|
@ -34,8 +34,8 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "sim/universe.hh"
|
|
||||||
#include "dev/etherdump.hh"
|
#include "dev/etherdump.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
#include "sim/universe.hh"
|
#include "sim/universe.hh"
|
||||||
|
|
||||||
using std::string;
|
using std::string;
|
||||||
|
|
|
@ -30,17 +30,17 @@
|
||||||
* Device module for modelling a fixed bandwidth full duplex ethernet link
|
* Device module for modelling a fixed bandwidth full duplex ethernet link
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
#include <deque>
|
#include <deque>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <math.h>
|
#include "base/trace.hh"
|
||||||
|
|
||||||
#include "dev/etherlink.hh"
|
|
||||||
#include "dev/etherdump.hh"
|
#include "dev/etherdump.hh"
|
||||||
#include "dev/etherint.hh"
|
#include "dev/etherint.hh"
|
||||||
|
#include "dev/etherlink.hh"
|
||||||
#include "dev/etherpkt.hh"
|
#include "dev/etherpkt.hh"
|
||||||
#include "base/trace.hh"
|
#include "sim/builder.hh"
|
||||||
#include "sim/universe.hh"
|
#include "sim/universe.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
|
@ -40,14 +40,15 @@
|
||||||
#include <deque>
|
#include <deque>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#include "base/misc.hh"
|
||||||
|
#include "base/pollevent.hh"
|
||||||
|
#include "base/socket.hh"
|
||||||
|
#include "base/trace.hh"
|
||||||
#include "dev/etherdump.hh"
|
#include "dev/etherdump.hh"
|
||||||
#include "dev/etherint.hh"
|
#include "dev/etherint.hh"
|
||||||
#include "dev/etherpkt.hh"
|
#include "dev/etherpkt.hh"
|
||||||
#include "dev/ethertap.hh"
|
#include "dev/ethertap.hh"
|
||||||
#include "base/pollevent.hh"
|
#include "sim/builder.hh"
|
||||||
#include "base/socket.hh"
|
|
||||||
#include "base/trace.hh"
|
|
||||||
#include "base/misc.hh"
|
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -30,19 +30,20 @@
|
||||||
* Simple disk interface for the system console
|
* Simple disk interface for the system console
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/uio.h>
|
#include <sys/uio.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "dev/disk_image.hh"
|
#include <cstring>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
#include "base/misc.hh"
|
#include "base/misc.hh"
|
||||||
#include "mem/functional_mem/physical_memory.hh"
|
|
||||||
#include "dev/simple_disk.hh"
|
|
||||||
#include "base/trace.hh"
|
#include "base/trace.hh"
|
||||||
|
#include "dev/disk_image.hh"
|
||||||
|
#include "dev/simple_disk.hh"
|
||||||
|
#include "mem/functional_mem/physical_memory.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
|
@ -26,17 +26,18 @@
|
||||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "base/remote_gdb.hh"
|
|
||||||
#include "base/trace.hh"
|
|
||||||
#include "base/loader/aout_object.hh"
|
#include "base/loader/aout_object.hh"
|
||||||
#include "base/loader/ecoff_object.hh"
|
#include "base/loader/ecoff_object.hh"
|
||||||
#include "base/loader/object_file.hh"
|
#include "base/loader/object_file.hh"
|
||||||
#include "base/loader/symtab.hh"
|
#include "base/loader/symtab.hh"
|
||||||
|
#include "base/remote_gdb.hh"
|
||||||
|
#include "base/trace.hh"
|
||||||
#include "cpu/exec_context.hh"
|
#include "cpu/exec_context.hh"
|
||||||
#include "kern/tru64/tru64_events.hh"
|
#include "kern/tru64/tru64_events.hh"
|
||||||
#include "kern/tru64/tru64_system.hh"
|
#include "kern/tru64/tru64_system.hh"
|
||||||
#include "mem/functional_mem/memory_control.hh"
|
#include "mem/functional_mem/memory_control.hh"
|
||||||
#include "mem/functional_mem/physical_memory.hh"
|
#include "mem/functional_mem/physical_memory.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
#include "targetarch/isa_traits.hh"
|
#include "targetarch/isa_traits.hh"
|
||||||
#include "targetarch/vtophys.hh"
|
#include "targetarch/vtophys.hh"
|
||||||
|
|
||||||
|
|
191
sim/builder.cc
Normal file
191
sim/builder.cc
Normal file
|
@ -0,0 +1,191 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2003 The Regents of The University of Michigan
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are
|
||||||
|
* met: redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer;
|
||||||
|
* redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution;
|
||||||
|
* neither the name of the copyright holders nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from
|
||||||
|
* this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "base/inifile.hh"
|
||||||
|
#include "base/misc.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "sim/configfile.hh"
|
||||||
|
#include "sim/host.hh"
|
||||||
|
#include "sim/sim_object.hh"
|
||||||
|
#include "sim/sim_stats.hh"
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
///////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// SimObjectBuilder member definitions
|
||||||
|
//
|
||||||
|
///////////////////////////////////////////
|
||||||
|
|
||||||
|
// override ParamContext::parseParams() to check params based on
|
||||||
|
// instance name first. If not found, then check based on iniSection
|
||||||
|
// (as in default ParamContext implementation).
|
||||||
|
void
|
||||||
|
SimObjectBuilder::parseParams(IniFile &iniFile)
|
||||||
|
{
|
||||||
|
iniFilePtr = &iniFile; // set object member
|
||||||
|
|
||||||
|
ParamList::iterator i;
|
||||||
|
|
||||||
|
for (i = paramList->begin(); i != paramList->end(); ++i) {
|
||||||
|
string string_value;
|
||||||
|
|
||||||
|
if (iniFile.findDefault(instanceName, (*i)->name, string_value)) {
|
||||||
|
(*i)->parse(string_value);
|
||||||
|
}
|
||||||
|
else if (iniFile.findDefault(iniSection, (*i)->name, string_value)) {
|
||||||
|
(*i)->parse(string_value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
SimObjectBuilder::printErrorProlog(ostream &os)
|
||||||
|
{
|
||||||
|
os << "Error creating object '" << getInstanceName()
|
||||||
|
<< "' of type '" << simObjClassName
|
||||||
|
<< "', section '" << iniSection << "':" << endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// SimObjectClass member definitions
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
// Map of class names to SimObjectBuilder creation functions. Need to
|
||||||
|
// make this a pointer so we can force initialization on the first
|
||||||
|
// reference; otherwise, some SimObjectClass constructors may be invoked
|
||||||
|
// before the classMap constructor.
|
||||||
|
map<string,SimObjectClass::CreateFunc> *SimObjectClass::classMap = NULL;
|
||||||
|
|
||||||
|
// SimObjectClass constructor: add mapping to classMap
|
||||||
|
SimObjectClass::SimObjectClass(const string &className, CreateFunc createFunc)
|
||||||
|
{
|
||||||
|
if (classMap == NULL)
|
||||||
|
classMap = new map<string,SimObjectClass::CreateFunc>();
|
||||||
|
|
||||||
|
if ((*classMap)[className])
|
||||||
|
{
|
||||||
|
cerr << "Error: simulation object class " << className << " redefined"
|
||||||
|
<< endl;
|
||||||
|
fatal("");
|
||||||
|
}
|
||||||
|
|
||||||
|
// add className --> createFunc to class map
|
||||||
|
(*classMap)[className] = createFunc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
//
|
||||||
|
SimObject *
|
||||||
|
SimObjectClass::createObject(IniFile &configDB,
|
||||||
|
const string &configClassName,
|
||||||
|
const string &objName,
|
||||||
|
ConfigNode *configNode)
|
||||||
|
{
|
||||||
|
// find simulation object class name from configuration class
|
||||||
|
// (specified by 'type=' parameter)
|
||||||
|
string simObjClassName;
|
||||||
|
|
||||||
|
if (!configDB.findDefault(configClassName, "type", simObjClassName)) {
|
||||||
|
cerr << "Configuration class '" << configClassName << "' not found."
|
||||||
|
<< endl;
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
|
||||||
|
// look up className to get appropriate createFunc
|
||||||
|
if (classMap->find(simObjClassName) == classMap->end()) {
|
||||||
|
cerr << "Simulator object class '" << simObjClassName << "' not found."
|
||||||
|
<< endl;
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
|
||||||
|
CreateFunc createFunc = (*classMap)[simObjClassName];
|
||||||
|
|
||||||
|
// call createFunc with config hierarchy node to get object
|
||||||
|
// builder instance (context with parameters for object creation)
|
||||||
|
SimObjectBuilder *objectBuilder = (*createFunc)(configClassName,
|
||||||
|
objName, configNode,
|
||||||
|
simObjClassName);
|
||||||
|
|
||||||
|
assert(objectBuilder != NULL);
|
||||||
|
|
||||||
|
// parse all parameters in context to generate parameter values
|
||||||
|
objectBuilder->parseParams(configDB);
|
||||||
|
|
||||||
|
// now create the actual simulation object
|
||||||
|
SimObject *object = objectBuilder->create();
|
||||||
|
|
||||||
|
assert(object != NULL);
|
||||||
|
|
||||||
|
// echo object parameters to stats file (for documenting the
|
||||||
|
// config used to generate the associated stats)
|
||||||
|
*statStream << "[" << object->name() << "]" << endl;
|
||||||
|
*statStream << "type=" << simObjClassName << endl;
|
||||||
|
objectBuilder->showParams(*statStream);
|
||||||
|
*statStream << endl;
|
||||||
|
|
||||||
|
// done with the SimObjectBuilder now
|
||||||
|
delete objectBuilder;
|
||||||
|
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// static method:
|
||||||
|
//
|
||||||
|
void
|
||||||
|
SimObjectClass::describeAllClasses(ostream &os)
|
||||||
|
{
|
||||||
|
map<string,CreateFunc>::iterator iter;
|
||||||
|
|
||||||
|
for (iter = classMap->begin(); iter != classMap->end(); ++iter) {
|
||||||
|
const string &className = iter->first;
|
||||||
|
CreateFunc createFunc = iter->second;
|
||||||
|
|
||||||
|
os << "[" << className << "]\n";
|
||||||
|
|
||||||
|
// create dummy object builder just to instantiate parameters
|
||||||
|
SimObjectBuilder *objectBuilder = (*createFunc)("", "", NULL, "");
|
||||||
|
|
||||||
|
// now get the object builder to describe ite params
|
||||||
|
objectBuilder->describeParams(os);
|
||||||
|
|
||||||
|
os << endl;
|
||||||
|
|
||||||
|
// done with the object builder now
|
||||||
|
delete objectBuilder;
|
||||||
|
}
|
||||||
|
}
|
221
sim/builder.hh
Normal file
221
sim/builder.hh
Normal file
|
@ -0,0 +1,221 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2003 The Regents of The University of Michigan
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are
|
||||||
|
* met: redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer;
|
||||||
|
* redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution;
|
||||||
|
* neither the name of the copyright holders nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from
|
||||||
|
* this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __BUILDER_HH__
|
||||||
|
#define __BUILDER_HH__
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <list>
|
||||||
|
#include <vector>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
#include "sim/param.hh"
|
||||||
|
|
||||||
|
class SimObject;
|
||||||
|
|
||||||
|
//
|
||||||
|
// A SimObjectBuilder serves as an evaluation context for a set of
|
||||||
|
// parameters that describe a specific instance of a SimObject. This
|
||||||
|
// evaluation context corresponds to a section in the .ini file (as
|
||||||
|
// with the base ParamContext) plus an optional node in the
|
||||||
|
// configuration hierarchy (the configNode member) for resolving
|
||||||
|
// SimObject references. SimObjectBuilder is an abstract superclass;
|
||||||
|
// derived classes specialize the class for particular subclasses of
|
||||||
|
// SimObject (e.g., BaseCache).
|
||||||
|
//
|
||||||
|
// For typical usage, see the definition of
|
||||||
|
// SimObjectClass::createObject().
|
||||||
|
//
|
||||||
|
class SimObjectBuilder : public ParamContext
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
// name of the instance we are creating
|
||||||
|
std::string instanceName;
|
||||||
|
|
||||||
|
// The corresponding node in the configuration hierarchy.
|
||||||
|
// (optional: may be null if the created object is not in the
|
||||||
|
// hierarchy)
|
||||||
|
ConfigNode *configNode;
|
||||||
|
|
||||||
|
// The external SimObject class name (for error messages)
|
||||||
|
std::string simObjClassName;
|
||||||
|
|
||||||
|
public:
|
||||||
|
SimObjectBuilder(const std::string &_configClass,
|
||||||
|
const std::string &_instanceName,
|
||||||
|
ConfigNode *_configNode,
|
||||||
|
const std::string &_simObjClassName)
|
||||||
|
: ParamContext(_configClass, true),
|
||||||
|
instanceName(_instanceName),
|
||||||
|
configNode(_configNode),
|
||||||
|
simObjClassName(_simObjClassName)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~SimObjectBuilder() {}
|
||||||
|
|
||||||
|
// call parse() on all params in this context to convert string
|
||||||
|
// representations to parameter values
|
||||||
|
virtual void parseParams(IniFile &iniFile);
|
||||||
|
|
||||||
|
// parameter error prolog (override of ParamContext)
|
||||||
|
virtual void printErrorProlog(std::ostream &);
|
||||||
|
|
||||||
|
// generate the name for this SimObject instance (derived from the
|
||||||
|
// configuration hierarchy node label and position)
|
||||||
|
virtual const std::string &getInstanceName() { return instanceName; }
|
||||||
|
|
||||||
|
// return the configuration hierarchy node for this context.
|
||||||
|
virtual ConfigNode *getConfigNode() { return configNode; }
|
||||||
|
|
||||||
|
// Create the actual SimObject corresponding to the parameter
|
||||||
|
// values in this context. This function is overridden in derived
|
||||||
|
// classes to call a specific constructor for a particular
|
||||||
|
// subclass of SimObject.
|
||||||
|
virtual SimObject *create() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Handy macros for initializing parameter members of classes derived
|
||||||
|
// from SimObjectBuilder. Assumes that the name of the parameter
|
||||||
|
// member object is the same as the textual parameter name seen by the
|
||||||
|
// user. (Note that '#p' is expanded by the preprocessor to '"p"'.)
|
||||||
|
//
|
||||||
|
#define INIT_PARAM(p, desc) p(this, #p, desc)
|
||||||
|
#define INIT_PARAM_DFLT(p, desc, dflt) p(this, #p, desc, dflt)
|
||||||
|
|
||||||
|
//
|
||||||
|
// Initialize an enumeration variable... assumes that 'map' is the
|
||||||
|
// name of an array of mappings (char * for SimpleEnumParam, or
|
||||||
|
// EnumParamMap for MappedEnumParam).
|
||||||
|
//
|
||||||
|
#define INIT_ENUM_PARAM(p, desc, map) \
|
||||||
|
p(this, #p, desc, map, sizeof(map)/sizeof(map[0]))
|
||||||
|
#define INIT_ENUM_PARAM_DFLT(p, desc, map, dflt) \
|
||||||
|
p(this, #p, desc, map, sizeof(map)/sizeof(map[0]), dflt)
|
||||||
|
|
||||||
|
//
|
||||||
|
// An instance of SimObjectClass corresponds to a class derived from
|
||||||
|
// SimObject. The SimObjectClass instance serves to bind the string
|
||||||
|
// name (found in the config file) to a function that creates an
|
||||||
|
// instance of the appropriate derived class.
|
||||||
|
//
|
||||||
|
// This would be much cleaner in Smalltalk or Objective-C, where types
|
||||||
|
// are first-class objects themselves.
|
||||||
|
//
|
||||||
|
class SimObjectClass
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
// Type CreateFunc is a pointer to a function that creates a new
|
||||||
|
// simulation object builder based on a .ini-file parameter
|
||||||
|
// section (specified by the first string argument), a unique name
|
||||||
|
// for the object (specified by the second string argument), and
|
||||||
|
// an optional config hierarchy node (specified by the third
|
||||||
|
// argument). A pointer to the new SimObjectBuilder is returned.
|
||||||
|
typedef SimObjectBuilder *(*CreateFunc)(const std::string &configClassName,
|
||||||
|
const std::string &objName,
|
||||||
|
ConfigNode *configNode,
|
||||||
|
const std::string &simObjClassName);
|
||||||
|
|
||||||
|
static std::map<std::string,CreateFunc> *classMap;
|
||||||
|
|
||||||
|
// Constructor. For example:
|
||||||
|
//
|
||||||
|
// SimObjectClass baseCacheClass("BaseCache", newBaseCacheBuilder);
|
||||||
|
//
|
||||||
|
SimObjectClass(const std::string &className, CreateFunc createFunc);
|
||||||
|
|
||||||
|
// create SimObject given name of class and pointer to
|
||||||
|
// configuration hierarchy node
|
||||||
|
static SimObject *createObject(IniFile &configDB,
|
||||||
|
const std::string &configClassName,
|
||||||
|
const std::string &objName,
|
||||||
|
ConfigNode *configNode);
|
||||||
|
|
||||||
|
// print descriptions of all parameters registered with all
|
||||||
|
// SimObject classes
|
||||||
|
static void describeAllClasses(std::ostream &os);
|
||||||
|
};
|
||||||
|
|
||||||
|
//
|
||||||
|
// Macros to encapsulate the magic of declaring & defining
|
||||||
|
// SimObjectBuilder and SimObjectClass objects
|
||||||
|
//
|
||||||
|
|
||||||
|
#define BEGIN_DECLARE_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
||||||
|
class OBJ_CLASS##Builder : public SimObjectBuilder \
|
||||||
|
{ \
|
||||||
|
public:
|
||||||
|
|
||||||
|
#define END_DECLARE_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
||||||
|
\
|
||||||
|
OBJ_CLASS##Builder(const std::string &configClass, \
|
||||||
|
const std::string &instanceName, \
|
||||||
|
ConfigNode *configNode, \
|
||||||
|
const std::string &simObjClassName); \
|
||||||
|
virtual ~OBJ_CLASS##Builder() {} \
|
||||||
|
\
|
||||||
|
OBJ_CLASS *create(); \
|
||||||
|
};
|
||||||
|
|
||||||
|
#define BEGIN_INIT_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
||||||
|
OBJ_CLASS##Builder::OBJ_CLASS##Builder(const std::string &configClass, \
|
||||||
|
const std::string &instanceName, \
|
||||||
|
ConfigNode *configNode, \
|
||||||
|
const std::string &simObjClassName) \
|
||||||
|
: SimObjectBuilder(configClass, instanceName, \
|
||||||
|
configNode, simObjClassName),
|
||||||
|
|
||||||
|
|
||||||
|
#define END_INIT_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
||||||
|
{ \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define CREATE_SIM_OBJECT(OBJ_CLASS) \
|
||||||
|
OBJ_CLASS *OBJ_CLASS##Builder::create()
|
||||||
|
|
||||||
|
#define REGISTER_SIM_OBJECT(CLASS_NAME, OBJ_CLASS) \
|
||||||
|
SimObjectBuilder * \
|
||||||
|
new##OBJ_CLASS##Builder(const std::string &configClass, \
|
||||||
|
const std::string &instanceName, \
|
||||||
|
ConfigNode *configNode, \
|
||||||
|
const std::string &simObjClassName) \
|
||||||
|
{ \
|
||||||
|
return new OBJ_CLASS##Builder(configClass, instanceName, \
|
||||||
|
configNode, simObjClassName); \
|
||||||
|
} \
|
||||||
|
\
|
||||||
|
SimObjectClass the##OBJ_CLASS##Class(CLASS_NAME, \
|
||||||
|
new##OBJ_CLASS##Builder); \
|
||||||
|
\
|
||||||
|
/* see param.hh */ \
|
||||||
|
DEFINE_SIM_OBJECT_CLASS_NAME(CLASS_NAME, OBJ_CLASS)
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __BUILDER_HH__
|
15
sim/main.cc
15
sim/main.cc
|
@ -37,23 +37,22 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "sim/host.hh"
|
|
||||||
#include "base/misc.hh"
|
|
||||||
|
|
||||||
#include "base/copyright.hh"
|
#include "base/copyright.hh"
|
||||||
#include "base/inifile.hh"
|
#include "base/inifile.hh"
|
||||||
#include "sim/configfile.hh"
|
#include "base/misc.hh"
|
||||||
#include "base/pollevent.hh"
|
#include "base/pollevent.hh"
|
||||||
#include "base/statistics.hh"
|
#include "base/statistics.hh"
|
||||||
|
#include "cpu/base_cpu.hh"
|
||||||
|
#include "cpu/full_cpu/smt.hh"
|
||||||
|
#include "sim/async.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "sim/configfile.hh"
|
||||||
|
#include "sim/host.hh"
|
||||||
#include "sim/sim_events.hh"
|
#include "sim/sim_events.hh"
|
||||||
#include "sim/sim_exit.hh"
|
#include "sim/sim_exit.hh"
|
||||||
#include "sim/sim_object.hh"
|
#include "sim/sim_object.hh"
|
||||||
#include "sim/sim_stats.hh"
|
#include "sim/sim_stats.hh"
|
||||||
#include "sim/sim_time.hh"
|
#include "sim/sim_time.hh"
|
||||||
#include "cpu/full_cpu/smt.hh"
|
|
||||||
|
|
||||||
#include "cpu/base_cpu.hh"
|
|
||||||
#include "sim/async.hh"
|
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
|
17
sim/prog.cc
17
sim/prog.cc
|
@ -28,22 +28,21 @@
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
|
#include <cstdio>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "mem/functional_mem/main_memory.hh"
|
|
||||||
#include "sim/prog.hh"
|
|
||||||
|
|
||||||
#include "eio/eio.hh"
|
|
||||||
#include "base/intmath.hh"
|
#include "base/intmath.hh"
|
||||||
#include "cpu/full_cpu/thread.hh"
|
|
||||||
#include "sim/fake_syscall.hh"
|
|
||||||
#include "base/loader/object_file.hh"
|
#include "base/loader/object_file.hh"
|
||||||
|
#include "base/statistics.hh"
|
||||||
#include "cpu/exec_context.hh"
|
#include "cpu/exec_context.hh"
|
||||||
#include "cpu/full_cpu/smt.hh"
|
#include "cpu/full_cpu/smt.hh"
|
||||||
|
#include "cpu/full_cpu/thread.hh"
|
||||||
#include "base/statistics.hh"
|
#include "eio/eio.hh"
|
||||||
|
#include "mem/functional_mem/main_memory.hh"
|
||||||
|
#include "sim/builder.hh"
|
||||||
|
#include "sim/fake_syscall.hh"
|
||||||
|
#include "sim/prog.hh"
|
||||||
#include "sim/sim_stats.hh"
|
#include "sim/sim_stats.hh"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
|
@ -121,155 +121,3 @@ SimObject::printAllExtraOutput(ostream &os)
|
||||||
(*i)->printExtraOutput(os);
|
(*i)->printExtraOutput(os);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////
|
|
||||||
//
|
|
||||||
// SimObjectBuilder member definitions
|
|
||||||
//
|
|
||||||
///////////////////////////////////////////
|
|
||||||
|
|
||||||
// override ParamContext::parseParams() to check params based on
|
|
||||||
// instance name first. If not found, then check based on iniSection
|
|
||||||
// (as in default ParamContext implementation).
|
|
||||||
void
|
|
||||||
SimObjectBuilder::parseParams(IniFile &iniFile)
|
|
||||||
{
|
|
||||||
iniFilePtr = &iniFile; // set object member
|
|
||||||
|
|
||||||
ParamList::iterator i;
|
|
||||||
|
|
||||||
for (i = paramList->begin(); i != paramList->end(); ++i) {
|
|
||||||
string string_value;
|
|
||||||
|
|
||||||
if (iniFile.findDefault(instanceName, (*i)->name, string_value)) {
|
|
||||||
(*i)->parse(string_value);
|
|
||||||
}
|
|
||||||
else if (iniFile.findDefault(iniSection, (*i)->name, string_value)) {
|
|
||||||
(*i)->parse(string_value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void
|
|
||||||
SimObjectBuilder::printErrorProlog(ostream &os)
|
|
||||||
{
|
|
||||||
os << "Error creating object '" << getInstanceName()
|
|
||||||
<< "' of type '" << simObjClassName
|
|
||||||
<< "', section '" << iniSection << "':" << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////
|
|
||||||
//
|
|
||||||
// SimObjectClass member definitions
|
|
||||||
//
|
|
||||||
////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
// Map of class names to SimObjectBuilder creation functions. Need to
|
|
||||||
// make this a pointer so we can force initialization on the first
|
|
||||||
// reference; otherwise, some SimObjectClass constructors may be invoked
|
|
||||||
// before the classMap constructor.
|
|
||||||
map<string,SimObjectClass::CreateFunc> *SimObjectClass::classMap = NULL;
|
|
||||||
|
|
||||||
// SimObjectClass constructor: add mapping to classMap
|
|
||||||
SimObjectClass::SimObjectClass(const string &className, CreateFunc createFunc)
|
|
||||||
{
|
|
||||||
if (classMap == NULL)
|
|
||||||
classMap = new map<string,SimObjectClass::CreateFunc>();
|
|
||||||
|
|
||||||
if ((*classMap)[className])
|
|
||||||
{
|
|
||||||
cerr << "Error: simulation object class " << className << " redefined"
|
|
||||||
<< endl;
|
|
||||||
fatal("");
|
|
||||||
}
|
|
||||||
|
|
||||||
// add className --> createFunc to class map
|
|
||||||
(*classMap)[className] = createFunc;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
//
|
|
||||||
SimObject *
|
|
||||||
SimObjectClass::createObject(IniFile &configDB,
|
|
||||||
const string &configClassName,
|
|
||||||
const string &objName,
|
|
||||||
ConfigNode *configNode)
|
|
||||||
{
|
|
||||||
// find simulation object class name from configuration class
|
|
||||||
// (specified by 'type=' parameter)
|
|
||||||
string simObjClassName;
|
|
||||||
|
|
||||||
if (!configDB.findDefault(configClassName, "type", simObjClassName)) {
|
|
||||||
cerr << "Configuration class '" << configClassName << "' not found."
|
|
||||||
<< endl;
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
// look up className to get appropriate createFunc
|
|
||||||
if (classMap->find(simObjClassName) == classMap->end()) {
|
|
||||||
cerr << "Simulator object class '" << simObjClassName << "' not found."
|
|
||||||
<< endl;
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
CreateFunc createFunc = (*classMap)[simObjClassName];
|
|
||||||
|
|
||||||
// call createFunc with config hierarchy node to get object
|
|
||||||
// builder instance (context with parameters for object creation)
|
|
||||||
SimObjectBuilder *objectBuilder = (*createFunc)(configClassName,
|
|
||||||
objName, configNode,
|
|
||||||
simObjClassName);
|
|
||||||
|
|
||||||
assert(objectBuilder != NULL);
|
|
||||||
|
|
||||||
// parse all parameters in context to generate parameter values
|
|
||||||
objectBuilder->parseParams(configDB);
|
|
||||||
|
|
||||||
// now create the actual simulation object
|
|
||||||
SimObject *object = objectBuilder->create();
|
|
||||||
|
|
||||||
assert(object != NULL);
|
|
||||||
|
|
||||||
// echo object parameters to stats file (for documenting the
|
|
||||||
// config used to generate the associated stats)
|
|
||||||
*statStream << "[" << object->name() << "]" << endl;
|
|
||||||
*statStream << "type=" << simObjClassName << endl;
|
|
||||||
objectBuilder->showParams(*statStream);
|
|
||||||
*statStream << endl;
|
|
||||||
|
|
||||||
// done with the SimObjectBuilder now
|
|
||||||
delete objectBuilder;
|
|
||||||
|
|
||||||
return object;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// static method:
|
|
||||||
//
|
|
||||||
void
|
|
||||||
SimObjectClass::describeAllClasses(ostream &os)
|
|
||||||
{
|
|
||||||
map<string,CreateFunc>::iterator iter;
|
|
||||||
|
|
||||||
for (iter = classMap->begin(); iter != classMap->end(); ++iter) {
|
|
||||||
const string &className = iter->first;
|
|
||||||
CreateFunc createFunc = iter->second;
|
|
||||||
|
|
||||||
os << "[" << className << "]\n";
|
|
||||||
|
|
||||||
// create dummy object builder just to instantiate parameters
|
|
||||||
SimObjectBuilder *objectBuilder = (*createFunc)("", "", NULL, "");
|
|
||||||
|
|
||||||
// now get the object builder to describe ite params
|
|
||||||
objectBuilder->describeParams(os);
|
|
||||||
|
|
||||||
os << endl;
|
|
||||||
|
|
||||||
// done with the object builder now
|
|
||||||
delete objectBuilder;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -76,185 +76,4 @@ class SimObject : public Serializeable
|
||||||
static void printAllExtraOutput(std::ostream&);
|
static void printAllExtraOutput(std::ostream&);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// A SimObjectBuilder serves as an evaluation context for a set of
|
|
||||||
// parameters that describe a specific instance of a SimObject. This
|
|
||||||
// evaluation context corresponds to a section in the .ini file (as
|
|
||||||
// with the base ParamContext) plus an optional node in the
|
|
||||||
// configuration hierarchy (the configNode member) for resolving
|
|
||||||
// SimObject references. SimObjectBuilder is an abstract superclass;
|
|
||||||
// derived classes specialize the class for particular subclasses of
|
|
||||||
// SimObject (e.g., BaseCache).
|
|
||||||
//
|
|
||||||
// For typical usage, see the definition of
|
|
||||||
// SimObjectClass::createObject().
|
|
||||||
//
|
|
||||||
class SimObjectBuilder : public ParamContext
|
|
||||||
{
|
|
||||||
private:
|
|
||||||
// name of the instance we are creating
|
|
||||||
std::string instanceName;
|
|
||||||
|
|
||||||
// The corresponding node in the configuration hierarchy.
|
|
||||||
// (optional: may be null if the created object is not in the
|
|
||||||
// hierarchy)
|
|
||||||
ConfigNode *configNode;
|
|
||||||
|
|
||||||
// The external SimObject class name (for error messages)
|
|
||||||
std::string simObjClassName;
|
|
||||||
|
|
||||||
public:
|
|
||||||
SimObjectBuilder(const std::string &_configClass,
|
|
||||||
const std::string &_instanceName,
|
|
||||||
ConfigNode *_configNode,
|
|
||||||
const std::string &_simObjClassName)
|
|
||||||
: ParamContext(_configClass, true),
|
|
||||||
instanceName(_instanceName),
|
|
||||||
configNode(_configNode),
|
|
||||||
simObjClassName(_simObjClassName)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ~SimObjectBuilder() {}
|
|
||||||
|
|
||||||
// call parse() on all params in this context to convert string
|
|
||||||
// representations to parameter values
|
|
||||||
virtual void parseParams(IniFile &iniFile);
|
|
||||||
|
|
||||||
// parameter error prolog (override of ParamContext)
|
|
||||||
virtual void printErrorProlog(std::ostream &);
|
|
||||||
|
|
||||||
// generate the name for this SimObject instance (derived from the
|
|
||||||
// configuration hierarchy node label and position)
|
|
||||||
virtual const std::string &getInstanceName() { return instanceName; }
|
|
||||||
|
|
||||||
// return the configuration hierarchy node for this context.
|
|
||||||
virtual ConfigNode *getConfigNode() { return configNode; }
|
|
||||||
|
|
||||||
// Create the actual SimObject corresponding to the parameter
|
|
||||||
// values in this context. This function is overridden in derived
|
|
||||||
// classes to call a specific constructor for a particular
|
|
||||||
// subclass of SimObject.
|
|
||||||
virtual SimObject *create() = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// Handy macros for initializing parameter members of classes derived
|
|
||||||
// from SimObjectBuilder. Assumes that the name of the parameter
|
|
||||||
// member object is the same as the textual parameter name seen by the
|
|
||||||
// user. (Note that '#p' is expanded by the preprocessor to '"p"'.)
|
|
||||||
//
|
|
||||||
#define INIT_PARAM(p, desc) p(this, #p, desc)
|
|
||||||
#define INIT_PARAM_DFLT(p, desc, dflt) p(this, #p, desc, dflt)
|
|
||||||
|
|
||||||
//
|
|
||||||
// Initialize an enumeration variable... assumes that 'map' is the
|
|
||||||
// name of an array of mappings (char * for SimpleEnumParam, or
|
|
||||||
// EnumParamMap for MappedEnumParam).
|
|
||||||
//
|
|
||||||
#define INIT_ENUM_PARAM(p, desc, map) \
|
|
||||||
p(this, #p, desc, map, sizeof(map)/sizeof(map[0]))
|
|
||||||
#define INIT_ENUM_PARAM_DFLT(p, desc, map, dflt) \
|
|
||||||
p(this, #p, desc, map, sizeof(map)/sizeof(map[0]), dflt)
|
|
||||||
|
|
||||||
//
|
|
||||||
// An instance of SimObjectClass corresponds to a class derived from
|
|
||||||
// SimObject. The SimObjectClass instance serves to bind the string
|
|
||||||
// name (found in the config file) to a function that creates an
|
|
||||||
// instance of the appropriate derived class.
|
|
||||||
//
|
|
||||||
// This would be much cleaner in Smalltalk or Objective-C, where types
|
|
||||||
// are first-class objects themselves.
|
|
||||||
//
|
|
||||||
class SimObjectClass
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// Type CreateFunc is a pointer to a function that creates a new
|
|
||||||
// simulation object builder based on a .ini-file parameter
|
|
||||||
// section (specified by the first string argument), a unique name
|
|
||||||
// for the object (specified by the second string argument), and
|
|
||||||
// an optional config hierarchy node (specified by the third
|
|
||||||
// argument). A pointer to the new SimObjectBuilder is returned.
|
|
||||||
typedef SimObjectBuilder *(*CreateFunc)(const std::string &configClassName,
|
|
||||||
const std::string &objName,
|
|
||||||
ConfigNode *configNode,
|
|
||||||
const std::string &simObjClassName);
|
|
||||||
|
|
||||||
static std::map<std::string,CreateFunc> *classMap;
|
|
||||||
|
|
||||||
// Constructor. For example:
|
|
||||||
//
|
|
||||||
// SimObjectClass baseCacheClass("BaseCache", newBaseCacheBuilder);
|
|
||||||
//
|
|
||||||
SimObjectClass(const std::string &className, CreateFunc createFunc);
|
|
||||||
|
|
||||||
// create SimObject given name of class and pointer to
|
|
||||||
// configuration hierarchy node
|
|
||||||
static SimObject *createObject(IniFile &configDB,
|
|
||||||
const std::string &configClassName,
|
|
||||||
const std::string &objName,
|
|
||||||
ConfigNode *configNode);
|
|
||||||
|
|
||||||
// print descriptions of all parameters registered with all
|
|
||||||
// SimObject classes
|
|
||||||
static void describeAllClasses(std::ostream &os);
|
|
||||||
};
|
|
||||||
|
|
||||||
//
|
|
||||||
// Macros to encapsulate the magic of declaring & defining
|
|
||||||
// SimObjectBuilder and SimObjectClass objects
|
|
||||||
//
|
|
||||||
|
|
||||||
#define BEGIN_DECLARE_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
|
||||||
class OBJ_CLASS##Builder : public SimObjectBuilder \
|
|
||||||
{ \
|
|
||||||
public:
|
|
||||||
|
|
||||||
#define END_DECLARE_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
|
||||||
\
|
|
||||||
OBJ_CLASS##Builder(const std::string &configClass, \
|
|
||||||
const std::string &instanceName, \
|
|
||||||
ConfigNode *configNode, \
|
|
||||||
const std::string &simObjClassName); \
|
|
||||||
virtual ~OBJ_CLASS##Builder() {} \
|
|
||||||
\
|
|
||||||
OBJ_CLASS *create(); \
|
|
||||||
};
|
|
||||||
|
|
||||||
#define BEGIN_INIT_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
|
||||||
OBJ_CLASS##Builder::OBJ_CLASS##Builder(const std::string &configClass, \
|
|
||||||
const std::string &instanceName, \
|
|
||||||
ConfigNode *configNode, \
|
|
||||||
const std::string &simObjClassName) \
|
|
||||||
: SimObjectBuilder(configClass, instanceName, \
|
|
||||||
configNode, simObjClassName),
|
|
||||||
|
|
||||||
|
|
||||||
#define END_INIT_SIM_OBJECT_PARAMS(OBJ_CLASS) \
|
|
||||||
{ \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define CREATE_SIM_OBJECT(OBJ_CLASS) \
|
|
||||||
OBJ_CLASS *OBJ_CLASS##Builder::create()
|
|
||||||
|
|
||||||
#define REGISTER_SIM_OBJECT(CLASS_NAME, OBJ_CLASS) \
|
|
||||||
SimObjectBuilder * \
|
|
||||||
new##OBJ_CLASS##Builder(const std::string &configClass, \
|
|
||||||
const std::string &instanceName, \
|
|
||||||
ConfigNode *configNode, \
|
|
||||||
const std::string &simObjClassName) \
|
|
||||||
{ \
|
|
||||||
return new OBJ_CLASS##Builder(configClass, instanceName, \
|
|
||||||
configNode, simObjClassName); \
|
|
||||||
} \
|
|
||||||
\
|
|
||||||
SimObjectClass the##OBJ_CLASS##Class(CLASS_NAME, \
|
|
||||||
new##OBJ_CLASS##Builder); \
|
|
||||||
\
|
|
||||||
/* see param.hh */ \
|
|
||||||
DEFINE_SIM_OBJECT_CLASS_NAME(CLASS_NAME, OBJ_CLASS)
|
|
||||||
|
|
||||||
|
|
||||||
#endif // __SIM_OBJECT_HH__
|
#endif // __SIM_OBJECT_HH__
|
||||||
|
|
Loading…
Reference in a new issue