summaryrefslogtreecommitdiff
path: root/src/sim86.h
diff options
context:
space:
mode:
authorRaymaekers Luca <luca@spacehb.net>2025-10-24 12:58:52 +0200
committerRaymaekers Luca <luca@spacehb.net>2025-10-24 12:58:52 +0200
commit856fd58549e5bf50e800a665f9deb27d967df2fb (patch)
tree6950210e5ae3618b501a7045f10f8fc06dd903df /src/sim86.h
parentd8b3ca9d02377cf04a09e0f518a3385b7324bc4d (diff)
checkpoint
Diffstat (limited to 'src/sim86.h')
-rw-r--r--src/sim86.h38
1 files changed, 38 insertions, 0 deletions
diff --git a/src/sim86.h b/src/sim86.h
new file mode 100644
index 0000000..d24cb70
--- /dev/null
+++ b/src/sim86.h
@@ -0,0 +1,38 @@
+/* date = August 13th 2025 1:51 pm */
+
+#ifndef SIM86_H
+#define SIM86_H
+
+#define internal static
+#define global_variable static
+#define local_persist static
+
+typedef size_t psize;
+
+#define Assert(Expression) if(!(Expression)) { __asm__ volatile("int3"); }
+#define ArrayCount(Array) (sizeof(Array) / sizeof((Array)[0]))
+
+//~ Stolen from the decoder.
+enum register_mapping_8086
+{
+ Register_none,
+
+ Register_a,
+ Register_b,
+ Register_c,
+ Register_d,
+ Register_sp,
+ Register_bp,
+ Register_si,
+ Register_di,
+ Register_es,
+ Register_cs,
+ Register_ss,
+ Register_ds,
+ Register_ip,
+ Register_flags,
+
+ Register_count,
+};
+
+#endif //SIM86_H