restore some hw regs on exit to startup values
[libpicofe.git] / common / input.h
CommitLineData
da767bd5 1#define IN_MAX_DEVS 10
2
82abf46f 3/* unified menu keys */
4#define PBTN_UP (1 << 0)
5#define PBTN_DOWN (1 << 1)
6#define PBTN_LEFT (1 << 2)
7#define PBTN_RIGHT (1 << 3)
8
9#define PBTN_MOK (1 << 4)
10#define PBTN_MBACK (1 << 5)
11#define PBTN_MA2 (1 << 6) /* menu action 2 */
12#define PBTN_MA3 (1 << 7)
13
14#define PBTN_L (1 << 8)
15#define PBTN_R (1 << 9)
16
17#define PBTN_MENU (1 << 10)
18
388947f3 19/* ui events */
20#define PEVB_VOL_DOWN 30
21#define PEVB_VOL_UP 29
22#define PEVB_STATE_LOAD 28
23#define PEVB_STATE_SAVE 27
24#define PEVB_SWITCH_RND 26
25#define PEVB_SSLOT_PREV 25
26#define PEVB_SSLOT_NEXT 24
27#define PEVB_MENU 23
28#define PEVB_FF 22
29
30#define PEV_VOL_DOWN (1 << PEVB_VOL_DOWN)
31#define PEV_VOL_UP (1 << PEVB_VOL_UP)
32#define PEV_STATE_LOAD (1 << PEVB_STATE_LOAD)
33#define PEV_STATE_SAVE (1 << PEVB_STATE_SAVE)
34#define PEV_SWITCH_RND (1 << PEVB_SWITCH_RND)
35#define PEV_SSLOT_PREV (1 << PEVB_SSLOT_PREV)
36#define PEV_SSLOT_NEXT (1 << PEVB_SSLOT_NEXT)
37#define PEV_MENU (1 << PEVB_MENU)
38#define PEV_FF (1 << PEVB_FF)
39
40#define PEV_MASK 0x7fc00000
41
42
34581c95 43enum {
da767bd5 44 IN_DRVID_UNKNOWN = 0,
7f022a8d 45 IN_DRVID_GP2X,
13b692eb 46 IN_DRVID_EVDEV,
2c600560 47 IN_DRVID_COUNT,
48};
49
50enum {
51 IN_INFO_BIND_COUNT = 0,
52 IN_INFO_DOES_COMBOS,
34581c95 53};
2258f158 54
da767bd5 55typedef struct {
56 const char *prefix;
57 void (*probe)(void);
58 void (*free)(void *drv_data);
59 int (*get_bind_count)(void);
60 void (*get_def_binds)(int *binds);
61 int (*clean_binds)(void *drv_data, int *binds);
62 void (*set_blocking)(void *data, int y);
7f022a8d 63 int (*update_keycode)(void *drv_data, int *is_down);
da767bd5 64 int (*menu_translate)(int keycode);
65 int (*get_key_code)(const char *key_name);
66 const char * (*get_key_name)(int keycode);
67} in_drv_t;
68
69
2258f158 70/* to be called by drivers */
2c600560 71void in_register(const char *nname, int drv_id, int fd_hnd, void *drv_data, int combos);
72void in_combos_find(int *binds, int last_key, int *combo_keys, int *combo_acts);
73int in_combos_do(int keys, int *binds, int last_key, int combo_keys, int combo_acts);
2258f158 74
75void in_init(void);
76void in_probe(void);
77int in_update(void);
595491c4 78void in_set_blocking(int is_blocking);
906bdc9f 79int in_update_keycode(int *dev_id, int *is_down, int timeout_ms);
fce20e73 80int in_menu_wait_any(int timeout_ms);
049a6b3e 81int in_menu_wait(int interesting, int autorep_delay_ms);
2c600560 82int in_get_dev_info(int dev_id, int what);
da767bd5 83void in_config_start(void);
84int in_config_parse_dev(const char *dev_name);
85int in_config_bind_key(int dev_id, const char *key, int mask);
86void in_config_end(void);
906bdc9f 87int in_bind_key(int dev_id, int keycode, int mask, int force_unbind);
da767bd5 88void in_debug_dump(void);
89
90const int *in_get_dev_binds(int dev_id);
91const int *in_get_dev_def_binds(int dev_id);
049a6b3e 92const char *in_get_dev_name(int dev_id, int must_be_active, int skip_pfix);
595491c4 93const char *in_get_key_name(int dev_id, int keycode);