|  (→Logsin and Exponent tables) |  (→I/O Ports) | ||
| (58 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| − | Willy - MIDI and OPL3 Soundcard adapter for CPC | + | Willy - [[MIDI]] and OPL3 Soundcard adapter for CPC | 
| − | [[File:Willy1.jpg]] | + | It is the spiritual successor of the [[CPCISA]] project. | 
| + | |||
| + | [[File:Willy1.jpg]] [[File:Willy2.jpg]] | ||
| <br> | <br> | ||
| Line 15: | Line 17: | ||
| == Weblinks == | == Weblinks == | ||
| − | * https://pulkomandy.github.io/shinra.github.io/willy.html | + | * [https://pulkomandy.github.io/shinra.github.io/willy.html Official website] | 
| − | * [http://www.roudoudou.com/ACE-DL/ OPL3  | + | * [https://framagit.org/offset/willy-acepansion Willy ACEpansion] [https://framagit.org/shinra/vgmplay vgmplay] [https://framagit.org/shinra/sa2play sa2play] on Framagit | 
| + | * [http://www.roudoudou.com/ACE-DL/ OPL3 Archive ZIP] Huge pack containing 3887 OPL2/OPL3 tunes to be played on Amstrad CPC | ||
| * [https://opl.wafflenet.com/ The OPL archive] [https://vgmrips.net/packs/chip/ym3812 VGMrips OPL2] [https://vgmrips.net/packs/chip/ymf262 VGMrips OPL3] | * [https://opl.wafflenet.com/ The OPL archive] [https://vgmrips.net/packs/chip/ym3812 VGMrips OPL2] [https://vgmrips.net/packs/chip/ymf262 VGMrips OPL3] | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| <br> | <br> | ||
| == Compatible Serdaco soundcards == | == Compatible Serdaco soundcards == | ||
| − | *[https://www.serdashop.com/S2P S2P soundcard] aka Roland MT-32 or General MIDI Wavetable  | + | *[https://www.serdashop.com/S2P S2P soundcard] aka Roland MT-32 or General MIDI Wavetable Synthesizer - based on SAM2695 (2014) - [[media:SAM2695.pdf|Datasheet]] | 
| − | *[https://www.serdashop.com/OPL3LPT OPL3LPT soundcard] aka AdLib Gold or Sound Blaster 16 - [[Media:YMF262 199110.pdf| | + | *[https://www.serdashop.com/OPL3LPT OPL3LPT soundcard] aka AdLib Gold or Sound Blaster 16 - based on OPL3 (1990) - [[Media:YMF262 199110.pdf|OPL3 datasheet]] [[Media:Yamaha yac512 datasheet.pdf|DAC datasheet]] | 
| − | *[https://www.serdashop.com/OPL2LPT OPL2LPT soundcard] [https://github.com/zjuyzj/OPL2LPT-Replica OPL2LPT-Replica] aka AdLib or Sound Blaster - [[ | + | *[https://www.serdashop.com/OPL2LPT OPL2LPT soundcard] [https://github.com/zjuyzj/OPL2LPT-Replica OPL2LPT-Replica] aka AdLib or Sound Blaster - based on OPL2 (1985) - [[Media:Yamaha_YM3812.pdf|OPL2 datasheet]]  [https://c64.xentax.com/media/Yamaha_YM3812_Application_Manual.pdf OPL2 application manual] [[Media:YM3014 DAC datasheet.pdf|DAC datasheet]] | 
| − | *[https://www.serdashop.com/CMSLPT CMSLPT soundcard] aka Creative Music System or Game Blaster - [[media:Philips_saa1099.pdf| | + | *[https://www.serdashop.com/CMSLPT CMSLPT soundcard] aka Creative Music System or Game Blaster - based on two SAA1099 (1984) - [[media:Philips_saa1099.pdf|Philips datasheet]] [[media:Mullard-saa-1099 datasheet.pdf|Mullard datasheet]] | 
| − | *[https://www.serdashop.com/TNDLPT TNDLPT soundcard] aka PCjr or Tandy Sound - [[media:Texas_instruments_sn76489an.pdf|Datasheet]] | + | *[https://www.serdashop.com/TNDLPT TNDLPT soundcard] aka PCjr or Tandy Sound - based on SN76489 (1979) - [[media:Texas_instruments_sn76489an.pdf|Datasheet]] | 
| *[https://www.serdashop.com/CVX4 CVX4 soundcard] aka Covox Speech Thing - [https://scalibq.wordpress.com/2017/11/28/the-covox-years/ Technical analysis] | *[https://www.serdashop.com/CVX4 CVX4 soundcard] aka Covox Speech Thing - [https://scalibq.wordpress.com/2017/11/28/the-covox-years/ Technical analysis] | ||
| + | |||
| + | Note: Like the MIDI synth functionality of the [[RSF3]], the S2P soundcard natively supports Wavetable MIDI. It doesn't require a software translation layer like the [[AMSDAP]] OPL4 & YRW801 ROM solution. | ||
| <br> | <br> | ||
| == I/O Ports == | == I/O Ports == | ||
| − | 2 ports are used to control the MIDI soundcard: &FEAC for data, and &FEAD for control and status. | + | 2 ports are used to control the [[MIDI]] soundcard: &FEAC for data, and &FEAD for control and status. Sadly, that means it is not compatible with the [[EMR MIDI Interface]] which is located at ports &F8F2 and &F8F3. | 
| − | 3 ports are used to control the OPL3 soundcard:  &FEBC and &FEBE are register select ports, and &FEBD is the data port. | + | 3 ports are used to control the OPL3 soundcard:  &FEBC and &FEBE are register select ports, and &FEBD is the data port. Again, we can regret it doesn't use the same ports as the [[AMSDAP|AMSDAP OPL4]]. | 
| <br> | <br> | ||
| Line 86: | Line 86: | ||
| <br> | <br> | ||
| − | ===  | + | === Algorithm === | 
| − | The OPL chips use two look-up tables | + | The OPL chips generate sound efficiently, without using any multiplication or other costly arithmetic operations. Instead, they use two look-up tables (exp and logsin) each containing 256 entries. | 
| − | + | The tables are used in this formula for 2-op "frequency modulated" (actually phase modulated) synthesis: | |
|   out = exp(logsin(phase2 + exp(logsin(phase1) + gain1)) + gain2) |   out = exp(logsin(phase2 + exp(logsin(phase1) + gain1)) + gain2) | ||
| Line 100: | Line 100: | ||
| When such a table is used for calculation of the exponential, the table is read at the position given by the 8 LSB's of the input. The value + 1024 (the hidden bit) is then the significand of the floating point output and the yet unused MSB's of the input are the exponent of the floating point output. | When such a table is used for calculation of the exponential, the table is read at the position given by the 8 LSB's of the input. The value + 1024 (the hidden bit) is then the significand of the floating point output and the yet unused MSB's of the input are the exponent of the floating point output. | ||
| − | ====  | + | ==== Logsin table ==== | 
|   x = 0..255, y = round(-log(sin((x+0.5)*pi/256/2))/log(2)*256) |   x = 0..255, y = round(-log(sin((x+0.5)*pi/256/2))/log(2)*256) | ||
| Line 144: | Line 144: | ||
| The OPL3 soundchip has been underused and unfairly criticized, largely due to 2 factors: | The OPL3 soundchip has been underused and unfairly criticized, largely due to 2 factors: | ||
| * As OPL3 is compatible with OPL2, PC game producers did not make the effort to specifically exploit the OPL3 soundchip capabilities, instead they relied on inferior OPL2 tunes. These are the equivalent of the Speccy ports that gave the Amstrad CPC a bad reputation. | * As OPL3 is compatible with OPL2, PC game producers did not make the effort to specifically exploit the OPL3 soundchip capabilities, instead they relied on inferior OPL2 tunes. These are the equivalent of the Speccy ports that gave the Amstrad CPC a bad reputation. | ||
| − | * Western PC game developers in the early 90's also tended to produce music by using a master MIDI track on Roland MT-32, and then downgrading it for the various PC soundchips. The result was a cheesy so-called "MIDI" music. That was unfair for OPL3 | + | * Western PC game developers in the early 90's also tended to produce music by using a master MIDI track on Roland MT-32, and then downgrading it for the various PC soundchips. The result was a cheesy so-called "MIDI" music. That was unfair for OPL3 (but also for MIDI, as Wavetable MIDI sounds way better than that). | 
| + | |||
| + | Examples of proper OPL3 music: [https://www.youtube.com/watch?v=a7I-QmrkAak MoonDriver] [https://www.youtube.com/watch?v=uyVOy02tW88 Paul the Penguin] [https://www.youtube.com/watch?v=6JlFIFz1CFY Zen Challenge] | ||
| + | |||
| + | <br> | ||
| − | == | + | == Links == | 
| − | * [https:// | + | *[https://moddingwiki.shikadi.net/wiki/OPL_chip Programmer's guide to OPL3] | 
| − | * [https://www. | + | *[https://g.co/kgs/Da1vEi4 OPLx decapsulated] | 
| − | * [https:// | + | *[https://www.righto.com/search/label/dx7 Yamaha DX7 chip reverse-engineered] from die shots | 
| + | *[https://youtu.be/BCwn26FePAo Yamaha DX7 - Famous Sounds Demo] Yamaha FM synthesis chips defined the sound of the 1980s | ||
| + | *[https://youtu.be/TVmZarPUc-Q Korg M1 Famous Songs and Sounds] Wavetable synthesizers dominated in the 1990s | ||
| − | [[Category:Music and sound]] [[Category:Peripherals]] | + | [[Category:Music and sound]] [[Category:Peripherals]] [[Category:Hardware]] | 
Latest revision as of 08:21, 11 April 2025
Willy - MIDI and OPL3 Soundcard adapter for CPC
It is the spiritual successor of the CPCISA project.
Demonstrations
- Willy OPL3 on a real CPC demoed by Prodatron
- Willy MIDI and Willy OPL3 emulated on ACE demoed by Offset
- Willy OPL3 emulated on ACE-DL demoed by Roudoudou
- OPL3LPT soundcard reviewed on PC by ChinnyVision
Weblinks
- Official website
- Willy ACEpansion vgmplay sa2play on Framagit
- OPL3 Archive ZIP Huge pack containing 3887 OPL2/OPL3 tunes to be played on Amstrad CPC
- The OPL archive VGMrips OPL2 VGMrips OPL3
Compatible Serdaco soundcards
- S2P soundcard aka Roland MT-32 or General MIDI Wavetable Synthesizer - based on SAM2695 (2014) - Datasheet
- OPL3LPT soundcard aka AdLib Gold or Sound Blaster 16 - based on OPL3 (1990) - OPL3 datasheet DAC datasheet
- OPL2LPT soundcard OPL2LPT-Replica aka AdLib or Sound Blaster - based on OPL2 (1985) - OPL2 datasheet OPL2 application manual DAC datasheet
- CMSLPT soundcard aka Creative Music System or Game Blaster - based on two SAA1099 (1984) - Philips datasheet Mullard datasheet
- TNDLPT soundcard aka PCjr or Tandy Sound - based on SN76489 (1979) - Datasheet
- CVX4 soundcard aka Covox Speech Thing - Technical analysis
Note: Like the MIDI synth functionality of the RSF3, the S2P soundcard natively supports Wavetable MIDI. It doesn't require a software translation layer like the AMSDAP OPL4 & YRW801 ROM solution.
I/O Ports
2 ports are used to control the MIDI soundcard: &FEAC for data, and &FEAD for control and status. Sadly, that means it is not compatible with the EMR MIDI Interface which is located at ports &F8F2 and &F8F3.
3 ports are used to control the OPL3 soundcard: &FEBC and &FEBE are register select ports, and &FEBD is the data port. Again, we can regret it doesn't use the same ports as the AMSDAP OPL4.
OPL3 sound chip
The OPL3, released by Yamaha in 1990, is an upgraded version of the OPL2, which came out in 1985.
OPL3 is register compatible with OPL2, with twice the number of signal sources, 4 new operator modes, 4 new selectable waveforms, and stereo output.
OPL3 offers 18 FM 2-op chans in its standard mode, but that can be configured:
- One setting converts 3 of the FM chans into a 5-chan FM percussion set
- Another setting pairs 12 of the FM chans into 6 FM 4-op chans
- Both settings can be used at the same time, to obtain 6 FM 4-op chans + 3 FM 2-op chans + 5-chan FM percussion set
Basic Components
The most basic elements of an OPL FM synthesiser are:
- envelope generators, which vary volume over time;
- phase generators, which produce a waveform such as a sine wave at a programmatic rate;
- operators, which combine an envelope generator and a phase generator;
- a global low-frequency oscillator which can provide additional vibrato (i.e. back-and-forth modification of frequency) and tremolo (like vibrato, but for volume) to operators;
- channels, which combine operators to produce a single tone output;
- a distinct rhythm section, which incorporates a noise generator with some of the parts above to provide a few fixed percussion noises.
Operators
On an OPL1 or 2, each channel consists of two operators. On an OPL3 it may also consist of four. In either case, the basic FM synthesis operation is the same:
The output of one operator is used to modulate the current phase of another. The former is known as the modulator, the latter as the carrier.
In two-operator frequency modulation mode, the output of the carrier, after modulation, is the audio output.
In four-operator mode there are some more complicated options involving routing outputs between operators.
Algorithm
The OPL chips generate sound efficiently, without using any multiplication or other costly arithmetic operations. Instead, they use two look-up tables (exp and logsin) each containing 256 entries.
The tables are used in this formula for 2-op "frequency modulated" (actually phase modulated) synthesis:
out = exp(logsin(phase2 + exp(logsin(phase1) + gain1)) + gain2)
Exponential table
x = 0..255, y = round((power(2, x/256)-1)*1024)
When such a table is used for calculation of the exponential, the table is read at the position given by the 8 LSB's of the input. The value + 1024 (the hidden bit) is then the significand of the floating point output and the yet unused MSB's of the input are the exponent of the floating point output.
Logsin table
x = 0..255, y = round(-log(sin((x+0.5)*pi/256/2))/log(2)*256)
This is the first (rising) quarter of sine wave. The rest can be constructed by flipping all the bits of x and/or by changing the sign of the samples.
Waveforms
The original OPL only has access to the sine wave.
From the OPL2 onwards other waves are also available, specifically a half sine (i.e. the positive part only, silence for the second half of the period), rectified sine (the positive part repeated twice per cycle) or quarter sine (just the first ramp from 0 to 1, repeated twice, providing harmonics a lot like a sawtooth).
The OPL3 goes even further, adding some extra sine options plus a square wave and a logarithmic sawtooth.
FM Percussion Set
FM synthesis does a great job relative to its hardware requirements at reproducing melodic instruments but isn't especially useful for harsh percussion noises like drums. Yamaha provides separate drum noises for this purpose. The programmer has to forfeit three channels of regular FM synthesis, freeing up six operators for five rhythm instruments.
A global random level generator is implemented for this mode; it's a standard LFSR just like the noise generator on simple chips like the AY-3-8910 or SN76489, so it provides a one-bit semi-random output. Source
The OPL can then generate:
- a bass drum, which is just another FM noise;
- a tom tom, which is the unmodulated output of a single operator;
- a snare drum, which combines the phase of a single operator with the random noise bit;
- a cymbal which XORs six bits from the phase of two operators;
- a high-hat, which uses the same XOR as the cymbal and combines it with the random noise bit.
OPL3 undeserved reputation
The OPL3 soundchip has been underused and unfairly criticized, largely due to 2 factors:
- As OPL3 is compatible with OPL2, PC game producers did not make the effort to specifically exploit the OPL3 soundchip capabilities, instead they relied on inferior OPL2 tunes. These are the equivalent of the Speccy ports that gave the Amstrad CPC a bad reputation.
- Western PC game developers in the early 90's also tended to produce music by using a master MIDI track on Roland MT-32, and then downgrading it for the various PC soundchips. The result was a cheesy so-called "MIDI" music. That was unfair for OPL3 (but also for MIDI, as Wavetable MIDI sounds way better than that).
Examples of proper OPL3 music: MoonDriver Paul the Penguin Zen Challenge
Links
- Programmer's guide to OPL3
- OPLx decapsulated
- Yamaha DX7 chip reverse-engineered from die shots
- Yamaha DX7 - Famous Sounds Demo Yamaha FM synthesis chips defined the sound of the 1980s
- Korg M1 Famous Songs and Sounds Wavetable synthesizers dominated in the 1990s


