* [PATCH, for-next] ALSA: usb-audio: caiaq: fix endianness bug in snd_usb_caiaq_maschine_dispatch
@ 2013-04-29 19:15 Eldad Zack
2013-04-29 19:20 ` Daniel Mack
0 siblings, 1 reply; 3+ messages in thread
From: Eldad Zack @ 2013-04-29 19:15 UTC (permalink / raw)
To: Takashi Iwai, Jaroslav Kysela, Daniel Mack; +Cc: alsa-devel, Eldad Zack
Current code does this:
be16_to_cpu(buf[i * 2] << 8 | buf[(i * 2) + 1])
Which is effectively (neglecting the index):
be16_to_cpu(be16_to_cpu(*((u16 *) buf)))
This means the int16 in the buffer is not converted at all.
Daniel Mack confirmed that the driver works on little endian
CPUs, leading to the conclusion that the device-side structure
is actually little endian.
This changes the code to use le16_to_cpu().
Caught by sparse.
Acked-by: Daniel Mack <zonque@gmail.com>
Signed-off-by: Eldad Zack <eldad@fogrefinery.com>
---
sound/usb/caiaq/input.c | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/sound/usb/caiaq/input.c b/sound/usb/caiaq/input.c
index efc70ae..4b3fb91 100644
--- a/sound/usb/caiaq/input.c
+++ b/sound/usb/caiaq/input.c
@@ -488,13 +488,13 @@ static void snd_usb_caiaq_maschine_dispatch(struct snd_usb_caiaqdev *cdev,
unsigned int len)
{
unsigned int i, pad_id;
- uint16_t pressure;
+ __le16 *pressure = (__le16 *) buf;
for (i = 0; i < MASCHINE_PADS; i++) {
- pressure = be16_to_cpu(buf[i * 2] << 8 | buf[(i * 2) + 1]);
- pad_id = pressure >> 12;
-
- input_report_abs(cdev->input_dev, MASCHINE_PAD(pad_id), pressure & 0xfff);
+ pad_id = le16_to_cpu(*pressure) >> 12;
+ input_report_abs(cdev->input_dev, MASCHINE_PAD(pad_id),
+ le16_to_cpu(*pressure) & 0xfff);
+ pressure++;
}
input_sync(cdev->input_dev);
--
1.8.1.5
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH, for-next] ALSA: usb-audio: caiaq: fix endianness bug in snd_usb_caiaq_maschine_dispatch
2013-04-29 19:15 [PATCH, for-next] ALSA: usb-audio: caiaq: fix endianness bug in snd_usb_caiaq_maschine_dispatch Eldad Zack
@ 2013-04-29 19:20 ` Daniel Mack
2013-04-30 7:19 ` Takashi Iwai
0 siblings, 1 reply; 3+ messages in thread
From: Daniel Mack @ 2013-04-29 19:20 UTC (permalink / raw)
To: Eldad Zack; +Cc: Takashi Iwai, alsa-devel
On 29.04.2013 21:15, Eldad Zack wrote:
> Current code does this:
>
> be16_to_cpu(buf[i * 2] << 8 | buf[(i * 2) + 1])
>
> Which is effectively (neglecting the index):
>
> be16_to_cpu(be16_to_cpu(*((u16 *) buf)))
>
> This means the int16 in the buffer is not converted at all.
>
> Daniel Mack confirmed that the driver works on little endian
> CPUs, leading to the conclusion that the device-side structure
> is actually little endian.
> This changes the code to use le16_to_cpu().
>
> Caught by sparse.
>
> Acked-by: Daniel Mack <zonque@gmail.com>
> Signed-off-by: Eldad Zack <eldad@fogrefinery.com>
Appearantly, nobody (including me) has ever used the pad controls of
this particular device on a BE machine. So I think it might not even be
worth Cc'ing stable.
Thanks for catching this, anyway!
Daniel
> ---
> sound/usb/caiaq/input.c | 10 +++++-----
> 1 file changed, 5 insertions(+), 5 deletions(-)
>
> diff --git a/sound/usb/caiaq/input.c b/sound/usb/caiaq/input.c
> index efc70ae..4b3fb91 100644
> --- a/sound/usb/caiaq/input.c
> +++ b/sound/usb/caiaq/input.c
> @@ -488,13 +488,13 @@ static void snd_usb_caiaq_maschine_dispatch(struct snd_usb_caiaqdev *cdev,
> unsigned int len)
> {
> unsigned int i, pad_id;
> - uint16_t pressure;
> + __le16 *pressure = (__le16 *) buf;
>
> for (i = 0; i < MASCHINE_PADS; i++) {
> - pressure = be16_to_cpu(buf[i * 2] << 8 | buf[(i * 2) + 1]);
> - pad_id = pressure >> 12;
> -
> - input_report_abs(cdev->input_dev, MASCHINE_PAD(pad_id), pressure & 0xfff);
> + pad_id = le16_to_cpu(*pressure) >> 12;
> + input_report_abs(cdev->input_dev, MASCHINE_PAD(pad_id),
> + le16_to_cpu(*pressure) & 0xfff);
> + pressure++;
> }
>
> input_sync(cdev->input_dev);
>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH, for-next] ALSA: usb-audio: caiaq: fix endianness bug in snd_usb_caiaq_maschine_dispatch
2013-04-29 19:20 ` Daniel Mack
@ 2013-04-30 7:19 ` Takashi Iwai
0 siblings, 0 replies; 3+ messages in thread
From: Takashi Iwai @ 2013-04-30 7:19 UTC (permalink / raw)
To: Daniel Mack; +Cc: Eldad Zack, alsa-devel
At Mon, 29 Apr 2013 21:20:43 +0200,
Daniel Mack wrote:
>
> On 29.04.2013 21:15, Eldad Zack wrote:
> > Current code does this:
> >
> > be16_to_cpu(buf[i * 2] << 8 | buf[(i * 2) + 1])
> >
> > Which is effectively (neglecting the index):
> >
> > be16_to_cpu(be16_to_cpu(*((u16 *) buf)))
> >
> > This means the int16 in the buffer is not converted at all.
> >
> > Daniel Mack confirmed that the driver works on little endian
> > CPUs, leading to the conclusion that the device-side structure
> > is actually little endian.
> > This changes the code to use le16_to_cpu().
> >
> > Caught by sparse.
> >
> > Acked-by: Daniel Mack <zonque@gmail.com>
> > Signed-off-by: Eldad Zack <eldad@fogrefinery.com>
>
> Appearantly, nobody (including me) has ever used the pad controls of
> this particular device on a BE machine. So I think it might not even be
> worth Cc'ing stable.
OK. Applied as is now.
Thanks.
Takashi
>
>
> Thanks for catching this, anyway!
>
> Daniel
>
>
>
> > ---
> > sound/usb/caiaq/input.c | 10 +++++-----
> > 1 file changed, 5 insertions(+), 5 deletions(-)
> >
> > diff --git a/sound/usb/caiaq/input.c b/sound/usb/caiaq/input.c
> > index efc70ae..4b3fb91 100644
> > --- a/sound/usb/caiaq/input.c
> > +++ b/sound/usb/caiaq/input.c
> > @@ -488,13 +488,13 @@ static void snd_usb_caiaq_maschine_dispatch(struct snd_usb_caiaqdev *cdev,
> > unsigned int len)
> > {
> > unsigned int i, pad_id;
> > - uint16_t pressure;
> > + __le16 *pressure = (__le16 *) buf;
> >
> > for (i = 0; i < MASCHINE_PADS; i++) {
> > - pressure = be16_to_cpu(buf[i * 2] << 8 | buf[(i * 2) + 1]);
> > - pad_id = pressure >> 12;
> > -
> > - input_report_abs(cdev->input_dev, MASCHINE_PAD(pad_id), pressure & 0xfff);
> > + pad_id = le16_to_cpu(*pressure) >> 12;
> > + input_report_abs(cdev->input_dev, MASCHINE_PAD(pad_id),
> > + le16_to_cpu(*pressure) & 0xfff);
> > + pressure++;
> > }
> >
> > input_sync(cdev->input_dev);
> >
>
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2013-04-30 7:19 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-04-29 19:15 [PATCH, for-next] ALSA: usb-audio: caiaq: fix endianness bug in snd_usb_caiaq_maschine_dispatch Eldad Zack
2013-04-29 19:20 ` Daniel Mack
2013-04-30 7:19 ` Takashi Iwai
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.