|
@@ -9,20 +9,26 @@
|
|
#include <mach/hardware.h>
|
|
#include <mach/hardware.h>
|
|
#include <mach/devices-common.h>
|
|
#include <mach/devices-common.h>
|
|
|
|
|
|
-#define imx_imx_keypad_data_entry_single(soc) \
|
|
|
|
|
|
+#define imx_imx_keypad_data_entry_single(soc, _size) \
|
|
{ \
|
|
{ \
|
|
.iobase = soc ## _KPP_BASE_ADDR, \
|
|
.iobase = soc ## _KPP_BASE_ADDR, \
|
|
|
|
+ .iosize = _size, \
|
|
.irq = soc ## _INT_KPP, \
|
|
.irq = soc ## _INT_KPP, \
|
|
}
|
|
}
|
|
|
|
|
|
#ifdef CONFIG_SOC_IMX21
|
|
#ifdef CONFIG_SOC_IMX21
|
|
const struct imx_imx_keypad_data imx21_imx_keypad_data __initconst =
|
|
const struct imx_imx_keypad_data imx21_imx_keypad_data __initconst =
|
|
- imx_imx_keypad_data_entry_single(MX21);
|
|
|
|
|
|
+ imx_imx_keypad_data_entry_single(MX21, SZ_16);
|
|
#endif /* ifdef CONFIG_SOC_IMX21 */
|
|
#endif /* ifdef CONFIG_SOC_IMX21 */
|
|
|
|
|
|
|
|
+#ifdef CONFIG_ARCH_MX25
|
|
|
|
+const struct imx_imx_keypad_data imx25_imx_keypad_data __initconst =
|
|
|
|
+ imx_imx_keypad_data_entry_single(MX25, SZ_16K);
|
|
|
|
+#endif
|
|
|
|
+
|
|
#ifdef CONFIG_SOC_IMX27
|
|
#ifdef CONFIG_SOC_IMX27
|
|
const struct imx_imx_keypad_data imx27_imx_keypad_data __initconst =
|
|
const struct imx_imx_keypad_data imx27_imx_keypad_data __initconst =
|
|
- imx_imx_keypad_data_entry_single(MX27);
|
|
|
|
|
|
+ imx_imx_keypad_data_entry_single(MX27, SZ_16);
|
|
#endif /* ifdef CONFIG_SOC_IMX27 */
|
|
#endif /* ifdef CONFIG_SOC_IMX27 */
|
|
|
|
|
|
struct platform_device *__init imx_add_imx_keypad(
|
|
struct platform_device *__init imx_add_imx_keypad(
|
|
@@ -32,7 +38,7 @@ struct platform_device *__init imx_add_imx_keypad(
|
|
struct resource res[] = {
|
|
struct resource res[] = {
|
|
{
|
|
{
|
|
.start = data->iobase,
|
|
.start = data->iobase,
|
|
- .end = data->iobase + SZ_16 - 1,
|
|
|
|
|
|
+ .end = data->iobase + data->iosize - 1,
|
|
.flags = IORESOURCE_MEM,
|
|
.flags = IORESOURCE_MEM,
|
|
}, {
|
|
}, {
|
|
.start = data->irq,
|
|
.start = data->irq,
|