X-Git-Url: http://git.squeep.com/?p=dcpu16;a=blobdiff_plain;f=dcpu16.h;h=af964e7e46c561f1923e5f49ff8dc5f8768623e8;hp=edfccdfb53be7edbb1f0b41c7129c8fa0a736c11;hb=0b4991bc7e50f503769a2d2a1a4b5c1690251899;hpb=395837ab88bd03a3dca10338b4cb0d53b4fa9587 diff --git a/dcpu16.h b/dcpu16.h index edfccdf..af964e7 100644 --- a/dcpu16.h +++ b/dcpu16.h @@ -7,16 +7,31 @@ typedef unsigned short DCPU16_WORD; /* how much ram the system has */ #define DCPU16_RAM 0x10000 +/* these are used for accounting/watchpointing/&c */ +typedef unsigned int dcpu16_acct_event_; +#define DCPU16_ACCT_EV_READ (1<<1) +#define DCPU16_ACCT_EV_WRITE (1<<2) +#define DCPU16_ACCT_RAM (1<<3) + +struct dcpu16_acct_cb { + void (*fn)(dcpu16_acct_event_ e, DCPU16_WORD addr); + dcpu16_acct_event_ match_all; + dcpu16_acct_event_ match_any; +}; + /* a self-contained dcpu16 core */ struct dcpu16 { - unsigned long long cycle; /* number of cycles this core has executed */ - DCPU16_WORD reg[8]; /* system registers, a b c x y z i j */ - DCPU16_WORD pc; /* program counter */ - DCPU16_WORD sp; /* stack pointer */ - DCPU16_WORD o; /* overflow */ - unsigned int skip_ : 1; /* skip execution of next instruction */ - DCPU16_WORD ram[DCPU16_RAM]; /* memory */ - DCPU16_WORD reg_work_[2]; /* (private) work registers for holding literal values while decoding instructions */ + unsigned long long cycle; /* number of cycles this core has executed */ + DCPU16_WORD reg[8]; /* system registers, a b c x y z i j */ + DCPU16_WORD pc; /* program counter */ + DCPU16_WORD sp; /* stack pointer */ + DCPU16_WORD o; /* overflow */ + unsigned int skip_ : 1; /* skip execution of next instruction */ + DCPU16_WORD ram[DCPU16_RAM]; /* memory */ + DCPU16_WORD reg_work_[2]; /* (private) work registers for holding literal values while decoding instructions */ + struct dcpu16_acct_cb *cb_table_; /* list of callbacks to invoke under certain conditions */ + size_t cb_table_entries_; /* callback list maintenance */ + size_t cb_table_allocated_; /* callback list maintenance */ }; /* instantiate a new core */ @@ -34,6 +49,8 @@ void dcpu16_dump_ram(struct dcpu16 *, DCPU16_WORD, DCPU16_WORD); /* print the instruction at the specified address */ void dcpu16_disassemble_print(struct dcpu16 *, DCPU16_WORD); +/* register a callback for an accounting event */ +int dcpu16_acct_add(struct dcpu16 *, dcpu16_acct_event_ match_all, dcpu16_acct_event_ match_any, void (*fn)(dcpu16_acct_event_, DCPU16_WORD)); /* execute the next instruction */ void dcpu16_step(struct dcpu16 *);