Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
alexbevi
GitHub Repository: alexbevi/BizHawk
Path: blob/master/libsnes/bsnes/snes/alt/smp/smp.cpp
2 views
1
#define CYCLE_ACCURATE
2
3
#include <snes/snes.hpp>
4
5
#define SMP_CPP
6
namespace SNES {
7
8
SMP smp;
9
10
#include "algorithms.cpp"
11
#include "core.cpp"
12
#include "iplrom.cpp"
13
#include "memory.cpp"
14
#include "timing.cpp"
15
16
void SMP::synchronize_cpu() {
17
if(CPU::Threaded == true) {
18
//if(clock >= 0 && scheduler.sync != Scheduler::SynchronizeMode::All) co_switch(cpu.thread);
19
} else {
20
while(clock >= 0) cpu.enter();
21
}
22
}
23
24
void SMP::synchronize_dsp() {
25
if(DSP::Threaded == true) {
26
//if(dsp.clock < 0 && scheduler.sync != Scheduler::SynchronizeMode::All) co_switch(dsp.thread);
27
} else {
28
while(dsp.clock < 0) dsp.enter();
29
}
30
}
31
32
void SMP::enter() {
33
while(clock < 0) op_step();
34
}
35
36
void SMP::power() {
37
Processor::frequency = system.apu_frequency();
38
Processor::clock = 0;
39
40
timer0.target = 0;
41
timer1.target = 0;
42
timer2.target = 0;
43
44
for(unsigned n = 0; n < 256; n++) {
45
cycle_table_dsp[n] = (cycle_count_table[n] * 24);
46
cycle_table_cpu[n] = (cycle_count_table[n] * 24) * cpu.frequency;
47
}
48
49
cycle_step_cpu = 24 * cpu.frequency;
50
51
reset();
52
}
53
54
void SMP::reset() {
55
for(unsigned n = 0x0000; n <= 0xffff; n++) apuram[n] = 0x00;
56
57
opcode_number = 0;
58
opcode_cycle = 0;
59
60
regs.pc = 0xffc0;
61
regs.sp = 0xef;
62
regs.a = 0x00;
63
regs.x = 0x00;
64
regs.y = 0x00;
65
regs.p = 0x02;
66
67
//$00f1
68
status.iplrom_enable = true;
69
70
//$00f2
71
status.dsp_addr = 0x00;
72
73
//$00f8,$00f9
74
status.ram00f8 = 0x00;
75
status.ram00f9 = 0x00;
76
77
//timers
78
timer0.enable = timer1.enable = timer2.enable = false;
79
timer0.stage1_ticks = timer1.stage1_ticks = timer2.stage1_ticks = 0;
80
timer0.stage2_ticks = timer1.stage2_ticks = timer2.stage2_ticks = 0;
81
timer0.stage3_ticks = timer1.stage3_ticks = timer2.stage3_ticks = 0;
82
}
83
84
void SMP::serialize(serializer &s) {
85
Processor::serialize(s);
86
87
s.array(apuram, 64 * 1024);
88
89
s.integer(opcode_number);
90
s.integer(opcode_cycle);
91
92
s.integer(regs.pc);
93
s.integer(regs.sp);
94
s.integer(regs.a);
95
s.integer(regs.x);
96
s.integer(regs.y);
97
98
s.integer(regs.p.n);
99
s.integer(regs.p.v);
100
s.integer(regs.p.p);
101
s.integer(regs.p.b);
102
s.integer(regs.p.h);
103
s.integer(regs.p.i);
104
s.integer(regs.p.z);
105
s.integer(regs.p.c);
106
107
s.integer(rd);
108
s.integer(wr);
109
s.integer(dp);
110
s.integer(sp);
111
s.integer(ya);
112
s.integer(bit);
113
114
s.integer(status.iplrom_enable);
115
116
s.integer(status.dsp_addr);
117
118
s.integer(status.ram00f8);
119
s.integer(status.ram00f9);
120
121
s.integer(timer0.enable);
122
s.integer(timer0.target);
123
s.integer(timer0.stage1_ticks);
124
s.integer(timer0.stage2_ticks);
125
s.integer(timer0.stage3_ticks);
126
127
s.integer(timer1.enable);
128
s.integer(timer1.target);
129
s.integer(timer1.stage1_ticks);
130
s.integer(timer1.stage2_ticks);
131
s.integer(timer1.stage3_ticks);
132
133
s.integer(timer2.enable);
134
s.integer(timer2.target);
135
136
s.integer(timer2.stage1_ticks);
137
s.integer(timer2.stage2_ticks);
138
s.integer(timer2.stage3_ticks);
139
}
140
141
SMP::SMP() :
142
apuram(nullptr)
143
{
144
145
}
146
147
SMP::~SMP() {
148
interface()->freeSharedMemory(apuram);
149
}
150
151
void SMP::initialize()
152
{
153
apuram = (uint8*)interface()->allocSharedMemory("APURAM", 64 * 1024);
154
}
155
156
157
158
}
159
160