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

📄 logic.cc

📁 Small Device C Compiler 面向Inter8051
💻 CC
字号:
/* * Simulator of microcontrollers (logic.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"// prj#include "stypes.h"// local#include "uc51cl.h"#include "regs51.h"/* * 0x42 2 12 ORL addr,A *____________________________________________________________________________ * */intt_uc51::inst_orl_addr_a(uchar code){  class cl_cell *cell;  cell= get_direct(fetch());  cell->write(cell->read(HW_PORT) | acc->read());  return(resGO);}/* * 0x43 3 24 ORL addr,#data *____________________________________________________________________________ * */intt_uc51::inst_orl_addr_Sdata(uchar code){  class cl_cell *cell;  int res= resGO;  cell= get_direct(fetch());  t_mem d= fetch();  cell->write(cell->read(HW_PORT) | d);  tick(1);  return(res);}/* * 0x44 2 12 ORL A,#data *____________________________________________________________________________ * */intt_uc51::inst_orl_a_Sdata(uchar code){  uchar d;  d= acc->read();  acc->write(d|= fetch());  return(resGO);}/* * 0x45 2 12 ORL A,addr *____________________________________________________________________________ * */intt_uc51::inst_orl_a_addr(uchar code){  t_mem d;  class cl_cell *cell;  cell= get_direct(fetch());  d= acc->read();  acc->write(d|= cell->read());  return(resGO);}/* * 0x46-0x47 1 12 ORL A,@Ri *____________________________________________________________________________ * */intt_uc51::inst_orl_a_Sri(uchar code){  t_mem d;  class cl_cell *cell;  cell= iram->get_cell(get_reg(code & 0x01)->read());  d= acc->read();  acc->write(d|= cell->read());  return(resGO);}/* * 0x48-0x4f 1 12 ORL A,Rn *____________________________________________________________________________ * */intt_uc51::inst_orl_a_rn(uchar code){  t_mem d;  d= acc->read();  acc->write(d|= get_reg(code & 0x07)->read());  return(resGO);}/* * 0x52 2 12 ANL addr,A *____________________________________________________________________________ * */intt_uc51::inst_anl_addr_a(uchar code){  class cl_cell *cell;    cell= get_direct(fetch());  cell->write(cell->read(HW_PORT) & acc->read());  return(resGO);}/* * 0x53 3 24 ANL addr,#data *____________________________________________________________________________ * */intt_uc51::inst_anl_addr_Sdata(uchar code){  class cl_cell *cell;  t_mem d;  cell= get_direct(fetch());  d= fetch();  cell->write(cell->read(HW_PORT) & d);  tick(1);  return(resGO);}/* * 0x54 2 12 ANL A,#data *____________________________________________________________________________ * */intt_uc51::inst_anl_a_Sdata(uchar code){  uchar d;  d= acc->read();  acc->write(d & fetch());  return(resGO);}/* * 0x55 2 12 ANL A,addr *____________________________________________________________________________ * */intt_uc51::inst_anl_a_addr(uchar code){  t_mem d;  class cl_cell *cell;  cell= get_direct(fetch());  d= acc->read();  acc->write(d & cell->read());  return(resGO);}/* * 0x56-0x57 1 12 ANL A,@Ri *____________________________________________________________________________ * */intt_uc51::inst_anl_a_Sri(uchar code){  t_mem d;  class cl_cell *cell;  cell= iram->get_cell(get_reg(code & 0x01)->read());  d= acc->read();  acc->write(d & cell->read());  return(resGO);}/* * 0x58-0x5f 1 12 ANL A,Rn *____________________________________________________________________________ * */intt_uc51::inst_anl_a_rn(uchar code){  uchar d;  d= acc->read();  acc->write(d & get_reg(code & 0x07)->read());  return(resGO);}/* * 0x62 2 12 XRL addr,A *____________________________________________________________________________ * */intt_uc51::inst_xrl_addr_a(uchar code){  class cl_cell *cell;  cell= get_direct(fetch());  cell->write(cell->read(HW_PORT) ^ acc->read());  return(resGO);}/* * 0x63 3 24 XRL addr,#data *____________________________________________________________________________ * */intt_uc51::inst_xrl_addr_Sdata(uchar code){  class cl_cell *cell;  cell= get_direct(fetch());  cell->write(cell->read(HW_PORT) ^ fetch());  tick(1);  return(resGO);}/* * 0x64 2 12 XRL A,#data *____________________________________________________________________________ * */intt_uc51::inst_xrl_a_Sdata(uchar code){  uchar d;  d= acc->read();  acc->write(d ^ fetch());  return(resGO);}/* * 0x65 2 12 XRL A,addr *____________________________________________________________________________ * */intt_uc51::inst_xrl_a_addr(uchar code){  t_mem d;  class cl_cell *cell;  cell= get_direct(fetch());  d= acc->read();  acc->write(d ^ cell->read());  return(resGO);}/* * 0x66-0x67 1 12 XRL A,@Ri *____________________________________________________________________________ * */intt_uc51::inst_xrl_a_Sri(uchar code){  t_mem d;  class cl_cell *cell;  cell= iram->get_cell(get_reg(code & 0x01)->read());  d= acc->read();  acc->write(d ^ cell->read());  return(resGO);}/* * 0x68-0x6f 1 12 XRL A,Rn *____________________________________________________________________________ * */intt_uc51::inst_xrl_a_rn(uchar code){  t_mem d;  d= acc->read();  acc->write(d ^ get_reg(code & 0x07)->read());  return(resGO);}/* * 0xf4 1 12 CPL A *____________________________________________________________________________ * */intt_uc51::inst_cpl_a(uchar code){  acc->write(~(acc->read()));  return(resGO);}/* End of s51.src/logic.cc */

⌨️ 快捷键说明

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