-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvdp.h
65 lines (51 loc) · 1.24 KB
/
vdp.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#ifndef _VDP_H_
#define _VDP_H_
/*
vdp1
mode 4 when m4 set and m1 reset
vdp2
mode 4 when m4 set and m2,m1 != 1,0
*/
/* Display timing (NTSC) */
#define MASTER_CLOCK 3579545
#define LINES_PER_FRAME 262
#define FRAMES_PER_SECOND 60
#define CYCLES_PER_LINE ((MASTER_CLOCK / FRAMES_PER_SECOND) / LINES_PER_FRAME)
/* VDP context */
typedef struct
{
uint8 vram[0x4000];
uint8 cram[0x40];
uint8 reg[0x10];
uint8 status;
uint8 latch;
uint8 pending;
uint8 buffer;
uint8 code;
uint16 addr;
int pn, ct, pg, sa, sg;
int ntab;
int satb;
int line;
int left;
uint8 height;
uint8 extended;
uint8 mode;
uint8 vint_pending;
uint8 hint_pending;
uint16 cram_latch;
uint8 bd;
} vdp_t;
/* Global data */
extern vdp_t vdp;
/* Function prototypes */
void vdp_init(void);
void vdp_shutdown(void);
void vdp_reset(void);
uint8 vdp_counter_r(int offset);
uint8 vdp_read(int offset);
void vdp_write(int offset, uint8 data);
void gg_vdp_write(int offset, uint8 data);
void md_vdp_write(int offset, uint8 data);
void tms_write(int offset, int data);
#endif /* _VDP_H_ */