2 class cl_mem: public cl_guiobj
5 char *addr_format, *data_format;
13 //class cl_memloc_coll *read_locs, *write_locs;
20 cl_mem(enum mem_class atype, char *aclass_name, t_addr asize, int awidth,
22 virtual ~cl_mem(void);
23 virtual int init(void);
24 virtual char *id_string(void);
25 virtual int get_cell_flag(t_addr //addr
26 ) { return(CELL_NORMAL); }
27 virtual bool get_cell_flag(t_addr //addr
31 virtual void set_cell_flag(t_addr addr, bool set_to, int flag) {}
33 virtual t_mem read(t_addr addr);
34 virtual t_mem read(t_addr addr, enum hw_cath //skip
35 ) {return(read(addr));}
36 virtual t_mem get(t_addr addr);
37 virtual t_mem write(t_addr addr, t_mem val);
38 virtual void set(t_addr addr, t_mem val);
39 virtual void set_bit1(t_addr addr, t_mem bits);
40 virtual void set_bit0(t_addr addr, t_mem bits);
41 virtual void write_bit1(t_addr addr, t_mem bits) { set_bit1(addr, bits); }
42 virtual void write_bit0(t_addr addr, t_mem bits) { set_bit0(addr, bits); }
43 virtual t_mem add(t_addr addr, long what);
44 virtual t_mem wadd(t_addr addr, long what) { return(add(addr, what)); }
45 virtual t_addr dump(t_addr start, t_addr stop, int bpl,
46 class cl_console *con);
47 virtual t_addr dump(class cl_console *con);
48 virtual bool search_next(bool case_sensitive,
49 t_mem *array, int len, t_addr *addr);
51 virtual class cl_cell *get_cell(t_addr addr) {return(0);}
52 virtual class cl_cell *register_hw(t_addr addr, class cl_hw *hw, int *ith,
55 virtual void set_brk(t_addr //addr
58 virtual void del_brk(t_addr addr, class cl_brk *brk) {}
60 virtual unsigned long get_nuof_reads(void) {return(0);}
61 virtual unsigned long get_nuof_writes(void) {return(0);}
62 virtual void set_nuof_reads(unsigned long value) {}
63 virtual void set_nuof_writes(unsigned long value) {}
69 class cl_mapped_cell: public cl_cell
72 class cl_cell *real_cell;
74 cl_mapped_cell(class cl_cell *realcell);
75 virtual ~cl_mapped_cell(void);
77 virtual t_mem read(void);
78 virtual t_mem read(enum hw_cath skip);
79 virtual t_mem get(void);
80 virtual t_mem write(t_mem val);
81 virtual t_mem set(t_mem val);
82 virtual t_mem add(long what);
83 virtual t_mem wadd(long what);
85 virtual void set_bit1(t_mem bits);
86 virtual void set_bit0(t_mem bits);
88 virtual class cl_cell *add_hw(class cl_hw *hw, int *ith);
89 virtual class cl_hw *get_hw(int ith);
90 virtual class cl_event_handler *get_event_handler(void);
95 class cl_m: public cl_memory
98 class cl_cell **array;
106 cl_m(enum mem_class atype, char *aclass_name, t_addr asize, int awidth,
108 cl_m(t_addr asize, int awidth);
110 virtual int init(void);
111 virtual char *id_string(void);
113 virtual int get_cell_flag(t_addr addr);
114 virtual bool get_cell_flag(t_addr addr, int flag);
115 virtual void set_cell_flag(t_addr addr, bool set_to, int flag);
117 virtual t_mem read(t_addr addr);
118 virtual t_mem read(t_addr addr, enum hw_cath skip);
119 virtual t_mem get(t_addr addr);
120 virtual t_mem write(t_addr addr, t_mem val);
121 virtual void set(t_addr addr, t_mem val);
122 virtual class cl_cell *get_cell(t_addr addr);
124 virtual void set_bit1(t_addr addr, t_mem bits);
125 virtual void set_bit0(t_addr addr, t_mem bits);
126 virtual void write_bit1(t_addr addr, t_mem bits);
127 virtual void write_bit0(t_addr addr, t_mem bits);
128 virtual t_mem add(t_addr addr, long what);
129 virtual t_mem wadd(t_addr addr, long what);
131 virtual bool search_next(bool case_sensitive,
132 t_mem *array, int len, t_addr *addr);
134 virtual class cl_cell *register_hw(t_addr addr, class cl_hw *hw, int *ith,
136 virtual void set_brk(t_addr addr, class cl_brk *brk);
137 virtual void del_brk(t_addr addr, class cl_brk *brk);
140 virtual unsigned long get_nuof_reads(void);
141 virtual unsigned long get_nuof_writes(void);
142 virtual void set_nuof_reads(unsigned long value);
143 virtual void set_nuof_writes(unsigned long value);
148 class cl_normal_cell: public cl_cell
152 TYPE_UBYTE type; // See CELL_XXXX
156 cl_normal_cell(uchar awidth);
157 //virtual void destroy(void) {}
159 virtual TYPE_UBYTE get_type(void) { return(type); }
160 virtual void set_type(TYPE_UBYTE what) { type= what; }
162 virtual t_mem read(void) {
168 virtual t_mem read(enum hw_cath skip) { return(data); }
169 virtual t_mem get(void) { return(data); }
170 virtual t_mem write(t_mem val) {
177 virtual t_mem set(t_mem val) { return(data= val & mask); }
178 virtual t_mem add(long what);
179 virtual t_mem wadd(long what);
181 virtual void set_bit1(t_mem bits);
182 virtual void set_bit0(t_mem bits);
184 virtual class cl_cell *add_hw(class cl_hw *hw, int *ith)
186 virtual class cl_hw *get_hw(int ith) { return(0); }
187 //virtual class cl_brk *get_brk(void) { return(0); }
188 virtual class cl_event_handler *get_event_handler(void) { return(0); }
191 class cl_registered_cell: public cl_memory_cell
194 //class cl_list *hws;
195 class cl_hw **hardwares;
198 cl_registered_cell(uchar awidth);
199 virtual ~cl_registered_cell(void);
200 //virtual void destroy(void);
202 virtual t_mem read(void);
203 virtual t_mem read(enum hw_cath skip);
204 virtual t_mem write(t_mem val);
206 virtual class cl_cell *add_hw(class cl_hw *hw, int *ith);
207 virtual class cl_hw *get_hw(int ith);
210 class cl_event_cell: public cl_normal_cell
213 class cl_event_handler *eh;
215 cl_event_cell(uchar awidth, class cl_uc *auc);
216 virtual ~cl_event_cell(void);
218 virtual t_mem read(void);
219 virtual t_mem write(t_mem val);
220 //virtual void event(void);
222 //virtual class cl_brk *get_brk(void) { return(brk); }
223 virtual class cl_event_handler *get_event_handler(void) { return(eh); }
226 class cl_ev_reg_cell: public cl_registered_cell
229 class cl_event_handler *eh;
231 cl_ev_reg_cell(uchar awidth, class cl_uc *auc);
232 virtual ~cl_ev_reg_cell(void);
234 virtual t_mem read(void);
235 virtual t_mem write(t_mem val);
236 //virtual void event(void);
238 //virtual class cl_brk *get_brk(void) { return(brk); }
239 virtual class cl_event_handler *get_event_handler(void) { return(eh); }
243 * 2nd version memory system
245 class cl_cell: public cl_base
251 virtual t_mem read(void)= 0;
252 virtual t_mem read(enum hw_cath skip)=0;
253 virtual t_mem get(void)=0;
254 virtual t_mem write(t_mem val)=0;
255 virtual t_mem set(t_mem val)=0;
256 virtual t_mem add(long what)=0;
257 virtual t_mem wadd(long what)=0;
259 virtual void set_bit1(t_mem bits)=0;
260 virtual void set_bit0(t_mem bits)=0;
262 virtual class cl_cell *add_hw(class cl_hw *hw, int *ith)=0;
263 virtual class cl_hw *get_hw(int ith)=0;
264 virtual class cl_event_handler *get_event_handler(void)=0;
269 class cl_event_handler: public cl_base
272 class cl_list *read_bps, *write_bps;
275 cl_event_handler(class cl_uc *auc);
276 virtual ~cl_event_handler(void);
278 virtual void write(void);
279 virtual void read(void);
281 virtual int add_bp(class cl_brk *bp);
282 virtual int copy_from(class cl_event_handler *eh);
283 virtual bool del_bp(class cl_brk *bp);