forked from Minki/linux
ALSA: fireworks: fix an endianness bug for transaction length
Although the 't->length' is a big-endian value, it's used without any conversion. This means that the driver always uses 'length' parameter. Fixes: 555e8a8f7f14("ALSA: fireworks: Add command/response functionality into hwdep interface") Reported-by: Clemens Ladisch <clemens@ladisch.de> Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
60834b73a9
commit
92cb46584e
@ -124,7 +124,7 @@ copy_resp_to_buf(struct snd_efw *efw, void *data, size_t length, int *rcode)
|
|||||||
spin_lock_irq(&efw->lock);
|
spin_lock_irq(&efw->lock);
|
||||||
|
|
||||||
t = (struct snd_efw_transaction *)data;
|
t = (struct snd_efw_transaction *)data;
|
||||||
length = min_t(size_t, t->length * sizeof(t->length), length);
|
length = min_t(size_t, be32_to_cpu(t->length) * sizeof(u32), length);
|
||||||
|
|
||||||
if (efw->push_ptr < efw->pull_ptr)
|
if (efw->push_ptr < efw->pull_ptr)
|
||||||
capacity = (unsigned int)(efw->pull_ptr - efw->push_ptr);
|
capacity = (unsigned int)(efw->pull_ptr - efw->push_ptr);
|
||||||
|
Loading…
Reference in New Issue
Block a user