Hyper Voice: Difference between revisions
No edit summary |
|||
Line 37: | Line 37: | ||
15 bit 8 7 bit 0 | 15 bit 8 7 bit 0 | ||
---- ---- ---- ---- | ---- ---- ---- ---- | ||
. | .ttc ???? errr ssvv | ||
||| |||| |||| | ||| |||| |||| | ||
||| |||| ||++- Shift | ||| |||| ||++- Volume/Shift: | ||
||| |||| || 0 = 100% 1 = 50% | ||| |||| || 0 = 100% 1 = 50% | ||
||| |||| || 2 = 25% 3 = 12.5% | ||| |||| || 2 = 25% 3 = 12.5% | ||
||| |||| ++--- Sample | ||| |||| ++--- Sample extension mode: | ||
||| |||| 0 = Unsigned | ||| |||| 0 = Unsigned | ||
||| |||| 1 = Unsigned, negated | ||| |||| 1 = Unsigned, negated | ||
Line 59: | Line 59: | ||
||+----------------- Reset: When 1 is written, the following DMA sample | ||+----------------- Reset: When 1 is written, the following DMA sample | ||
|| will be used for the left channel. | || will be used for the left channel. | ||
++------------------ | ++------------------ Target channel layout: | ||
0 = Stereo | 0 = Stereo | ||
1 = Mono, left channel only | 1 = Mono, left channel only | ||
Line 69: | Line 69: | ||
{| class="wikitable" | {| class="wikitable" | ||
! Sample | ! Sample extension mode | ||
! Bit representation | ! Bit representation | ||
|- | |- |
Latest revision as of 08:49, 4 May 2025
Hyper Voice is a headphone-only sample output channel introduced with the WonderSwan Color. It allows converting 8-bit signed and unsigned, mono and stereo samples into 16-bit signed PCM sent directly to the headphone output, after mixing with the traditional four channels.
I/O Ports
Hyper Voice Left Output ($64, $65 write)
Hyper Voice Right Output ($66, $67 write)
15 bit 8 7 bit 0 ---- ---- ---- ---- ssss ssss ssss ssss |||| |||| |||| |||| ++++-++++--++++-++++- Signed 16-bit sample.
Unlike the Sound sample output registers, these can be written to - allowing for direct 16-bit sample output.
Hyper Voice Input ($69 write)
7 bit 0 ---- ---- ssss ssss |||| |||| ++++-++++- Signed 8-bit sample.
Hyper Voice samples are typically written by Sound DMA, but can also be written manually by the user. In the latter case, the "channel mode" setting is ignored - it always behaves as if it were in "stereo" mode, writing one channel after the other in sequence.
Hyper Voice Control ($6A, $6B)
15 bit 8 7 bit 0 ---- ---- ---- ---- .ttc ???? errr ssvv ||| |||| |||| ||| |||| ||++- Volume/Shift: ||| |||| || 0 = 100% 1 = 50% ||| |||| || 2 = 25% 3 = 12.5% ||| |||| ++--- Sample extension mode: ||| |||| 0 = Unsigned ||| |||| 1 = Unsigned, negated ||| |||| 2 = Signed ||| |||| 3 = Ignored ||| |+++------ Update sample rate/Divisor: ||| | 0 = 24000/1 = 24000 Hz ||| | 1 = 24000/2 = 12000 Hz ||| | 2 = 24000/3 = 8000 Hz ||| | 3 = 24000/4 = 6000 Hz ||| | 4 = 24000/5 = 4800 Hz ||| | 5 = 24000/6 = 4000 Hz ||| | 6 = 24000/8 = 3000 Hz ||| | 7 = 24000/12 = 2000 Hz ||| +--------- Enable: 0 = off, 1 = on ||+----------------- Reset: When 1 is written, the following DMA sample || will be used for the left channel. ++------------------ Target channel layout: 0 = Stereo 1 = Mono, left channel only 2 = Mono, right channel only 3 = Mono, both channels
Internally, 8-bit values of the form Vvvv vvvv are transformed to signed 16-bit samples based on the scaling mode as follows, where V
represents the highest, 7th bit of the input value:
Sample extension mode | Bit representation |
---|---|
Unsigned | 000 Vvvv vvvv 0000 0000 |
Unsigned, negated | 111 Vvvv vvvv 0000 0000 |
Signed | VVV Vvvv vvvv 0000 0000 |
Ignored | ___ Vvvv vvvv 0000 0000 |
With the exception of the Ignored mode, the resulting value is shifted right by Shift
bits, and the result's bottom 16 bits are used as the sample.