summary refs log tree commit diff
path: root/src/6522.h
diff options
context:
space:
mode:
authorMaxwell Beck <max@rastertail.net>2024-12-24 10:54:02 -0600
committerMaxwell Beck <max@rastertail.net>2024-12-24 10:54:02 -0600
commitc684c194bccdb08df75423680ba334739a945fe5 (patch)
treeea052b7f413936629421fbb784aaea1dedb8133c /src/6522.h
Initial commit
Diffstat (limited to 'src/6522.h')
-rw-r--r--src/6522.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/6522.h b/src/6522.h
new file mode 100644
index 0000000..5582ba3
--- /dev/null
+++ b/src/6522.h
@@ -0,0 +1,40 @@
+#ifndef MOS6522_H
+#define MOS6522_H
+
+#include <stdint.h>
+#include <stdbool.h>
+
+typedef struct via_s {
+	uint8_t ira;
+	uint8_t irb;
+	uint8_t ora;
+	uint8_t orb;
+	uint8_t ddra;
+	uint8_t ddrb;
+	uint16_t tca;
+	uint16_t tcb;
+	uint16_t tla;
+	uint16_t tlb;
+	uint8_t acr;
+	uint8_t pcr;
+	uint8_t ifr;
+	uint8_t ier;
+	uint8_t latch_a;
+	uint8_t latch_b;
+
+	bool tav;
+	bool tbv;
+} via_t;
+
+extern void via_pa_read(via_t *via, uint8_t cycle);
+extern void via_pb_read(via_t *via, uint8_t cycle);
+extern void via_pa_write(via_t *via, uint8_t cycle);
+extern void via_pb_write(via_t *via, uint8_t cycle);
+
+void via_init(via_t *via);
+void via_read(via_t *via, uint8_t addr, uint8_t *v, uint8_t cycle);
+void via_write(via_t *via, uint8_t addr, uint8_t v, uint8_t cycle);
+void via_cycle(via_t *via, uint8_t cycles);
+bool via_irq(via_t *via);
+
+#endif
\ No newline at end of file