Welcome to the new way of playing SID tunes
There are plenty of similar projects over the internet, where AVR's are used to control SID chip in any way to play the music. However, what do they all have in common is the way the SID registers are driven - in a very simplified way, there is an array of registers 'snapshots' prepared and each time frame these registers are updated with another 'snapshot' from an array.
The goal for me was to be able to play SID music by executing the native code of 6502 processor, just the same as it is when you listen to the SID tunes on your real C64.
Check out the /miscellaneous/
folder for some examples of how this prototype looks and sounds like.
You'll find the hardware-specific details in /schematics/
folder. There's a KiCad project containing schematics sheet you might find quite helpful in building your own RealSIDPlayer prototype. However, if you're interested only in exploration how emulator works, then all you need is within the /src/
folder.
Most of all, you will absolutely need the ATxmega128A3U uC, since all the code, memory management, use of onboard features etc. are done for this particular model. For more details look into /docs/
folder, where among the others you'll find a diagram with all necessary elements the circuit is made of.
You will obviously need the SID chip too.
As for the parts not listed on schematics, it might be good to have a larger breadboard, bunch (or better two) of wires, three sources of stabilized power supply: 3.3V (host's logic), 5V (SID's logic) and 9V (both SID's audio output & preamp of line-out output).
As an interface between Atmel Studio and ATxmega128A3U I used the AVR PROG MKII programmer, mainly because it's simply convenient to use for me, but it's up to you and your preferences what to use to program your chip.
You need KiCad
only in case you'd like to contribute in this project. If all what you want is just the connections diagram, there's a PNG file prepared in /docs/
folder for you.
Install Saleae Logic
to open two sample diagrams I grabbed from logic analyzer during tests (also in /docs/
folder). You don't need that if you don't want to play with zooming in and out - there are PNG files prepared for you as well.
As for the IDE you will need Atmel Studio 7.0
to run the whole project.
NOTE: Once you're done with installing/setting up
Atmel Studio 7.0
you need to downloadTMPx
from turbo.style64.org and putTMPx.exe
file into/src/xmega/
folder.TMPx
is a multiplatform cross-assembler for the 6502 CPU by STYLE. It's been used in the pre-build event of Atmel Studio IDE to compile C64's source code files.
NOTE #2: As for now the style64.org site is down, so here's the alternative way (from csdb.dk) of getting the TMPx package.
PRO TIP: In fact, you can use any 6502 cross-assembler you like. There is no problem to use any of your choice unless it supports Turbo Assembler's syntax. Otherwise you might want to consider adjusting the following two things:
- The C64 sources in
/src/xmega/c64_code/
folder- Atmel Studio's pre-build event to refer to your tool instead of TMPx
- Atmel Studio 7.0 - the IDE
- TMPx - great cross-assembler for 6502 CPU by STYLE (alternative download here)
- KiCad - for its schematic editor (optional)
- Saleae Logic - to open the logic analyzer diagrams (optional)
Having prerequisites fulfilled, you're ready to go!
- Assembly the circuit
- Before placing your ATxmega128A3U into the circuit, program it first:
- Open Atmel Studio
- Build project
- Program the microcontroller
- Place ATxmega128A3U into the circuit
- Check all connections once again
- Turn the power on
If you connected everything correctly, you should be able to hear music (remember to plug your speakers's jack into the AUDIO OUT connector).
You can select between several included zaks.
In order to do that:
-
Edit the
/src/xmega/c64_resources.inc
file. You will find set of#define
directives, similar to these://#define _silence_ /* 1 time per frame */ #define zak1 //#define zak2 //#define zak3
-
Comment the uncommented line and uncomment another one, so there is still the only one uncommented
#define
directive. Example://#define _silence_ /* 1 time per frame */ //#define zak1 #define zak2 //#define zak3
-
Re-build project and program your uC.
Refer to /tools/TOOLS.md (SID2ASM section) for step-by-step instructions and more detailed informations.
Due to the uC used, the application cannot handle zaks more than 0x1c00 bytes in size. This limitation is because of the memory size implemented in ATxmega128A3U (refer to /docs/EMU.md file for more details).
The actual shape of this project is the very basic one as this is just an early prototype or kind of proof-of-concept. It lacks of many features and cool functions and I'm not able to work on all of them alone efficiently. Please refer to TODOS.md if you think you could help - your contribution is always warmly welcome.
- Łukasz Drzewiecki (Hank/Draco) - Initial work (concept, schematics, programming)
See also the list of contributors who participated in this project. I hope that soon it will not only me be listed there.
In alphabetical order:
- AMJ
- DAF
- Dane
- DRAX
- Glenn Rune Gallefoss
- Jeff
- Kristian Røstøen
- KB
- MHD
- Mitch&Dane
- Orcan
- PRI
- Red Devil
- Shogoon
- Vincenzo
- Wayne
and me.
Yes, I know these are quite old nowadays. But I still like them! :)
This project is licensed under the MIT License - see the LICENSE.md file for details.
During the work on this project I gathered a small collection of interesting readings and specs regarding various topics. Below is the list of few more valuable positions that might come in handy if you're about to do your own research:
- unusedino.de - datasheets and schematics of the C64 hardware (and more)
- 6502.org - the 6502 microprocessor resource
- Using the MOS 6581 SID chip - interesting reading :)
- Visual Guide to 65xx CPU Timing - good article with cool animations
- Tests for all valid opcodes of the 6502 and 65C02 processor - outstanding and reliable set of tests if you develop 6502 CPU emulator and want to test if it works
- "Tick Tock, know your Clock!" - totally awesome article explaining the whole clock-magic of the C64. Very well written and very informative
- AVR Assembler - AVR assembler docs