mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-30 16:07:39 +00:00
Input: keyboard - "keycode & KEY_MAX" changes some keycode values
For exmaple, keycode: KEY_OK(0x160) is changed by "and" operation with KEY_MAX(0x2ff) to KEY_KPENTER(96). Signed-off-by: Andrew Liu <andrew.liu200917@gmail.com> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
This commit is contained in:
parent
5cf0eb9875
commit
e4cfb034e8
4 changed files with 11 additions and 5 deletions
|
@ -536,7 +536,8 @@ static int adp5588_probe(struct i2c_client *client,
|
||||||
__set_bit(EV_REP, input->evbit);
|
__set_bit(EV_REP, input->evbit);
|
||||||
|
|
||||||
for (i = 0; i < input->keycodemax; i++)
|
for (i = 0; i < input->keycodemax; i++)
|
||||||
__set_bit(kpad->keycode[i] & KEY_MAX, input->keybit);
|
if (kpad->keycode[i] <= KEY_MAX)
|
||||||
|
__set_bit(kpad->keycode[i], input->keybit);
|
||||||
__clear_bit(KEY_RESERVED, input->keybit);
|
__clear_bit(KEY_RESERVED, input->keybit);
|
||||||
|
|
||||||
if (kpad->gpimapsize)
|
if (kpad->gpimapsize)
|
||||||
|
|
|
@ -992,7 +992,8 @@ static int adp5589_probe(struct i2c_client *client,
|
||||||
__set_bit(EV_REP, input->evbit);
|
__set_bit(EV_REP, input->evbit);
|
||||||
|
|
||||||
for (i = 0; i < input->keycodemax; i++)
|
for (i = 0; i < input->keycodemax; i++)
|
||||||
__set_bit(kpad->keycode[i] & KEY_MAX, input->keybit);
|
if (kpad->keycode[i] <= KEY_MAX)
|
||||||
|
__set_bit(kpad->keycode[i], input->keybit);
|
||||||
__clear_bit(KEY_RESERVED, input->keybit);
|
__clear_bit(KEY_RESERVED, input->keybit);
|
||||||
|
|
||||||
if (kpad->gpimapsize)
|
if (kpad->gpimapsize)
|
||||||
|
|
|
@ -289,7 +289,8 @@ static int bfin_kpad_probe(struct platform_device *pdev)
|
||||||
__set_bit(EV_REP, input->evbit);
|
__set_bit(EV_REP, input->evbit);
|
||||||
|
|
||||||
for (i = 0; i < input->keycodemax; i++)
|
for (i = 0; i < input->keycodemax; i++)
|
||||||
__set_bit(bf54x_kpad->keycode[i] & KEY_MAX, input->keybit);
|
if (bf54x_kpad->keycode[i] <= KEY_MAX)
|
||||||
|
__set_bit(bf54x_kpad->keycode[i], input->keybit);
|
||||||
__clear_bit(KEY_RESERVED, input->keybit);
|
__clear_bit(KEY_RESERVED, input->keybit);
|
||||||
|
|
||||||
error = input_register_device(input);
|
error = input_register_device(input);
|
||||||
|
|
|
@ -113,9 +113,12 @@ static int pcf8574_kp_probe(struct i2c_client *client, const struct i2c_device_i
|
||||||
idev->keycodemax = ARRAY_SIZE(lp->btncode);
|
idev->keycodemax = ARRAY_SIZE(lp->btncode);
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(pcf8574_kp_btncode); i++) {
|
for (i = 0; i < ARRAY_SIZE(pcf8574_kp_btncode); i++) {
|
||||||
lp->btncode[i] = pcf8574_kp_btncode[i];
|
if (lp->btncode[i] <= KEY_MAX) {
|
||||||
__set_bit(lp->btncode[i] & KEY_MAX, idev->keybit);
|
lp->btncode[i] = pcf8574_kp_btncode[i];
|
||||||
|
__set_bit(lp->btncode[i], idev->keybit);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
__clear_bit(KEY_RESERVED, idev->keybit);
|
||||||
|
|
||||||
sprintf(lp->name, DRV_NAME);
|
sprintf(lp->name, DRV_NAME);
|
||||||
sprintf(lp->phys, "kp_data/input0");
|
sprintf(lp->phys, "kp_data/input0");
|
||||||
|
|
Loading…
Reference in a new issue