VDP timing analysis tool for MSX
Pedro Gimeno 616ae3b041 asc2cld.py: Fix tokenization of DATA statements | 4 years ago | |
---|---|---|
test_asc2cld | 3 years ago | |
.gitattributes | 4 years ago | |
.gitignore | 4 years ago | |
LICENSE.md | 4 years ago | |
Makefile | 4 years ago | |
README.md | 4 years ago | |
RESULTS.txt | 4 years ago | |
USAGE.txt | 4 years ago | |
asc2cas.py | 4 years ago | |
asc2cld.py | 3 years ago | |
blank1.dsk.gz | 4 years ago | |
blank2.dsk.gz | 4 years ago | |
frametime.bss.asm | 4 years ago | |
frametime.code.asm | 4 years ago | |
im2setup.code.asm | 4 years ago | |
im2setup.equ.asm | 4 years ago | |
loadertpl.py | 4 years ago | |
main.bss.asm | 4 years ago | |
main.code.asm | 4 years ago | |
raw2bin.py | 4 years ago | |
raw2cas.py | 4 years ago | |
syncvint.code.asm | 4 years ago | |
sysdefs.equ.asm | 4 years ago | |
test-ack-timing.bss.asm | 4 years ago | |
test-ack-timing.code.asm | 4 years ago | |
vdptest.asm | 4 years ago |
This program is designed to test the intricacies and fine details of how the VDP interacts with the CPU, especially in areas of possible interest to emulator authors, and also to MSX/MSX2/MSX2+/TR coders that want to make the most out of the VDP to e.g. squeeze as many transfers as possible in the shortest time.
An important detail is that it's designed to run on MSX machines with synced CPU/VDP clocks, not separate. This makes things hard for a particular VDP, the Toshiba T6950, a chip designed for PAL which needs a 22.168 MHz crystal that is not compatible with the regular CPU timings, and therefore always includes a separate crystal for it. That leaves several Sony machines basically untestable with any degree of reliability.
Currently, the code consists solely of a cycles per frame measurer, as the exact cycle count is the basis for syncing with the CPU, which will be needed by the rest of tests. As it is now, it can't run on a machine with less than 16K RAM. If run on a machine with floppies, the second floppy needs to be disabled by pressing CTRL during boot.
See the Releases page for pre-built binaries. Read USAGE.txt for more information.
The license for this code is the Expat license. See the file LICENSE.md for details.