diff options
Diffstat (limited to 'keyboard/onekey/config.h')
| -rw-r--r-- | keyboard/onekey/config.h | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/keyboard/onekey/config.h b/keyboard/onekey/config.h index c5bc64de9..1d2e052bf 100644 --- a/keyboard/onekey/config.h +++ b/keyboard/onekey/config.h | |||
| @@ -67,4 +67,90 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 67 | //#define NO_ACTION_MACRO | 67 | //#define NO_ACTION_MACRO |
| 68 | //#define NO_ACTION_FUNCTION | 68 | //#define NO_ACTION_FUNCTION |
| 69 | 69 | ||
| 70 | |||
| 71 | /* PS/2 mouse */ | ||
| 72 | #ifdef PS2_USE_BUSYWAIT | ||
| 73 | # define PS2_CLOCK_PORT PORTD | ||
| 74 | # define PS2_CLOCK_PIN PIND | ||
| 75 | # define PS2_CLOCK_DDR DDRD | ||
| 76 | # define PS2_CLOCK_BIT 5 | ||
| 77 | # define PS2_DATA_PORT PORTD | ||
| 78 | # define PS2_DATA_PIN PIND | ||
| 79 | # define PS2_DATA_DDR DDRD | ||
| 80 | # define PS2_DATA_BIT 2 | ||
| 81 | #endif | ||
| 82 | |||
| 83 | |||
| 84 | /* PS/2 mouse interrupt version */ | ||
| 85 | #ifdef PS2_USE_INT | ||
| 86 | /* uses INT1 for clock line(ATMega32U4) */ | ||
| 87 | #define PS2_CLOCK_PORT PORTD | ||
| 88 | #define PS2_CLOCK_PIN PIND | ||
| 89 | #define PS2_CLOCK_DDR DDRD | ||
| 90 | #define PS2_CLOCK_BIT 5 | ||
| 91 | #define PS2_DATA_PORT PORTD | ||
| 92 | #define PS2_DATA_PIN PIND | ||
| 93 | #define PS2_DATA_DDR DDRD | ||
| 94 | #define PS2_DATA_BIT 2 | ||
| 95 | |||
| 96 | #define PS2_INT_INIT() do { \ | ||
| 97 | EICRA |= ((1<<ISC11) | \ | ||
| 98 | (0<<ISC10)); \ | ||
| 99 | } while (0) | ||
| 100 | #define PS2_INT_ON() do { \ | ||
| 101 | EIMSK |= (1<<INT1); \ | ||
| 102 | } while (0) | ||
| 103 | #define PS2_INT_OFF() do { \ | ||
| 104 | EIMSK &= ~(1<<INT1); \ | ||
| 105 | } while (0) | ||
| 106 | #define PS2_INT_VECT INT1_vect | ||
| 107 | #endif | ||
| 108 | |||
| 109 | |||
| 110 | /* PS/2 mouse USART version */ | ||
| 111 | #ifdef PS2_USE_USART | ||
| 112 | #if defined(__AVR_ATmega16U4__) || defined(__AVR_ATmega32U4__) | ||
| 113 | /* XCK for clock line and RXD for data line */ | ||
| 114 | #define PS2_CLOCK_PORT PORTD | ||
| 115 | #define PS2_CLOCK_PIN PIND | ||
| 116 | #define PS2_CLOCK_DDR DDRD | ||
| 117 | #define PS2_CLOCK_BIT 5 | ||
| 118 | #define PS2_DATA_PORT PORTD | ||
| 119 | #define PS2_DATA_PIN PIND | ||
| 120 | #define PS2_DATA_DDR DDRD | ||
| 121 | #define PS2_DATA_BIT 2 | ||
| 122 | |||
| 123 | /* synchronous, odd parity, 1-bit stop, 8-bit data, sample at falling edge */ | ||
| 124 | /* set DDR of CLOCK as input to be slave */ | ||
| 125 | #define PS2_USART_INIT() do { \ | ||
| 126 | PS2_CLOCK_DDR &= ~(1<<PS2_CLOCK_BIT); \ | ||
| 127 | PS2_DATA_DDR &= ~(1<<PS2_DATA_BIT); \ | ||
| 128 | UCSR1C = ((1 << UMSEL10) | \ | ||
| 129 | (3 << UPM10) | \ | ||
| 130 | (0 << USBS1) | \ | ||
| 131 | (3 << UCSZ10) | \ | ||
| 132 | (0 << UCPOL1)); \ | ||
| 133 | UCSR1A = 0; \ | ||
| 134 | UBRR1H = 0; \ | ||
| 135 | UBRR1L = 0; \ | ||
| 136 | } while (0) | ||
| 137 | #define PS2_USART_RX_INT_ON() do { \ | ||
| 138 | UCSR1B = ((1 << RXCIE1) | \ | ||
| 139 | (1 << RXEN1)); \ | ||
| 140 | } while (0) | ||
| 141 | #define PS2_USART_RX_POLL_ON() do { \ | ||
| 142 | UCSR1B = (1 << RXEN1); \ | ||
| 143 | } while (0) | ||
| 144 | #define PS2_USART_OFF() do { \ | ||
| 145 | UCSR1C = 0; \ | ||
| 146 | UCSR1B &= ~((1 << RXEN1) | \ | ||
| 147 | (1 << TXEN1)); \ | ||
| 148 | } while (0) | ||
| 149 | #define PS2_USART_RX_READY (UCSR1A & (1<<RXC1)) | ||
| 150 | #define PS2_USART_RX_DATA UDR1 | ||
| 151 | #define PS2_USART_ERROR (UCSR1A & ((1<<FE1) | (1<<DOR1) | (1<<UPE1))) | ||
| 152 | #define PS2_USART_RX_VECT USART1_RX_vect | ||
| 153 | #endif | ||
| 154 | #endif | ||
| 155 | |||
| 70 | #endif | 156 | #endif |
