mirror of
https://github.com/tildearrow/furnace.git
synced 2024-11-30 08:23:01 +00:00
81 lines
3.5 KiB
Markdown
81 lines
3.5 KiB
Markdown
# General Instrument AY-3-8910
|
|
|
|
this chip was used in many home computers (ZX Spectrum, MSX, Amstrad CPC, Atari ST, etc.), video game consoles (Intellivision and Vectrex), arcade boards and even slot machines!
|
|
|
|
it is a 3-channel square/noise/envelope sound generator. the chip's powerful sound comes from the envelope...
|
|
|
|
the AY-3-8914 variant was used in Intellivision, which is pretty much an AY with 4 level envelope volume per channel and different register format.
|
|
|
|
Furnace is capable of doing software sample playback on AY-3-8910, where all 3 channels can play 4-bit PCM samples (at the cost of a very high CPU usage).
|
|
|
|
## effects
|
|
|
|
- `20xx`: **set channel mode.**
|
|
- `0`: square
|
|
- `1`: noise
|
|
- `2`: square and noise
|
|
- `3`: envelope
|
|
- `4`: envelope and square
|
|
- `5`: envelope and noise
|
|
- `6`: envelope and square and noise
|
|
- `7`: nothing
|
|
- `21xx`: **set noise frequency.** range is `0` to `1F`.
|
|
- `22xy`: **set envelope mode.**
|
|
- `x` sets the envelope shape:
|
|
- `0`: `\___` decay
|
|
- `4`: `/___` attack once
|
|
- `8`: `\\\\` saw
|
|
- `9`: `\___` decay
|
|
- `A`: `\/\/` inverse obelisco
|
|
- `B`: `\¯¯¯` decay once
|
|
- `C`: `////` inverse saw
|
|
- `D`: `/¯¯¯` attack
|
|
- `E`: `/\/\` obelisco
|
|
- `F`: `/___` attack once
|
|
- if `y` is 1 then the envelope will affect this channel.
|
|
- `23xx`: **set envelope period low byte.**
|
|
- `24xx`: **set envelope period high byte.**
|
|
- `25xx`: **slide envelope period up.**
|
|
- `26xx`: **slide envelope period down.**
|
|
- `29xy`: **enable auto-envelope mode.**
|
|
- in this mode the envelope period is set to the channel's notes, multiplied by a fraction.
|
|
- `x` is the numerator.
|
|
- `y` is the denominator.
|
|
- if `x` or `y` are 0 this will disable auto-envelope mode.
|
|
- `2Exx`: **write to I/O port A.**
|
|
- this changes the port's mode to "write". make sure you have connected something to it.
|
|
- `2Fxx`: **write to I/O port B.**
|
|
- this changes the port's mode to "write". make sure you have connected something to it.
|
|
|
|
## what is obelisco
|
|
|
|
it's a name I use for a spiky waveform that starts low.
|
|
|
|
its origin is a wavetable that comes in DefleMask that happens to be called Obelisco.
|
|
|
|
## AY derivative modes
|
|
|
|
AY-3-810 was an absurdly popular chip that was blessed with many third-party clones, licensed or not.
|
|
|
|
- the AY-3-8914 variant was used in Intellivision, which is pretty much an 8910 with 4 level envelope volume per channel and different register format.
|
|
- Yamaha YM2149 was an AY-3-8910 clone released in 1983. it's almost identical to AY with minor differences being: higher hardware envelope step resolution (16 vs 32), half-clock mode when voltage level is low, much stronger DC offset and cleaner, but softer output.
|
|
- Sunsoft 5B is YM2149 clone with half-clock mode forced on.
|
|
|
|
## info
|
|
|
|
this chip uses the [AY-3-8910](../4-instrument/ay8910.md) instrument editor.
|
|
|
|
## chip config
|
|
|
|
the following options are available in the Chip Manager window:
|
|
|
|
- **Clock rate**: sets the rate at which the chip will run.
|
|
- **Chip type**: changes the chip model.
|
|
- AY-3-8910: the original model.
|
|
- YM2149(F): Yamaha clone with higher envelope resolution and a different volume curve.
|
|
- Sunsoft 5B: a special model found in one of Sunsoft's Famicom cartridges.
|
|
- AY-3-8914: scrambled registers. has envelope volume control.
|
|
- **Stereo**: enable stereo output. channel 1 is output left, channel 2 is output center and channel 3 is output right.
|
|
- **Separation**: allows you to set left/right separation.
|
|
- **Half Clock divider**: pulls the half clock pin, running the chip at half the speed.
|
|
- only available in YM2149.
|