2 * Texas Instruments TNETV107X Keypad Driver
4 * Copyright (C) 2010 Texas Instruments
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation version 2.
10 * This program is distributed "as is" WITHOUT ANY WARRANTY of any
11 * kind, whether express or implied; without even the implied warranty
12 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
16 #include <linux/kernel.h>
17 #include <linux/err.h>
18 #include <linux/errno.h>
19 #include <linux/input.h>
20 #include <linux/platform_device.h>
21 #include <linux/interrupt.h>
22 #include <linux/slab.h>
23 #include <linux/delay.h>
25 #include <linux/clk.h>
26 #include <linux/input/matrix_keypad.h>
27 #include <linux/module.h>
29 #define BITS(x) (BIT(x) - 1)
34 #define DEBOUNCE_MIN 0x400ul
35 #define DEBOUNCE_MAX 0x3ffffffful
53 #define keypad_read(kp, reg) __raw_readl(&(kp)->regs->reg)
54 #define keypad_write(kp, reg, val) __raw_writel(val, &(kp)->regs->reg)
57 struct input_dev
*input_dev
;
59 struct keypad_regs __iomem
*regs
;
65 int rows
, cols
, row_shift
;
66 int debounce_ms
, active_low
;
68 unsigned short keycodes
[];
71 static irqreturn_t
keypad_irq(int irq
, void *data
)
73 struct keypad_data
*kp
= data
;
74 int i
, bit
, val
, row
, col
, code
;
79 spin_lock_irqsave(&kp
->lock
, flags
);
81 memset(curr_keys
, 0, sizeof(curr_keys
));
82 if (irq
== kp
->irq_press
)
83 for (i
= 0; i
< 3; i
++)
84 curr_keys
[i
] = keypad_read(kp
, pres
[i
]);
86 for (i
= 0; i
< 3; i
++) {
87 change
= curr_keys
[i
] ^ kp
->prev_keys
[i
];
90 bit
= fls(change
) - 1;
92 val
= curr_keys
[i
] & BIT(bit
);
94 row
= bit
/ KEYPAD_COLS
;
95 col
= bit
% KEYPAD_COLS
;
97 code
= MATRIX_SCAN_CODE(row
, col
, kp
->row_shift
);
98 input_event(kp
->input_dev
, EV_MSC
, MSC_SCAN
, code
);
99 input_report_key(kp
->input_dev
, kp
->keycodes
[code
],
103 input_sync(kp
->input_dev
);
104 memcpy(kp
->prev_keys
, curr_keys
, sizeof(curr_keys
));
106 if (irq
== kp
->irq_press
)
107 keypad_write(kp
, lock
, 0); /* Allow hardware updates */
109 spin_unlock_irqrestore(&kp
->lock
, flags
);
114 static int keypad_start(struct input_dev
*dev
)
116 struct keypad_data
*kp
= input_get_drvdata(dev
);
117 unsigned long mask
, debounce
, clk_rate_khz
;
121 clk_rate_khz
= clk_get_rate(kp
->clk
) / 1000;
123 spin_lock_irqsave(&kp
->lock
, flags
);
125 /* Initialize device registers */
126 keypad_write(kp
, mode
, 0);
128 mask
= BITS(kp
->rows
) << KEYPAD_COLS
;
129 mask
|= BITS(kp
->cols
);
130 keypad_write(kp
, mask
, ~mask
);
132 keypad_write(kp
, pol
, kp
->active_low
? 0 : 0x3ffff);
133 keypad_write(kp
, stable_cnt
, 3);
135 debounce
= kp
->debounce_ms
* clk_rate_khz
;
136 debounce
= clamp(debounce
, DEBOUNCE_MIN
, DEBOUNCE_MAX
);
137 keypad_write(kp
, dclock
, debounce
);
138 keypad_write(kp
, rclock
, 4 * debounce
);
140 keypad_write(kp
, in_en
, 1);
142 spin_unlock_irqrestore(&kp
->lock
, flags
);
147 static void keypad_stop(struct input_dev
*dev
)
149 struct keypad_data
*kp
= input_get_drvdata(dev
);
151 synchronize_irq(kp
->irq_press
);
152 synchronize_irq(kp
->irq_release
);
153 clk_disable(kp
->clk
);
156 static int keypad_probe(struct platform_device
*pdev
)
158 const struct matrix_keypad_platform_data
*pdata
;
159 const struct matrix_keymap_data
*keymap_data
;
160 struct device
*dev
= &pdev
->dev
;
161 struct keypad_data
*kp
;
162 int error
= 0, sz
, row_shift
;
165 pdata
= dev_get_platdata(&pdev
->dev
);
167 dev_err(dev
, "cannot find device data\n");
171 keymap_data
= pdata
->keymap_data
;
173 dev_err(dev
, "cannot find keymap data\n");
177 row_shift
= get_count_order(pdata
->num_col_gpios
);
178 sz
= offsetof(struct keypad_data
, keycodes
);
179 sz
+= (pdata
->num_row_gpios
<< row_shift
) * sizeof(kp
->keycodes
[0]);
180 kp
= kzalloc(sz
, GFP_KERNEL
);
182 dev_err(dev
, "cannot allocate device info\n");
187 kp
->rows
= pdata
->num_row_gpios
;
188 kp
->cols
= pdata
->num_col_gpios
;
189 kp
->row_shift
= row_shift
;
190 platform_set_drvdata(pdev
, kp
);
191 spin_lock_init(&kp
->lock
);
193 kp
->irq_press
= platform_get_irq_byname(pdev
, "press");
194 kp
->irq_release
= platform_get_irq_byname(pdev
, "release");
195 if (kp
->irq_press
< 0 || kp
->irq_release
< 0) {
196 dev_err(dev
, "cannot determine device interrupts\n");
201 kp
->res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
203 dev_err(dev
, "cannot determine register area\n");
208 if (!request_mem_region(kp
->res
->start
, resource_size(kp
->res
),
210 dev_err(dev
, "cannot claim register memory\n");
216 kp
->regs
= ioremap(kp
->res
->start
, resource_size(kp
->res
));
218 dev_err(dev
, "cannot map register memory\n");
223 kp
->clk
= clk_get(dev
, NULL
);
224 if (IS_ERR(kp
->clk
)) {
225 dev_err(dev
, "cannot claim device clock\n");
226 error
= PTR_ERR(kp
->clk
);
230 error
= request_threaded_irq(kp
->irq_press
, NULL
, keypad_irq
,
231 IRQF_ONESHOT
, dev_name(dev
), kp
);
233 dev_err(kp
->dev
, "Could not allocate keypad press key irq\n");
234 goto error_irq_press
;
237 error
= request_threaded_irq(kp
->irq_release
, NULL
, keypad_irq
,
238 IRQF_ONESHOT
, dev_name(dev
), kp
);
240 dev_err(kp
->dev
, "Could not allocate keypad release key irq\n");
241 goto error_irq_release
;
244 kp
->input_dev
= input_allocate_device();
245 if (!kp
->input_dev
) {
246 dev_err(dev
, "cannot allocate input device\n");
251 kp
->input_dev
->name
= pdev
->name
;
252 kp
->input_dev
->dev
.parent
= &pdev
->dev
;
253 kp
->input_dev
->open
= keypad_start
;
254 kp
->input_dev
->close
= keypad_stop
;
257 rev
= keypad_read(kp
, rev
);
258 kp
->input_dev
->id
.bustype
= BUS_HOST
;
259 kp
->input_dev
->id
.product
= ((rev
>> 8) & 0x07);
260 kp
->input_dev
->id
.version
= ((rev
>> 16) & 0xfff);
261 clk_disable(kp
->clk
);
263 error
= matrix_keypad_build_keymap(keymap_data
, NULL
,
265 kp
->keycodes
, kp
->input_dev
);
267 dev_err(dev
, "Failed to build keymap\n");
271 if (!pdata
->no_autorepeat
)
272 kp
->input_dev
->evbit
[0] |= BIT_MASK(EV_REP
);
273 input_set_capability(kp
->input_dev
, EV_MSC
, MSC_SCAN
);
275 input_set_drvdata(kp
->input_dev
, kp
);
277 error
= input_register_device(kp
->input_dev
);
279 dev_err(dev
, "Could not register input device\n");
287 input_free_device(kp
->input_dev
);
289 free_irq(kp
->irq_release
, kp
);
291 free_irq(kp
->irq_press
, kp
);
297 release_mem_region(kp
->res
->start
, resource_size(kp
->res
));
303 static int keypad_remove(struct platform_device
*pdev
)
305 struct keypad_data
*kp
= platform_get_drvdata(pdev
);
307 free_irq(kp
->irq_press
, kp
);
308 free_irq(kp
->irq_release
, kp
);
309 input_unregister_device(kp
->input_dev
);
312 release_mem_region(kp
->res
->start
, resource_size(kp
->res
));
318 static struct platform_driver keypad_driver
= {
319 .probe
= keypad_probe
,
320 .remove
= keypad_remove
,
321 .driver
.name
= "tnetv107x-keypad",
322 .driver
.owner
= THIS_MODULE
,
324 module_platform_driver(keypad_driver
);
326 MODULE_AUTHOR("Cyril Chemparathy");
327 MODULE_DESCRIPTION("TNETV107X Keypad Driver");
328 MODULE_ALIAS("platform:tnetv107x-keypad");
329 MODULE_LICENSE("GPL");