#include "dcpu16.h"
#include "hw_spc2000.h"
-static dcpu16_hw_signal_t spc2000_reset_;
-static dcpu16_hw_signal_t spc2000_cycle_;
-static dcpu16_hw_signal_t spc2000_hwi_;
-static struct dcpu16_hw hw_ = {
- .vm = NULL,
- .name_ = "SPC2000 - Suspension Chamber 2000",
- .id_l = 0x1d9d,
- .id_h = 0x40e4,
- .ver = 0x005e,
- .mfg_l = 0x8b36,
- .mfg_h = 0x1c6c,
- .hwi = spc2000_hwi_,
- .cycle = spc2000_cycle_,
- .reset = spc2000_reset_,
- .data = (struct spc2000_ *)NULL
-};
-
-static dcpu16_hw_data_init_t spc2000_data_init_;
-static dcpu16_hw_data_free_t spc2000_data_free_;
-struct dcpu16_hw_module dcpu16_hw_module_spc2000 = {
- .template = &hw_,
- .data_init = spc2000_data_init_,
- .data_free = spc2000_data_free_,
-};
+#define MSG_(__level__, __vm__, ...) do { ((__vm__) ? ((struct dcpu16 *)(__vm__))->msg_cb_ : dcpu16_msg_)(__level__, __VA_ARGS__); } while (0)
+#define MSG_INFO(__vm__, ...) MSG_(DCPU16_MSG_INFO, __vm__, __VA_ARGS__)
+#define MSG_ERROR(__vm__, ...) MSG_(DCPU16_MSG_ERROR, __vm__, __VA_ARGS__)
+#ifdef DEBUG
+#define MSG_DEBUG(__vm__, ...) MSG_(DCPU16_MSG_DEBUG, __vm__, __VA_ARGS__)
+#else /* DEBUG */
+#define MSG_DEBUG(__vm__, ...) do { } while (0)
+#endif /* DEBUG */
struct spc2000_ {
DCPU16_WORD skip_unit;
};
static
-int spc2000_data_init_(struct dcpu16_hw *hw, void *extra) {
- (void)extra;
+int spc2000_data_init_(struct dcpu16_hw *hw, void *data) {
+ (void)data;
hw->data = calloc(1, sizeof(struct spc2000_));
if (hw->data == NULL) {
- hw->vm->warn_cb_("%s():%s", "calloc", strerror(errno));
+ MSG_ERROR(hw->vm, "%s():%s", "calloc", strerror(errno));
return -1;
}
return 0;
}
static
-void spc2000_reset_(struct dcpu16 *vm, void *data) {
- struct spc2000_ *spc2000 = (struct spc2000_ *)data;
+void spc2000_reset_(struct dcpu16 *vm, struct dcpu16_hw *hw) {
+ struct spc2000_ *spc2000 = (struct spc2000_ *)hw->data;
(void)vm;
}
static
-void spc2000_cycle_(struct dcpu16 *vm, void *data) {
- struct spc2000_ *spc2000 = (struct spc2000_ *)data;
+void spc2000_cycle_(struct dcpu16 *vm, struct dcpu16_hw *hw) {
+ struct spc2000_ *spc2000 = (struct spc2000_ *)hw->data;
(void)vm;
(void)spc2000;
}
static
-void spc2000_hwi_(struct dcpu16 *vm, void *data) {
- struct spc2000_ *spc2000 = (struct spc2000_ *)data;
+void spc2000_hwi_(struct dcpu16 *vm, struct dcpu16_hw *hw) {
+ struct spc2000_ *spc2000 = (struct spc2000_ *)hw->data;
DCPU16_WORD reg_a = vm->reg[DCPU16_REG_A],
reg_b = vm->reg[DCPU16_REG_B];
long long x;
|| vm->reg[DCPU16_REG_C] != 0)
break;
/* trigger */
- vm->warn_cb_("spc2000 triggered\n");
+ MSG_INFO(vm, "spc2000 triggered\n");
break;
case 1: /* SET_UNIT_TO_SKIP */
}
}
-struct dcpu16_hw *spc2000_new(struct dcpu16 *vm) {
- struct dcpu16_hw *hw;
-
- hw = calloc(1, sizeof *hw);
- if (hw == NULL) {
- vm->warn_cb_("%s():%s", "calloc", strerror(errno));
- return NULL;
- }
-
- memcpy(hw, &hw_, sizeof *hw);
-
- hw->data = calloc(1, sizeof(struct spc2000_));
- if (hw->data == NULL) {
- vm->warn_cb_("%s():%s", "calloc", strerror(errno));
- free(hw);
- return NULL;
- }
-
- hw->vm = vm;
+struct dcpu16_hw_module dcpu16_hw_module_spc2000 = {
+ .name_ = "SPC2000 - Suspension Chamber 2000",
- return hw;
-}
+ .id_l = 0x1d9d,
+ .id_h = 0x40e4,
+ .ver = 0x005e,
+ .mfg_l = 0x8b36,
+ .mfg_h = 0x1c6c,
+ .hwi = spc2000_hwi_,
+ .cycle = spc2000_cycle_,
+ .reset = spc2000_reset_,
-void spc2000_del(struct dcpu16_hw **hw) {
- if (hw) {
- if (*hw) {
- if ((*hw)->data) {
- free((*hw)->data);
- (*hw)->data = NULL;
- }
- free(*hw);
- *hw = NULL;
- }
- }
-}
+ .data_init = spc2000_data_init_,
+ .data_free = spc2000_data_free_,
+ .ctl = NULL,
+ .ctl_cmd = NULL,
+};