Skip to content

Commit

Permalink
Implement DMA
Browse files Browse the repository at this point in the history
  • Loading branch information
maxfierke committed Jan 1, 2025
1 parent d418d78 commit e4abe6f
Showing 1 changed file with 50 additions and 6 deletions.
56 changes: 50 additions & 6 deletions devices/ppu.go
Original file line number Diff line number Diff line change
Expand Up @@ -365,6 +365,11 @@ const (
PPU_MODE_VRAM
)

type ppuDMARequest struct {
addr uint8
value byte
}

type PPU struct {
Mode PPUMode

Expand All @@ -387,14 +392,18 @@ type PPU struct {
vram [VRAM_SIZE]byte
tileset [VRAM_TILESET_SIZE]Tile

clock uint
clock uint
dmaClock uint
dmaEnabled bool
pendingDMA []*ppuDMARequest

ic *InterruptController
}

func NewPPU(ic *InterruptController) *PPU {
return &PPU{
ic: ic,
ic: ic,
pendingDMA: make([]*ppuDMARequest, 0, 160),
}
}

Expand Down Expand Up @@ -424,6 +433,23 @@ func (ppu *PPU) IsCurrentLineEqualToCompare() bool {
}

func (ppu *PPU) Step(cycles uint8) {
if ppu.dmaEnabled {
ppu.dmaClock += uint(cycles)

if ppu.dmaClock >= 640 {
ppu.dmaClock = 0

for _, request := range ppu.pendingDMA {
ppu.oam[request.addr] = request.value
ppu.writeObj(request.addr, request.value)
}

clear(ppu.pendingDMA)
ppu.pendingDMA = make([]*ppuDMARequest, 0, 160)
ppu.dmaEnabled = false
}
}

if !ppu.lcdCtrl.enabled {
return
}
Expand Down Expand Up @@ -583,10 +609,28 @@ func (ppu *PPU) OnWrite(mmu *mem.MMU, addr uint16, value byte) mem.MemWrite {
return mem.WriteBlock()
}

// if addr == REG_PPU_DMA {
// // TODO: Implement DMA
// return mem.WriteBlock()
// }
if addr == REG_PPU_DMA {
if ppu.dmaEnabled {
return mem.WriteBlock()
}

srcAddrStart := uint16(value) << 8

for oamAddr := uint8(0); oamAddr < 160; oamAddr++ {
srcAddr := srcAddrStart + uint16(oamAddr)
copiedValue := mmu.Read8(srcAddr)

ppu.pendingDMA = append(ppu.pendingDMA,
&ppuDMARequest{
addr: oamAddr,
value: copiedValue,
},
)
}
ppu.dmaEnabled = true

return mem.WriteBlock()
}

if addr == REG_PPU_BGP {
ppu.bgPalette.Write(value)
Expand Down

0 comments on commit e4abe6f

Please sign in to comment.