diff mbox

ALSA: fireworks: fix an endianness bug for transaction length

Message ID 1420644676-29863-1-git-send-email-o-takashi@sakamocchi.jp (mailing list archive)
State Accepted
Commit 92cb46584e104e2f4b14a44959109ffe13524a26
Headers show

Commit Message

Takashi Sakamoto Jan. 7, 2015, 3:31 p.m. UTC
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>
---
 sound/firewire/fireworks/fireworks_transaction.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Takashi Iwai Jan. 7, 2015, 3:40 p.m. UTC | #1
At Thu,  8 Jan 2015 00:31:16 +0900,
Takashi Sakamoto wrote:
> 
> 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>

Applied, thanks.


Takashi

> ---
>  sound/firewire/fireworks/fireworks_transaction.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/sound/firewire/fireworks/fireworks_transaction.c b/sound/firewire/fireworks/fireworks_transaction.c
> index 255dabc..2a85e42 100644
> --- a/sound/firewire/fireworks/fireworks_transaction.c
> +++ b/sound/firewire/fireworks/fireworks_transaction.c
> @@ -124,7 +124,7 @@ copy_resp_to_buf(struct snd_efw *efw, void *data, size_t length, int *rcode)
>  	spin_lock_irq(&efw->lock);
>  
>  	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)
>  		capacity = (unsigned int)(efw->pull_ptr - efw->push_ptr);
> -- 
> 2.1.0
>
diff mbox

Patch

diff --git a/sound/firewire/fireworks/fireworks_transaction.c b/sound/firewire/fireworks/fireworks_transaction.c
index 255dabc..2a85e42 100644
--- a/sound/firewire/fireworks/fireworks_transaction.c
+++ b/sound/firewire/fireworks/fireworks_transaction.c
@@ -124,7 +124,7 @@  copy_resp_to_buf(struct snd_efw *efw, void *data, size_t length, int *rcode)
 	spin_lock_irq(&efw->lock);
 
 	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)
 		capacity = (unsigned int)(efw->pull_ptr - efw->push_ptr);