hardware:audio
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
hardware:audio [2025/03/01 18:48] – clyde | hardware:audio [2025/03/01 20:39] (current) – [Effective sample rate] clyde | ||
---|---|---|---|
Line 22: | Line 22: | ||
The DAC is not directly writable by the ACP. Any write by the ACP to an address at $8000 or above will also be mirrored to a buffer register. This buffer register is copied to the DAC at every IRQ signal. | The DAC is not directly writable by the ACP. Any write by the ACP to an address at $8000 or above will also be mirrored to a buffer register. This buffer register is copied to the DAC at every IRQ signal. | ||
+ | |||
+ | ==== Audio Control Registers ==== | ||
+ | |||
+ | Write-only registers. $2000 and $2001 trigger on any write, regardless of value. | ||
+ | |||
+ | ^ Addr ^ Use ^ | ||
+ | | $2000 | Write to reset audio coprocessor. | ||
+ | | $2001 | Write to send NMI to audio coprocessor | | ||
+ | | $2006 | Audio enable and sample rate | | ||
===== Programming ===== | ===== Programming ===== | ||
Line 32: | Line 41: | ||
Conversely the IRQ rate can go as high as 3.5795MHz but without time for any CPU operations this isn't very useful | Conversely the IRQ rate can go as high as 3.5795MHz but without time for any CPU operations this isn't very useful | ||
+ | |||
+ | Here's a table with some example rate settings close to some commonly used sample rates | ||
+ | |||
+ | ^ Hex ^ Sample Rate (Hz) ^ Closest Common Rate ^ Difference ^ ACP cycles per sample ^ | ||
+ | | **$FF** | **13983** | N/A (Lowest setting) | ||
+ | | **$EF** | **15980** | 16000 | 19.9 | 896 | | ||
+ | | **$D0** | **22233** | 22050 | 183.2 | 644 | | ||
+ | | **$B7** | **31960** | 32000 | 39.8 | 448 | | ||
+ | | **$A8** | **44192** | 44100 | 91.9 | 324 | | ||
+ | | **$A5** | **47099** | 32000 | 900.7 :( | 304 | | ||
+ | | **$94** | **87306** | 88200 | 894.0 :( | 164 | | ||
+ | | **$92** | **96744** | 96000 | 744.5 :( | 148 | | ||
+ | |||
==== Initializing the audio system ==== | ==== Initializing the audio system ==== | ||
Line 43: | Line 65: | ||
Whichever value you choose for audio rate, the highest bit of $2006 should be set to enable the ACP. | Whichever value you choose for audio rate, the highest bit of $2006 should be set to enable the ACP. | ||
+ | |||
+ | Example ASM code: | ||
+ | |||
+ | <code ASM> | ||
+ | LDA #0 | ||
+ | STA $2006 ; audio rate/enable register | ||
+ | JSR CopyMyAudioProgramIntoAudioRam | ||
+ | LDA #0 | ||
+ | STA $2000 ; audio reset | ||
+ | LDA #255 | ||
+ | STA $2006 ; 255 sets enable bit and lowest sample rate / highest cycles per sample | ||
+ | </ |
hardware/audio.1740854919.txt.gz · Last modified: 2025/03/01 18:48 by clyde