blob: 91a165bbf1ee1a9afd23499fab96fe718d3fa4fc (
plain)
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
#include "../copyright"
#ifndef _65c816_h_
#define _65c816_h_
#define AL A.B.l
#define AH A.B.h
#define XL X.B.l
#define XH X.B.h
#define YL Y.B.l
#define YH Y.B.h
#define SL S.B.l
#define SH S.B.h
#define DL D.B.l
#define DH D.B.h
#define PL P.B.l
#define PH P.B.h
#define Carry 1
#define Zero 2
#define IRQ 4
#define Decimal 8
#define IndexFlag 16
#define MemoryFlag 32
#define Overflow 64
#define Negative 128
#define Emulation 256
#define SetCarry() (ICPU._Carry = 1)
#define ClearCarry() (ICPU._Carry = 0)
#define SetZero() (ICPU._Zero = 0)
#define ClearZero() (ICPU._Zero = 1)
#define SetIRQ() (ICPU.Registers.PL |= IRQ)
#define ClearIRQ() (ICPU.Registers.PL &= ~IRQ)
#define SetDecimal() (ICPU.Registers.PL |= Decimal)
#define ClearDecimal() (ICPU.Registers.PL &= ~Decimal)
#define SetIndex() (ICPU.Registers.PL |= IndexFlag)
#define ClearIndex() (ICPU.Registers.PL &= ~IndexFlag)
#define SetMemory() (ICPU.Registers.PL |= MemoryFlag)
#define ClearMemory() (ICPU.Registers.PL &= ~MemoryFlag)
#define SetOverflow() (ICPU._Overflow = 1)
#define ClearOverflow() (ICPU._Overflow = 0)
#define SetNegative() (ICPU._Negative = 0x80)
#define ClearNegative() (ICPU._Negative = 0)
#define CheckCarry() (ICPU._Carry)
#define CheckZero() (ICPU._Zero == 0)
#define CheckIRQ() (ICPU.Registers.PL & IRQ)
#define CheckDecimal() (ICPU.Registers.PL & Decimal)
#define CheckIndex() (ICPU.Registers.PL & IndexFlag)
#define CheckMemory() (ICPU.Registers.PL & MemoryFlag)
#define CheckOverflow() (ICPU._Overflow)
#define CheckNegative() (ICPU._Negative & 0x80)
#define CheckEmulation() (ICPU.Registers.P.W & Emulation)
#define SetFlags(f) (ICPU.Registers.P.W |= (f))
#define ClearFlags(f) (ICPU.Registers.P.W &= ~(f))
#define CheckFlag(f) (ICPU.Registers.PL & (f))
typedef union
{
struct
{
#ifdef MSB_FIRST
uint8_t h, l;
#else
uint8_t l, h;
#endif
} B;
uint16_t W;
} pair;
typedef struct
{
uint8_t PB;
uint8_t DB;
pair P;
pair A;
pair D;
pair S;
pair X;
pair Y;
uint16_t PC;
} SRegisters;
#endif
|