1 From 92a45a8ec4bf1abe5ff5ac123bf4edd6ccb2f353 Mon Sep 17 00:00:00 2001
2 From: Eric Nelson <eric.nelson@boundarydevices.com>
3 Date: Wed, 25 Apr 2012 14:14:04 +0000
4 Subject: [PATCH 15/56] i.MX6Q: mx6qsabrelite: Add keypress support to alter
7 Uses the 'magic_keys' idiom as described in doc/README.kbd:
8 http://lists.denx.de/pipermail/u-boot/2012-April/122502.html
10 Signed-off-by: Eric Nelson <eric.nelson@boundarydevices.com>
11 Acked-by: Marek Vasut <marex@denx.de>
12 Acked-by: Stefano Babic <sbabic@denx.de>
14 board/freescale/mx6qsabrelite/mx6qsabrelite.c | 122 ++++++++++++++++++++++++-
15 include/configs/mx6qsabrelite.h | 3 +
16 2 files changed, 123 insertions(+), 2 deletions(-)
18 diff --git a/board/freescale/mx6qsabrelite/mx6qsabrelite.c b/board/freescale/mx6qsabrelite/mx6qsabrelite.c
19 index b4d9519..90773aa 100644
20 --- a/board/freescale/mx6qsabrelite/mx6qsabrelite.c
21 +++ b/board/freescale/mx6qsabrelite/mx6qsabrelite.c
22 @@ -50,6 +50,10 @@ DECLARE_GLOBAL_DATA_PTR;
23 PAD_CTL_PUS_100K_DOWN | PAD_CTL_SPEED_MED | \
24 PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST)
26 +#define BUTTON_PAD_CTRL (PAD_CTL_PKE | PAD_CTL_PUE | \
27 + PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \
28 + PAD_CTL_DSE_40ohm | PAD_CTL_HYS)
32 gd->ram_size = get_ram_size((void *)PHYS_SDRAM, PHYS_SDRAM_SIZE);
33 @@ -122,6 +126,22 @@ iomux_v3_cfg_t enet_pads2[] = {
34 MX6Q_PAD_RGMII_RX_CTL__RGMII_RX_CTL | MUX_PAD_CTRL(ENET_PAD_CTRL),
37 +/* Button assignments for J14 */
38 +static iomux_v3_cfg_t button_pads[] = {
40 + MX6Q_PAD_NANDF_D1__GPIO_2_1 | MUX_PAD_CTRL(BUTTON_PAD_CTRL),
42 + MX6Q_PAD_NANDF_D2__GPIO_2_2 | MUX_PAD_CTRL(BUTTON_PAD_CTRL),
43 + /* Labelled Search (mapped to Power under Android) */
44 + MX6Q_PAD_NANDF_D3__GPIO_2_3 | MUX_PAD_CTRL(BUTTON_PAD_CTRL),
46 + MX6Q_PAD_NANDF_D4__GPIO_2_4 | MUX_PAD_CTRL(BUTTON_PAD_CTRL),
48 + MX6Q_PAD_GPIO_19__GPIO_4_5 | MUX_PAD_CTRL(BUTTON_PAD_CTRL),
50 + MX6Q_PAD_GPIO_18__GPIO_7_13 | MUX_PAD_CTRL(BUTTON_PAD_CTRL),
53 static void setup_iomux_enet(void)
55 gpio_direction_output(87, 0); /* GPIO 3-23 */
56 @@ -267,11 +287,18 @@ int board_eth_init(bd_t *bis)
60 +static void setup_buttons(void)
62 + imx_iomux_v3_setup_multiple_pads(button_pads,
63 + ARRAY_SIZE(button_pads));
66 int board_early_init_f(void)
77 @@ -292,3 +319,94 @@ int checkboard(void)
88 +static struct button_key const buttons[] = {
89 + {"back", GPIO_NUMBER(2, 2), 'B'},
90 + {"home", GPIO_NUMBER(2, 4), 'H'},
91 + {"menu", GPIO_NUMBER(2, 1), 'M'},
92 + {"search", GPIO_NUMBER(2, 3), 'S'},
93 + {"volup", GPIO_NUMBER(7, 13), 'V'},
94 + {"voldown", GPIO_NUMBER(4, 5), 'v'},
98 + * generate a null-terminated string containing the buttons pressed
99 + * returns number of keys pressed
101 +static int read_keys(char *buf)
103 + int i, numpressed = 0;
104 + for (i = 0; i < ARRAY_SIZE(buttons); i++) {
105 + if (!gpio_get_value(buttons[i].gpnum))
106 + buf[numpressed++] = buttons[i].ident;
108 + buf[numpressed] = '\0';
112 +static int do_kbd(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
114 + char envvalue[ARRAY_SIZE(buttons)+1];
115 + int numpressed = read_keys(envvalue);
116 + setenv("keybd", envvalue);
117 + return numpressed == 0;
122 + "Tests for keypresses, sets 'keybd' environment variable",
123 + "Returns 0 (true) to shell if key is pressed."
126 +#ifdef CONFIG_PREBOOT
127 +static char const kbd_magic_prefix[] = "key_magic";
128 +static char const kbd_command_prefix[] = "key_cmd";
130 +static void preboot_keys(void)
133 + char keypress[ARRAY_SIZE(buttons)+1];
134 + numpressed = read_keys(keypress);
136 + char *kbd_magic_keys = getenv("magic_keys");
139 + * loop over all magic keys
141 + for (suffix = kbd_magic_keys; *suffix; ++suffix) {
143 + char magic[sizeof(kbd_magic_prefix) + 1];
144 + sprintf(magic, "%s%c", kbd_magic_prefix, *suffix);
145 + keys = getenv(magic);
147 + if (!strcmp(keys, keypress))
152 + char cmd_name[sizeof(kbd_command_prefix) + 1];
154 + sprintf(cmd_name, "%s%c", kbd_command_prefix, *suffix);
155 + cmd = getenv(cmd_name);
157 + setenv("preboot", cmd);
165 +int misc_init_r(void)
167 +#ifdef CONFIG_PREBOOT
172 diff --git a/include/configs/mx6qsabrelite.h b/include/configs/mx6qsabrelite.h
173 index 492c618..48be6e6 100644
174 --- a/include/configs/mx6qsabrelite.h
175 +++ b/include/configs/mx6qsabrelite.h
178 #define CONFIG_ARCH_CPU_INIT
179 #define CONFIG_BOARD_EARLY_INIT_F
180 +#define CONFIG_MISC_INIT_R
181 #define CONFIG_MXC_GPIO
183 #define CONFIG_MXC_UART
186 #define CONFIG_BOOTDELAY 3
188 +#define CONFIG_PREBOOT ""
190 #define CONFIG_LOADADDR 0x10800000
191 #define CONFIG_SYS_TEXT_BASE 0x17800000