summaryrefslogtreecommitdiff
path: root/sim/ucsim/cmd.src/cmd_info.cc
diff options
context:
space:
mode:
authorXavier ASUS <xavi92psx@gmail.com>2019-10-18 00:31:54 +0200
committerXavier ASUS <xavi92psx@gmail.com>2019-10-18 00:31:54 +0200
commit268a53de823a6750d6256ee1fb1e7707b4b45740 (patch)
tree42c1799a9a82b2f7d9790ee9fe181d72a7274751 /sim/ucsim/cmd.src/cmd_info.cc
downloadsdcc-gas-268a53de823a6750d6256ee1fb1e7707b4b45740.tar.gz
sdcc-3.9.0 fork implementing GNU assembler syntax
This fork aims to provide better support for stm8-binutils
Diffstat (limited to 'sim/ucsim/cmd.src/cmd_info.cc')
-rw-r--r--sim/ucsim/cmd.src/cmd_info.cc266
1 files changed, 266 insertions, 0 deletions
diff --git a/sim/ucsim/cmd.src/cmd_info.cc b/sim/ucsim/cmd.src/cmd_info.cc
new file mode 100644
index 0000000..3ead2b3
--- /dev/null
+++ b/sim/ucsim/cmd.src/cmd_info.cc
@@ -0,0 +1,266 @@
+/*
+ * Simulator of microcontrollers (cmd.src/info.cc)
+ *
+ * Copyright (C) 1999,99 Drotos Daniel, Talker Bt.
+ *
+ * To contact author send email to drdani@mazsola.iit.uni-miskolc.hu
+ *
+ */
+
+/* This file is part of microcontroller simulator: ucsim.
+
+UCSIM 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 of the License, or
+(at your option) any later version.
+
+UCSIM 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 UCSIM; see the file COPYING. If not, write to the Free
+Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+02111-1307, USA. */
+/*@1@*/
+
+#include <stdlib.h>
+#include "i_string.h"
+
+// sim.src
+#include "simcl.h"
+
+// local
+#include "cmd_infocl.h"
+
+void
+set_info_help(class cl_cmd *cmd)
+{
+ cmd->set_help("info subcommand",
+ "Information about simulator objects",
+ "Long of info");
+}
+
+/*
+ * INFO BREAKPOINTS command
+ */
+
+COMMAND_DO_WORK_UC(cl_info_bp_cmd)
+{
+ int i;
+ bool extra;
+
+ con->dd_printf("Num Type Disp Hit Cnt Address Cond What\n");
+ for (i= 0; i < uc->fbrk->count; i++)
+ {
+ class cl_brk *fb= (class cl_brk *)(uc->fbrk->at(i));
+ const char *s= uc->disass(fb->addr, NULL);
+ con->dd_printf("%-3d %-10s %s %-5d %-5d 0x%06x %-5s %s\n", fb->nr,
+ "fetch", (fb->perm==brkFIX)?"keep":"del ",
+ fb->hit, fb->cnt, AU(fb->addr),
+ fb->condition()?"true":"false",
+ s);
+ extra= false;
+ if (!(fb->cond.empty()))
+ con->dd_printf(" cond=\"%s\"", (char*)(fb->cond)), extra= true;
+ if (!(fb->commands.empty()))
+ con->dd_printf(" cmd=\"%s\"", (char*)(fb->commands)), extra= true;
+ free((char *)s);
+ if (extra) con->dd_printf("\n");
+ }
+ for (i= 0; i < uc->ebrk->count; i++)
+ {
+ class cl_ev_brk *eb= (class cl_ev_brk *)(uc->ebrk->at(i));
+ con->dd_printf("%-3d %-10s %s %-5d %-5d 0x%06x %s\n", eb->nr,
+ "event", (eb->perm==brkFIX)?"keep":"del ",
+ eb->hit, eb->cnt,
+ AU(eb->addr), eb->id);
+ extra= false;
+ if (!(eb->cond.empty()))
+ con->dd_printf(" cond=\"%s\"", (char*)(eb->cond)), extra= true;
+ if (!(eb->commands.empty()))
+ con->dd_printf(" cmd=\"%s\"", (char*)(eb->commands)), extra= true;
+ if (extra) con->dd_printf("\n");
+ }
+ return(0);
+}
+
+CMDHELP(cl_info_bp_cmd,
+ "info breakpoints",
+ "Status of user-settable breakpoints",
+ "long help of info breakpoints")
+
+/*
+ * INFO REGISTERS command
+ */
+
+COMMAND_DO_WORK_UC(cl_info_reg_cmd)
+{
+ uc->print_regs(con);
+ return(0);
+}
+
+CMDHELP(cl_info_reg_cmd,
+ "info registers",
+ "List of integer registers and their contents",
+ "long help of info registers")
+
+/*
+ * INFO HW command
+ */
+
+//int
+//cl_info_hw_cmd::do_work(class cl_sim *sim,
+// class cl_cmdline *cmdline, class cl_console *con)
+COMMAND_DO_WORK_UC(cl_info_hw_cmd)
+{
+ class cl_hw *hw;
+ class cl_cmd_arg *params[4]= { cmdline->param(0),
+ cmdline->param(1),
+ cmdline->param(2),
+ cmdline->param(3) };
+
+ if (cmdline->syntax_match(uc, HW)) {
+ hw= params[0]->value.hw;
+ hw->print_info(con);
+ }
+ else if (cmdline->syntax_match(uc, STRING))
+ {
+ char *s= params[0]->get_svalue();
+ if (s && *s && (strcmp("cpu", s)==0))
+ {
+ if (uc->cpu)
+ uc->cpu->print_info(con);
+ }
+ }
+ else
+ syntax_error(con);
+
+ return(false);
+}
+
+CMDHELP(cl_info_hw_cmd,
+ "info hardware cathegory",
+ "Status of hardware elements of the CPU",
+ "long help of info hardware")
+
+/*
+ * INFO STACK command
+ */
+/*
+COMMAND_DO_WORK_UC(cl_info_stack_cmd)
+{
+ int i;
+
+ cl_stack_op::info_head(con);
+ for (i= uc->stack_ops->count-1; i >= 0; i--)
+ {
+ class cl_stack_op *so= (class cl_stack_op *)(uc->stack_ops->at(i));
+ so->info(con, uc);
+ }
+ return(false);
+}
+*/
+
+/*CMDHELP(cl_info_stack_cmd,
+ "info stack",
+ "Status of stack of the CPU",
+ "long help of info stack")*/
+
+/*
+ * INFO MEMORY command
+ *----------------------------------------------------------------------------
+ */
+
+COMMAND_DO_WORK_UC(cl_info_memory_cmd)
+{
+ int i;
+ class cl_memory *mem= NULL;
+ class cl_cmd_arg *params[4]= { cmdline->param(0),
+ cmdline->param(1),
+ cmdline->param(2),
+ cmdline->param(3) };
+
+ if (cmdline->syntax_match(uc, MEMORY))
+ {
+ mem= params[0]->value.memory.memory;
+ if (mem)
+ {
+ mem->print_info("", con);
+ }
+ return false;
+ }
+ con->dd_printf("Memory chips:\n");
+ for (i= 0; i < uc->memchips->count; i++)
+ {
+ class cl_memory_chip *m= (class cl_memory_chip *)(uc->memchips->at(i));
+ m->print_info(" ", con);
+ }
+ con->dd_printf("Address spaces:\n");
+ for (i= 0; i < uc->address_spaces->count; i++)
+ {
+ class cl_address_space *m=
+ (class cl_address_space *)(uc->address_spaces->at(i));
+ m->print_info(" ", con);
+ }
+ con->dd_printf("Address decoders:\n");
+ for (i= 0; i < uc->address_spaces->count; i++)
+ {
+ class cl_address_space *m=
+ (class cl_address_space *)(uc->address_spaces->at(i));
+ int j;
+ for (j= 0; j < m->decoders->count; j++)
+ {
+ class cl_address_decoder *d=
+ (class cl_address_decoder *)(m->decoders->at(j));
+ d->print_info(chars(" "), con);
+ }
+ }
+ return(0);
+}
+
+CMDHELP(cl_info_memory_cmd,
+ "info memory",
+ "Information about memory system",
+ "long help of info memory")
+
+/*
+ * INFO VARIABLES command
+ *----------------------------------------------------------------------------
+ */
+
+COMMAND_DO_WORK_UC(cl_info_var_cmd)
+{
+ class cl_var *v;
+ int i;
+ class cl_cmd_arg *params[1]= { cmdline->param(0) };
+ char *s= NULL;
+
+ if (cmdline->syntax_match(uc, STRING))
+ {
+ s= params[0]->get_svalue();
+ if (!s ||
+ !*s)
+ s= NULL;
+ }
+ for (i= 0; i < uc->vars->count; i++)
+ {
+ v= (class cl_var *)(uc->vars->at(i));
+ if ((s == NULL) ||
+ (
+ (strstr(v->as->get_name(), s) != NULL) ||
+ (strstr(v->get_name(), s) != NULL)
+ )
+ )
+ v->print_info(con);
+ }
+ return 0;
+}
+
+CMDHELP(cl_info_var_cmd,
+ "info variables [filter]",
+ "Information about variables",
+ "long help of info variables")
+
+/* End of cmd.src/cmd_info.cc */