diff options
| author | Xavier ASUS <xavi92psx@gmail.com> | 2019-10-18 00:31:54 +0200 |
|---|---|---|
| committer | Xavier ASUS <xavi92psx@gmail.com> | 2019-10-18 00:31:54 +0200 |
| commit | 268a53de823a6750d6256ee1fb1e7707b4b45740 (patch) | |
| tree | 42c1799a9a82b2f7d9790ee9fe181d72a7274751 /sim/ucsim/cmd.src/cmd_stat.cc | |
| download | sdcc-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_stat.cc')
| -rw-r--r-- | sim/ucsim/cmd.src/cmd_stat.cc | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/sim/ucsim/cmd.src/cmd_stat.cc b/sim/ucsim/cmd.src/cmd_stat.cc new file mode 100644 index 0000000..c77436b --- /dev/null +++ b/sim/ucsim/cmd.src/cmd_stat.cc @@ -0,0 +1,123 @@ +/* + * Simulator of microcontrollers (cmd.src/cmdstat.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 "ddconfig.h" + +// prj +#include "globals.h" + +// sim +#include "simcl.h" + +// local +#include "cmd_statcl.h" + + +#ifdef STATISTIC +/* + * Command: statistic + *---------------------------------------------------------------------------- + */ + +//int +//cl_stat_cmd::do_work(class cl_sim *sim, +// class cl_cmdline *cmdline, class cl_console *con) +COMMAND_DO_WORK_UC(cl_statistic_cmd) +{ + class cl_address_space *mem; + t_addr start= 0, end= 0; + bool addresses= false; + class cl_cmd_arg *params[4]= { cmdline->param(0), + cmdline->param(1), + cmdline->param(2), + cmdline->param(3) }; + + mem= 0; + if (cmdline->syntax_match(uc, MEMORY ADDRESS ADDRESS)) { + mem= params[0]->value.memory.address_space; + start= params[1]->value.address; + end= params[2]->value.address; + addresses= true; + } + else if (cmdline->syntax_match(uc, MEMORY ADDRESS)) { + mem= params[0]->value.memory.address_space; + start= end= params[1]->value.address; + addresses= true; + } + else if (cmdline->syntax_match(uc, MEMORY)) { + mem= params[0]->value.memory.address_space; + addresses= false; + } + else + { + int i; + unsigned long wr, ww; + for (i= 0; i < uc->address_spaces->count; i++) + { + mem= (class cl_address_space *)(uc->address_spaces->at(i)); + wr= mem->get_nuof_reads(); + ww= mem->get_nuof_writes(); + con->dd_printf("%s writes= %10lu " + "reads= %10lu " + "(%10lu operations)\n", + mem->get_name("mem"), ww, wr, ww+wr); + } + } + if (mem) + { + t_addr i; + unsigned long wr, ww; + wr= mem->get_nuof_reads(); + ww= mem->get_nuof_writes(); + if (!addresses) + con->dd_printf("%s writes= %10lu " + "reads= %10lu\n", mem->get_name("mem"), ww, wr); + else + for (i= start; i <= end; i++) + { + class cl_memory_cell *c= mem->get_cell(i); + unsigned long w= c->nuof_writes, r= c->nuof_reads; + double dr= wr?((double(r)*100.0)/double(wr)):0.0; + double dw= ww?((double(w)*100.0)/double(ww)):0.0; + con->dd_printf("%s[0x%06x] writes= %10lu (%6.2lf%%) " + "reads= %10lu (%6.2lf%%)\n", + mem->get_name("mem"), AU(i), w, dw, r, dr); + } + } + + return(false);; +} + +CMDHELP(cl_statistic_cmd, + "statistic [mem [startaddr [endaddr]]]", + "Statistic of memory accesses", + "long help of statistic") + +#endif + + +/* End of cmd.src/cmd_stat.cc */ |
