mirror of
https://github.com/ivanizag/izapple2.git
synced 2025-01-02 20:29:44 +00:00
Name all the memory segments
This commit is contained in:
parent
634a079857
commit
8ebd745a63
@ -78,7 +78,7 @@ func (a *Apple2) LoadRom(filename string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
romBase := 0x10000 - size
|
romBase := 0x10000 - size
|
||||||
a.mmu.physicalROM[0] = newMemoryRangeROM(uint16(romBase), data)
|
a.mmu.physicalROM[0] = newMemoryRangeROM(uint16(romBase), data, "Main ROM")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ func loadBase64aRom(a *Apple2) error {
|
|||||||
|
|
||||||
// Create banks
|
// Create banks
|
||||||
for j := range romBanksBytes {
|
for j := range romBanksBytes {
|
||||||
a.mmu.physicalROM[j] = newMemoryRange(0xd000, romBanksBytes[j])
|
a.mmu.physicalROM[j] = newMemoryRange(0xd000, romBanksBytes[j], fmt.Sprintf("Base64 ROM page %v", j))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Start with first bank active
|
// Start with first bank active
|
||||||
|
@ -23,16 +23,16 @@ func (c *cardBase) loadRom(data []uint8) {
|
|||||||
}
|
}
|
||||||
if len(data) == 0x100 {
|
if len(data) == 0x100 {
|
||||||
// Just 256 bytes in Cs00
|
// Just 256 bytes in Cs00
|
||||||
c.romCsxx = newMemoryRangeROM(0, data)
|
c.romCsxx = newMemoryRangeROM(0, data, "Slot ROM")
|
||||||
} else if len(data) == 0x800 {
|
} else if len(data) == 0x800 {
|
||||||
// The file has C800 to C8FF
|
// The file has C800 to C8FF
|
||||||
// The 256 bytes in Cx00 are copied from the first page in C800
|
// The 256 bytes in Cx00 are copied from the first page in C800
|
||||||
c.romCsxx = newMemoryRangeROM(0, data)
|
c.romCsxx = newMemoryRangeROM(0, data, "Slor ROM")
|
||||||
c.romC8xx = newMemoryRangeROM(0xc800, data)
|
c.romC8xx = newMemoryRangeROM(0xc800, data, "Slot C8 ROM")
|
||||||
} else if len(data) == 0x1000 {
|
} else if len(data) == 0x1000 {
|
||||||
// The file covers the full Cxxx range. Only showing the page
|
// The file covers the full Cxxx range. Only showing the page
|
||||||
// corresponding to the slot used.
|
// corresponding to the slot used.
|
||||||
c.romCxxx = newMemoryRangeROM(0xc000, data)
|
c.romCxxx = newMemoryRangeROM(0xc000, data, "Slot ROM")
|
||||||
} else {
|
} else {
|
||||||
panic("Invalid ROM size")
|
panic("Invalid ROM size")
|
||||||
}
|
}
|
||||||
|
@ -71,10 +71,10 @@ func (c *cardInOut) assign(a *Apple2, slot int) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
c.romCsxx = newMemoryRangeROM(0xC200, data[0:255])
|
c.romCsxx = newMemoryRangeROM(0xC200, data[0:255], "InOUt card")
|
||||||
|
|
||||||
if slot != 2 {
|
if slot != 2 {
|
||||||
// To make ifwork on other slots, patch C2, A0 and A1
|
// To make it work on other slots, patch C2, A0 and A1
|
||||||
panic("Assert failed. Only slot 2 supported for the InOut card")
|
panic("Assert failed. Only slot 2 supported for the InOut card")
|
||||||
}
|
}
|
||||||
c.cardBase.assign(a, slot)
|
c.cardBase.assign(a, slot)
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package apple2
|
package apple2
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
// See https://fabiensanglard.net/fd_proxy/prince_of_persia/Inside%20the%20Apple%20IIe.pdf
|
// See https://fabiensanglard.net/fd_proxy/prince_of_persia/Inside%20the%20Apple%20IIe.pdf
|
||||||
// See https://i.stack.imgur.com/yn21s.gif
|
// See https://i.stack.imgur.com/yn21s.gif
|
||||||
|
|
||||||
@ -72,7 +74,7 @@ type memoryHandler interface {
|
|||||||
func newMemoryManager(a *Apple2) *memoryManager {
|
func newMemoryManager(a *Apple2) *memoryManager {
|
||||||
var mmu memoryManager
|
var mmu memoryManager
|
||||||
mmu.apple2 = a
|
mmu.apple2 = a
|
||||||
mmu.physicalMainRAM = newMemoryRange(0, make([]uint8, 0xc000))
|
mmu.physicalMainRAM = newMemoryRange(0, make([]uint8, 0xc000), "Main RAM")
|
||||||
|
|
||||||
mmu.slotC3ROMActive = true // For II+, this is the default behaviour
|
mmu.slotC3ROMActive = true // For II+, this is the default behaviour
|
||||||
|
|
||||||
@ -138,23 +140,6 @@ func (mmu *memoryManager) getVideoRAM(ext bool) *memoryRange {
|
|||||||
return mmu.physicalMainRAM
|
return mmu.physicalMainRAM
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mmu *memoryManager) accessReadCached(address uint16) memoryHandler {
|
|
||||||
page := address & 0xff00
|
|
||||||
if address&0xff00 == mmu.lastAddressPage {
|
|
||||||
//fmt.Printf(" hit %v\n", mmu.apple2.cpu.GetCycles())
|
|
||||||
return mmu.lastAddressHandler
|
|
||||||
}
|
|
||||||
|
|
||||||
//fmt.Printf("Not hit %v\n", mmu.apple2.cpu.GetCycles())
|
|
||||||
mh := mmu.accessRead(address)
|
|
||||||
if address&0xf000 != 0xc000 {
|
|
||||||
// Do not cache 0xC area as it may reconfigure the MMU
|
|
||||||
mmu.lastAddressPage = page
|
|
||||||
mmu.lastAddressHandler = mh
|
|
||||||
}
|
|
||||||
return mh
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mmu *memoryManager) accessRead(address uint16) memoryHandler {
|
func (mmu *memoryManager) accessRead(address uint16) memoryHandler {
|
||||||
if address <= addressLimitZero {
|
if address <= addressLimitZero {
|
||||||
return mmu.getPhysicalMainRAM(mmu.altZeroPage)
|
return mmu.getPhysicalMainRAM(mmu.altZeroPage)
|
||||||
@ -266,8 +251,8 @@ func (mmu *memoryManager) initLanguageRAM(groups uint8) {
|
|||||||
mmu.physicalLangRAM = make([]*memoryRange, groups)
|
mmu.physicalLangRAM = make([]*memoryRange, groups)
|
||||||
mmu.physicalLangAltRAM = make([]*memoryRange, groups)
|
mmu.physicalLangAltRAM = make([]*memoryRange, groups)
|
||||||
for i := uint8(0); i < groups; i++ {
|
for i := uint8(0); i < groups; i++ {
|
||||||
mmu.physicalLangRAM[i] = newMemoryRange(0xd000, make([]uint8, 0x3000))
|
mmu.physicalLangRAM[i] = newMemoryRange(0xd000, make([]uint8, 0x3000), fmt.Sprintf("LC RAM block %v", i))
|
||||||
mmu.physicalLangAltRAM[i] = newMemoryRange(0xd000, make([]uint8, 0x1000))
|
mmu.physicalLangAltRAM[i] = newMemoryRange(0xd000, make([]uint8, 0x1000), fmt.Sprintf("LC RAM Alt block %v", i))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -276,8 +261,8 @@ func (mmu *memoryManager) initExtendedRAM(groups int) {
|
|||||||
mmu.physicalExtRAM = make([]*memoryRange, groups)
|
mmu.physicalExtRAM = make([]*memoryRange, groups)
|
||||||
mmu.physicalExtAltRAM = make([]*memoryRange, groups)
|
mmu.physicalExtAltRAM = make([]*memoryRange, groups)
|
||||||
for i := 0; i < groups; i++ {
|
for i := 0; i < groups; i++ {
|
||||||
mmu.physicalExtRAM[i] = newMemoryRange(0, make([]uint8, 0x10000))
|
mmu.physicalExtRAM[i] = newMemoryRange(0, make([]uint8, 0x10000), fmt.Sprintf("Extra RAM block %v", i))
|
||||||
mmu.physicalExtAltRAM[i] = newMemoryRange(0xd000, make([]uint8, 0x1000))
|
mmu.physicalExtAltRAM[i] = newMemoryRange(0xd000, make([]uint8, 0x1000), fmt.Sprintf("Extra RAM Alt block %v", i))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,28 +1,40 @@
|
|||||||
package apple2
|
package apple2
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
type memoryRange struct {
|
type memoryRange struct {
|
||||||
base uint16
|
base uint16
|
||||||
data []uint8
|
data []uint8
|
||||||
basePtr uintptr
|
name string
|
||||||
|
address string
|
||||||
|
//basePtr uintptr
|
||||||
}
|
}
|
||||||
|
|
||||||
type memoryRangeROM struct {
|
type memoryRangeROM struct {
|
||||||
memoryRange
|
memoryRange
|
||||||
}
|
}
|
||||||
|
|
||||||
func newMemoryRange(base uint16, data []uint8) *memoryRange {
|
func newMemoryRange(base uint16, data []uint8, name string) *memoryRange {
|
||||||
var m memoryRange
|
var m memoryRange
|
||||||
m.base = base
|
m.base = base
|
||||||
m.data = data
|
m.data = data
|
||||||
m.setBase(base)
|
m.setBase(base)
|
||||||
|
|
||||||
|
m.name = name
|
||||||
|
m.address = fmt.Sprintf("%p", &m)
|
||||||
return &m
|
return &m
|
||||||
}
|
}
|
||||||
|
|
||||||
func newMemoryRangeROM(base uint16, data []uint8) *memoryRangeROM {
|
func newMemoryRangeROM(base uint16, data []uint8, name string) *memoryRangeROM {
|
||||||
var m memoryRangeROM
|
var m memoryRangeROM
|
||||||
m.base = base
|
m.base = base
|
||||||
m.data = data
|
m.data = data
|
||||||
m.setBase(base)
|
m.setBase(base)
|
||||||
|
|
||||||
|
m.name = name
|
||||||
|
m.address = fmt.Sprintf("%p", &m)
|
||||||
return &m
|
return &m
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,3 +68,17 @@ func (m *memoryRange) subRange(a, b uint16) []uint8 {
|
|||||||
func (m *memoryRangeROM) poke(address uint16, value uint8) {
|
func (m *memoryRangeROM) poke(address uint16, value uint8) {
|
||||||
// Ignore
|
// Ignore
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func identifyMemory(m memoryHandler) string {
|
||||||
|
ram, ok := m.(*memoryRange)
|
||||||
|
if ok {
|
||||||
|
return fmt.Sprintf("RAM 0x%04x %s at %s", ram.base, ram.name, ram.address)
|
||||||
|
}
|
||||||
|
|
||||||
|
rom, ok := m.(*memoryRangeROM)
|
||||||
|
if ok {
|
||||||
|
return fmt.Sprintf("ROM 0x%04x %s at %s", rom.base, ram.name, rom.address)
|
||||||
|
}
|
||||||
|
|
||||||
|
return ("Unknown memory")
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user