* HBlank flag and IRQ.

* VBlank and HBlank DMA.
This commit is contained in:
StapleButter 2017-02-03 18:47:40 +01:00
parent f4335b9292
commit 1f691f3795
6 changed files with 46 additions and 16 deletions

View File

@ -89,8 +89,9 @@ void DMA::WriteCnt(u32 val)
Start(); Start();
//else //else
// printf("SPECIAL ARM%d DMA%d START MODE %02X\n", CPU?7:9, Num, StartMode); // printf("SPECIAL ARM%d DMA%d START MODE %02X\n", CPU?7:9, Num, StartMode);
if (StartMode!=0x00 && StartMode!=0x10 && StartMode!=0x05 && StartMode!=0x12) if ((StartMode&7)!=0x00 && (StartMode&7)!=0x1 && StartMode!=2 && StartMode!=0x05 && StartMode!=0x12)
printf("UNIMPLEMENTED ARM%d DMA%d START MODE %02X\n", CPU?7:9, Num, StartMode); printf("UNIMPLEMENTED ARM%d DMA%d START MODE %02X\n", CPU?7:9, Num, StartMode);
//if (StartMode==2)printf("HBLANK DMA %08X -> %08X\n", SrcAddr, DstAddr);
} }
} }
@ -106,13 +107,13 @@ void DMA::Start()
if (!RemCount) if (!RemCount)
RemCount = countmask+1; RemCount = countmask+1;
if ((Cnt & 0x00060000) == 0x00060000) if ((Cnt & 0x00600000) == 0x00600000)
CurDstAddr = DstAddr; CurDstAddr = DstAddr;
// special path for cart DMA. this is a gross hack. // special path for cart DMA. this is a gross hack.
// emulating it properly requires emulating cart transfer delays, so uh... TODO // emulating it properly requires emulating cart transfer delays, so uh... TODO
if (CurSrcAddr==0x04100010 && RemCount==1 && (Cnt & 0x07E00000)==0x07000000 && if (CurSrcAddr==0x04100010 && RemCount==1 && (Cnt & 0x07E00000)==0x07000000 &&
((CPU==0 && StartMode==0x05) || (CPU==1 && StartMode==0x12))) StartMode==0x05 || StartMode==0x12)
{ {
NDSCart::DMA(CurDstAddr); NDSCart::DMA(CurDstAddr);
Cnt &= ~0x80000000; Cnt &= ~0x80000000;

28
GPU.cpp
View File

@ -26,6 +26,7 @@ namespace GPU
{ {
#define LINE_CYCLES (355*6) #define LINE_CYCLES (355*6)
#define HBLANK_CYCLES (256*6)
#define FRAME_CYCLES (LINE_CYCLES * 263) #define FRAME_CYCLES (LINE_CYCLES * 263)
u16 VCount; u16 VCount;
@ -756,10 +757,27 @@ void StartFrame()
StartScanline(0); StartScanline(0);
} }
void StartHBlank(u32 line)
{
DispStat[0] |= (1<<1);
DispStat[1] |= (1<<1);
NDS::CheckDMAs(0, 0x02);
if (DispStat[0] & (1<<4)) NDS::TriggerIRQ(0, NDS::IRQ_HBlank);
if (DispStat[1] & (1<<4)) NDS::TriggerIRQ(1, NDS::IRQ_HBlank);
if (line < 262)
NDS::ScheduleEvent(NDS::Event_LCD, true, (LINE_CYCLES - HBLANK_CYCLES), StartScanline, line+1);
}
void StartScanline(u32 line) void StartScanline(u32 line)
{ {
VCount = line; VCount = line;
DispStat[0] &= ~(1<<1);
DispStat[1] &= ~(1<<1);
if (line == VMatch[0]) if (line == VMatch[0])
{ {
DispStat[0] |= (1<<2); DispStat[0] |= (1<<2);
@ -785,7 +803,6 @@ void StartScanline(u32 line)
GPU2D_B->DrawScanline(line); GPU2D_B->DrawScanline(line);
//NDS::ScheduleEvent(LINE_CYCLES, StartScanline, line+1); //NDS::ScheduleEvent(LINE_CYCLES, StartScanline, line+1);
NDS::ScheduleEvent(NDS::Event_ScanlineStart, true, LINE_CYCLES, StartScanline, line+1);
} }
else if (line == 262) else if (line == 262)
{ {
@ -802,13 +819,18 @@ void StartScanline(u32 line)
DispStat[0] |= (1<<0); DispStat[0] |= (1<<0);
DispStat[1] |= (1<<0); DispStat[1] |= (1<<0);
NDS::CheckDMAs(0, 0x01);
NDS::CheckDMAs(1, 0x11);
if (DispStat[0] & (1<<3)) NDS::TriggerIRQ(0, NDS::IRQ_VBlank); if (DispStat[0] & (1<<3)) NDS::TriggerIRQ(0, NDS::IRQ_VBlank);
if (DispStat[1] & (1<<3)) NDS::TriggerIRQ(1, NDS::IRQ_VBlank); if (DispStat[1] & (1<<3)) NDS::TriggerIRQ(1, NDS::IRQ_VBlank);
} }
//NDS::ScheduleEvent(LINE_CYCLES, StartScanline, line+1); //NDS::ScheduleEvent(LINE_CYCLES, StartScanline, line+1);
NDS::ScheduleEvent(NDS::Event_ScanlineStart, true, LINE_CYCLES, StartScanline, line+1); //NDS::ScheduleEvent(NDS::Event_LCD, true, LINE_CYCLES, StartScanline, line+1);
} }
NDS::ScheduleEvent(NDS::Event_LCD, true, HBLANK_CYCLES, StartHBlank, line);
} }
@ -819,8 +841,6 @@ void SetDispStat(u32 cpu, u16 val)
DispStat[cpu] |= val; DispStat[cpu] |= val;
VMatch[cpu] = (val >> 8) | ((val & 0x80) << 1); VMatch[cpu] = (val >> 8) | ((val & 0x80) << 1);
if (val & 0x10) printf("!! HBLANK ENABLED\n");
} }
} }

