aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorJanusz Krzysztofik <jkrzyszt@tis.icnet.pl>2011-12-20 17:10:34 -0500
committerTony Lindgren <tony@atomide.com>2011-12-22 12:00:46 -0500
commit8d09a1bb3147ddbcf0a9483021ca699c54c54732 (patch)
tree5d968498a2d40612b94e93831ce6f59d9cb355cc /arch
parenta218d19f6a91c076c7ed8a7c0082f777248c5394 (diff)
input: serio: ams-delta: toggle keyboard power over GPIO
Don't use Amstrad Delta custom I/O functions once GPIO interface is available for the underlying hardware. While requesting and initializing GPIO pins used, also take care of one extra pin KEYBRD_DATAOUT which, even if not used by the driver, belongs to the device and affects its functioning. Once done, move the driver initialization back to the device_initcall level, reverting the temporary chane introduced with patch 1/7 "ARM: OMAP1: ams-delta: register latch dependent devices later". That change is no longer required once the driver takes care of registering used GPIO pins, and it's better to initialize the device before others using the latch2 based GPIO pins, otherwise a garbage is reported on boot, perhaps due to random data already captured by the FIQ handler while the keyboard related latch bits are written with random values during initialization of those other latch2 dependent devices. Signed-off-by: Janusz Krzysztofik <jkrzyszt@tis.icnet.pl> Acked-by: Dmitry Torokhov <dtor@mail.ru> [tony@atomide.com: renamed _gpios to ams_delta_gpios] Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch')
-rw-r--r--arch/arm/mach-omap1/board-ams-delta.c10
-rw-r--r--arch/arm/plat-omap/include/plat/board-ams-delta.h2
2 files changed, 0 insertions, 12 deletions
diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c
index 3aba8f99cc7e..673cf21a90f8 100644
--- a/arch/arm/mach-omap1/board-ams-delta.c
+++ b/arch/arm/mach-omap1/board-ams-delta.c
@@ -227,16 +227,6 @@ static struct gpio latch_gpios[] __initconst = {
227 .label = "dockit2", 227 .label = "dockit2",
228 }, 228 },
229 { 229 {
230 .gpio = AMS_DELTA_GPIO_PIN_KEYBRD_PWR,
231 .flags = GPIOF_OUT_INIT_LOW,
232 .label = "keybrd_pwr",
233 },
234 {
235 .gpio = AMS_DELTA_GPIO_PIN_KEYBRD_DATAOUT,
236 .flags = GPIOF_OUT_INIT_LOW,
237 .label = "keybrd_dataout",
238 },
239 {
240 .gpio = AMS_DELTA_GPIO_PIN_SCARD_RSTIN, 230 .gpio = AMS_DELTA_GPIO_PIN_SCARD_RSTIN,
241 .flags = GPIOF_OUT_INIT_LOW, 231 .flags = GPIOF_OUT_INIT_LOW,
242 .label = "scard_rstin", 232 .label = "scard_rstin",
diff --git a/arch/arm/plat-omap/include/plat/board-ams-delta.h b/arch/arm/plat-omap/include/plat/board-ams-delta.h
index e9ad673be32f..027e79eead5e 100644
--- a/arch/arm/plat-omap/include/plat/board-ams-delta.h
+++ b/arch/arm/plat-omap/include/plat/board-ams-delta.h
@@ -28,8 +28,6 @@
28 28
29#if defined (CONFIG_MACH_AMS_DELTA) 29#if defined (CONFIG_MACH_AMS_DELTA)
30 30
31#define AMD_DELTA_LATCH2_KEYBRD_PWR 0x0100
32#define AMD_DELTA_LATCH2_KEYBRD_DATA 0x0200
33#define AMD_DELTA_LATCH2_SCARD_RSTIN 0x0400 31#define AMD_DELTA_LATCH2_SCARD_RSTIN 0x0400
34#define AMD_DELTA_LATCH2_SCARD_CMDVCC 0x0800 32#define AMD_DELTA_LATCH2_SCARD_CMDVCC 0x0800
35#define AMS_DELTA_LATCH2_MODEM_NRESET 0x1000 33#define AMS_DELTA_LATCH2_MODEM_NRESET 0x1000