Commit 81b77f94 authored by Jonathan Cameron's avatar Jonathan Cameron Committed by Greg Kroah-Hartman

Staging: iio: max1363 Fix two bugs in single_channel_from_ring

This patch contains fixes for the two bugs Michael pointed
out last week.  As the other suggestion Michael made is
not a bug fix (just a much more sensible way of handling
things), I'll do that as a separate patch soon.

The bugs were introduced with the abi changes.
Signed-off-by: default avatarJonathan Cameron <jic23@cam.ac.uk>
Reported-by: default avatarMichael Hennerich <Michael.Hennerich@analog.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 9a3af585
...@@ -51,15 +51,15 @@ int max1363_single_channel_from_ring(long mask, struct max1363_state *st) ...@@ -51,15 +51,15 @@ int max1363_single_channel_from_ring(long mask, struct max1363_state *st)
/* Need a count of channels prior to this one */ /* Need a count of channels prior to this one */
mask >>= 1; mask >>= 1;
while (mask) { while (mask) {
if (mask && st->current_mode->modemask) if (mask & st->current_mode->modemask)
count++; count++;
mask >>= 1; mask >>= 1;
} }
if (st->chip_info->bits != 8) if (st->chip_info->bits != 8)
return ((int)(ring_data[count*2 + 0] & 0x0F) << 8) ret = ((int)(ring_data[count*2 + 0] & 0x0F) << 8)
+ (int)(ring_data[count*2 + 1]); + (int)(ring_data[count*2 + 1]);
else else
return ring_data[count]; ret = ring_data[count];
error_free_ring_data: error_free_ring_data:
kfree(ring_data); kfree(ring_data);
......
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