]> Shamusworld >> Repos - virtualjaguar/blob - src/tom.h
0fb1f2e5e234682788c3044b5072457a1c158103
[virtualjaguar] / src / tom.h
1 //
2 // TOM Header file
3 //
4
5 #ifndef __TOM_H__
6 #define __TOM_H__
7
8 #include "memory.h"
9
10 #define VIDEO_MODE_16BPP_CRY    0
11 #define VIDEO_MODE_24BPP_RGB    1
12 #define VIDEO_MODE_16BPP_DIRECT 2
13 #define VIDEO_MODE_16BPP_RGB    3
14
15 // 68000 Interrupt bit positions (enabled at $F000E0)
16
17 enum { IRQ_VIDEO = 0, IRQ_GPU, IRQ_OPFLAG, IRQ_TIMER, IRQ_DSP };
18
19 void TOMInit(void);
20 void TOMReset(void);
21 void TOMDone(void);
22
23 uint8 TOMReadByte(uint32 offset, uint32 who = UNKNOWN);
24 uint16 TOMReadWord(uint32 offset, uint32 who = UNKNOWN);
25 void TOMWriteByte(uint32 offset, uint8 data, uint32 who = UNKNOWN);
26 void TOMWriteWord(uint32 offset, uint16 data, uint32 who = UNKNOWN);
27
28 void TOMExecHalfline(uint16 halfline, bool render);
29 uint32 TOMGetVideoModeWidth(void);
30 uint32 TOMGetVideoModeHeight(void);
31 uint8 TOMGetVideoMode(void);
32 uint8 * TOMGetRamPointer(void);
33 uint16 TOMGetHDB(void);
34 uint16 TOMGetVDB(void);
35
36 int TOMIRQEnabled(int irq);
37 uint16 TOMIRQControlReg(void);
38 void TOMSetIRQLatch(int irq, int enabled);
39 void TOMExecPIT(uint32 cycles);
40 void TOMSetPendingJERRYInt(void);
41 void TOMSetPendingTimerInt(void);
42 void TOMSetPendingObjectInt(void);
43 void TOMSetPendingGPUInt(void);
44 void TOMSetPendingVideoInt(void);
45 void TOMResetPIT(void);
46
47 // Exported variables
48
49 extern uint32 tomWidth;
50 extern uint32 tomHeight;
51 extern uint8 tomRam8[];
52 extern uint32 tomTimerPrescaler;
53 extern uint32 tomTimerDivider;
54 extern int32 tomTimerCounter;
55
56 extern uint32 screenPitch;
57 extern uint32 * screenBuffer;
58
59 #endif  // __TOM_H__