From: Jiri Kosina Date: Fri, 28 Oct 2011 16:15:02 +0000 (+0200) Subject: HID: ignore absolute values which don't fit between logical min and max X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=6da7066906e977d42104a859c490f5f9a300488c;p=openwrt%2Fstaging%2Fblogic.git HID: ignore absolute values which don't fit between logical min and max Linux should ignore values outside logical min/max range, as they are not meaningful. This is what at least some of other OSes do, and it also makes sense (currently the value gets misinterpreted larger up the stack). Reported-by: Denilson Figueiredo de Sá Tested-by: Denilson Figueiredo de Sá Signed-off-by: Jiri Kosina --- diff --git a/drivers/hid/hid-input.c b/drivers/hid/hid-input.c index f333139d1a48..b7b0d55c0ede 100644 --- a/drivers/hid/hid-input.c +++ b/drivers/hid/hid-input.c @@ -822,6 +822,13 @@ void hidinput_hid_event(struct hid_device *hid, struct hid_field *field, struct return; } + /* Ignore absolute values that are out of bounds */ + if ((usage->type == EV_ABS && (value < field->logical_minimum || + value > field->logical_maximum))) { + dbg_hid("Ignoring out-of-range value %x\n", value); + return; + } + /* report the usage code as scancode if the key status has changed */ if (usage->type == EV_KEY && !!test_bit(usage->code, input->key) != value) input_event(input, EV_MSC, MSC_SCAN, usage->hid);