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.

пре 11 година
пре 11 година
пре 11 година
пре 13 година
пре 13 година
пре 11 година
пре 13 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 13 година
пре 11 година
пре 11 година
пре 11 година
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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 MANUFACTURER t.m.k.
  20. #define PRODUCT PS/2 keyboard converter
  21. #define DESCRIPTION convert PS/2 keyboard to USB
  22. /* matrix size */
  23. #define MATRIX_ROWS 32 // keycode bit: 3-0
  24. #define MATRIX_COLS 8 // keycode bit: 6-4
  25. /* key combination for command */
  26. #define IS_COMMAND() ( \
  27. keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) || \
  28. keyboard_report->mods == (MOD_BIT(KC_LCTRL) | MOD_BIT(KC_RSHIFT)) \
  29. )
  30. #ifdef PS2_USE_USART
  31. #if defined(__AVR_ATmega16U4__) || defined(__AVR_ATmega32U4__)
  32. /* XCK for clock line and RXD for data line */
  33. #define PS2_CLOCK_PORT PORTD
  34. #define PS2_CLOCK_PIN PIND
  35. #define PS2_CLOCK_DDR DDRD
  36. #define PS2_CLOCK_BIT 5
  37. #define PS2_DATA_PORT PORTD
  38. #define PS2_DATA_PIN PIND
  39. #define PS2_DATA_DDR DDRD
  40. #define PS2_DATA_BIT 2
  41. /* synchronous, odd parity, 1-bit stop, 8-bit data, sample at falling edge */
  42. /* set DDR of CLOCK as input to be slave */
  43. #define PS2_USART_INIT() do { \
  44. PS2_CLOCK_DDR &= ~(1<<PS2_CLOCK_BIT); \
  45. PS2_DATA_DDR &= ~(1<<PS2_DATA_BIT); \
  46. UCSR1C = ((1 << UMSEL10) | \
  47. (3 << UPM10) | \
  48. (0 << USBS1) | \
  49. (3 << UCSZ10) | \
  50. (0 << UCPOL1)); \
  51. UCSR1A = 0; \
  52. UBRR1H = 0; \
  53. UBRR1L = 0; \
  54. } while (0)
  55. #define PS2_USART_RX_INT_ON() do { \
  56. UCSR1B = ((1 << RXCIE1) | \
  57. (1 << RXEN1)); \
  58. } while (0)
  59. #define PS2_USART_RX_POLL_ON() do { \
  60. UCSR1B = (1 << RXEN1); \
  61. } while (0)
  62. #define PS2_USART_OFF() do { \
  63. UCSR1C = 0; \
  64. UCSR1B &= ~((1 << RXEN1) | \
  65. (1 << TXEN1)); \
  66. } while (0)
  67. #define PS2_USART_RX_READY (UCSR1A & (1<<RXC1))
  68. #define PS2_USART_RX_DATA UDR1
  69. #define PS2_USART_ERROR (UCSR1A & ((1<<FE1) | (1<<DOR1) | (1<<UPE1)))
  70. #define PS2_USART_RX_VECT USART1_RX_vect
  71. #elif defined(__AVR_ATmega168__) || defined(__AVR_ATmega168P__) || defined(__AVR_ATmega328P__)
  72. /* XCK for clock line and RXD for data line */
  73. #define PS2_CLOCK_PORT PORTD
  74. #define PS2_CLOCK_PIN PIND
  75. #define PS2_CLOCK_DDR DDRD
  76. #define PS2_CLOCK_BIT 4
  77. #define PS2_DATA_PORT PORTD
  78. #define PS2_DATA_PIN PIND
  79. #define PS2_DATA_DDR DDRD
  80. #define PS2_DATA_BIT 0
  81. /* synchronous, odd parity, 1-bit stop, 8-bit data, sample at falling edge */
  82. /* set DDR of CLOCK as input to be slave */
  83. #define PS2_USART_INIT() do { \
  84. PS2_CLOCK_DDR &= ~(1<<PS2_CLOCK_BIT); \
  85. PS2_DATA_DDR &= ~(1<<PS2_DATA_BIT); \
  86. UCSR0C = ((1 << UMSEL00) | \
  87. (3 << UPM00) | \
  88. (0 << USBS0) | \
  89. (3 << UCSZ00) | \
  90. (0 << UCPOL0)); \
  91. UCSR0A = 0; \
  92. UBRR0H = 0; \
  93. UBRR0L = 0; \
  94. } while (0)
  95. #define PS2_USART_RX_INT_ON() do { \
  96. UCSR0B = ((1 << RXCIE0) | \
  97. (1 << RXEN0)); \
  98. } while (0)
  99. #define PS2_USART_RX_POLL_ON() do { \
  100. UCSR0B = (1 << RXEN0); \
  101. } while (0)
  102. #define PS2_USART_OFF() do { \
  103. UCSR0C = 0; \
  104. UCSR0B &= ~((1 << RXEN0) | \
  105. (1 << TXEN0)); \
  106. } while (0)
  107. #define PS2_USART_RX_READY (UCSR0A & (1<<RXC0))
  108. #define PS2_USART_RX_DATA UDR0
  109. #define PS2_USART_ERROR (UCSR0A & ((1<<FE0) | (1<<DOR0) | (1<<UPE0)))
  110. #define PS2_USART_RX_VECT USART_RX_vect
  111. #endif
  112. #endif
  113. #ifdef PS2_USE_INT
  114. /* uses INT1 for clock line(ATMega32U4) */
  115. #define PS2_CLOCK_PORT PORTD
  116. #define PS2_CLOCK_PIN PIND
  117. #define PS2_CLOCK_DDR DDRD
  118. #define PS2_CLOCK_BIT 1
  119. #define PS2_DATA_PORT PORTD
  120. #define PS2_DATA_PIN PIND
  121. #define PS2_DATA_DDR DDRD
  122. #define PS2_DATA_BIT 2
  123. #define PS2_INT_INIT() do { \
  124. EICRA |= ((1<<ISC11) | \
  125. (0<<ISC10)); \
  126. } while (0)
  127. #define PS2_INT_ON() do { \
  128. EIMSK |= (1<<INT1); \
  129. } while (0)
  130. #define PS2_INT_OFF() do { \
  131. EIMSK &= ~(1<<INT1); \
  132. } while (0)
  133. #define PS2_INT_VECT INT1_vect
  134. #endif
  135. #ifdef PS2_USE_BUSYWAIT
  136. #define PS2_CLOCK_PORT PORTF
  137. #define PS2_CLOCK_PIN PINF
  138. #define PS2_CLOCK_DDR DDRF
  139. #define PS2_CLOCK_BIT 0
  140. #define PS2_DATA_PORT PORTF
  141. #define PS2_DATA_PIN PINF
  142. #define PS2_DATA_DDR DDRF
  143. #define PS2_DATA_BIT 1
  144. #endif
  145. #endif