chip-8/src/vcpu.h

39 lines
759 B
C
Raw Normal View History

2023-12-25 07:24:17 +01:00
#pragma once
2023-12-25 09:25:14 +01:00
#define REG_FLAG 0xF
2023-12-25 07:24:17 +01:00
typedef struct VCPU_State {
2023-12-25 07:32:11 +01:00
// Program Counter (16 bits but only 12 bits used (4096 memory addresses))
unsigned short PC;
// Index register (16 bits but only 12 bits used (4096 memory addresses))
unsigned short I;
// Stack register (16 bits)
unsigned short S;
// General purpose registers (8 bits each)
// Note last one often used as a flag register
unsigned char V[16];
// Delay timer (8 bits)
unsigned char DT;
// Sound timer (8 bits)
unsigned char ST;
// Intruction (opcode + decoded fields)
2023-12-25 09:11:45 +01:00
unsigned short opcode;
2023-12-25 07:24:17 +01:00
char X;
char Y;
char N;
char NN;
2023-12-25 09:11:45 +01:00
unsigned short NNN;
2023-12-25 07:24:17 +01:00
} VCPU_State;
void VCPUInit();
void VCPUFetch();
void VCPUDecode();
void VCPUExecute();
2023-12-25 09:11:45 +01:00
void VCPUDump();