2019-01-21 05:27:24 +00:00
|
|
|
#include <ngp/ngp.hpp>
|
|
|
|
|
|
|
|
namespace NeoGeoPocket {
|
|
|
|
|
|
|
|
VPU vpu;
|
|
|
|
#include "serialization.cpp"
|
|
|
|
|
|
|
|
auto VPU::Enter() -> void {
|
|
|
|
while(true) scheduler.synchronize(), vpu.main();
|
|
|
|
}
|
|
|
|
|
|
|
|
auto VPU::main() -> void {
|
Update to v106r85 release.
byuu says:
The bad instruction was due to the instruction before it fetching one
too many bytes. Didn't notice right away as the disassembler got it
right.
The register map was incorrect on the active 16-bit flags.
I fixed and improved some other things along those lines. Hooked up some
basic KnGE (VPU) timings, made it print out VRAM and some of the WRAM
onto the screen each frame, tried to drive Vblank and Hblank IRQs, but
... I don't know for sure what vector addresses they belong to.
MAME says "INT4" for Vblank, and says nothing for Hblank. I am wildly
guessing INT4==SWI 4==0xffff10, but ... I have no idea. I'm also not
emulating the interrupts properly based on line levels, I'm just firing
on the 0→1 transitions. Sounds like Vblank is more nuanced too, but I
guess we'll see.
Emulation is running further along now, even to the point of it
successfully enabling the KnGE IRQs, but VRAM doesn't appear to get much
useful stuff written into it yet.
I reverted the nall/primitive changes, so request for testing is I guess
rescinded, for whatever it was worth.
2019-01-22 00:26:20 +00:00
|
|
|
cpu.setInterruptHblank(0);
|
|
|
|
for(uint hclock : range(480)) {
|
|
|
|
io.hcounter++;
|
|
|
|
step(1);
|
|
|
|
}
|
|
|
|
if(io.vcounter <= 150) {
|
|
|
|
if(ram[0x0000].bit(6)) cpu.setInterruptHblank(1);
|
|
|
|
}
|
|
|
|
for(uint hclock : range(35)) {
|
|
|
|
io.hcounter++;
|
|
|
|
step(1);
|
|
|
|
}
|
|
|
|
cpu.setInterruptHblank(0);
|
|
|
|
io.hcounter = 0;
|
|
|
|
io.vcounter++;
|
|
|
|
if(io.vcounter == 152) {
|
|
|
|
ram[0x0010].bit(6) = 1;
|
|
|
|
if(ram[0x0000].bit(7)) cpu.setInterruptVblank(1);
|
|
|
|
scheduler.exit(Scheduler::Event::Frame);
|
|
|
|
}
|
|
|
|
if(io.vcounter == 198) {
|
|
|
|
if(ram[0x0000].bit(6)) cpu.setInterruptHblank(1);
|
|
|
|
}
|
|
|
|
if(io.vcounter == 199) {
|
|
|
|
ram[0x0010].bit(6) = 0;
|
|
|
|
cpu.setInterruptVblank(0);
|
|
|
|
io.vcounter = 0;
|
|
|
|
}
|
2019-01-21 05:27:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
auto VPU::step(uint clocks) -> void {
|
|
|
|
Thread::step(clocks);
|
|
|
|
synchronize(cpu);
|
|
|
|
}
|
|
|
|
|
|
|
|
auto VPU::refresh() -> void {
|
Update to v106r85 release.
byuu says:
The bad instruction was due to the instruction before it fetching one
too many bytes. Didn't notice right away as the disassembler got it
right.
The register map was incorrect on the active 16-bit flags.
I fixed and improved some other things along those lines. Hooked up some
basic KnGE (VPU) timings, made it print out VRAM and some of the WRAM
onto the screen each frame, tried to drive Vblank and Hblank IRQs, but
... I don't know for sure what vector addresses they belong to.
MAME says "INT4" for Vblank, and says nothing for Hblank. I am wildly
guessing INT4==SWI 4==0xffff10, but ... I have no idea. I'm also not
emulating the interrupts properly based on line levels, I'm just firing
on the 0→1 transitions. Sounds like Vblank is more nuanced too, but I
guess we'll see.
Emulation is running further along now, even to the point of it
successfully enabling the KnGE IRQs, but VRAM doesn't appear to get much
useful stuff written into it yet.
I reverted the nall/primitive changes, so request for testing is I guess
rescinded, for whatever it was worth.
2019-01-22 00:26:20 +00:00
|
|
|
for(uint address : range(0x4000)) buffer[address] = ram[address];
|
|
|
|
for(uint address : range(0x1f00)) buffer[address + 0x4000] = cpu.ram[address + 0x3000 - 0x1f00];
|
2019-01-21 05:27:24 +00:00
|
|
|
Emulator::video.refresh(buffer, 160 * sizeof(uint32), 160, 152);
|
|
|
|
}
|
|
|
|
|
|
|
|
auto VPU::power() -> void {
|
|
|
|
create(VPU::Enter, system.frequency());
|
|
|
|
ram.allocate(0x4000);
|
Update to v106r85 release.
byuu says:
The bad instruction was due to the instruction before it fetching one
too many bytes. Didn't notice right away as the disassembler got it
right.
The register map was incorrect on the active 16-bit flags.
I fixed and improved some other things along those lines. Hooked up some
basic KnGE (VPU) timings, made it print out VRAM and some of the WRAM
onto the screen each frame, tried to drive Vblank and Hblank IRQs, but
... I don't know for sure what vector addresses they belong to.
MAME says "INT4" for Vblank, and says nothing for Hblank. I am wildly
guessing INT4==SWI 4==0xffff10, but ... I have no idea. I'm also not
emulating the interrupts properly based on line levels, I'm just firing
on the 0→1 transitions. Sounds like Vblank is more nuanced too, but I
guess we'll see.
Emulation is running further along now, even to the point of it
successfully enabling the KnGE IRQs, but VRAM doesn't appear to get much
useful stuff written into it yet.
I reverted the nall/primitive changes, so request for testing is I guess
rescinded, for whatever it was worth.
2019-01-22 00:26:20 +00:00
|
|
|
io = {};
|
2019-01-21 05:27:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|