You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

преди 13 години
преди 11 години
преди 13 години
преди 11 години
преди 11 години
преди 13 години
преди 13 години
преди 13 години
преди 13 години
преди 11 години
преди 13 години
преди 10 години
преди 9 години
преди 10 години
преди 9 години
преди 10 години
преди 8 години
преди 10 години
преди 9 години
преди 10 години
преди 8 години
преди 10 години
преди 11 години
преди 11 години
преди 11 години
преди 11 години
преди 13 години
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. /*
  2. Copyright 2012 Jun Wako <[email protected]>
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. */
  14. #ifndef CONFIG_H
  15. #define CONFIG_H
  16. #include <avr/interrupt.h>
  17. #define VENDOR_ID 0xFEED
  18. #define PRODUCT_ID 0x6512
  19. #define DEVICE_VER 0x0001
  20. #define MANUFACTURER t.m.k.
  21. #define PRODUCT PS/2 keyboard converter
  22. #define DESCRIPTION convert PS/2 keyboard to USB
  23. /* matrix size */
  24. #define MATRIX_ROWS 32 // keycode bit: 3-0
  25. #define MATRIX_COLS 8 // keycode bit: 6-4
  26. /* key combination for command */
  27. #define IS_COMMAND() ( \
  28. keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) || \
  29. keyboard_report->mods == (MOD_BIT(KC_LCTRL) | MOD_BIT(KC_RSHIFT)) \
  30. )
  31. //#define NO_SUSPEND_POWER_DOWN
  32. /*
  33. * PS/2 Busywait
  34. */
  35. #ifdef PS2_USE_BUSYWAIT
  36. #define PS2_CLOCK_PORT PORTD
  37. #define PS2_CLOCK_PIN PIND
  38. #define PS2_CLOCK_DDR DDRD
  39. #define PS2_CLOCK_BIT 1
  40. #define PS2_DATA_PORT PORTD
  41. #define PS2_DATA_PIN PIND
  42. #define PS2_DATA_DDR DDRD
  43. #define PS2_DATA_BIT 0
  44. #endif
  45. /*
  46. * PS/2 Pin interrupt
  47. */
  48. #ifdef PS2_USE_INT
  49. #if defined(__AVR_ATmega16U4__) || defined(__AVR_ATmega32U4__)
  50. /* uses INT1 for clock line(ATMega32U4) */
  51. #define PS2_CLOCK_PORT PORTD
  52. #define PS2_CLOCK_PIN PIND
  53. #define PS2_CLOCK_DDR DDRD
  54. #define PS2_CLOCK_BIT 1
  55. #define PS2_DATA_PORT PORTD
  56. #define PS2_DATA_PIN PIND
  57. #define PS2_DATA_DDR DDRD
  58. #define PS2_DATA_BIT 0
  59. #define PS2_INT_INIT() do { \
  60. EICRA |= ((1<<ISC11) | \
  61. (0<<ISC10)); \
  62. } while (0)
  63. #define PS2_INT_ON() do { \
  64. EIMSK |= (1<<INT1); \
  65. } while (0)
  66. #define PS2_INT_OFF() do { \
  67. EIMSK &= ~(1<<INT1); \
  68. } while (0)
  69. #define PS2_INT_VECT INT1_vect
  70. #elif defined(__AVR_ATmega168__) || defined(__AVR_ATmega168P__) || defined(__AVR_ATmega328P__)
  71. /* uses PCINT17(PD1) for clock line. this doesn't work with VUSB */
  72. #define PS2_CLOCK_PORT PORTD
  73. #define PS2_CLOCK_PIN PIND
  74. #define PS2_CLOCK_DDR DDRD
  75. #define PS2_CLOCK_BIT 1
  76. #define PS2_DATA_PORT PORTD
  77. #define PS2_DATA_PIN PIND
  78. #define PS2_DATA_DDR DDRD
  79. #define PS2_DATA_BIT 0
  80. #define PS2_INT_INIT() do { \
  81. PCICR |= (1<<PCIE2); \
  82. } while (0)
  83. #define PS2_INT_ON() do { \
  84. PCMSK2 |= (1<<PCINT17); \
  85. } while (0)
  86. #define PS2_INT_OFF() do { \
  87. PCMSK2 &= ~(1<<PCINT17); \
  88. } while (0)
  89. #define PS2_INT_VECT PCINT2_vect
  90. #endif
  91. #endif
  92. /*
  93. * PS/2 USART
  94. */
  95. #ifdef PS2_USE_USART
  96. #if defined(__AVR_ATmega16U4__) || defined(__AVR_ATmega32U4__)
  97. /* XCK for clock line and RXD for data line */
  98. #define PS2_CLOCK_PORT PORTD
  99. #define PS2_CLOCK_PIN PIND
  100. #define PS2_CLOCK_DDR DDRD
  101. #define PS2_CLOCK_BIT 5
  102. #define PS2_DATA_PORT PORTD
  103. #define PS2_DATA_PIN PIND
  104. #define PS2_DATA_DDR DDRD
  105. #define PS2_DATA_BIT 2
  106. /* synchronous, odd parity, 1-bit stop, 8-bit data, sample at falling edge */
  107. /* set DDR of CLOCK as input to be slave */
  108. #define PS2_USART_INIT() do { \
  109. PS2_CLOCK_DDR &= ~(1<<PS2_CLOCK_BIT); \
  110. PS2_DATA_DDR &= ~(1<<PS2_DATA_BIT); \
  111. UCSR1C = ((1 << UMSEL10) | \
  112. (3 << UPM10) | \
  113. (0 << USBS1) | \
  114. (3 << UCSZ10) | \
  115. (0 << UCPOL1)); \
  116. UCSR1A = 0; \
  117. UBRR1H = 0; \
  118. UBRR1L = 0; \
  119. } while (0)
  120. #define PS2_USART_RX_INT_ON() do { \
  121. UCSR1B = ((1 << RXCIE1) | \
  122. (1 << RXEN1)); \
  123. } while (0)
  124. #define PS2_USART_RX_POLL_ON() do { \
  125. UCSR1B = (1 << RXEN1); \
  126. } while (0)
  127. #define PS2_USART_OFF() do { \
  128. UCSR1C = 0; \
  129. UCSR1B &= ~((1 << RXEN1) | \
  130. (1 << TXEN1)); \
  131. } while (0)
  132. #define PS2_USART_RX_READY (UCSR1A & (1<<RXC1))
  133. #define PS2_USART_RX_DATA UDR1
  134. #define PS2_USART_ERROR (UCSR1A & ((1<<FE1) | (1<<DOR1) | (1<<UPE1)))
  135. #define PS2_USART_RX_VECT USART1_RX_vect
  136. #elif defined(__AVR_ATmega168__) || defined(__AVR_ATmega168P__) || defined(__AVR_ATmega328P__)
  137. /* XCK for clock line and RXD for data line */
  138. #define PS2_CLOCK_PORT PORTD
  139. #define PS2_CLOCK_PIN PIND
  140. #define PS2_CLOCK_DDR DDRD
  141. #define PS2_CLOCK_BIT 4
  142. #define PS2_DATA_PORT PORTD
  143. #define PS2_DATA_PIN PIND
  144. #define PS2_DATA_DDR DDRD
  145. #define PS2_DATA_BIT 0
  146. /* synchronous, odd parity, 1-bit stop, 8-bit data, sample at falling edge */
  147. /* set DDR of CLOCK as input to be slave */
  148. #define PS2_USART_INIT() do { \
  149. PS2_CLOCK_DDR &= ~(1<<PS2_CLOCK_BIT); \
  150. PS2_DATA_DDR &= ~(1<<PS2_DATA_BIT); \
  151. UCSR0C = ((1 << UMSEL00) | \
  152. (3 << UPM00) | \
  153. (0 << USBS0) | \
  154. (3 << UCSZ00) | \
  155. (0 << UCPOL0)); \
  156. UCSR0A = 0; \
  157. UBRR0H = 0; \
  158. UBRR0L = 0; \
  159. } while (0)
  160. #define PS2_USART_RX_INT_ON() do { \
  161. UCSR0B = ((1 << RXCIE0) | \
  162. (1 << RXEN0)); \
  163. } while (0)
  164. #define PS2_USART_RX_POLL_ON() do { \
  165. UCSR0B = (1 << RXEN0); \
  166. } while (0)
  167. #define PS2_USART_OFF() do { \
  168. UCSR0C = 0; \
  169. UCSR0B &= ~((1 << RXEN0) | \
  170. (1 << TXEN0)); \
  171. } while (0)
  172. #define PS2_USART_RX_READY (UCSR0A & (1<<RXC0))
  173. #define PS2_USART_RX_DATA UDR0
  174. #define PS2_USART_ERROR (UCSR0A & ((1<<FE0) | (1<<DOR0) | (1<<UPE0)))
  175. #define PS2_USART_RX_VECT USART_RX_vect
  176. #endif
  177. #endif
  178. #endif