⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cmdset.cc

📁 sdcc是为51等小型嵌入式cpu设计的c语言编译器支持数种不同类型的cpu
💻 CC
字号:
/* * Simulator of microcontrollers (cmd.src/cmdset.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 modifyit under the terms of the GNU General Public License as published bythe 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 ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with UCSIM; see the file COPYING.  If not, write to the FreeSoftware Foundation, 59 Temple Place - Suite 330, Boston, MA02111-1307, USA. *//*@1@*/#include "ddconfig.h"#include "cmdlexcl.h"#include "cmdpars.h"// prj#include "i_string.h"#include "utils.h"#include "globals.h"// sim.src#include "simcl.h"// local, cmd.src#include "cmdsetcl.h"#include "cmdutil.h"/* * Command: run *---------------------------------------------------------------------------- *///int//cl_run_cmd::do_work(class cl_sim *sim,//		    class cl_cmdline *cmdline, class cl_console *con)COMMAND_DO_WORK_SIM(cl_run_cmd){  class cl_brk *b;  t_addr start, end;  class cl_cmd_arg *params[4]= { cmdline->param(0),				 cmdline->param(1),				 cmdline->param(2),				 cmdline->param(3) };  if (params[0])    if (!(params[0]->get_address(sim->uc, &start)))      {	con->dd_printf("Error: wrong start address\n");	return(DD_FALSE);      }  if (params[1])    if (!(params[1]->get_address(sim->uc, &end)))      {	con->dd_printf("Error: wromg end address\n");	return(DD_FALSE);      }  if (params[0])    {      if (!sim->uc->inst_at(start))	con->dd_printf("Warning: maybe not instruction at 0x%06lx\n", start);      sim->uc->PC= start;      if (params[1])	{	  if (start == end)	    {	      con->dd_printf("Addresses must be different.\n");	      return(DD_FALSE);	    }	  if ((b= sim->uc->fbrk_at(end)))	    {	    }	  else	    {	      b= new cl_fetch_brk(sim->uc->address_space(MEM_ROM_ID),				  sim->uc->make_new_brknr(), end,				  brkDYNAMIC, 1);	      sim->uc->fbrk->add_bp(b);	    }	}    }  con->dd_printf("Simulation started, PC=0x%06x\n", sim->uc->PC);  if (sim->uc->fbrk_at(sim->uc->PC))    sim->uc->do_inst(1);  sim->start(con);  return(DD_FALSE);}/* * Command: stop *---------------------------------------------------------------------------- *///int//cl_stop_cmd::do_work(class cl_sim *sim,//		     class cl_cmdline *cmdline, class cl_console *con)COMMAND_DO_WORK_SIM(cl_stop_cmd){  sim->stop(resUSER);  sim->uc->print_disass(sim->uc->PC, con);  return(DD_FALSE);}/* * Command: step *---------------------------------------------------------------------------- *///int//cl_step_cmd::do_work(class cl_sim *sim,//		     class cl_cmdline *cmdline, class cl_console *con)COMMAND_DO_WORK_UC(cl_step_cmd){  //printf("step %x\n",uc->PC);  uc->do_inst(1);  //printf("step done %x\n",uc->PC);  uc->print_regs(con);  return(0);}/* * Command: next *---------------------------------------------------------------------------- *///int//cl_next_cmd::do_work(class cl_sim *sim,//		     class cl_cmdline *cmdline, class cl_console *con)COMMAND_DO_WORK_SIM(cl_next_cmd){  class cl_brk *b;  t_addr next;  int branch;  int inst_len;#if 0  struct dis_entry *de;  t_mem code= sim->uc->get_mem(MEM_ROM, sim->uc->PC);  int i= 0;  de= &(sim->uc->dis_tbl()[i]);  while ((code & de->mask) != de->code &&	 de->mnemonic)    {      i++;      de= &(sim->uc->dis_tbl()[i]);    }#endif  branch = sim->uc->inst_branch(sim->uc->PC);  inst_len = sim->uc->inst_length(sim->uc->PC);  if ((branch == 'a') || (branch == 'l'))    {      next= sim->uc->PC + inst_len;      if (!sim->uc->fbrk_at(next))	{	  b= new cl_fetch_brk(sim->uc->address_space(MEM_ROM_ID),			      sim->uc->make_new_brknr(),			      next, brkDYNAMIC, 1);	  b->init();//	  sim->uc->fbrk->add_bp(b);	  sim->uc->fbrk->add(b);	  b->activate();	}      if (sim->uc->fbrk_at(sim->uc->PC))	sim->uc->do_inst(1);      sim->start(con);      //sim->uc->do_inst(-1);    }  else {    sim->uc->do_inst(1);    sim->uc->print_regs(con);  }  return(DD_FALSE);}/* * Command: help *---------------------------------------------------------------------------- *///int//cl_help_cmd::do_work(class cl_sim *sim,//		     class cl_cmdline *cmdline, class cl_console *con)COMMAND_DO_WORK_APP(cl_help_cmd){  class cl_sim *sim;  class cl_commander *commander;  class cl_cmdset *cmdset= 0;  int i;  class cl_cmd_arg *parm= cmdline->param(0);  sim= app->get_sim();  if ((commander= app->get_commander()) != 0)    cmdset= commander->cmdset;  if (!cmdset)    return(DD_FALSE);  if (!parm) {    for (i= 0; i < cmdset->count; i++)      {	class cl_cmd *c= (class cl_cmd *)(cmdset->at(i));	if (c->short_help)	  con->dd_printf("%s\n", c->short_help);	else	  con->dd_printf("%s\n", (char*)(c->names->at(0)));      }  }  else    {      matches= 0;      do_set(cmdline, 0, cmdset, con);      if (matches == 1 &&	  cmd_found)	{	  int names;	  con->dd_printf("Names of command:");	  for (names= 0; names < cmd_found->names->count; names++)	    con->dd_printf(" %s", (char*)(cmd_found->names->at(names)));	  con->dd_printf("\n");	  class cl_cmdset *subset= cmd_found->get_subcommands();	  if (subset)	    {	      con->dd_printf("\"%s\" must be followed by the name of a "			     "subcommand\nList of subcommands:\n",			     (char*)(cmd_found->names->at(0)));	      for (i= 0; i < subset->count; i++)		{		  class cl_cmd *c=		    dynamic_cast<class cl_cmd *>(subset->object_at(i));		  con->dd_printf("%s\n", c->short_help);		}	    }	  if (cmd_found->long_help)	    con->dd_printf("%s\n", cmd_found->long_help);	}      if (!matches ||	  !cmd_found)	con->dd_printf("No such command.\n");      //return(DD_FALSE);      /*      int pari;      for (pari= 0; pari < cmdline->nuof_params(); pari++)	{	  class cl_cmd_arg *act_param;	  act_param= (class cl_cmd_arg *)(cmdline->param(pari));	  for (i= 0; i < cmdset->count; i++)	    {	      class cl_cmd *c= (class cl_cmd *)(cmdset->at(i));	      if (!c->name_match(act_param->s_value, DD_FALSE))		continue;	      if (c->short_help)		con->dd_printf("%s\n", c->short_help);	      else		con->dd_printf("%s\n", (char*)(c->names->at(0)));	      if (pari < cmdline->nuof_params()-1)		continue;	      cmdset= c->get_subcommands();	      if (!cmdset)		return(DD_FALSE);	    }	}      return(DD_FALSE);      */    }  return(DD_FALSE);  /*  if (cmdline->syntax_match(0, STRING)) {    matches= 0;    for (i= 0; i < cmdset->count; i++)      {	c= (class cl_cmd *)(cmdset->at(i));	if (c->name_match(parm->value.string.string, DD_FALSE))	  matches++;      }    if (!matches)      con->dd_printf("No such command\n");    else if (matches > 1)      for (i= 0; i < cmdset->count; i++)	{	  c= (class cl_cmd *)(cmdset->at(i));	  if (!c->name_match(parm->value.string.string, DD_FALSE))	    continue;	  if (c->short_help)	    con->dd_printf("%s\n", c->short_help);	  else	    con->dd_printf("%s\n", (char*)(c->names->at(0)));	}    else      for (i= 0; i < cmdset->count; i++)	{	  c= (class cl_cmd *)(cmdset->at(i));	  if (!c->name_match(parm->value.string.string, DD_FALSE))	    continue;	  if (c->short_help)	    con->dd_printf("%s\n", c->short_help);	  else	    con->dd_printf("%s\n", (char*)(c->names->at(0)));	  int names;	  con->dd_printf("Names of command:");	  for (names= 0; names < c->names->count; names++)	    con->dd_printf(" %s", (char*)(c->names->at(names)));	  con->dd_printf("\n");	  if (c->long_help)	    con->dd_printf("%s\n", c->long_help);	  else	    con->dd_printf("%s\n", (char*)(c->names->at(0)));	}  }  else    con->dd_printf("%s\n", short_help?short_help:"Error: wrong syntax");  return(0);  */}boolcl_help_cmd::do_set(class cl_cmdline *cmdline, int pari,		    class cl_cmdset *cmdset,		    class cl_console *con){  int i;  for (i= 0; i < cmdset->count; i++)    {      class cl_cmd *cmd= dynamic_cast<class cl_cmd *>(cmdset->object_at(i));      if (!cmd)	continue;      if (pari >= cmdline->nuof_params())	return(DD_FALSE);      class cl_cmd_arg *param= cmdline->param(pari);      if (!param)	return(DD_FALSE);      class cl_cmdset *next_set= cmd->get_subcommands();      if (cmd->name_match(param->s_value, DD_FALSE))	{	  if (pari+1 >= cmdline->nuof_params())	    {	      matches++;	      cmd_found= cmd;	      if (cmd->short_help)		con->dd_printf("%s\n", cmd->short_help);	      else		con->dd_printf("%s\n", (char*)(cmd->names->at(0)));	      //continue;	    }	  else	    if (next_set)	      do_set(cmdline, pari+1, next_set, con);	}    }  return(DD_TRUE);}/* * Command: quit *---------------------------------------------------------------------------- *///int//cl_quit_cmd::do_work(class cl_sim *sim,//		     class cl_cmdline */*cmdline*/, class cl_console */*con*/)COMMAND_DO_WORK(cl_quit_cmd){  return(1);}/* * Command: kill *---------------------------------------------------------------------------- *///int//cl_kill_cmd::do_work(class cl_sim *sim,//		     class cl_cmdline */*cmdline*/, class cl_console */*con*/)COMMAND_DO_WORK_APP(cl_kill_cmd){  app->going= 0;  if (app->sim)    app->sim->state|= SIM_QUIT;  return(1);}/* * EXEC file */COMMAND_DO_WORK_APP(cl_exec_cmd){  class cl_cmd_arg *parm= cmdline->param(0);  char *fn= 0;  if (cmdline->syntax_match(0, STRING)) {    fn= parm->value.string.string;   }  else    con->dd_printf("%s\n", short_help?short_help:"Error: wrong syntax\n");  class cl_commander *c= app->get_commander();  class cl_console *cons= con->clone_for_exec(fn);  if (cons)    {      cons->flags|= CONS_NOWELCOME;      c->add_console(cons);    }  return(DD_FALSE);}/* * expression expression */COMMAND_DO_WORK_APP(cl_expression_cmd){  //con->dd_printf("\"%s\"\n", cmdline->cmd);  char *s= cmdline->cmd;  if (!s ||      !*s)    return(DD_FALSE);  int i= strspn(s, " \t\v\n");  s+= i;  //con->dd_printf("\"%s\"\n", s);  i= strspn(s, "abcdefghijklmnopqrstuvwxyz");  s+= i;  //con->dd_printf("\"%s\"\n", s);  class YY_cl_ucsim_parser_CLASS *pars;  class cl_ucsim_lexer *lexer;  lexer= new cl_ucsim_lexer(s);  pars= new YY_cl_ucsim_parser_CLASS(lexer);  pars->yyparse();  delete pars;  return(DD_FALSE);}/* End of cmd.src/cmdset.cc */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -