2 years ago
I pushed this Pull Request on GitHub with improvements to the way DMA is used to update the display. The result is reduced duration of the display update duration and larger contiguous periods of idle CPU during display line update.
Total frame update duration is reduced to ~15ms.
During each line update 2 large contiguous idle CPU periods (adding up to ~63% of the line
update duration) are now present. This means that out the ~15ms frame update duration, ~9ms are spent idling and that time could be exploited for more game logic related computation (would require a task scheduler) or for implementing more CPU intensive video modes like e.g. tiled modes.
Total frame duration was shortened by eliminating inter-line gaps caused by line processing time and accesses to DMA channel/descriptor.
Some Oscilloscope prøn:
In top down order: interline gap, total frame duration and line duration
In top down order: total frame duration, line duration, inter-line gap, per line CPU idle time
In top down order: total frame duration, line duration, per line CPU idle time periods 1 and 2