summaryrefslogtreecommitdiff
path: root/sim/common/sim-module.c
diff options
context:
space:
mode:
authorDavid Edelsohn <dje.gcc@gmail.com>1997-05-01 18:05:37 +0000
committerDavid Edelsohn <dje.gcc@gmail.com>1997-05-01 18:05:37 +0000
commitc967f1874a9a38bdc0040f218b6905f4987ab600 (patch)
tree9ce497975c88d89234605916e6013936afebd153 /sim/common/sim-module.c
parent2c8f0de695ce97cd6c09eca707e1a216c8b69943 (diff)
downloadbinutils-gdb-c967f1874a9a38bdc0040f218b6905f4987ab600.tar.gz
* Makefile.in (sim-options_h): Define.
(sim-{module,options,trace,profile,utils}.o): Clean up dependencies. (sim-model.o): Add new rule. (cgen-{scache,trace,utils}.o): Add new rules. * aclocal.m4 (SIM_AC_OPTION_{SCACHE,DEFAULT_MODEL}): Add. * cgen-scache.c (scache_print_profile): Change `sd' arg to `cpu'. Indent output by 2 spaces. * cgen-scache.h (scache_print_profile): Update. * cgen-trace.c (trace_insn_fini): Indent output by 2 spaces. Use trace_printf, not fprintf. (trace_extract): Use trace_printf, not cgen_trace_printf. * genmloop.sh (!FAST case): Increment `insn_count'. * sim-base.h (sim_state_base): Only include scache_size if WITH_SCACHE. (sim_cpu_base): Rename member `sd' to `state' to be consistent with access macro's name. * sim-core.c (sim_core_init): Use EXTERN_SIM_CORE to define it. Change return type to SIM_RC. (sim_core_{install,uninstall}): New functions. * sim-core.h (sim_core_{install,uninstall}): Declare. (sim_core_init): Use EXTERN_SIM_CORE to define it. Change return type to SIM_RC. * sim-model.h (models,machs,model_install): Declare. * sim-module.c (modules): Add scache_install, model_install. (sim_post_argv_init): Set cpu->state backlinks. * sim-options.c (standard_options): Delete --simcache-size,--max-insns. (standard_option_handler): Likewise. * sim-profile.c (PROFILE_{HISTOGRAM,LABEL}_WIDTH): Move to sim-profile.h. (*): Assume ANSI C. (profile_options): Delete --profile-simcache. (profile_option_handler): Likewise. (profile_print_insn): Change `sd' arg to `cpu'. Indent output 2 spaces. (profile_print_{memory,model}): Likewise. (profile_print_simcache): Delete. (profile_print_speed): New function. (profile_print): Rewrite. * sim-profile.h (PROFILE_scache): Renamed from PROFILE_simcache. (WITH_PROFILE_SCACHE_P): Renamed from WITH_PROFILE_SIMCACHE_P. (PROFILE_DATA): Delete members simcache_{hits,misses}. (PROFILE_COUNT_SIMCACHE_{HIT,MISS}): Delete. (PROFILE_{CALLBACK,CPU_CALLBACK}): New types. (profile_print): Update prototype.
Diffstat (limited to 'sim/common/sim-module.c')
-rw-r--r--sim/common/sim-module.c146
1 files changed, 146 insertions, 0 deletions
diff --git a/sim/common/sim-module.c b/sim/common/sim-module.c
new file mode 100644
index 00000000000..b68a4f3edce
--- /dev/null
+++ b/sim/common/sim-module.c
@@ -0,0 +1,146 @@
+/* Module support.
+ Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+ Contributed by Cygnus Support.
+
+This file is part of GDB, the GNU debugger.
+
+This program is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License along
+with this program; if not, write to the Free Software Foundation, Inc.,
+59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
+
+#include "sim-main.h"
+#include "sim-io.h"
+#include "sim-options.h"
+
+/* List of all modules. */
+static MODULE_INSTALL_FN * const modules[] = {
+ standard_install,
+ trace_install,
+ profile_install,
+ sim_core_install,
+#if WITH_SCACHE
+ scache_install,
+#endif
+#ifdef SIM_HAVE_MODEL /* FIXME: temporary */
+ model_install,
+#endif
+ /* Configured in [simulator specific] additional modules. */
+#ifdef MODULE_LIST
+ MODULE_LIST
+#endif
+ 0
+};
+
+/* Functions called from sim_open. */
+
+/* Initialize common parts before argument processing. */
+
+SIM_RC
+sim_pre_argv_init (SIM_DESC sd, const char *myname)
+{
+ STATE_MY_NAME (sd) = myname + strlen (myname);
+ while (STATE_MY_NAME (sd) > myname && STATE_MY_NAME (sd)[-1] != '/')
+ --STATE_MY_NAME (sd);
+
+ /* Install all configured in modules. */
+ if (sim_module_install (sd) != SIM_RC_OK)
+ return SIM_RC_FAIL;
+
+ return SIM_RC_OK;
+}
+
+/* Initialize common parts after argument processing. */
+
+SIM_RC
+sim_post_argv_init (SIM_DESC sd)
+{
+ int i;
+
+ if (sim_module_init (sd) != SIM_RC_OK)
+ return SIM_RC_FAIL;
+
+ /* Set the cpu->state backlinks for each cpu. */
+ for (i = 0; i < MAX_NR_PROCESSORS; ++i)
+ CPU_STATE (STATE_CPU (sd, i)) = sd;
+
+ return SIM_RC_OK;
+}
+
+/* Install all modules. */
+
+SIM_RC
+sim_module_install (SIM_DESC sd)
+{
+ MODULE_INSTALL_FN * const *modp;
+
+ for (modp = modules; *modp != NULL; ++modp)
+ {
+ if ((*modp) (sd) != SIM_RC_OK)
+ return SIM_RC_FAIL;
+ }
+ return SIM_RC_OK;
+}
+
+/* Called after all modules have been installed and after argv
+ has been processed. */
+
+SIM_RC
+sim_module_init (SIM_DESC sd)
+{
+ MODULE_INIT_LIST *modp;
+
+ for (modp = STATE_INIT_LIST (sd); modp != NULL; modp = modp->next)
+ {
+ if ((*modp->fn) (sd) != SIM_RC_OK)
+ return SIM_RC_FAIL;
+ }
+ return SIM_RC_OK;
+}
+
+/* Uninstall installed modules, called by sim_close. */
+
+void
+sim_module_uninstall (SIM_DESC sd)
+{
+ MODULE_UNINSTALL_LIST *modp;
+
+ /* Uninstall the modules. */
+ for (modp = STATE_UNINSTALL_LIST (sd); modp != NULL; modp = modp->next)
+ (*modp->fn) (sd);
+}
+
+/* Add FN to the init handler list. */
+
+void
+sim_module_add_init_fn (SIM_DESC sd, MODULE_INIT_FN fn)
+{
+ MODULE_INIT_LIST *l =
+ (MODULE_INIT_LIST *) xmalloc (sizeof (MODULE_INIT_LIST));
+
+ l->fn = fn;
+ l->next = STATE_INIT_LIST (sd);
+ STATE_INIT_LIST (sd) = l;
+}
+
+/* Add FN to the uninstall handler list. */
+
+void
+sim_module_add_uninstall_fn (SIM_DESC sd, MODULE_UNINSTALL_FN fn)
+{
+ MODULE_UNINSTALL_LIST *l =
+ (MODULE_UNINSTALL_LIST *) xmalloc (sizeof (MODULE_UNINSTALL_LIST));
+
+ l->fn = fn;
+ l->next = STATE_UNINSTALL_LIST (sd);
+ STATE_UNINSTALL_LIST (sd) = l;
+}