diff mbox

ALSA: firewire-motu: remove invalid bitshift for register value

Message ID 20170403121350.19579-1-o-takashi@sakamocchi.jp (mailing list archive)
State New, archived
Headers show

Commit Message

Takashi Sakamoto April 3, 2017, 12:13 p.m. UTC
In protocol version 3, drivers can read current sampling clock status from
register 0x'ffff'f000'0b14. 8 bits of LSB of this register represents type
of signal as source of clock.

Current driver code includes invalid bitshift to handle the parameter. This
commit fixes the bug.

Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Fixes: 5992e30034c4 ("ALSA: firewire-motu: add support for MOTU 828mk3 (FireWire/Hybrid) as a model with protocol version 3")
Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
---
 sound/firewire/motu/motu-protocol-v3.c | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)

Comments

Takashi Iwai April 5, 2017, 7:38 p.m. UTC | #1
On Mon, 03 Apr 2017 14:13:50 +0200,
Takashi Sakamoto wrote:
> 
> In protocol version 3, drivers can read current sampling clock status from
> register 0x'ffff'f000'0b14. 8 bits of LSB of this register represents type
> of signal as source of clock.
> 
> Current driver code includes invalid bitshift to handle the parameter. This
> commit fixes the bug.
> 
> Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
> Fixes: 5992e30034c4 ("ALSA: firewire-motu: add support for MOTU 828mk3 (FireWire/Hybrid) as a model with protocol version 3")
> Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>

Applied to for-next branch now.  Thanks.


Takashi

> ---
>  sound/firewire/motu/motu-protocol-v3.c | 3 +--
>  1 file changed, 1 insertion(+), 2 deletions(-)
> 
> diff --git a/sound/firewire/motu/motu-protocol-v3.c b/sound/firewire/motu/motu-protocol-v3.c
> index b463da9..ddb6472 100644
> --- a/sound/firewire/motu/motu-protocol-v3.c
> +++ b/sound/firewire/motu/motu-protocol-v3.c
> @@ -14,7 +14,6 @@
>  #define  V3_CLOCK_RATE_MASK		0x0000ff00
>  #define  V3_CLOCK_RATE_SHIFT		8
>  #define  V3_CLOCK_SOURCE_MASK		0x000000ff
> -#define  V3_CLOCK_SOURCE_SHIFT		8
>  
>  #define V3_OPT_IFACE_MODE_OFFSET	0x0c94
>  #define  V3_ENABLE_OPT_IN_IFACE_A	0x00000001
> @@ -101,7 +100,7 @@ static int v3_get_clock_source(struct snd_motu *motu,
>  		return err;
>  	data = be32_to_cpu(reg);
>  
> -	val = (data & V3_CLOCK_SOURCE_MASK) >> V3_CLOCK_SOURCE_SHIFT;
> +	val = data & V3_CLOCK_SOURCE_MASK;
>  	if (val == 0x00) {
>  		*src = SND_MOTU_CLOCK_SOURCE_INTERNAL;
>  	} else if (val == 0x01) {
> -- 
> 2.9.3
>
diff mbox

Patch

diff --git a/sound/firewire/motu/motu-protocol-v3.c b/sound/firewire/motu/motu-protocol-v3.c
index b463da9..ddb6472 100644
--- a/sound/firewire/motu/motu-protocol-v3.c
+++ b/sound/firewire/motu/motu-protocol-v3.c
@@ -14,7 +14,6 @@ 
 #define  V3_CLOCK_RATE_MASK		0x0000ff00
 #define  V3_CLOCK_RATE_SHIFT		8
 #define  V3_CLOCK_SOURCE_MASK		0x000000ff
-#define  V3_CLOCK_SOURCE_SHIFT		8
 
 #define V3_OPT_IFACE_MODE_OFFSET	0x0c94
 #define  V3_ENABLE_OPT_IN_IFACE_A	0x00000001
@@ -101,7 +100,7 @@  static int v3_get_clock_source(struct snd_motu *motu,
 		return err;
 	data = be32_to_cpu(reg);
 
-	val = (data & V3_CLOCK_SOURCE_MASK) >> V3_CLOCK_SOURCE_SHIFT;
+	val = data & V3_CLOCK_SOURCE_MASK;
 	if (val == 0x00) {
 		*src = SND_MOTU_CLOCK_SOURCE_INTERNAL;
 	} else if (val == 0x01) {