izapple2/softSwitches2e.go

91 lines
3.0 KiB
Go
Raw Normal View History

2020-10-03 23:38:26 +02:00
package izapple2
2019-10-21 00:00:42 +02:00
/*
See:
https://www.apple.asimov.net/documentation/hardware/machines/APPLE%20IIe%20Auxiliary%20Memory%20Softswitches.pdf
*/
const (
2019-11-04 00:23:03 +01:00
ioFlagAltChar uint8 = 0x1E
ioFlag80Col uint8 = 0x1F
2019-11-11 22:58:42 +01:00
)
const (
screenDrawCycles = uint64(12480 + 4550)
screenVertBlankingCycles = uint64(4550)
)
2019-02-24 15:05:50 +01:00
func addApple2ESoftSwitches(io *ioC0Page) {
2019-10-12 21:37:37 +02:00
// New MMU read softswithes
2019-11-04 00:23:03 +01:00
mmu := io.apple2.mmu
addSoftSwitchesMmu(io, 0x02, 0x03, 0x13, &mmu.altMainRAMActiveRead, "RAMRD")
addSoftSwitchesMmu(io, 0x04, 0x05, 0x14, &mmu.altMainRAMActiveWrite, "RAMWRT")
2019-11-06 00:02:03 +01:00
addSoftSwitchesMmu(io, 0x06, 0x07, 0x15, &mmu.intCxROMActive, "INTCXROM")
2019-11-04 00:23:03 +01:00
addSoftSwitchesMmu(io, 0x08, 0x09, 0x16, &mmu.altZeroPage, "ALTZP")
2019-11-06 00:02:03 +01:00
addSoftSwitchesMmu(io, 0x0a, 0x0b, 0x17, &mmu.slotC3ROMActive, "SLOTC3ROM")
2020-08-30 18:59:00 +02:00
mmu.slotC3ROMActive = false // Default behavior in II+ was true
2019-11-08 23:56:54 +01:00
addSoftSwitchesMmu(io, 0x00, 0x01, 0x18, &mmu.store80Active, "80STORE")
2019-10-21 00:00:42 +02:00
2019-11-04 00:23:03 +01:00
// New IOU read softswithes
addSoftSwitchesIou(io, 0x0c, 0x0d, 0x1f, ioFlag80Col, "80COL")
addSoftSwitchesIou(io, 0x0e, 0x0f, 0x1e, ioFlagAltChar, "ALTCHARSET")
2019-10-12 21:37:37 +02:00
// Previous read softswithes
2019-10-21 00:00:42 +02:00
io.addSoftSwitchR(0x1A, getStatusSoftSwitch(ioFlagText), "TEXT")
io.addSoftSwitchR(0x1B, getStatusSoftSwitch(ioFlagMixed), "MIXED")
io.addSoftSwitchR(0x1C, getStatusSoftSwitch(ioFlagSecondPage), "PAGE2")
io.addSoftSwitchR(0x1D, getStatusSoftSwitch(ioFlagHiRes), "HIRES")
2019-10-12 21:37:37 +02:00
2019-11-06 00:02:03 +01:00
io.addSoftSwitchR(0x11, func(_ *ioC0Page) uint8 {
return ssFromBool(mmu.lcAltBank)
}, "BSRBANK2")
io.addSoftSwitchR(0x12, func(_ *ioC0Page) uint8 {
return ssFromBool(mmu.lcActiveRead)
}, "BSRREADRAM")
2019-11-11 22:58:42 +01:00
io.addSoftSwitchR(0x19, func(_ *ioC0Page) uint8 {
// See "Inside Apple IIe", page 268
// See http://rich12345.tripod.com/aiivideo/vbl.html
// For each screen draw:
// 12480 cycles drawing lines, VERTBLANK = $00
// 4550 cycles doing the return to position (0,0), VERTBLANK = $80
// Vert blank takes 12480 cycles every page redraw
cycles := io.apple2.cpu.GetCycles() % screenDrawCycles
if cycles <= screenVertBlankingCycles {
return ssOn
}
return ssOff
}, "VERTBLANK")
2019-10-12 21:37:37 +02:00
//io.softSwitchesData[ioFlagAltChar] = ssOn // Not sure about this.
}
2019-11-04 00:23:03 +01:00
func addSoftSwitchesMmu(io *ioC0Page, addressClear uint8, addressSet uint8, AddressGet uint8, flag *bool, name string) {
io.addSoftSwitchW(addressClear, func(_ *ioC0Page, _ uint8) {
*flag = false
}, name+"OFF")
2019-11-04 00:23:03 +01:00
io.addSoftSwitchW(addressSet, func(_ *ioC0Page, _ uint8) {
*flag = true
}, name+"ON")
io.addSoftSwitchR(AddressGet, func(_ *ioC0Page) uint8 {
2019-11-06 00:02:03 +01:00
return ssFromBool(*flag)
2019-11-04 00:23:03 +01:00
}, name)
}
2019-11-04 00:23:03 +01:00
func addSoftSwitchesIou(io *ioC0Page, addressClear uint8, addressSet uint8, AddressGet uint8, ioFlag uint8, name string) {
io.addSoftSwitchW(addressClear, func(_ *ioC0Page, _ uint8) {
io.softSwitchesData[ioFlag] = ssOff
}, name+"OFF")
2019-11-04 00:23:03 +01:00
io.addSoftSwitchW(addressSet, func(_ *ioC0Page, _ uint8) {
io.softSwitchesData[ioFlag] = ssOn
}, name+"ON")
2019-11-04 00:23:03 +01:00
io.addSoftSwitchR(AddressGet, func(_ *ioC0Page) uint8 {
return io.softSwitchesData[ioFlag]
}, name)
}