diff options
| -rw-r--r-- | drivers/input/keyboard/sh_keysc.c | 3 | ||||
| -rw-r--r-- | include/linux/input/sh_keysc.h | 6 |
2 files changed, 5 insertions, 4 deletions
diff --git a/drivers/input/keyboard/sh_keysc.c b/drivers/input/keyboard/sh_keysc.c index c2fc97732f0c..854e2035cd6e 100644 --- a/drivers/input/keyboard/sh_keysc.c +++ b/drivers/input/keyboard/sh_keysc.c | |||
| @@ -31,6 +31,7 @@ static const struct { | |||
| 31 | [SH_KEYSC_MODE_3] = { 2, 4, 7 }, | 31 | [SH_KEYSC_MODE_3] = { 2, 4, 7 }, |
| 32 | [SH_KEYSC_MODE_4] = { 3, 6, 6 }, | 32 | [SH_KEYSC_MODE_4] = { 3, 6, 6 }, |
| 33 | [SH_KEYSC_MODE_5] = { 4, 6, 7 }, | 33 | [SH_KEYSC_MODE_5] = { 4, 6, 7 }, |
| 34 | [SH_KEYSC_MODE_6] = { 5, 7, 7 }, | ||
| 34 | }; | 35 | }; |
| 35 | 36 | ||
| 36 | struct sh_keysc_priv { | 37 | struct sh_keysc_priv { |
| @@ -109,7 +110,7 @@ static irqreturn_t sh_keysc_isr(int irq, void *dev_id) | |||
| 109 | n = keyin_nr * i; | 110 | n = keyin_nr * i; |
| 110 | 111 | ||
| 111 | /* drive one KEYOUT pin low, read KEYIN pins */ | 112 | /* drive one KEYOUT pin low, read KEYIN pins */ |
| 112 | sh_keysc_write(priv, KYOUTDR, 0xfff ^ (3 << (i * 2))); | 113 | sh_keysc_write(priv, KYOUTDR, 0xffff ^ (3 << (i * 2))); |
| 113 | udelay(pdata->delay); | 114 | udelay(pdata->delay); |
| 114 | tmp = sh_keysc_read(priv, KYINDR); | 115 | tmp = sh_keysc_read(priv, KYINDR); |
| 115 | 116 | ||
diff --git a/include/linux/input/sh_keysc.h b/include/linux/input/sh_keysc.h index 2aff38bcf2ba..649dc7f12925 100644 --- a/include/linux/input/sh_keysc.h +++ b/include/linux/input/sh_keysc.h | |||
| @@ -1,15 +1,15 @@ | |||
| 1 | #ifndef __SH_KEYSC_H__ | 1 | #ifndef __SH_KEYSC_H__ |
| 2 | #define __SH_KEYSC_H__ | 2 | #define __SH_KEYSC_H__ |
| 3 | 3 | ||
| 4 | #define SH_KEYSC_MAXKEYS 42 | 4 | #define SH_KEYSC_MAXKEYS 49 |
| 5 | 5 | ||
| 6 | struct sh_keysc_info { | 6 | struct sh_keysc_info { |
| 7 | enum { SH_KEYSC_MODE_1, SH_KEYSC_MODE_2, SH_KEYSC_MODE_3, | 7 | enum { SH_KEYSC_MODE_1, SH_KEYSC_MODE_2, SH_KEYSC_MODE_3, |
| 8 | SH_KEYSC_MODE_4, SH_KEYSC_MODE_5 } mode; | 8 | SH_KEYSC_MODE_4, SH_KEYSC_MODE_5, SH_KEYSC_MODE_6 } mode; |
| 9 | int scan_timing; /* 0 -> 7, see KYCR1, SCN[2:0] */ | 9 | int scan_timing; /* 0 -> 7, see KYCR1, SCN[2:0] */ |
| 10 | int delay; | 10 | int delay; |
| 11 | int kycr2_delay; | 11 | int kycr2_delay; |
| 12 | int keycodes[SH_KEYSC_MAXKEYS]; | 12 | int keycodes[SH_KEYSC_MAXKEYS]; /* KEYIN * KEYOUT */ |
| 13 | }; | 13 | }; |
| 14 | 14 | ||
| 15 | #endif /* __SH_KEYSC_H__ */ | 15 | #endif /* __SH_KEYSC_H__ */ |
