Skip to main content

Homebrew game for C64 - part 2: more SID tune fun

The development of the music for this game has gone so well - way better than the development of the gameplay itself, which I'm having serious doubts about!

Writing a silly tune was the easiest part. I've now improved that - it has a 'chorus' which is deliberately reminiscent of 'English Country Garden'. The main part of the tune is meant to accompany sheep trotting / blundering around a field.

It even has a fourth part now, although I can only use three because the C64's sound chip - SID - has three tone voices.
And here's how it sounds using the Vice C64 emulator:



Disclaimer: Tonight I've been messing around with voices and ASDR envelopes, and haven't yet found settings that I really like. The bass in particular is raspy here, I want a smooth sound, but when I use the triangle waveform it sounds very quiet even with the highest sustain volume.

In the first part of this little diary, I mentioned that I started to use Derek Morris' sound library. It allowed me to 'code' the tune with his user-friendly constants.
It worked with three voices at once but I had trouble with the synchronisation. At first I devised a method of breaking the music down into bars, and having the main program loop kick off each bar of the three voices at the same time. That's why there's a cmdEnd at the end of each bar in the code above.

That worked. To a point. The music was in sync at the start of each bar. Within each bar, things got a little rough, and I started to fiddle with the delays on certain notes to try and straighten that out. That worked. To a point. That was all a bit of a fudge, so I carefully read DM's code to make sure that it was doing what I assumed it was doing. It really was, and it's beautifully-written (I don't mean to sound patronising. I mean that I've learned so much by reading his code and his book.)

But after manually following the loops in his code around and around as if I were the processor, noting down variable values on paper, I found that the delay loops were delaying for one more cycle than I thought they were. It's to do with counting down to zero. You get one more delay than the number you specify after the CmdDelay. I wouldn't call this a bug, Mr Morris designed this for playing a sound effect on a single voice so this point is insignificant in that context.

It took a single 'dec' instruction in the right place, and the soundlib is playing my music perfectly. (although faster than before, so I've had to re-write the delay values in my sound command files so that there are 48 in each bar rather than 32). I no longer need my 'bar-by-bar' system to keep everything in sync, because as long as the delay count is the same in each bar, everything will stay in sync. That saves one byte per bar per voice, plus my sync routine and the execution time of that each programme loop.

Manually translating the notated music to the sound library instructions is very laborious. Particularly looking up the high and low note values for each note in Appendix E of the Prog Ref Guide (I bought a copy of the C64 one in the end). I'm thinking about how I might write a tool(s) to help with this, because I've really enjoyed the composition part and want to do a lot more. Possibly even a mac app to take the sheet music (as musicXML) and build those sound commands. 

Comments

Popular posts from this blog

ZX81 reversible internal 16k upgrade

T his post is an upvote for Tynemouth Software's  ZX81 reversible Internal 16K RAM upgrade . Their instructions are easy enough for even me to follow and don't involve cutting tracks. This is the ZX81 I've had out on display and used whenever I wanted to. It's an issue 1 and was probably a kit judging by some very untidy assembly. It has a ZX8-CCB  composite video mod and an external keyboard fitted. On board it has two 1k x 4-bit chips.  The ZX81 originally came with 1k on board. Thanks to a trick with compressing the display in ram, that was enough to type and run a small program but you soon felt the limitations. Back in the early 80s, the solution was a 16k ram pack which plugged into the back[1] and this is the way I've been using this particular machine. These ram packs are notorious for 'ram pack wobble'. Even if fastened into place, you can still randomly find your work disappearing. This is a very reliable solution using a more modern 32k chip (half

Driving NeoPixels with Z80

I 've long been thinking about a version two   RC2014 LED matrix module . I've had a matrix with a MAX 7219 on a module. It's a nice enhancement. But there's only so much you can do with a single-colour LED array right? Wouldn't it be cool to have RGB LEDs?  At Liverpool MakeFest I saw a wall-sized ping-pong ball NeoPixel display and picked up some NeoPixels with the intention of making one. Possibly driven by my RC2014.  I enjoy learning about protocols and have had some SPI devices working with the RC2014 - bit-banging SPI works really well because it doesn't care about timing. NeoPixels really do care about timing though. From Adafruit's web page about their 8x8  NeoPixel matrix: If there's one thing I want to get across in this blog post, it's don't just accept what you're told . Question everything. Learn about what's going on and find out why you're being told something isn't possible. Get creative with workarounds. I'

Making new ROMs for the Vic20 / Vicky Twenty

M y Vicky Twenty is very nearly complete.  As things stand, the board and every single component is new*. The processor and VIAs are newly-manufactured (W65C02 and W65C22).  Obviously the Vic1 chip isn't manufactured today, but there is 'new old' stock about. I have been able to buy a Vic 1, date code 1987 (which seems very late). It obviously hasn't been in a computer before, passes the acetone test and works. The same goes for two of the ROMs - character and BASIC. But I haven't been able to buy a new-old Kernal ROM (901486-07). I am able to borrow one - all of the boards I have, have this particular ROM socketed. I don't know whether all of this indicates that the Kernal has proved less reliable than the other two. I recently bought a TL866 for another project. Of all the retro-computing hardware things I've had to learn to do, making ROMs has been one of the simplest. So far, everything has been very easy and worked first time.  I'm not sure that it&