Staging: iio: max1363 Fix two bugs in single_channel_from_ring
authorJonathan Cameron <jic23@cam.ac.uk>
Sun, 16 May 2010 20:29:25 +0000 (21:29 +0100)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 18 May 2010 21:43:08 +0000 (14:43 -0700)
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>
drivers/staging/iio/adc/max1363_ring.c

index c8aa01109ec2a7c7314282c5aa5662d08de026ef..56688dc9c92f37f073737617627726246e438219 100644 (file)
@@ -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);