mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-04 03:33:58 +08:00
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: Jonathan Cameron <jic23@cam.ac.uk> Reported-by: Michael Hennerich <Michael.Hennerich@analog.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
9a3af585e7
commit
81b77f94a1
@ -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 */
|
||||
mask >>= 1;
|
||||
while (mask) {
|
||||
if (mask && st->current_mode->modemask)
|
||||
if (mask & st->current_mode->modemask)
|
||||
count++;
|
||||
mask >>= 1;
|
||||
}
|
||||
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]);
|
||||
else
|
||||
return ring_data[count];
|
||||
ret = ring_data[count];
|
||||
|
||||
error_free_ring_data:
|
||||
kfree(ring_data);
|
||||
|
Loading…
Reference in New Issue
Block a user