mirror of
https://github.com/bradgrantham/apple2e.git
synced 2025-01-15 05:31:15 +00:00
separate notes on VBLANK and mode switch
This commit is contained in:
parent
bfe64192a3
commit
332dca17de
53
notes.vblank
Normal file
53
notes.vblank
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
per-scanline modes
|
||||||
|
Actual Apple II TEXT/GR and HGR video address patterns are in Understanding the Apple II
|
||||||
|
Not for DHGR or 80-col but they're probably just same address twice alternating banks
|
||||||
|
tracking clock and reporting video memory contents
|
||||||
|
clock
|
||||||
|
one tick of ~1MHz clock maps to one tick of address counter
|
||||||
|
so is 7 HGR bits or one GR/TEXT horizontal cell
|
||||||
|
"most 6502 cycles are 978 nS long [14 14mhz clocks], but every 65th cycle is 1117 nS long [16 14mhz clocks]."
|
||||||
|
source clock is 14.31818MHz
|
||||||
|
unsigned long would overflow after 20 minutes
|
||||||
|
Could modulo byteclock by 14318180 at iterate() and not overflow
|
||||||
|
as long as it doesn't take longer than 20 minutes between calls to APPLE2Einterface::iterate than 20 minutes...)
|
||||||
|
Could have clk be in 14MHz ticks.
|
||||||
|
unsigned long long will last 40853 years (could be slow on embedded systems)
|
||||||
|
Keep track of phase at clk delta time, and add 14 usually but 16 every 65th
|
||||||
|
Then wall clock is just always ticks / 14318180.0
|
||||||
|
phase_hpe initially 0
|
||||||
|
add_cpu_cycles(elapsed_cpu) {
|
||||||
|
clock_cpu += elapsed_cpu
|
||||||
|
clock_14mhz = elapsed_cpu * 14 + (elapsed_cpu + phase_hpe) / 65 * 16
|
||||||
|
phase_hpe = (phase_hpe + elapsed_cpu) % 65
|
||||||
|
}
|
||||||
|
clock_14mhz is 14mhz ticks
|
||||||
|
clock_cpu is CPU clocks, averaging 1.023MHz
|
||||||
|
phase_hpe is clock_cpu within horizontal line
|
||||||
|
Current CPU clk (in 1MHz CPU cycles) is used for
|
||||||
|
which audio sample (at libAO sample rate) in the audio waveform we should fill
|
||||||
|
OK - should work with higher fixed rate
|
||||||
|
mark after how many cycles the open apple key should be raised
|
||||||
|
OK - should work with higher fixed rate
|
||||||
|
mark paddle timer
|
||||||
|
OK - should work with higher fixed rate
|
||||||
|
incrementing CPU instruction cycles
|
||||||
|
OK - call add_cpu_cycles()
|
||||||
|
address generator
|
||||||
|
every line is 65 bytes, there are 262 lines, so there are 17030 bytes per field
|
||||||
|
honor softswitches
|
||||||
|
convert clock_cpu to address
|
||||||
|
blanking and offscreen addressing during HIRES MIXED
|
||||||
|
160 through 191 and 224 through 261
|
||||||
|
TEXT addressing at 160, HPE' + 1 through at 192, HPE'
|
||||||
|
argh
|
||||||
|
read empty memory address on bus no longer fails but instead
|
||||||
|
generate address, get byte from RAM and return it
|
||||||
|
recording softswitch mode changes
|
||||||
|
store vector of switch or mode change and byteclock
|
||||||
|
instead of setting before APPLE2Einterface::iterate, pass into iterate
|
||||||
|
honoring softswitch change in APPLE2Einterface
|
||||||
|
initialize scanline mode array to text
|
||||||
|
receive vector of tuple of byteclock and modes
|
||||||
|
fill scanline mode array from passed in vector
|
||||||
|
draw framebuffer by scanline
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user