b2
b2 copied to clipboard
Display output vs dispen timing isn't quite right
Mode 7 in b2:
Mode 7 on a beeb: (blue is DISPEN - monitor is TTL RGB, its blue input is attached to the video ULA's dispen pin)
data:image/s3,"s3://crabby-images/0a998/0a998fc2655943e08367660aea83c94f63a2c5cd" alt="image"
There's an extra 1 microsec delay that isn't being accounted for...
Also, mode 4. Note the extra column after dispen goes to 0.
data:image/s3,"s3://crabby-images/30385/30385f93455863e6883c29006492ee5679468ea9" alt="image"
Mode 2. Perhaps not super obvious from this crap pic, but there's 1 additional column here too after dispen goes to 0.
data:image/s3,"s3://crabby-images/1f20e/1f20e732d92076ea74878bfae5280e411d369a6d" alt="image"
For bitmap modes: I guess the video ULA can't start to shift data out until it's read the data in. It must take 1 cycle for that to happen, perhaps?
So for the top left byte in Mode 4, the period when DISPEN=1 and MAx/RAx=$5800 is occupied by the video ULA latching that byte in, and shifting out nothing. (Presumably when DISPEN=0, it sets its latch to 0.)
And so you don't get to see the contents of $5800 until 1 byte's-worth of time later, when the CRTC outputs refer to $5808. And so on.
For teletext modes: b2 will be modelling the ~3 microsec SAA5050 delay incorrectly... probably? I don't feel like I understand the timing here any more...