View File

@ -1679,7 +1679,7 @@ void ARM9IOWrite32(u32 addr, u32 val)
case 0x040001B4: *(u32*)&ROMSeed1[0] = val; return; case 0x040001B4: *(u32*)&ROMSeed1[0] = val; return;
case 0x04000208: IME[0] = val & 0x1; return; case 0x04000208: IME[0] = val & 0x1; return;
case 0x04000210: IE[0] = val; if (val&~0x000F0F7D)printf("unusual IRQ %08X\n",val);return; case 0x04000210: IE[0] = val; if (val&~0x000F0F7F)printf("unusual IRQ %08X\n",val);return;
case 0x04000214: IF[0] &= ~val; return; case 0x04000214: IF[0] &= ~val; return;
case 0x04000240: case 0x04000240:

2
NDS.h
View File

@ -38,7 +38,7 @@ typedef struct _SchedEvent
enum enum
{ {
Event_ScanlineStart = 0, Event_LCD = 0,
Event_Timer9_0, Event_Timer9_0,
Event_Timer9_1, Event_Timer9_1,

View File

@ -40,7 +40,6 @@ LRESULT CALLBACK derpo(HWND window, UINT msg, WPARAM wparam, LPARAM lparam)
case WM_CLOSE: case WM_CLOSE:
printf("close\n"); printf("close\n");
{ {
// 6006800 6008000
FILE* f = fopen("debug/wram.bin", "wb"); FILE* f = fopen("debug/wram.bin", "wb");
if (f) if (f)
{ {
@ -51,6 +50,16 @@ LRESULT CALLBACK derpo(HWND window, UINT msg, WPARAM wparam, LPARAM lparam)
} }
fclose(f); fclose(f);
} }
f = fopen("debug/arm7vram.bin", "wb");
if (f)
{
for (u32 i = 0x6000000; i < 0x6040000; i+=4)
{
u32 blarg = NDS::ARM7Read32(i);
fwrite(&blarg, 4, 1, f);
}
fclose(f);
}
f = fopen("debug/mainram.bin", "wb"); f = fopen("debug/mainram.bin", "wb");
if (f) if (f)
{ {

View File

@ -1,16 +1,16 @@
# depslib dependency file v1.0 # depslib dependency file v1.0
1486086940 source:c:\documents\sources\melonds\main.cpp 1486141269 source:c:\documents\sources\melonds\main.cpp
<stdio.h> <stdio.h>
<windows.h> <windows.h>
"NDS.h" "NDS.h"
"GPU.h" "GPU.h"
1485981187 c:\documents\sources\melonds\nds.h 1486142800 c:\documents\sources\melonds\nds.h
"types.h" "types.h"
1481161027 c:\documents\sources\melonds\types.h 1481161027 c:\documents\sources\melonds\types.h
1486135026 source:c:\documents\sources\melonds\nds.cpp 1486143063 source:c:\documents\sources\melonds\nds.cpp
<stdio.h> <stdio.h>
<string.h> <string.h>
"NDS.h" "NDS.h"
@ -86,7 +86,7 @@
"NDS.h" "NDS.h"
"SPI.h" "SPI.h"
1485994573 source:c:\documents\sources\melonds\gpu2d.cpp 1486143936 source:c:\documents\sources\melonds\gpu2d.cpp
<stdio.h> <stdio.h>
<string.h> <string.h>
"NDS.h" "NDS.h"
@ -108,7 +108,7 @@
1484612398 c:\documents\sources\melonds\fifo.h 1484612398 c:\documents\sources\melonds\fifo.h
"types.h" "types.h"
1486093630 source:c:\documents\sources\melonds\dma.cpp 1486143294 source:c:\documents\sources\melonds\dma.cpp
<stdio.h> <stdio.h>
"NDS.h" "NDS.h"
"DMA.h" "DMA.h"
@ -117,7 +117,7 @@
1484698068 c:\documents\sources\melonds\dma.h 1484698068 c:\documents\sources\melonds\dma.h
"types.h" "types.h"
1485990504 source:c:\documents\sources\melonds\gpu.cpp 1486142983 source:c:\documents\sources\melonds\gpu.cpp
<stdio.h> <stdio.h>
<string.h> <string.h>
"NDS.h" "NDS.h"