Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: 4DGL mbed ConfigFile
Fork of 4DGLtest by
keyboard.h@11:a5b0d98794c0, 2014-07-16 (annotated)
- Committer:
- WillemBraat
- Date:
- Wed Jul 16 19:15:40 2014 +0000
- Revision:
- 11:a5b0d98794c0
- Parent:
- 9:311b6676272d
Rewritten function CDU_DSP_CSS()
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| WillemBraat | 3:f7bce78b04c1 | 1 | /* Keyboard TCA8418 declarations */ |
| WillemBraat | 3:f7bce78b04c1 | 2 | |
| WillemBraat | 3:f7bce78b04c1 | 3 | |
| WillemBraat | 3:f7bce78b04c1 | 4 | /* TCA8418 hardware limits */ |
| WillemBraat | 3:f7bce78b04c1 | 5 | #define TCA8418_MAX_ROWS 8 |
| WillemBraat | 3:f7bce78b04c1 | 6 | #define TCA8418_MAX_COLS 10 |
| WillemBraat | 3:f7bce78b04c1 | 7 | |
| WillemBraat | 3:f7bce78b04c1 | 8 | /* TCA8418 register offsets */ |
| WillemBraat | 3:f7bce78b04c1 | 9 | #define REG_CFG 0x01 |
| WillemBraat | 3:f7bce78b04c1 | 10 | #define REG_INT_STAT 0x02 |
| WillemBraat | 3:f7bce78b04c1 | 11 | #define REG_KEY_LCK_EC 0x03 |
| WillemBraat | 3:f7bce78b04c1 | 12 | #define REG_KEY_EVENT_A 0x04 |
| WillemBraat | 3:f7bce78b04c1 | 13 | #define REG_KEY_EVENT_B 0x05 |
| WillemBraat | 3:f7bce78b04c1 | 14 | #define REG_KEY_EVENT_C 0x06 |
| WillemBraat | 3:f7bce78b04c1 | 15 | #define REG_KEY_EVENT_D 0x07 |
| WillemBraat | 3:f7bce78b04c1 | 16 | #define REG_KEY_EVENT_E 0x08 |
| WillemBraat | 3:f7bce78b04c1 | 17 | #define REG_KEY_EVENT_F 0x09 |
| WillemBraat | 3:f7bce78b04c1 | 18 | #define REG_KEY_EVENT_G 0x0A |
| WillemBraat | 3:f7bce78b04c1 | 19 | #define REG_KEY_EVENT_H 0x0B |
| WillemBraat | 3:f7bce78b04c1 | 20 | #define REG_KEY_EVENT_I 0x0C |
| WillemBraat | 3:f7bce78b04c1 | 21 | #define REG_KEY_EVENT_J 0x0D |
| WillemBraat | 3:f7bce78b04c1 | 22 | #define REG_KP_LCK_TIMER 0x0E |
| WillemBraat | 3:f7bce78b04c1 | 23 | #define REG_UNLOCK1 0x0F |
| WillemBraat | 3:f7bce78b04c1 | 24 | #define REG_UNLOCK2 0x10 |
| WillemBraat | 3:f7bce78b04c1 | 25 | #define REG_GPIO_INT_STAT1 0x11 |
| WillemBraat | 3:f7bce78b04c1 | 26 | #define REG_GPIO_INT_STAT2 0x12 |
| WillemBraat | 3:f7bce78b04c1 | 27 | #define REG_GPIO_INT_STAT3 0x13 |
| WillemBraat | 3:f7bce78b04c1 | 28 | #define REG_GPIO_DAT_STAT1 0x14 |
| WillemBraat | 3:f7bce78b04c1 | 29 | #define REG_GPIO_DAT_STAT2 0x15 |
| WillemBraat | 3:f7bce78b04c1 | 30 | #define REG_GPIO_DAT_STAT3 0x16 |
| WillemBraat | 3:f7bce78b04c1 | 31 | #define REG_GPIO_DAT_OUT1 0x17 |
| WillemBraat | 3:f7bce78b04c1 | 32 | #define REG_GPIO_DAT_OUT2 0x18 |
| WillemBraat | 3:f7bce78b04c1 | 33 | #define REG_GPIO_DAT_OUT3 0x19 |
| WillemBraat | 3:f7bce78b04c1 | 34 | #define REG_GPIO_INT_EN1 0x1A |
| WillemBraat | 3:f7bce78b04c1 | 35 | #define REG_GPIO_INT_EN2 0x1B |
| WillemBraat | 3:f7bce78b04c1 | 36 | #define REG_GPIO_INT_EN3 0x1C |
| WillemBraat | 3:f7bce78b04c1 | 37 | #define REG_KP_GPIO1 0x1D |
| WillemBraat | 3:f7bce78b04c1 | 38 | #define REG_KP_GPIO2 0x1E |
| WillemBraat | 3:f7bce78b04c1 | 39 | #define REG_KP_GPIO3 0x1F |
| WillemBraat | 3:f7bce78b04c1 | 40 | #define REG_GPI_EM1 0x20 |
| WillemBraat | 3:f7bce78b04c1 | 41 | #define REG_GPI_EM2 0x21 |
| WillemBraat | 3:f7bce78b04c1 | 42 | #define REG_GPI_EM3 0x22 |
| WillemBraat | 3:f7bce78b04c1 | 43 | #define REG_GPIO_DIR1 0x23 |
| WillemBraat | 3:f7bce78b04c1 | 44 | #define REG_GPIO_DIR2 0x24 |
| WillemBraat | 3:f7bce78b04c1 | 45 | #define REG_GPIO_DIR3 0x25 |
| WillemBraat | 3:f7bce78b04c1 | 46 | #define REG_GPIO_INT_LVL1 0x26 |
| WillemBraat | 3:f7bce78b04c1 | 47 | #define REG_GPIO_INT_LVL2 0x27 |
| WillemBraat | 3:f7bce78b04c1 | 48 | #define REG_GPIO_INT_LVL3 0x28 |
| WillemBraat | 3:f7bce78b04c1 | 49 | #define REG_DEBOUNCE_DIS1 0x29 |
| WillemBraat | 3:f7bce78b04c1 | 50 | #define REG_DEBOUNCE_DIS2 0x2A |
| WillemBraat | 3:f7bce78b04c1 | 51 | #define REG_DEBOUNCE_DIS3 0x2B |
| WillemBraat | 3:f7bce78b04c1 | 52 | #define REG_GPIO_PULL1 0x2C |
| WillemBraat | 3:f7bce78b04c1 | 53 | #define REG_GPIO_PULL2 0x2D |
| WillemBraat | 3:f7bce78b04c1 | 54 | #define REG_GPIO_PULL3 0x2E |
| WillemBraat | 3:f7bce78b04c1 | 55 | |
| WillemBraat | 3:f7bce78b04c1 | 56 | /* TCA8418 bit definitions */ |
| WillemBraat | 3:f7bce78b04c1 | 57 | #define CFG_AI BIT(7) |
| WillemBraat | 3:f7bce78b04c1 | 58 | #define CFG_GPI_E_CFG BIT(6) |
| WillemBraat | 3:f7bce78b04c1 | 59 | #define CFG_OVR_FLOW_M BIT(5) |
| WillemBraat | 3:f7bce78b04c1 | 60 | #define CFG_INT_CFG BIT(4) |
| WillemBraat | 3:f7bce78b04c1 | 61 | #define CFG_OVR_FLOW_IEN BIT(3) |
| WillemBraat | 3:f7bce78b04c1 | 62 | #define CFG_K_LCK_IEN BIT(2) |
| WillemBraat | 3:f7bce78b04c1 | 63 | #define CFG_GPI_IEN BIT(1) |
| WillemBraat | 3:f7bce78b04c1 | 64 | #define CFG_KE_IEN BIT(0) |
| WillemBraat | 3:f7bce78b04c1 | 65 | |
| WillemBraat | 3:f7bce78b04c1 | 66 | #define INT_STAT_CAD_INT BIT(4) |
| WillemBraat | 3:f7bce78b04c1 | 67 | #define INT_STAT_OVR_FLOW_INT BIT(3) |
| WillemBraat | 3:f7bce78b04c1 | 68 | #define INT_STAT_K_LCK_INT BIT(2) |
| WillemBraat | 3:f7bce78b04c1 | 69 | #define INT_STAT_GPI_INT BIT(1) |
| WillemBraat | 3:f7bce78b04c1 | 70 | #define INT_STAT_K_INT BIT(0) |
| WillemBraat | 3:f7bce78b04c1 | 71 | |
| WillemBraat | 3:f7bce78b04c1 | 72 | /* TCA8418 register masks */ |
| WillemBraat | 3:f7bce78b04c1 | 73 | #define KEY_LCK_EC_KEC 0x7 |
| WillemBraat | 3:f7bce78b04c1 | 74 | #define KEY_EVENT_CODE 0x7f |
| WillemBraat | 3:f7bce78b04c1 | 75 | #define KEY_EVENT_VALUE 0x80 |
| WillemBraat | 3:f7bce78b04c1 | 76 | |
| WillemBraat | 3:f7bce78b04c1 | 77 |
