X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=sim%2Fucsim%2Fs51.src%2Ftimer0cl.h;h=950041fc5503a55d9e7ada03761ad4881bd98129;hb=8c8f34ff4281a55d2f535335c02999246e9e12f2;hp=648f9239fa3d6ae7ff40d488d934d04eed0887c2;hpb=0ac34444ce2ccdcaa5fe722e2420f96c46224039;p=fw%2Fsdcc diff --git a/sim/ucsim/s51.src/timer0cl.h b/sim/ucsim/s51.src/timer0cl.h index 648f9239..950041fc 100644 --- a/sim/ucsim/s51.src/timer0cl.h +++ b/sim/ucsim/s51.src/timer0cl.h @@ -34,17 +34,36 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA #include "newcmdcl.h" +#include "uc51cl.h" + class cl_timer0: public cl_hw { +protected: + class cl_cell *cell_tmod, *cell_tcon, *cell_tl, *cell_th; + t_mem mask_M0, mask_M1, mask_C_T, mask_GATE, mask_TR, mask_INT, + mask_T, mask_TF; + t_addr addr_tl, addr_th; + int mode, GATE, C_T, TR, INT, T_edge; public: - cl_timer0(class cl_uc *auc); - //virtual int init(void); + cl_timer0(class cl_uc *auc, int aid, char *aid_string); + virtual int init(void); + + virtual void added_to_uc(void); + + //virtual t_mem read(class cl_cell *cell); + virtual void write(class cl_cell *cell, t_mem *val); + + //virtual void mem_cell_changed(class cl_mem *mem, t_addr addr); - //virtual ulong read(class cl_mem *mem, long addr); - //virtual void write(class cl_mem *mem, long addr, ulong *val); + virtual int tick(int cycles); + virtual int do_mode0(int cycles); + virtual int do_mode1(int cycles); + virtual int do_mode2(int cycles); + virtual int do_mode3(int cycles); + virtual void overflow(void); + virtual void happen(class cl_hw *where, enum hw_event he, void *params); - //virtual int tick(int cycles); virtual void print_info(class cl_console *con); };