for (i = 0; i < vm->cb_table_entries_; i++) {
if ( (cb[i].mask & ev) )
- cb[i].fn(vm, ev, addr);
+ cb[i].fn(vm, ev, addr, cb[i].data);
}
}
* Register callback fn to be triggered whenever event matching any events
* in bitwise mask occur.
*/
-int dcpu16_acct_add(struct dcpu16 *vm, dcpu16_acct_event_ mask, void (*fn)(struct dcpu16 *, dcpu16_acct_event_, DCPU16_WORD)) {
+int dcpu16_acct_add(struct dcpu16 *vm, dcpu16_acct_event_ mask, void (*fn)(struct dcpu16 *, dcpu16_acct_event_, DCPU16_WORD, void *), void *data) {
struct dcpu16_acct_cb cb;
cb.mask = mask;
cb.fn = fn;
+ cb.data = data;
if (vm->cb_table_entries_ == vm->cb_table_allocated_) {
size_t new_entries = vm->cb_table_allocated_ + 32;
#define DCPU16_ACCT_EV_WRITE (1<<2)
#define DCPU16_ACCT_EV_NOP (1<<3)
struct dcpu16_acct_cb {
- void (*fn)(struct dcpu16 *, dcpu16_acct_event_ e, DCPU16_WORD addr);
+ void (*fn)(struct dcpu16 *, dcpu16_acct_event_ e, DCPU16_WORD addr, void *);
+ void *data;
dcpu16_acct_event_ mask;
};
DCPU16_WORD dcpu16_disassemble_print(struct dcpu16 *, DCPU16_WORD);
/* register a callback for an accounting event */
-int dcpu16_acct_add(struct dcpu16 *, dcpu16_acct_event_ mask, void (*fn)(struct dcpu16 *, dcpu16_acct_event_, DCPU16_WORD));
+int dcpu16_acct_add(struct dcpu16 *, dcpu16_acct_event_ mask, void (*fn)(struct dcpu16 *, dcpu16_acct_event_, DCPU16_WORD, void *), void *data);
/* execute the next instruction */
void dcpu16_step(struct dcpu16 *);