Input: ff-memless - fix a couple min_t() casts
authorDan Carpenter <dan.carpenter@oracle.com>
Sun, 8 Jul 2012 01:17:54 +0000 (18:17 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Sun, 8 Jul 2012 01:20:12 +0000 (18:20 -0700)
envelope->attack_level is a u16 type.  We're trying to clamp it here
so it's between 0 and 0x7fff.  Unfortunately, the cast to __s16 turns
all the values larger than 0x7fff into negative numbers and min_t()
thinks they are less than 0x7fff.  envelope_level is an int so now
we've got negative values stored there.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
drivers/input/ff-memless.c

index 5f558851d6467cbeda592c17d3343a80f83db49f..b107922514fb378a89e8951d985a0e89d5ed481d 100644 (file)
@@ -176,7 +176,7 @@ static int apply_envelope(struct ml_effect_state *state, int value,
                         value, envelope->attack_level);
                time_from_level = jiffies_to_msecs(now - state->play_at);
                time_of_envelope = envelope->attack_length;
-               envelope_level = min_t(__s16, envelope->attack_level, 0x7fff);
+               envelope_level = min_t(u16, envelope->attack_level, 0x7fff);
 
        } else if (envelope->fade_length && effect->replay.length &&
                   time_after(now,
@@ -184,7 +184,7 @@ static int apply_envelope(struct ml_effect_state *state, int value,
                   time_before(now, state->stop_at)) {
                time_from_level = jiffies_to_msecs(state->stop_at - now);
                time_of_envelope = envelope->fade_length;
-               envelope_level = min_t(__s16, envelope->fade_level, 0x7fff);
+               envelope_level = min_t(u16, envelope->fade_level, 0x7fff);
        } else
                return value;