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

📄 memcl.h

📁 sdcc是为51等小型嵌入式cpu设计的c语言编译器支持数种不同类型的cpu
💻 H
字号:
/* * Simulator of microcontrollers (sim.src/memcl.h) * * 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@*/#ifndef SIM_MEMCL_HEADER#define SIM_MEMCL_HEADER#include "ddconfig.h"// prj#include "stypes.h"#include "pobjcl.h"// gui.src#include "guiobjcl.h"class cl_event_handler;// Cell types#define CELL_NORMAL	0x00	/* Nothing special */#define CELL_HW_READ	0x01	/* Hw handles read */#define CELL_HW_WRITE	0x02	/* Hw catches write *///#define CELL_INST	0x04	/* Marked as instruction *///#define CELL_FETCH_BRK	0x08	/* Fetch breakpoint */#define CELL_READ_BRK	0x10	/* Read event breakpoint */#define CELL_WRITE_BRK	0x20	/* Write event breakpoint */// Cell flagsenum cell_flag {  CELL_NONE		= 0x00,  CELL_INST		= 0x04,	/* Marked as instruction */  CELL_FETCH_BRK	= 0x08,	/* Fetch breakpoint */  CELL_NON_DECODED	= 0x40	/* Cell is not decoded (yet) */};#define CELL_GENERAL	(CELL_NORMAL|CELL_INST|CELL_FETCH_BRK)/* * 3rd version of memory system */class cl_memory: public cl_base{public:  t_addr start_address;protected:  class cl_uc *uc;  t_addr size;public:  char *addr_format, *data_format;  int width; // in bits  t_mem data_mask;  //char *class_name; // used by cl_m!!protected:  t_addr dump_finished;public:  cl_memory(char *id, t_addr asize, int awidth);  virtual ~cl_memory(void);  virtual int init(void);  t_addr get_start_address(void) { return(start_address); }  t_addr get_size(void) { return(size); }  virtual void set_uc(class cl_uc *auc) { uc= auc; }  virtual bool valid_address(t_addr addr);  virtual t_addr inc_address(t_addr addr, int val);  virtual t_addr inc_address(t_addr addr);  virtual t_addr validate_address(t_addr addr);  virtual bool is_chip(void) { return(DD_FALSE); }  virtual bool is_address_space(void) { return(DD_FALSE); }  virtual void err_inv_addr(t_addr addr);  virtual void err_non_decoded(t_addr addr);  virtual t_addr dump(t_addr start, t_addr stop, int bpl,		      class cl_console *con);  virtual t_addr dump(class cl_console *con);  virtual bool search_next(bool case_sensitive,			   t_mem *array, int len, t_addr *addr);  virtual t_addr lowest_valid_address(void) { return(start_address); }  virtual t_addr highest_valid_address(void) { return(start_address+size-1); }  virtual t_mem read(t_addr addr)=0;  virtual t_mem read(t_addr addr, enum hw_cath skip)=0;  virtual t_mem get(t_addr addr)=0;  virtual t_mem write(t_addr addr, t_mem val)=0;  virtual void set(t_addr addr, t_mem val)=0;  virtual void set_bit1(t_addr addr, t_mem bits)=0;  virtual void set_bit0(t_addr addr, t_mem bits)=0;};/* * Operators for memory cells */class cl_memory_operator: public cl_base{protected:  t_addr address;  t_mem *data;  t_mem mask;  class cl_memory_operator *next_operator;  class cl_memory_cell *cell;public:  cl_memory_operator(class cl_memory_cell *acell, t_addr addr);  cl_memory_operator(class cl_memory_cell *acell, t_addr addr,		     t_mem *data_place, t_mem the_mask);  virtual void set_data(t_mem *data_place, t_mem the_mask);  virtual class cl_memory_operator *get_next(void) { return(next_operator); }  virtual void set_next(class cl_memory_operator *next) { next_operator= next;}  virtual bool match(class cl_hw *the_hw) { return(DD_FALSE); }  virtual bool match(class cl_brk *brk) { return(DD_FALSE); }  virtual t_mem read(void);  virtual t_mem read(enum hw_cath skip) { return(read()); }  virtual t_mem write(t_mem val);};class cl_hw_operator: public cl_memory_operator{protected:  class cl_hw *hw;public:  cl_hw_operator(class cl_memory_cell *acell, t_addr addr,		 t_mem *data_place, t_mem the_mask, class cl_hw *ahw);  virtual bool match(class cl_hw *the_hw) { return(hw == the_hw); }  virtual t_mem read(void);  virtual t_mem read(enum hw_cath skip);  virtual t_mem write(t_mem val);};class cl_event_break_operator: public cl_memory_operator{protected:  class cl_uc *uc;  class cl_brk *bp;public:  cl_event_break_operator(class cl_memory_cell *acell, t_addr addr,			  t_mem *data_place, t_mem the_mask,			  class cl_uc *auc, class cl_brk *the_bp):    cl_memory_operator(acell, addr, data_place, the_mask)  {    uc= auc;    bp= the_bp;  }  virtual bool match(class cl_brk *brk) { return(bp == brk); }};class cl_write_operator: public cl_event_break_operator{public:  cl_write_operator(class cl_memory_cell *acell, t_addr addr,		    t_mem *data_place, t_mem the_mask,		    class cl_uc *auc, class cl_brk *the_bp);  virtual t_mem write(t_mem val);};class cl_read_operator: public cl_event_break_operator{public:  cl_read_operator(class cl_memory_cell *acell, t_addr addr,		   t_mem *data_place, t_mem the_mask,		   class cl_uc *auc, class cl_brk *the_bp);  virtual t_mem read(void);};/* * version 3 of cell */class cl_memory_cell: public cl_base{#ifdef STATISTICpublic:  unsigned long nuof_writes, nuof_reads;#endifprotected:  t_mem *data;  t_mem mask;  uchar width;  TYPE_UBYTE flags;  class cl_memory_operator *operators;public:  cl_memory_cell(void);  virtual ~cl_memory_cell(void);  virtual int init(void);  virtual t_mem *get_data(void) { return(data); }  virtual t_mem get_mask(void) { return(mask); }  virtual TYPE_UBYTE get_flags(void);  virtual bool get_flag(enum cell_flag flag);  virtual void set_flags(TYPE_UBYTE what);  virtual void set_flag(enum cell_flag flag, bool val);  virtual void un_decode(void);  virtual void decode(class cl_memory_chip *chip, t_addr addr);  virtual t_mem read(void);  virtual t_mem read(enum hw_cath skip);  virtual t_mem get(void);  virtual t_mem write(t_mem val);  virtual t_mem set(t_mem val);  virtual t_mem add(long what);  virtual t_mem wadd(long what);  virtual void set_bit1(t_mem bits);  virtual void set_bit0(t_mem bits);  virtual void append_operator(class cl_memory_operator *op);  virtual void prepend_operator(class cl_memory_operator *op);  virtual void del_operator(class cl_brk *brk);  virtual class cl_memory_cell *add_hw(class cl_hw *hw, int *ith, t_addr addr);  //virtual class cl_hw *get_hw(int ith);  virtual class cl_event_handler *get_event_handler(void);};class cl_dummy_cell: public cl_memory_cell{public:  cl_dummy_cell(void): cl_memory_cell() {}  virtual t_mem write(t_mem val);  virtual t_mem set(t_mem val);};/* * Address space */class cl_memory_chip;class cl_address_space: public cl_memory{protected:  class cl_memory_cell **cells, *dummy;public:  class cl_decoder_list *decoders;public:  cl_address_space(char *id, t_addr astart, t_addr asize, int awidth);  virtual ~cl_address_space(void);  virtual bool is_address_space(void) { return(DD_TRUE); }  virtual t_mem read(t_addr addr);  virtual t_mem read(t_addr addr, enum hw_cath skip);  virtual t_mem get(t_addr addr);  virtual t_mem write(t_addr addr, t_mem val);  virtual void set(t_addr addr, t_mem val);  virtual t_mem wadd(t_addr addr, long what);  virtual void set_bit1(t_addr addr, t_mem bits);  virtual void set_bit0(t_addr addr, t_mem bits);  virtual class cl_address_decoder *get_decoder(t_addr addr);  virtual class cl_memory_cell *get_cell(t_addr addr);  virtual int get_cell_flag(t_addr addr);  virtual bool get_cell_flag(t_addr addr, enum cell_flag flag);  virtual void set_cell_flag(t_addr addr, bool set_to, enum cell_flag flag);  virtual bool decode_cell(t_addr addr,			   class cl_memory_chip *chip, t_addr chipaddr);  virtual void undecode_cell(t_addr addr);  virtual void undecode_area(class cl_address_decoder *skip,			     t_addr begin, t_addr end, class cl_console *con);  virtual class cl_memory_cell *register_hw(t_addr addr, class cl_hw *hw,					    int *ith,					    bool announce);  virtual void set_brk(t_addr addr, class cl_brk *brk);  virtual void del_brk(t_addr addr, class cl_brk *brk);#ifdef STATISTIC  virtual unsigned long get_nuof_reads(void) { return(0); }  virtual unsigned long get_nuof_writes(void) { return(0); }  virtual void set_nuof_reads(unsigned long value) {}  virtual void set_nuof_writes(unsigned long value) {}#endif};class cl_address_space_list: public cl_list{protected:  class cl_uc *uc;public:  cl_address_space_list(class cl_uc *the_uc);  virtual t_index add(class cl_address_space *mem);};/* * Memory chip (storage) */class cl_memory_chip: public cl_memory{protected:  t_mem *array;  int init_value;public:  cl_memory_chip(char *id, int asize, int awidth, int initial= -1);  virtual ~cl_memory_chip(void);  virtual int init(void);  virtual bool is_chip(void) { return(DD_TRUE); }  virtual t_mem *get_slot(t_addr addr);  virtual t_mem read(t_addr addr) { return(get(addr)); }  virtual t_mem read(t_addr addr, enum hw_cath skip) { return(get(addr)); }  virtual t_mem get(t_addr addr);  virtual t_mem write(t_addr addr, t_mem val) { set(addr, val); return(val); }  virtual void set(t_addr addr, t_mem val);  virtual void set_bit1(t_addr addr, t_mem bits);  virtual void set_bit0(t_addr addr, t_mem bits);};/* * Address decoder */class cl_address_decoder: public cl_base{public:  class cl_address_space *address_space;  class cl_memory_chip *memchip;  t_addr as_begin, as_end;  t_addr chip_begin;  bool activated;public:  cl_address_decoder(class cl_memory *as, class cl_memory *chip,		     t_addr asb, t_addr ase, t_addr cb);  virtual ~cl_address_decoder(void);  virtual int init(void);  virtual bool activate(class cl_console *con);  virtual bool fully_covered_by(t_addr begin, t_addr end);  virtual bool is_in(t_addr begin, t_addr end);  virtual bool covers(t_addr begin, t_addr end);  virtual bool shrink_out_of(t_addr begin, t_addr end);  virtual class cl_address_decoder *split(t_addr begin, t_addr end);};/* List of address decoders */class cl_decoder_list: public cl_sorted_list{protected:  bool by_chip;public:  cl_decoder_list(t_index alimit, t_index adelta, bool bychip);  virtual void *key_of(void *item);  virtual int compare(void *key1, void *key2);};/* * Messages */#include "eventcl.h"class cl_event_address_space_added: public cl_event{public:  class cl_address_space *as;  cl_event_address_space_added(class cl_address_space *the_as):    cl_event(ev_address_space_added)  { as= the_as; }};/* * Errors in memory handling */#include "errorcl.h"class cl_error_mem: public cl_error{protected:  class cl_memory *mem;  t_addr addr;public:  cl_error_mem(class cl_memory *amem, t_addr aaddr);};class cl_error_mem_invalid_address: public cl_error_mem{public:  cl_error_mem_invalid_address(class cl_memory *amem, t_addr aaddr);  virtual void print(class cl_commander *c);};class cl_error_mem_non_decoded: public cl_error_mem{public:  cl_error_mem_non_decoded(class cl_memory *amem, t_addr aaddr);  virtual void print(class cl_commander *c);};class cl_mem_error_registry: public cl_error_registry{public:  cl_mem_error_registry(void);};#endif/* End of memcl.h */

⌨️ 快捷键说明

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