Commit bca5174b authored by Oswald Buddenhagen's avatar Oswald Buddenhagen Committed by Takashi Iwai

ALSA: emu10k1: fix playback of 8-bit wavetable samples

Samples are byte-sized in this mode, and thus the offset calculation
needs no shifting.
Signed-off-by: default avatarOswald Buddenhagen <oswald.buddenhagen@gmx.de>
Message-ID: <20240406064830.1029573-11-oswald.buddenhagen@gmx.de>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 38fc804a
...@@ -310,6 +310,7 @@ start_voice(struct snd_emux_voice *vp) ...@@ -310,6 +310,7 @@ start_voice(struct snd_emux_voice *vp)
{ {
unsigned int temp; unsigned int temp;
int ch; int ch;
bool w_16;
u32 psst, dsl, map, ccca, vtarget; u32 psst, dsl, map, ccca, vtarget;
unsigned int addr, mapped_offset; unsigned int addr, mapped_offset;
struct snd_midi_channel *chan; struct snd_midi_channel *chan;
...@@ -321,6 +322,7 @@ start_voice(struct snd_emux_voice *vp) ...@@ -321,6 +322,7 @@ start_voice(struct snd_emux_voice *vp)
if (snd_BUG_ON(ch < 0)) if (snd_BUG_ON(ch < 0))
return -EINVAL; return -EINVAL;
chan = vp->chan; chan = vp->chan;
w_16 = !(vp->reg.sample_mode & SNDRV_SFNT_SAMPLE_8BITS);
emem = (struct snd_emu10k1_memblk *)vp->block; emem = (struct snd_emu10k1_memblk *)vp->block;
if (emem == NULL) if (emem == NULL)
...@@ -330,7 +332,7 @@ start_voice(struct snd_emux_voice *vp) ...@@ -330,7 +332,7 @@ start_voice(struct snd_emux_voice *vp)
/* dev_err(hw->card->devK, "emu: cannot map!\n"); */ /* dev_err(hw->card->devK, "emu: cannot map!\n"); */
return -ENOMEM; return -ENOMEM;
} }
mapped_offset = snd_emu10k1_memblk_offset(emem) >> 1; mapped_offset = snd_emu10k1_memblk_offset(emem) >> w_16;
vp->reg.start += mapped_offset; vp->reg.start += mapped_offset;
vp->reg.end += mapped_offset; vp->reg.end += mapped_offset;
vp->reg.loopstart += mapped_offset; vp->reg.loopstart += mapped_offset;
...@@ -371,7 +373,7 @@ start_voice(struct snd_emux_voice *vp) ...@@ -371,7 +373,7 @@ start_voice(struct snd_emux_voice *vp)
unsigned int shift = (vp->apitch - 0xe000) >> 10; unsigned int shift = (vp->apitch - 0xe000) >> 10;
ccca |= shift << 25; ccca |= shift << 25;
} }
if (vp->reg.sample_mode & SNDRV_SFNT_SAMPLE_8BITS) if (!w_16)
ccca |= CCCA_8BITSELECT; ccca |= CCCA_8BITSELECT;
vtarget = (unsigned int)vp->vtarget << 16; vtarget = (unsigned int)vp->vtarget << 16;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment