summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Arigo <markarigo@gmail.com>2009-06-19 03:23:38 +0000
committerMark Arigo <markarigo@gmail.com>2009-06-19 03:23:38 +0000
commita61196fd3ae5ebd71134da8eb10e3189403c116f (patch)
tree7ce78201cb299ebfd6ac92f490776072c47a9e03
parent6a0d931f383259b4b82fcfd1cc87700f53bbcb02 (diff)
downloadrockbox-a61196fd3ae5ebd71134da8eb10e3189403c116f.tar.gz
rockbox-a61196fd3ae5ebd71134da8eb10e3189403c116f.zip
Philips SA9200: Working touchpad and button lights! Also, improvements to the keymap (still needs work).
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@21346 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/keymaps/keymap-sa9200.c299
-rw-r--r--apps/lang/english.lang22
-rw-r--r--firmware/SOURCES3
-rw-r--r--firmware/drivers/synaptics-mep.c20
-rwxr-xr-xfirmware/export/config-sa9200.h8
-rw-r--r--firmware/export/usb.h6
-rw-r--r--firmware/target/arm/philips/sa9200/backlight-sa9200.c23
-rw-r--r--firmware/target/arm/philips/sa9200/backlight-target.h3
-rwxr-xr-xfirmware/target/arm/philips/sa9200/button-sa9200.c79
-rwxr-xr-xfirmware/target/arm/philips/sa9200/button-target.h10
-rw-r--r--firmware/target/arm/philips/sa9200/power-sa9200.c40
11 files changed, 329 insertions, 184 deletions
diff --git a/apps/keymaps/keymap-sa9200.c b/apps/keymaps/keymap-sa9200.c
index c77f3e9bb4..bf693600c8 100644
--- a/apps/keymaps/keymap-sa9200.c
+++ b/apps/keymaps/keymap-sa9200.c
@@ -53,22 +53,22 @@ static const struct button_mapping button_context_standard[] = {
53 { ACTION_STD_NEXTREPEAT, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 53 { ACTION_STD_NEXTREPEAT, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
54 54
55 { ACTION_STD_CANCEL, BUTTON_REW, BUTTON_NONE }, 55 { ACTION_STD_CANCEL, BUTTON_REW, BUTTON_NONE },
56 { ACTION_STD_CANCEL, BUTTON_LEFT, BUTTON_NONE },
56 { ACTION_STD_CANCEL, BUTTON_POWER, BUTTON_NONE }, 57 { ACTION_STD_CANCEL, BUTTON_POWER, BUTTON_NONE },
57 58
58 { ACTION_STD_CONTEXT, BUTTON_SELECT|BUTTON_REPEAT, BUTTON_SELECT }, 59 { ACTION_STD_OK, BUTTON_FFWD, BUTTON_NONE },
60 { ACTION_STD_OK, BUTTON_PLAY|BUTTON_REL, BUTTON_PLAY },
59 61
60 { ACTION_STD_QUICKSCREEN, BUTTON_MENU|BUTTON_REPEAT, BUTTON_MENU },
61 { ACTION_STD_MENU, BUTTON_MENU|BUTTON_REL, BUTTON_MENU }, 62 { ACTION_STD_MENU, BUTTON_MENU|BUTTON_REL, BUTTON_MENU },
62 63 { ACTION_STD_QUICKSCREEN, BUTTON_MENU|BUTTON_REPEAT, BUTTON_MENU },
63 { ACTION_STD_OK, BUTTON_SELECT|BUTTON_REL, BUTTON_SELECT }, 64 { ACTION_STD_CONTEXT, BUTTON_PLAY|BUTTON_REPEAT, BUTTON_PLAY },
64 { ACTION_STD_OK, BUTTON_FFWD, BUTTON_NONE },
65 65
66 LAST_ITEM_IN_LIST 66 LAST_ITEM_IN_LIST
67}; /* button_context_standard */ 67}; /* button_context_standard */
68 68
69 69
70static const struct button_mapping button_context_wps[] = { 70static const struct button_mapping button_context_wps[] = {
71 { ACTION_WPS_PLAY, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT }, 71 { ACTION_WPS_PLAY, BUTTON_PLAY|BUTTON_REL, BUTTON_PLAY },
72 { ACTION_WPS_STOP, BUTTON_POWER|BUTTON_REL, BUTTON_POWER }, 72 { ACTION_WPS_STOP, BUTTON_POWER|BUTTON_REL, BUTTON_POWER },
73 73
74 { ACTION_WPS_SKIPNEXT, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD }, 74 { ACTION_WPS_SKIPNEXT, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD },
@@ -76,45 +76,43 @@ static const struct button_mapping button_context_wps[] = {
76 76
77 { ACTION_WPS_SEEKBACK, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE }, 77 { ACTION_WPS_SEEKBACK, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
78 { ACTION_WPS_SEEKFWD, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE }, 78 { ACTION_WPS_SEEKFWD, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
79
79 { ACTION_WPS_STOPSEEK, BUTTON_REW|BUTTON_REL, BUTTON_REW|BUTTON_REPEAT }, 80 { ACTION_WPS_STOPSEEK, BUTTON_REW|BUTTON_REL, BUTTON_REW|BUTTON_REPEAT },
80 { ACTION_WPS_STOPSEEK, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD|BUTTON_REPEAT }, 81 { ACTION_WPS_STOPSEEK, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD|BUTTON_REPEAT },
81 82
82 { ACTION_WPS_ABSETB_NEXTDIR, BUTTON_RIGHT|BUTTON_FFWD, BUTTON_NONE }, 83 { ACTION_WPS_ABSETB_NEXTDIR,BUTTON_POWER|BUTTON_RIGHT, BUTTON_POWER },
83 { ACTION_WPS_ABSETA_PREVDIR, BUTTON_RIGHT|BUTTON_REW, BUTTON_NONE }, 84 { ACTION_WPS_ABSETA_PREVDIR,BUTTON_POWER|BUTTON_LEFT, BUTTON_POWER },
84 { ACTION_WPS_ABRESET, BUTTON_RIGHT|BUTTON_SELECT, BUTTON_NONE }, 85 { ACTION_WPS_ABRESET, BUTTON_POWER|BUTTON_UP, BUTTON_POWER },
85 86
86 { ACTION_WPS_VOLDOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 87 { ACTION_WPS_VOLDOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
87 { ACTION_WPS_VOLDOWN, BUTTON_DOWN, BUTTON_NONE }, 88 { ACTION_WPS_VOLDOWN, BUTTON_DOWN, BUTTON_NONE },
88 { ACTION_WPS_VOLDOWN, BUTTON_VOL_DOWN, BUTTON_NONE }, 89 { ACTION_WPS_VOLDOWN, BUTTON_VOL_DOWN, BUTTON_NONE },
89 { ACTION_WPS_VOLDOWN, BUTTON_VOL_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 90 { ACTION_WPS_VOLDOWN, BUTTON_VOL_DOWN|BUTTON_REPEAT, BUTTON_NONE },
91
90 { ACTION_WPS_VOLUP, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 92 { ACTION_WPS_VOLUP, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
91 { ACTION_WPS_VOLUP, BUTTON_UP, BUTTON_NONE }, 93 { ACTION_WPS_VOLUP, BUTTON_UP, BUTTON_NONE },
92 { ACTION_WPS_VOLUP, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE }, 94 { ACTION_WPS_VOLUP, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE },
93 { ACTION_WPS_VOLUP, BUTTON_VOL_UP, BUTTON_NONE }, 95 { ACTION_WPS_VOLUP, BUTTON_VOL_UP, BUTTON_NONE },
94 96
95 { ACTION_WPS_PITCHSCREEN, BUTTON_RIGHT|BUTTON_UP, BUTTON_RIGHT },
96 { ACTION_WPS_PITCHSCREEN, BUTTON_RIGHT|BUTTON_DOWN, BUTTON_RIGHT },
97
98 { ACTION_WPS_QUICKSCREEN, BUTTON_MENU|BUTTON_REPEAT, BUTTON_MENU },
99 { ACTION_WPS_MENU, BUTTON_MENU|BUTTON_REL, BUTTON_MENU }, 97 { ACTION_WPS_MENU, BUTTON_MENU|BUTTON_REL, BUTTON_MENU },
100 { ACTION_WPS_CONTEXT, BUTTON_SELECT|BUTTON_REPEAT, BUTTON_SELECT }, 98 { ACTION_WPS_BROWSE, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT },
101 99
102 { ACTION_WPS_ID3SCREEN, BUTTON_RIGHT|BUTTON_MENU, BUTTON_NONE }, 100 { ACTION_WPS_CONTEXT, BUTTON_PLAY|BUTTON_REPEAT, BUTTON_PLAY },
103 { ACTION_WPS_BROWSE, BUTTON_SELECT|BUTTON_REL, BUTTON_SELECT }, 101 { ACTION_WPS_QUICKSCREEN, BUTTON_MENU|BUTTON_REPEAT, BUTTON_MENU },
102 { ACTION_WPS_PITCHSCREEN, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE },
103 { ACTION_WPS_ID3SCREEN, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE },
104 104
105 LAST_ITEM_IN_LIST 105 LAST_ITEM_IN_LIST
106}; /* button_context_wps */ 106}; /* button_context_wps */
107 107
108static const struct button_mapping button_context_list[] = { 108static const struct button_mapping button_context_list[] = {
109 { ACTION_LISTTREE_PGUP, BUTTON_RIGHT|BUTTON_UP, BUTTON_RIGHT }, 109 { ACTION_LISTTREE_PGUP, BUTTON_VOL_UP|BUTTON_UP, BUTTON_VOL_UP },
110 { ACTION_LISTTREE_PGUP, BUTTON_UP|BUTTON_REL, BUTTON_RIGHT|BUTTON_UP }, 110 { ACTION_LISTTREE_PGDOWN, BUTTON_VOL_DOWN|BUTTON_DOWN, BUTTON_VOL_DOWN },
111 { ACTION_LISTTREE_PGUP, BUTTON_RIGHT|BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 111
112 { ACTION_LISTTREE_PGDOWN, BUTTON_RIGHT|BUTTON_DOWN, BUTTON_RIGHT },
113 { ACTION_LISTTREE_PGDOWN, BUTTON_DOWN|BUTTON_REL, BUTTON_RIGHT|BUTTON_DOWN },
114 { ACTION_LISTTREE_PGDOWN, BUTTON_RIGHT|BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
115#ifdef HAVE_VOLUME_IN_LIST 112#ifdef HAVE_VOLUME_IN_LIST
116 { ACTION_LIST_VOLUP, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE }, 113 { ACTION_LIST_VOLUP, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE },
117 { ACTION_LIST_VOLUP, BUTTON_VOL_UP, BUTTON_NONE }, 114 { ACTION_LIST_VOLUP, BUTTON_VOL_UP, BUTTON_NONE },
115
118 { ACTION_LIST_VOLDOWN, BUTTON_VOL_DOWN, BUTTON_NONE }, 116 { ACTION_LIST_VOLDOWN, BUTTON_VOL_DOWN, BUTTON_NONE },
119 { ACTION_LIST_VOLDOWN, BUTTON_VOL_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 117 { ACTION_LIST_VOLDOWN, BUTTON_VOL_DOWN|BUTTON_REPEAT, BUTTON_NONE },
120#endif 118#endif
@@ -123,170 +121,181 @@ static const struct button_mapping button_context_list[] = {
123}; /* button_context_list */ 121}; /* button_context_list */
124 122
125static const struct button_mapping button_context_tree[] = { 123static const struct button_mapping button_context_tree[] = {
126 { ACTION_TREE_WPS, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT }, 124 { ACTION_TREE_WPS, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE },
127 { ACTION_TREE_STOP, BUTTON_POWER, BUTTON_NONE }, 125 { ACTION_TREE_STOP, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE },
128 { ACTION_TREE_STOP, BUTTON_POWER|BUTTON_REL, BUTTON_POWER },
129 { ACTION_TREE_STOP, BUTTON_POWER|BUTTON_REPEAT, BUTTON_NONE },
130 126
131 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_LIST) 127 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_LIST)
132}; /* button_context_tree */ 128}; /* button_context_tree */
133 129
134static const struct button_mapping button_context_listtree_scroll_with_combo[] = { 130static const struct button_mapping button_context_listtree_scroll_with_combo[] = {
135 { ACTION_NONE, BUTTON_RIGHT, BUTTON_NONE }, 131 { ACTION_TREE_ROOT_INIT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
136 { ACTION_TREE_PGLEFT, BUTTON_RIGHT|BUTTON_REW, BUTTON_RIGHT }, 132
137 { ACTION_TREE_PGLEFT, BUTTON_REW|BUTTON_REL, BUTTON_RIGHT|BUTTON_REW }, 133 { ACTION_TREE_PGLEFT, BUTTON_LEFT, BUTTON_NONE },
138 { ACTION_TREE_PGLEFT, BUTTON_RIGHT|BUTTON_REW, BUTTON_REW|BUTTON_REL }, 134 { ACTION_TREE_PGLEFT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE },
139 { ACTION_TREE_ROOT_INIT, BUTTON_RIGHT|BUTTON_REW|BUTTON_REPEAT, BUTTON_RIGHT|BUTTON_REW }, 135
140 { ACTION_TREE_PGLEFT, BUTTON_RIGHT|BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE }, 136 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT, BUTTON_NONE },
141 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_FFWD, BUTTON_RIGHT }, 137 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE },
142 { ACTION_TREE_PGRIGHT, BUTTON_FFWD|BUTTON_REL, BUTTON_RIGHT|BUTTON_FFWD }, 138
143 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_FFWD, BUTTON_FFWD|BUTTON_REL },
144 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
145 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_TREE), 139 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_TREE),
146}; 140};
147 141
148static const struct button_mapping button_context_listtree_scroll_without_combo[] = { 142static const struct button_mapping button_context_listtree_scroll_without_combo[] = {
149 { ACTION_NONE, BUTTON_REW, BUTTON_NONE }, 143 { ACTION_NONE, BUTTON_REW, BUTTON_NONE },
150 { ACTION_STD_CANCEL, BUTTON_REW|BUTTON_REL, BUTTON_REW },
151 { ACTION_TREE_ROOT_INIT, BUTTON_REW|BUTTON_REPEAT, BUTTON_REW },
152 { ACTION_TREE_PGLEFT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
153 { ACTION_TREE_PGLEFT, BUTTON_REW|BUTTON_REL, BUTTON_REW|BUTTON_REPEAT },
154 { ACTION_NONE, BUTTON_FFWD, BUTTON_NONE }, 144 { ACTION_NONE, BUTTON_FFWD, BUTTON_NONE },
145
155 { ACTION_STD_OK, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD }, 146 { ACTION_STD_OK, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD },
156 { ACTION_TREE_PGRIGHT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE }, 147 { ACTION_STD_CANCEL, BUTTON_REW|BUTTON_REL, BUTTON_REW },
157 { ACTION_TREE_PGRIGHT, BUTTON_FFWD|BUTTON_REL, BUTTON_FFWD|BUTTON_REPEAT }, 148 { ACTION_TREE_ROOT_INIT, BUTTON_MENU, BUTTON_NONE },
149
150 { ACTION_TREE_PGLEFT, BUTTON_LEFT, BUTTON_NONE },
151 { ACTION_TREE_PGLEFT, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT|BUTTON_REPEAT },
152
153 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE },
154 { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT|BUTTON_REPEAT },
155
158 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_TREE), 156 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_TREE),
159}; 157};
160 158
161static const struct button_mapping button_context_settings[] = { 159static const struct button_mapping button_context_settings[] = {
162 { ACTION_SETTINGS_INC, BUTTON_UP, BUTTON_NONE }, 160 { ACTION_STD_CANCEL, BUTTON_POWER, BUTTON_NONE },
163 { ACTION_SETTINGS_INCREPEAT, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 161 { ACTION_SETTINGS_RESET, BUTTON_PLAY, BUTTON_NONE },
164 { ACTION_SETTINGS_DEC, BUTTON_DOWN, BUTTON_NONE }, 162
165 { ACTION_SETTINGS_DECREPEAT, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 163 { ACTION_SETTINGS_INC, BUTTON_UP, BUTTON_NONE },
166 { ACTION_STD_PREV, BUTTON_REW, BUTTON_NONE }, 164 { ACTION_SETTINGS_INCREPEAT,BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
167 { ACTION_STD_PREVREPEAT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE }, 165
168 { ACTION_STD_NEXT, BUTTON_FFWD, BUTTON_NONE }, 166 { ACTION_SETTINGS_DEC, BUTTON_DOWN, BUTTON_NONE },
169 { ACTION_STD_NEXTREPEAT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE }, 167 { ACTION_SETTINGS_DECREPEAT,BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
170 { ACTION_SETTINGS_RESET, BUTTON_RIGHT, BUTTON_NONE }, 168
169 { ACTION_STD_PREV, BUTTON_REW, BUTTON_NONE },
170 { ACTION_STD_PREVREPEAT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
171
172 { ACTION_STD_NEXT, BUTTON_FFWD, BUTTON_NONE },
173 { ACTION_STD_NEXTREPEAT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
171 174
172 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) 175 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD)
173}; /* button_context_settings */ 176}; /* button_context_settings */
174 177
175static const struct button_mapping button_context_settings_right_is_inc[] = { 178static const struct button_mapping button_context_settings_right_is_inc[] = {
176 { ACTION_SETTINGS_INC, BUTTON_FFWD, BUTTON_NONE }, 179 { ACTION_SETTINGS_INC, BUTTON_FFWD, BUTTON_NONE },
177 { ACTION_SETTINGS_INCREPEAT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE }, 180 { ACTION_SETTINGS_INCREPEAT,BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
178 { ACTION_SETTINGS_DEC, BUTTON_REW, BUTTON_NONE }, 181
179 { ACTION_SETTINGS_DECREPEAT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE }, 182 { ACTION_SETTINGS_DEC, BUTTON_REW, BUTTON_NONE },
180 { ACTION_STD_PREV, BUTTON_UP, BUTTON_NONE }, 183 { ACTION_SETTINGS_DECREPEAT,BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
181 { ACTION_STD_PREVREPEAT, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
182 { ACTION_STD_NEXT, BUTTON_DOWN, BUTTON_NONE },
183 { ACTION_STD_NEXTREPEAT, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
184 { ACTION_SETTINGS_RESET, BUTTON_RIGHT, BUTTON_NONE },
185 184
186 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) 185 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD)
187}; /* button_context_settingsgraphical */ 186}; /* button_context_settingsgraphical */
188 187
189static const struct button_mapping button_context_yesno[] = { 188static const struct button_mapping button_context_yesno[] = {
190 { ACTION_YESNO_ACCEPT, BUTTON_SELECT, BUTTON_NONE }, 189 { ACTION_YESNO_ACCEPT, BUTTON_PLAY, BUTTON_NONE },
190
191 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) 191 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD)
192}; /* button_context_settings_yesno */ 192}; /* button_context_settings_yesno */
193 193
194static const struct button_mapping button_context_colorchooser[] = {
195 { ACTION_STD_OK, BUTTON_RIGHT|BUTTON_REL, BUTTON_NONE },
196 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_SETTINGS),
197}; /* button_context_colorchooser */
198
199static const struct button_mapping button_context_eq[] = {
200 { ACTION_STD_OK, BUTTON_SELECT|BUTTON_REL, BUTTON_NONE },
201 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_SETTINGS),
202}; /* button_context_eq */
203
204/** Bookmark Screen **/ 194/** Bookmark Screen **/
205static const struct button_mapping button_context_bmark[] = { 195static const struct button_mapping button_context_bmark[] = {
206 { ACTION_BMS_DELETE, BUTTON_RIGHT, BUTTON_NONE }, 196 { ACTION_BMS_DELETE, BUTTON_RIGHT, BUTTON_NONE },
207 197
208 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_LIST), 198 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_LIST),
209}; /* button_context_bmark */ 199}; /* button_context_bmark */
210 200
211static const struct button_mapping button_context_time[] = {
212 { ACTION_STD_CANCEL, BUTTON_POWER, BUTTON_NONE },
213 { ACTION_STD_OK, BUTTON_RIGHT, BUTTON_NONE },
214 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_SETTINGS),
215}; /* button_context_time */
216
217static const struct button_mapping button_context_quickscreen[] = { 201static const struct button_mapping button_context_quickscreen[] = {
218 { ACTION_QS_DOWNINV, BUTTON_UP, BUTTON_NONE }, 202 { ACTION_NONE, BUTTON_REW, BUTTON_NONE },
219 { ACTION_QS_DOWNINV, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 203 { ACTION_STD_CANCEL, BUTTON_MENU, BUTTON_NONE },
220 { ACTION_QS_DOWN, BUTTON_DOWN, BUTTON_NONE },
221 { ACTION_QS_DOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
222 { ACTION_QS_LEFT, BUTTON_REW, BUTTON_NONE },
223 { ACTION_QS_LEFT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
224 { ACTION_QS_RIGHT, BUTTON_FFWD, BUTTON_NONE },
225 { ACTION_QS_RIGHT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
226 { ACTION_STD_CANCEL, BUTTON_MENU, BUTTON_NONE },
227 204
228 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) 205 { ACTION_QS_DOWNINV, BUTTON_UP|BUTTON_REL, BUTTON_NONE },
206 { ACTION_QS_DOWNINV, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
207
208 { ACTION_QS_DOWN, BUTTON_DOWN|BUTTON_REL, BUTTON_NONE },
209 { ACTION_QS_DOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
210
211 { ACTION_QS_LEFT, BUTTON_REW|BUTTON_REL, BUTTON_NONE },
212 { ACTION_QS_LEFT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
213
214 { ACTION_QS_RIGHT, BUTTON_FFWD|BUTTON_REL, BUTTON_NONE },
215 { ACTION_QS_RIGHT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
216
217 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD),
229}; /* button_context_quickscreen */ 218}; /* button_context_quickscreen */
230 219
231static const struct button_mapping button_context_pitchscreen[] = { 220static const struct button_mapping button_context_pitchscreen[] = {
232 { ACTION_PS_INC_SMALL, BUTTON_UP, BUTTON_NONE }, 221 { ACTION_PS_RESET, BUTTON_PLAY, BUTTON_NONE },
233 { ACTION_PS_INC_BIG, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 222 { ACTION_PS_EXIT, BUTTON_MENU, BUTTON_NONE },
234 { ACTION_PS_DEC_SMALL, BUTTON_DOWN, BUTTON_NONE }, 223 { ACTION_PS_EXIT, BUTTON_LEFT, BUTTON_NONE },
235 { ACTION_PS_DEC_BIG, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 224 { ACTION_PS_EXIT, BUTTON_POWER, BUTTON_NONE },
236 { ACTION_PS_NUDGE_LEFT, BUTTON_REW, BUTTON_NONE },
237 { ACTION_PS_NUDGE_LEFTOFF, BUTTON_REW|BUTTON_REL, BUTTON_NONE },
238 { ACTION_PS_NUDGE_RIGHT, BUTTON_FFWD, BUTTON_NONE },
239 { ACTION_PS_NUDGE_RIGHTOFF, BUTTON_FFWD|BUTTON_REL, BUTTON_NONE },
240 { ACTION_PS_TOGGLE_MODE, BUTTON_MENU, BUTTON_NONE },
241 { ACTION_PS_RESET, BUTTON_RIGHT, BUTTON_NONE },
242 { ACTION_PS_EXIT, BUTTON_POWER, BUTTON_NONE },
243 { ACTION_PS_SLOWER, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
244 { ACTION_PS_FASTER, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
245 225
246 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) 226 { ACTION_PS_INC_SMALL, BUTTON_UP, BUTTON_NONE },
227 { ACTION_PS_INC_BIG, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
228
229 { ACTION_PS_DEC_SMALL, BUTTON_DOWN, BUTTON_NONE },
230 { ACTION_PS_DEC_BIG, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
231
232 { ACTION_PS_NUDGE_LEFT, BUTTON_REW, BUTTON_NONE },
233 { ACTION_PS_NUDGE_LEFTOFF, BUTTON_REW|BUTTON_REL, BUTTON_NONE },
234
235 { ACTION_PS_NUDGE_RIGHT, BUTTON_FFWD, BUTTON_NONE },
236 { ACTION_PS_NUDGE_RIGHTOFF, BUTTON_FFWD|BUTTON_REL, BUTTON_NONE },
237
238 { ACTION_PS_SLOWER, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
239 { ACTION_PS_FASTER, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
240
241 LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD),
247}; /* button_context_pitchcreen */ 242}; /* button_context_pitchcreen */
248 243
249static const struct button_mapping button_context_keyboard[] = { 244static const struct button_mapping button_context_keyboard[] = {
250 { ACTION_KBD_LEFT, BUTTON_REW, BUTTON_NONE }, 245 { ACTION_KBD_SELECT, BUTTON_PLAY|BUTTON_REL, BUTTON_NONE },
251 { ACTION_KBD_LEFT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE }, 246 { ACTION_KBD_DONE, BUTTON_PLAY|BUTTON_REPEAT, BUTTON_NONE },
252 { ACTION_KBD_RIGHT, BUTTON_FFWD, BUTTON_NONE }, 247 { ACTION_KBD_ABORT, BUTTON_POWER, BUTTON_NONE },
253 { ACTION_KBD_RIGHT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE }, 248
254 { ACTION_KBD_CURSOR_LEFT, BUTTON_RIGHT|BUTTON_REW, BUTTON_NONE }, 249 { ACTION_KBD_LEFT, BUTTON_REW, BUTTON_NONE },
255 { ACTION_KBD_CURSOR_LEFT, BUTTON_RIGHT|BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE }, 250 { ACTION_KBD_LEFT, BUTTON_REW|BUTTON_REPEAT, BUTTON_NONE },
256 { ACTION_KBD_CURSOR_RIGHT, BUTTON_RIGHT|BUTTON_FFWD, BUTTON_NONE }, 251
257 { ACTION_KBD_CURSOR_RIGHT, BUTTON_RIGHT|BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE }, 252 { ACTION_KBD_RIGHT, BUTTON_FFWD, BUTTON_NONE },
258 { ACTION_KBD_SELECT, BUTTON_SELECT, BUTTON_NONE }, 253 { ACTION_KBD_RIGHT, BUTTON_FFWD|BUTTON_REPEAT, BUTTON_NONE },
259 { ACTION_KBD_PAGE_FLIP, BUTTON_RIGHT|BUTTON_MENU, BUTTON_NONE }, 254
260 { ACTION_KBD_DONE, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT }, 255 { ACTION_KBD_UP, BUTTON_UP, BUTTON_NONE },
261 { ACTION_KBD_ABORT, BUTTON_POWER|BUTTON_REL, BUTTON_POWER }, 256 { ACTION_KBD_UP, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
262 { ACTION_KBD_BACKSPACE, BUTTON_MENU, BUTTON_NONE }, 257
263 { ACTION_KBD_BACKSPACE, BUTTON_MENU|BUTTON_REPEAT, BUTTON_NONE }, 258 { ACTION_KBD_DOWN, BUTTON_DOWN, BUTTON_NONE },
264 { ACTION_KBD_UP, BUTTON_UP, BUTTON_NONE }, 259 { ACTION_KBD_DOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
265 { ACTION_KBD_UP, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 260
266 { ACTION_KBD_DOWN, BUTTON_DOWN, BUTTON_NONE }, 261 { ACTION_KBD_CURSOR_LEFT, BUTTON_LEFT, BUTTON_NONE },
267 { ACTION_KBD_DOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 262 { ACTION_KBD_CURSOR_LEFT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE },
268 { ACTION_KBD_MORSE_INPUT, BUTTON_RIGHT|BUTTON_POWER, BUTTON_NONE }, 263
269 { ACTION_KBD_MORSE_SELECT, BUTTON_SELECT|BUTTON_REL, BUTTON_NONE }, 264 { ACTION_KBD_CURSOR_RIGHT, BUTTON_RIGHT, BUTTON_NONE },
265 { ACTION_KBD_CURSOR_RIGHT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE },
266
267 { ACTION_KBD_BACKSPACE, BUTTON_VOL_UP, BUTTON_NONE },
268 { ACTION_KBD_BACKSPACE, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE },
269
270 { ACTION_KBD_PAGE_FLIP, BUTTON_VOL_DOWN, BUTTON_NONE },
271
272 { ACTION_KBD_MORSE_INPUT, BUTTON_MENU|BUTTON_REPEAT, BUTTON_NONE },
273 { ACTION_KBD_MORSE_SELECT, BUTTON_MENU|BUTTON_REL, BUTTON_NONE },
270 274
271 LAST_ITEM_IN_LIST 275 LAST_ITEM_IN_LIST
272}; /* button_context_keyboard */ 276}; /* button_context_keyboard */
273 277
274#ifdef HAVE_USBSTACK 278#ifdef HAVE_USBSTACK
275static const struct button_mapping button_context_usb_hid[] = { 279static const struct button_mapping button_context_usb_hid[] = {
276 { ACTION_USB_HID_PLAY, BUTTON_RIGHT, BUTTON_NONE }, 280 { ACTION_USB_HID_PLAY, BUTTON_PLAY, BUTTON_NONE },
277 { ACTION_USB_HID_STOP, BUTTON_POWER, BUTTON_NONE }, 281 { ACTION_USB_HID_STOP, BUTTON_LEFT, BUTTON_NONE },
278 { ACTION_USB_HID_SKIPPREV, BUTTON_REW, BUTTON_NONE }, 282 { ACTION_USB_HID_STOP, BUTTON_POWER, BUTTON_NONE },
279 { ACTION_USB_HID_SKIPNEXT, BUTTON_FFWD, BUTTON_NONE }, 283
280 { ACTION_USB_HID_VOLUP, BUTTON_UP, BUTTON_NONE }, 284 { ACTION_USB_HID_SKIPPREV, BUTTON_REW, BUTTON_NONE },
281 { ACTION_USB_HID_VOLUP, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, 285 { ACTION_USB_HID_SKIPNEXT, BUTTON_FFWD, BUTTON_NONE },
282 { ACTION_USB_HID_VOLUP, BUTTON_VOL_UP, BUTTON_NONE }, 286
283 { ACTION_USB_HID_VOLUP, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE }, 287 { ACTION_USB_HID_VOLUP, BUTTON_UP, BUTTON_NONE },
284 { ACTION_USB_HID_VOLDOWN, BUTTON_DOWN, BUTTON_NONE }, 288 { ACTION_USB_HID_VOLUP, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE },
285 { ACTION_USB_HID_VOLDOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 289 { ACTION_USB_HID_VOLUP, BUTTON_VOL_UP, BUTTON_NONE },
286 { ACTION_USB_HID_VOLDOWN, BUTTON_VOL_DOWN, BUTTON_NONE }, 290 { ACTION_USB_HID_VOLUP, BUTTON_VOL_UP|BUTTON_REPEAT, BUTTON_NONE },
287 { ACTION_USB_HID_VOLDOWN, BUTTON_VOL_DOWN|BUTTON_REPEAT, BUTTON_NONE }, 291
288 { ACTION_USB_HID_MUTE, BUTTON_SELECT, BUTTON_NONE }, 292 { ACTION_USB_HID_VOLDOWN, BUTTON_DOWN, BUTTON_NONE },
289 { ACTION_USB_HID_MENU, BUTTON_MENU, BUTTON_NONE }, 293 { ACTION_USB_HID_VOLDOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE },
294 { ACTION_USB_HID_VOLDOWN, BUTTON_VOL_DOWN, BUTTON_NONE },
295 { ACTION_USB_HID_VOLDOWN, BUTTON_VOL_DOWN|BUTTON_REPEAT, BUTTON_NONE },
296
297 { ACTION_USB_HID_MUTE, BUTTON_RIGHT, BUTTON_NONE },
298 { ACTION_USB_HID_MENU, BUTTON_MENU, BUTTON_NONE },
290 299
291 LAST_ITEM_IN_LIST 300 LAST_ITEM_IN_LIST
292}; /* button_context_usb_hid */ 301}; /* button_context_usb_hid */
@@ -298,43 +307,47 @@ const struct button_mapping* get_context_mapping(int context)
298 { 307 {
299 case CONTEXT_STD: 308 case CONTEXT_STD:
300 return button_context_standard; 309 return button_context_standard;
310
301 case CONTEXT_WPS: 311 case CONTEXT_WPS:
302 return button_context_wps; 312 return button_context_wps;
303 313
304 case CONTEXT_LIST: 314 case CONTEXT_LIST:
305 return button_context_list; 315 return button_context_list;
316
306 case CONTEXT_MAINMENU: 317 case CONTEXT_MAINMENU:
307 case CONTEXT_TREE: 318 case CONTEXT_TREE:
308 if (global_settings.hold_lr_for_scroll_in_list) 319 if (global_settings.hold_lr_for_scroll_in_list)
309 return button_context_listtree_scroll_without_combo; 320 return button_context_listtree_scroll_without_combo;
310 else 321 else
311 return button_context_listtree_scroll_with_combo; 322 return button_context_listtree_scroll_with_combo;
323
312 case CONTEXT_CUSTOM|CONTEXT_TREE: 324 case CONTEXT_CUSTOM|CONTEXT_TREE:
313 return button_context_tree; 325 return button_context_tree;
314 326
327 case CONTEXT_SETTINGS_TIME:
315 case CONTEXT_SETTINGS: 328 case CONTEXT_SETTINGS:
316 return button_context_settings; 329 return button_context_settings;
317 case CONTEXT_CUSTOM|CONTEXT_SETTINGS:
318 return button_context_settings_right_is_inc;
319 330
331 case CONTEXT_CUSTOM|CONTEXT_SETTINGS:
320 case CONTEXT_SETTINGS_COLOURCHOOSER: 332 case CONTEXT_SETTINGS_COLOURCHOOSER:
321 return button_context_colorchooser;
322 case CONTEXT_SETTINGS_EQ: 333 case CONTEXT_SETTINGS_EQ:
323 return button_context_eq; 334 return button_context_settings_right_is_inc;
324
325 case CONTEXT_SETTINGS_TIME:
326 return button_context_time;
327 335
328 case CONTEXT_YESNOSCREEN: 336 case CONTEXT_YESNOSCREEN:
329 return button_context_yesno; 337 return button_context_yesno;
338
330 case CONTEXT_BOOKMARKSCREEN: 339 case CONTEXT_BOOKMARKSCREEN:
331 return button_context_bmark; 340 return button_context_bmark;
341
332 case CONTEXT_QUICKSCREEN: 342 case CONTEXT_QUICKSCREEN:
333 return button_context_quickscreen; 343 return button_context_quickscreen;
344
334 case CONTEXT_PITCHSCREEN: 345 case CONTEXT_PITCHSCREEN:
335 return button_context_pitchscreen; 346 return button_context_pitchscreen;
347
336 case CONTEXT_KEYBOARD: 348 case CONTEXT_KEYBOARD:
337 return button_context_keyboard; 349 return button_context_keyboard;
350
338#ifdef HAVE_USBSTACK 351#ifdef HAVE_USBSTACK
339 case CONTEXT_USB_HID: 352 case CONTEXT_USB_HID:
340 return button_context_usb_hid; 353 return button_context_usb_hid;
diff --git a/apps/lang/english.lang b/apps/lang/english.lang
index da09e3c49a..987833a6f2 100644
--- a/apps/lang/english.lang
+++ b/apps/lang/english.lang
@@ -334,13 +334,13 @@
334 <source> 334 <source>
335 *: "PLAY = Yes" 335 *: "PLAY = Yes"
336 h100,h120,h300: "NAVI = Yes" 336 h100,h120,h300: "NAVI = Yes"
337 yh*,ipod*,x5,m5,gigabeat*,e200*,c200,h10,h10_5gb,mrobe100,sa9200: "SELECT = Yes" 337 yh*,ipod*,x5,m5,gigabeat*,e200*,c200,h10,h10_5gb,mrobe100: "SELECT = Yes"
338 player: "(PLAY/STOP)" 338 player: "(PLAY/STOP)"
339 </source> 339 </source>
340 <dest> 340 <dest>
341 *: "PLAY = Yes" 341 *: "PLAY = Yes"
342 h100,h120,h300: "NAVI = Yes" 342 h100,h120,h300: "NAVI = Yes"
343 yh*,ipod*,x5,m5,gigabeat*,e200*,c200,h10,h10_5gb,mrobe100,sa9200: "SELECT = Yes" 343 yh*,ipod*,x5,m5,gigabeat*,e200*,c200,h10,h10_5gb,mrobe100: "SELECT = Yes"
344 player: "(PLAY/STOP)" 344 player: "(PLAY/STOP)"
345 </dest> 345 </dest>
346 <voice> 346 <voice>
@@ -2457,14 +2457,16 @@
2457 h100,h120,h300: "Building database... %d found (STOP to return)" 2457 h100,h120,h300: "Building database... %d found (STOP to return)"
2458 ipod*: "Building database... %d found (PREV to return)" 2458 ipod*: "Building database... %d found (PREV to return)"
2459 x5,m5,gigabeat*,mrobe100: "Building database... %d found (LEFT to return)" 2459 x5,m5,gigabeat*,mrobe100: "Building database... %d found (LEFT to return)"
2460 h10,h10_5gb,e200*,c200,sa9200: "Building database... %d found (PREV to return)" 2460 h10,h10_5gb,e200*,c200: "Building database... %d found (PREV to return)"
2461 sa9200: "Building database... %d found (REW to return)"
2461 </source> 2462 </source>
2462 <dest> 2463 <dest>
2463 *: "Building database... %d found (OFF to return)" 2464 *: "Building database... %d found (OFF to return)"
2464 h100,h120,h300: "Building database... %d found (STOP to return)" 2465 h100,h120,h300: "Building database... %d found (STOP to return)"
2465 ipod*: "Building database... %d found (PREV to return)" 2466 ipod*: "Building database... %d found (PREV to return)"
2466 x5,m5,gigabeat*,mrobe100: "Building database... %d found (LEFT to return)" 2467 x5,m5,gigabeat*,mrobe100: "Building database... %d found (LEFT to return)"
2467 h10,h10_5gb,e200*,c200,sa9200: "Building database... %d found (PREV to return)" 2468 h10,h10_5gb,e200*,c200: "Building database... %d found (PREV to return)"
2469 sa9200: "Building database... %d found (REW to return)"
2468 </dest> 2470 </dest>
2469 <voice> 2471 <voice>
2470 *: "entries found for database" 2472 *: "entries found for database"
@@ -4216,13 +4218,15 @@
4216 *: none 4218 *: none
4217 rtc: "ON = Set" 4219 rtc: "ON = Set"
4218 h100,h120,h300: "NAVI = Set" 4220 h100,h120,h300: "NAVI = Set"
4219 ipod*,x5,m5,h10,h10_5gb,e200*,c200,gigabeat*,mrobe100,sa9200: "SELECT = Set" 4221 ipod*,x5,m5,h10,h10_5gb,e200*,c200,gigabeat*,mrobe100: "SELECT = Set"
4222 sa9200: "PLAY = Set"
4220 </source> 4223 </source>
4221 <dest> 4224 <dest>
4222 *: none 4225 *: none
4223 rtc: "ON = Set" 4226 rtc: "ON = Set"
4224 h100,h120,h300: "NAVI = Set" 4227 h100,h120,h300: "NAVI = Set"
4225 ipod*,x5,m5,h10,h10_5gb,e200*,c200,gigabeat*,mrobe100,sa9200: "SELECT = Set" 4228 ipod*,x5,m5,h10,h10_5gb,e200*,c200,gigabeat*,mrobe100: "SELECT = Set"
4229 sa9200: "PLAY = Set"
4226 </dest> 4230 </dest>
4227 <voice> 4231 <voice>
4228 *: none 4232 *: none
@@ -4237,23 +4241,25 @@
4237 *: none 4241 *: none
4238 rtc: "OFF = Revert" 4242 rtc: "OFF = Revert"
4239 h100,h120,h300: "STOP = Revert" 4243 h100,h120,h300: "STOP = Revert"
4240 ipod*,c200,sa9200: "MENU = Revert" 4244 ipod*,c200: "MENU = Revert"
4241 x5,m5: "RECORD = Revert" 4245 x5,m5: "RECORD = Revert"
4242 h10,h10_5gb,e200*: "PREV = Revert" 4246 h10,h10_5gb,e200*: "PREV = Revert"
4243 gigabeatf: "POWER = Revert" 4247 gigabeatf: "POWER = Revert"
4244 mrobe100: "DISPLAY = Revert" 4248 mrobe100: "DISPLAY = Revert"
4245 gigabeats: "BACK = Revert" 4249 gigabeats: "BACK = Revert"
4250 sa9200: "LEFT = Revert"
4246 </source> 4251 </source>
4247 <dest> 4252 <dest>
4248 *: none 4253 *: none
4249 rtc: "OFF = Revert" 4254 rtc: "OFF = Revert"
4250 h100,h120,h300: "STOP = Revert" 4255 h100,h120,h300: "STOP = Revert"
4251 ipod*,c200,sa9200: "MENU = Revert" 4256 ipod*,c200: "MENU = Revert"
4252 x5,m5: "RECORD = Revert" 4257 x5,m5: "RECORD = Revert"
4253 h10,h10_5gb,e200*: "PREV = Revert" 4258 h10,h10_5gb,e200*: "PREV = Revert"
4254 gigabeatf: "POWER = Revert" 4259 gigabeatf: "POWER = Revert"
4255 mrobe100: "DISPLAY = Revert" 4260 mrobe100: "DISPLAY = Revert"
4256 gigabeats: "BACK = Revert" 4261 gigabeats: "BACK = Revert"
4262 sa9200: "LEFT = Revert"
4257 </dest> 4263 </dest>
4258 <voice> 4264 <voice>
4259 *: none 4265 *: none
diff --git a/firmware/SOURCES b/firmware/SOURCES
index 78f13a9444..bba9ef1dc5 100644
--- a/firmware/SOURCES
+++ b/firmware/SOURCES
@@ -547,6 +547,9 @@ target/arm/sandisk/audio-c200_e200.c
547 547
548#ifdef PHILIPS_SA9200 548#ifdef PHILIPS_SA9200
549#ifndef SIMULATOR 549#ifndef SIMULATOR
550#ifndef BOOTLOADER
551drivers/synaptics-mep.c
552#endif /* BOOTLOADER */
550target/arm/adc-as3514.c 553target/arm/adc-as3514.c
551target/arm/ascodec-pp.c 554target/arm/ascodec-pp.c
552target/arm/ata-sd-pp.c 555target/arm/ata-sd-pp.c
diff --git a/firmware/drivers/synaptics-mep.c b/firmware/drivers/synaptics-mep.c
index 64b63397f7..f4b5a99aa7 100644
--- a/firmware/drivers/synaptics-mep.c
+++ b/firmware/drivers/synaptics-mep.c
@@ -73,6 +73,26 @@
73#define DATA_LO GPIO_SET_BITWISE(GPIOA_OUTPUT_EN, 0x10);\ 73#define DATA_LO GPIO_SET_BITWISE(GPIOA_OUTPUT_EN, 0x10);\
74 GPIO_CLEAR_BITWISE(GPIOA_OUTPUT_VAL, 0x10) 74 GPIO_CLEAR_BITWISE(GPIOA_OUTPUT_VAL, 0x10)
75#define DATA_CL GPIO_CLEAR_BITWISE(GPIOA_OUTPUT_EN, 0x10) 75#define DATA_CL GPIO_CLEAR_BITWISE(GPIOA_OUTPUT_EN, 0x10)
76
77#elif defined(PHILIPS_SA9200)
78#define INT_ENABLE GPIO_CLEAR_BITWISE(GPIOD_INT_LEV, 0x2);\
79 GPIO_SET_BITWISE(GPIOD_INT_EN, 0x2)
80#define INT_DISABLE GPIO_CLEAR_BITWISE(GPIOD_INT_EN, 0x2);\
81 GPIO_SET_BITWISE(GPIOD_INT_CLR, 0x2)
82
83#define ACK (GPIOD_INPUT_VAL & 0x8)
84#define ACK_HI GPIO_SET_BITWISE(GPIOD_OUTPUT_VAL, 0x8)
85#define ACK_LO GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_VAL, 0x8)
86
87#define CLK ((GPIOD_INPUT_VAL & 0x2) >> 1)
88#define CLK_HI GPIO_SET_BITWISE(GPIOD_OUTPUT_VAL, 0x2)
89#define CLK_LO GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_VAL, 0x2)
90
91#define DATA ((GPIOD_INPUT_VAL & 0x10) >> 4)
92#define DATA_HI GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_EN, 0x10)
93#define DATA_LO GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_VAL, 0x10);\
94 GPIO_SET_BITWISE(GPIOD_OUTPUT_EN, 0x10)
95#define DATA_CL GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_EN, 0x10)
76#endif 96#endif
77 97
78#define LO 0 98#define LO 0
diff --git a/firmware/export/config-sa9200.h b/firmware/export/config-sa9200.h
index e35c27e15e..37c0b50035 100755
--- a/firmware/export/config-sa9200.h
+++ b/firmware/export/config-sa9200.h
@@ -59,6 +59,9 @@
59 59
60#define CONFIG_KEYPAD PHILIPS_SA9200_PAD 60#define CONFIG_KEYPAD PHILIPS_SA9200_PAD
61 61
62/* define this if the target has volume keys which can be used in the lists */
63#define HAVE_VOLUME_IN_LIST
64
62/* Define this if you do software codec */ 65/* Define this if you do software codec */
63#define CONFIG_CODEC SWCODEC 66#define CONFIG_CODEC SWCODEC
64 67
@@ -99,6 +102,11 @@
99/* Which backlight fading type? */ 102/* Which backlight fading type? */
100#define CONFIG_BACKLIGHT_FADING BACKLIGHT_FADING_SW_SETTING 103#define CONFIG_BACKLIGHT_FADING BACKLIGHT_FADING_SW_SETTING
101 104
105/* define this if you have a light associated with the buttons */
106#define HAVE_BUTTON_LIGHT
107/* Can't control the brightness on all the buttons */
108/* #define HAVE_BUTTONLIGHT_BRIGHTNESS */
109
102/* define this if you have a flash memory storage */ 110/* define this if you have a flash memory storage */
103#define HAVE_FLASH_STORAGE 111#define HAVE_FLASH_STORAGE
104 112
diff --git a/firmware/export/usb.h b/firmware/export/usb.h
index 557639c622..2707541bff 100644
--- a/firmware/export/usb.h
+++ b/firmware/export/usb.h
@@ -77,10 +77,12 @@ enum {
77#elif (CONFIG_KEYPAD == SANSA_E200_PAD) || \ 77#elif (CONFIG_KEYPAD == SANSA_E200_PAD) || \
78 (CONFIG_KEYPAD == SANSA_C200_PAD) || \ 78 (CONFIG_KEYPAD == SANSA_C200_PAD) || \
79 (CONFIG_KEYPAD == SANSA_CLIP_PAD) || \ 79 (CONFIG_KEYPAD == SANSA_CLIP_PAD) || \
80 (CONFIG_KEYPAD == SANSA_FUZE_PAD) || \ 80 (CONFIG_KEYPAD == SANSA_FUZE_PAD)
81 (CONFIG_KEYPAD == PHILIPS_SA9200_PAD)
82#define USBPOWER_BUTTON BUTTON_SELECT 81#define USBPOWER_BUTTON BUTTON_SELECT
83#define USBPOWER_BTN_IGNORE BUTTON_POWER 82#define USBPOWER_BTN_IGNORE BUTTON_POWER
83#elif (CONFIG_KEYPAD == PHILIPS_SA9200_PAD)
84#define USBPOWER_BUTTON BUTTON_PLAY
85#define USBPOWER_BTN_IGNORE BUTTON_POWER
84#elif CONFIG_KEYPAD == PHILIPS_HDD1630_PAD 86#elif CONFIG_KEYPAD == PHILIPS_HDD1630_PAD
85#define USBPOWER_BUTTON BUTTON_PLAYLIST 87#define USBPOWER_BUTTON BUTTON_PLAYLIST
86#define USBPOWER_BTN_IGNORE BUTTON_POWER 88#define USBPOWER_BTN_IGNORE BUTTON_POWER
diff --git a/firmware/target/arm/philips/sa9200/backlight-sa9200.c b/firmware/target/arm/philips/sa9200/backlight-sa9200.c
index a0acaa0abd..22aae1ae6b 100644
--- a/firmware/target/arm/philips/sa9200/backlight-sa9200.c
+++ b/firmware/target/arm/philips/sa9200/backlight-sa9200.c
@@ -21,10 +21,10 @@
21#include "config.h" 21#include "config.h"
22#include "backlight-target.h" 22#include "backlight-target.h"
23#include "system.h" 23#include "system.h"
24#include "lcd.h"
25#include "backlight.h" 24#include "backlight.h"
26#include "ascodec.h" 25#include "ascodec.h"
27#include "as3514.h" 26#include "as3514.h"
27#include "synaptics-mep.h"
28 28
29void _backlight_set_brightness(int brightness) 29void _backlight_set_brightness(int brightness)
30{ 30{
@@ -51,12 +51,29 @@ void _backlight_off(void)
51#endif 51#endif
52} 52}
53 53
54#ifdef HAVE_BUTTON_LIGHT
55
56#define BUTTONLIGHT_MASK 0x7f
57#define BUTTONLIGHT_MAX 0x0f
58static unsigned short buttonlight_status = 0;
59
54void _buttonlight_on(void) 60void _buttonlight_on(void)
55{ 61{
56 /* TODO */ 62 if (!buttonlight_status)
63 {
64 touchpad_set_buttonlights(BUTTONLIGHT_MASK, BUTTONLIGHT_MAX);
65 GPIOD_OUTPUT_VAL &= ~(0x40 | 0x20 | 0x04); /* REW/FFWD/MENU */
66 buttonlight_status = 1;
67 }
57} 68}
58 69
59void _buttonlight_off(void) 70void _buttonlight_off(void)
60{ 71{
61 /* TODO */ 72 if (buttonlight_status)
73 {
74 touchpad_set_buttonlights(BUTTONLIGHT_MASK, 0);
75 GPIOD_OUTPUT_VAL |= (0x40 | 0x20 | 0x04); /* REW/FFWD/MENU */
76 buttonlight_status = 0;
77 }
62} 78}
79#endif
diff --git a/firmware/target/arm/philips/sa9200/backlight-target.h b/firmware/target/arm/philips/sa9200/backlight-target.h
index 21fad6d22e..9d695e5a22 100644
--- a/firmware/target/arm/philips/sa9200/backlight-target.h
+++ b/firmware/target/arm/philips/sa9200/backlight-target.h
@@ -27,6 +27,9 @@ void _backlight_off(void);
27void _backlight_set_brightness(int brightness); 27void _backlight_set_brightness(int brightness);
28int __backlight_is_on(void); 28int __backlight_is_on(void);
29 29
30#ifdef HAVE_BUTTON_LIGHT
30void _buttonlight_on(void); 31void _buttonlight_on(void);
31void _buttonlight_off(void); 32void _buttonlight_off(void);
32#endif 33#endif
34
35#endif
diff --git a/firmware/target/arm/philips/sa9200/button-sa9200.c b/firmware/target/arm/philips/sa9200/button-sa9200.c
index d965966075..be37111ecb 100755
--- a/firmware/target/arm/philips/sa9200/button-sa9200.c
+++ b/firmware/target/arm/philips/sa9200/button-sa9200.c
@@ -22,11 +22,58 @@
22#include "system.h" 22#include "system.h"
23#include "button.h" 23#include "button.h"
24#include "backlight.h" 24#include "backlight.h"
25#include "synaptics-mep.h"
25 26
27#define LOGF_ENABLE
28#include "logf.h"
29
30static int int_btn = BUTTON_NONE;
31
32#ifndef BOOTLOADER
26void button_init_device(void) 33void button_init_device(void)
27{ 34{
28 /* TODO...for now, hardware initialisation is done by the c200 bootloader */ 35 /* The touchpad is powered on and initialized in power-sa9200.c
36 since it needs to be ready for both buttons and button lights. */
37}
38
39/*
40 * Button interrupt handler
41 */
42void button_int(void)
43{
44 char data[4];
45 int val;
46
47 int_btn = BUTTON_NONE;
48
49 val = touchpad_read_device(data, 4);
50
51 if (val == MEP_BUTTON_HEADER)
52 {
53 /* Buttons packet */
54 if (data[1] & 0x1) int_btn |= BUTTON_FFWD;
55 if (data[1] & 0x2) int_btn |= BUTTON_RIGHT;
56 if (data[1] & 0x4) int_btn |= BUTTON_LEFT;
57 if (data[1] & 0x8) int_btn |= BUTTON_REW;
58 if (data[2] & 0x1) int_btn |= BUTTON_MENU;
59 }
60 else if (val == MEP_ABSOLUTE_HEADER)
61 {
62 /* Absolute packet - the finger is on the vertical strip.
63 Position ranges from 1-4095, with 1 at the bottom. */
64 val = ((data[1] >> 4) << 8) | data[2]; /* position */
65
66 if ((val > 0) && (val <= 1365))
67 int_btn |= BUTTON_DOWN;
68 else if ((val > 1365) && (val <= 2730))
69 int_btn |= BUTTON_PLAY;
70 else if ((val > 2730) && (val <= 4095))
71 int_btn |= BUTTON_UP;
72 }
29} 73}
74#else
75void button_init_device(void){}
76#endif /* bootloader */
30 77
31bool button_hold(void) 78bool button_hold(void)
32{ 79{
@@ -38,32 +85,14 @@ bool button_hold(void)
38 */ 85 */
39int button_read_device(void) 86int button_read_device(void)
40{ 87{
41 int btn = BUTTON_NONE; 88 int btn = int_btn;
42 static bool hold_button = false;
43 bool hold_button_old;
44
45 /* Hold */
46 hold_button_old = hold_button;
47 hold_button = button_hold();
48 89
49#ifndef BOOTLOADER 90 if (button_hold())
50 if (hold_button != hold_button_old) 91 return BUTTON_NONE;
51 backlight_hold_changed(hold_button);
52#endif
53 92
54 /* device buttons */ 93 if (!(GPIOB_INPUT_VAL & 0x20)) btn |= BUTTON_POWER;
55 if (!hold_button) 94 if (!(GPIOF_INPUT_VAL & 0x10)) btn |= BUTTON_VOL_UP;
56 { 95 if (!(GPIOF_INPUT_VAL & 0x04)) btn |= BUTTON_VOL_DOWN;
57#if 0
58 if (!(GPIOB_INPUT_VAL & 0x20)) btn |= BUTTON_POWER;
59 if (!(GPIOF_INPUT_VAL & 0x10)) btn |= BUTTON_VOL_UP;
60 if (!(GPIOF_INPUT_VAL & 0x04)) btn |= BUTTON_VOL_DOWN;
61#endif
62 /* A hack until the touchpad works */
63 if (!(GPIOB_INPUT_VAL & 0x20)) btn |= BUTTON_SELECT;
64 if (!(GPIOF_INPUT_VAL & 0x10)) btn |= BUTTON_UP;
65 if (!(GPIOF_INPUT_VAL & 0x04)) btn |= BUTTON_DOWN;
66 }
67 96
68 return btn; 97 return btn;
69} 98}
diff --git a/firmware/target/arm/philips/sa9200/button-target.h b/firmware/target/arm/philips/sa9200/button-target.h
index 0d691506d2..6259aa0737 100755
--- a/firmware/target/arm/philips/sa9200/button-target.h
+++ b/firmware/target/arm/philips/sa9200/button-target.h
@@ -25,15 +25,23 @@
25#include <stdbool.h> 25#include <stdbool.h>
26#include "config.h" 26#include "config.h"
27 27
28#define MEP_BUTTON_HEADER 0x1a
29#define MEP_BUTTON_ID 0x09
30#define MEP_ABSOLUTE_HEADER 0x0b
31
28#define HAS_BUTTON_HOLD 32#define HAS_BUTTON_HOLD
29 33
30bool button_hold(void); 34bool button_hold(void);
31void button_init_device(void); 35void button_init_device(void);
32int button_read_device(void); 36int button_read_device(void);
33 37
38#ifndef BOOTLOADER
39void button_int(void);
40#endif
41
34/* Main unit's buttons */ 42/* Main unit's buttons */
35#define BUTTON_POWER 0x00000001 43#define BUTTON_POWER 0x00000001
36#define BUTTON_SELECT 0x00000002 44#define BUTTON_PLAY 0x00000002
37#define BUTTON_MENU 0x00000004 45#define BUTTON_MENU 0x00000004
38#define BUTTON_LEFT 0x00000008 46#define BUTTON_LEFT 0x00000008
39#define BUTTON_RIGHT 0x00000010 47#define BUTTON_RIGHT 0x00000010
diff --git a/firmware/target/arm/philips/sa9200/power-sa9200.c b/firmware/target/arm/philips/sa9200/power-sa9200.c
index cf9468cb1d..5da1fc5fc4 100644
--- a/firmware/target/arm/philips/sa9200/power-sa9200.c
+++ b/firmware/target/arm/philips/sa9200/power-sa9200.c
@@ -22,14 +22,50 @@
22#include <stdbool.h> 22#include <stdbool.h>
23#include "system.h" 23#include "system.h"
24#include "cpu.h" 24#include "cpu.h"
25#include "i2c-pp.h"
26#include "tuner.h"
27#include "ascodec.h" 25#include "ascodec.h"
28#include "as3514.h" 26#include "as3514.h"
29#include "power.h" 27#include "power.h"
28#include "synaptics-mep.h"
29#include "logf.h"
30 30
31void power_init(void) 31void power_init(void)
32{ 32{
33#ifndef BOOTLOADER
34 /* Power on and initialize the touchpad here because we need it for
35 both buttons and button lights */
36 DEV_INIT2 &= ~0x800;
37
38 char byte = ascodec_read(AS3514_CVDD_DCDC3);
39 byte = (byte & ~0x18) | 0x08;
40 ascodec_write(AS3514_CVDD_DCDC3, byte);
41
42 /* LEDs for REW, FFWD, MENU */
43 GPIOD_ENABLE |= (0x40 | 0x20 | 0x04);
44 GPIOD_OUTPUT_VAL |= (0x40 | 0x20 | 0x04);
45 GPIOD_OUTPUT_EN |= (0x40 | 0x20 | 0x04);
46 udelay(20000);
47
48 GPIOL_ENABLE |= 0x10;
49 GPIOL_OUTPUT_VAL &= ~0x10;
50 GPIOL_OUTPUT_EN |= 0x10;
51 udelay(100000);
52
53 /* enable DATA, ACK, CLK lines */
54 GPIOD_ENABLE |= (0x10 | 0x08 | 0x02);
55
56 GPIOD_OUTPUT_EN |= 0x08; /* ACK */
57 GPIOD_OUTPUT_VAL |= 0x08; /* high */
58
59 GPIOD_OUTPUT_EN &= ~0x02; /* CLK */
60
61 GPIOD_OUTPUT_EN |= 0x10; /* DATA */
62 GPIOD_OUTPUT_VAL |= 0x10; /* high */
63
64 if (!touchpad_init())
65 {
66 logf("touchpad not ready");
67 }
68#endif
33} 69}
34 70
35void power_off(void) 71void power_off(void)