diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2009-08-14 16:58:45 -0400 |
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2009-08-14 16:58:45 -0400 |
| commit | d2dcd9101b1a940ce8496601ba871e47f84881ec (patch) | |
| tree | 3de9cb11379d51eb01b568a20c8d7c585c89d10e /drivers/input/keyboard/matrix_keypad.c | |
| parent | 8010fbe7a67c2f993cbb11b9d8b7e98528256dd1 (diff) | |
| parent | 606b4c992f3b28f906100f1b6eb49059909d8da7 (diff) | |
Merge branch 'master' into sh/cachetlb
Diffstat (limited to 'drivers/input/keyboard/matrix_keypad.c')
| -rw-r--r-- | drivers/input/keyboard/matrix_keypad.c | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/drivers/input/keyboard/matrix_keypad.c b/drivers/input/keyboard/matrix_keypad.c index e9b2e7cb05be..541b981ff075 100644 --- a/drivers/input/keyboard/matrix_keypad.c +++ b/drivers/input/keyboard/matrix_keypad.c | |||
| @@ -27,6 +27,7 @@ struct matrix_keypad { | |||
| 27 | const struct matrix_keypad_platform_data *pdata; | 27 | const struct matrix_keypad_platform_data *pdata; |
| 28 | struct input_dev *input_dev; | 28 | struct input_dev *input_dev; |
| 29 | unsigned short *keycodes; | 29 | unsigned short *keycodes; |
| 30 | unsigned int row_shift; | ||
| 30 | 31 | ||
| 31 | uint32_t last_key_state[MATRIX_MAX_COLS]; | 32 | uint32_t last_key_state[MATRIX_MAX_COLS]; |
| 32 | struct delayed_work work; | 33 | struct delayed_work work; |
| @@ -136,7 +137,7 @@ static void matrix_keypad_scan(struct work_struct *work) | |||
| 136 | if ((bits_changed & (1 << row)) == 0) | 137 | if ((bits_changed & (1 << row)) == 0) |
| 137 | continue; | 138 | continue; |
| 138 | 139 | ||
| 139 | code = (row << 4) + col; | 140 | code = MATRIX_SCAN_CODE(row, col, keypad->row_shift); |
| 140 | input_event(input_dev, EV_MSC, MSC_SCAN, code); | 141 | input_event(input_dev, EV_MSC, MSC_SCAN, code); |
| 141 | input_report_key(input_dev, | 142 | input_report_key(input_dev, |
| 142 | keypad->keycodes[code], | 143 | keypad->keycodes[code], |
| @@ -317,6 +318,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 317 | struct matrix_keypad *keypad; | 318 | struct matrix_keypad *keypad; |
| 318 | struct input_dev *input_dev; | 319 | struct input_dev *input_dev; |
| 319 | unsigned short *keycodes; | 320 | unsigned short *keycodes; |
| 321 | unsigned int row_shift; | ||
| 320 | int i; | 322 | int i; |
| 321 | int err; | 323 | int err; |
| 322 | 324 | ||
| @@ -332,14 +334,11 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 332 | return -EINVAL; | 334 | return -EINVAL; |
| 333 | } | 335 | } |
| 334 | 336 | ||
| 335 | if (!keymap_data->max_keymap_size) { | 337 | row_shift = get_count_order(pdata->num_col_gpios); |
| 336 | dev_err(&pdev->dev, "invalid keymap data supplied\n"); | ||
| 337 | return -EINVAL; | ||
| 338 | } | ||
| 339 | 338 | ||
| 340 | keypad = kzalloc(sizeof(struct matrix_keypad), GFP_KERNEL); | 339 | keypad = kzalloc(sizeof(struct matrix_keypad), GFP_KERNEL); |
| 341 | keycodes = kzalloc(keymap_data->max_keymap_size * | 340 | keycodes = kzalloc((pdata->num_row_gpios << row_shift) * |
| 342 | sizeof(keypad->keycodes), | 341 | sizeof(*keycodes), |
| 343 | GFP_KERNEL); | 342 | GFP_KERNEL); |
| 344 | input_dev = input_allocate_device(); | 343 | input_dev = input_allocate_device(); |
| 345 | if (!keypad || !keycodes || !input_dev) { | 344 | if (!keypad || !keycodes || !input_dev) { |
| @@ -350,6 +349,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 350 | keypad->input_dev = input_dev; | 349 | keypad->input_dev = input_dev; |
| 351 | keypad->pdata = pdata; | 350 | keypad->pdata = pdata; |
| 352 | keypad->keycodes = keycodes; | 351 | keypad->keycodes = keycodes; |
| 352 | keypad->row_shift = row_shift; | ||
| 353 | keypad->stopped = true; | 353 | keypad->stopped = true; |
| 354 | INIT_DELAYED_WORK(&keypad->work, matrix_keypad_scan); | 354 | INIT_DELAYED_WORK(&keypad->work, matrix_keypad_scan); |
| 355 | spin_lock_init(&keypad->lock); | 355 | spin_lock_init(&keypad->lock); |
| @@ -363,7 +363,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 363 | 363 | ||
| 364 | input_dev->keycode = keycodes; | 364 | input_dev->keycode = keycodes; |
| 365 | input_dev->keycodesize = sizeof(*keycodes); | 365 | input_dev->keycodesize = sizeof(*keycodes); |
| 366 | input_dev->keycodemax = keymap_data->max_keymap_size; | 366 | input_dev->keycodemax = pdata->num_row_gpios << keypad->row_shift; |
| 367 | 367 | ||
| 368 | for (i = 0; i < keymap_data->keymap_size; i++) { | 368 | for (i = 0; i < keymap_data->keymap_size; i++) { |
| 369 | unsigned int key = keymap_data->keymap[i]; | 369 | unsigned int key = keymap_data->keymap[i]; |
| @@ -371,7 +371,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 371 | unsigned int col = KEY_COL(key); | 371 | unsigned int col = KEY_COL(key); |
| 372 | unsigned short code = KEY_VAL(key); | 372 | unsigned short code = KEY_VAL(key); |
| 373 | 373 | ||
| 374 | keycodes[(row << 4) + col] = code; | 374 | keycodes[MATRIX_SCAN_CODE(row, col, row_shift)] = code; |
| 375 | __set_bit(code, input_dev->keybit); | 375 | __set_bit(code, input_dev->keybit); |
| 376 | } | 376 | } |
| 377 | __clear_bit(KEY_RESERVED, input_dev->keybit); | 377 | __clear_bit(KEY_RESERVED, input_dev->keybit); |
