upload
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.
Este repositório está arquivado. Você pode visualizar os arquivos e realizar clone, mas não poderá realizar push nem abrir issues e pull requests.

config_common.h 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. #ifndef CONFIG_DEFINITIONS_H
  2. #define CONFIG_DEFINITIONS_H
  3. /* diode directions */
  4. #define COL2ROW 0
  5. #define ROW2COL 1
  6. /* I/O pins */
  7. #define B0 { .input_addr = 3, .bit = 0 }
  8. #define B1 { .input_addr = 3, .bit = 1 }
  9. #define B2 { .input_addr = 3, .bit = 2 }
  10. #define B3 { .input_addr = 3, .bit = 3 }
  11. #define B4 { .input_addr = 3, .bit = 4 }
  12. #define B5 { .input_addr = 3, .bit = 5 }
  13. #define B6 { .input_addr = 3, .bit = 6 }
  14. #define B7 { .input_addr = 3, .bit = 7 }
  15. #define C0 { .input_addr = 6, .bit = 0 }
  16. #define C1 { .input_addr = 6, .bit = 1 }
  17. #define C2 { .input_addr = 6, .bit = 2 }
  18. #define C3 { .input_addr = 6, .bit = 3 }
  19. #define C4 { .input_addr = 6, .bit = 4 }
  20. #define C5 { .input_addr = 6, .bit = 5 }
  21. #define C6 { .input_addr = 6, .bit = 6 }
  22. #define C7 { .input_addr = 6, .bit = 7 }
  23. #define D0 { .input_addr = 9, .bit = 0 }
  24. #define D1 { .input_addr = 9, .bit = 1 }
  25. #define D2 { .input_addr = 9, .bit = 2 }
  26. #define D3 { .input_addr = 9, .bit = 3 }
  27. #define D4 { .input_addr = 9, .bit = 4 }
  28. #define D5 { .input_addr = 9, .bit = 5 }
  29. #define D6 { .input_addr = 9, .bit = 6 }
  30. #define D7 { .input_addr = 9, .bit = 7 }
  31. #define E0 { .input_addr = 0xC, .bit = 0 }
  32. #define E1 { .input_addr = 0xC, .bit = 1 }
  33. #define E2 { .input_addr = 0xC, .bit = 2 }
  34. #define E3 { .input_addr = 0xC, .bit = 3 }
  35. #define E4 { .input_addr = 0xC, .bit = 4 }
  36. #define E5 { .input_addr = 0xC, .bit = 5 }
  37. #define E6 { .input_addr = 0xC, .bit = 6 }
  38. #define E7 { .input_addr = 0xC, .bit = 7 }
  39. #define F0 { .input_addr = 0xF, .bit = 0 }
  40. #define F1 { .input_addr = 0xF, .bit = 1 }
  41. #define F2 { .input_addr = 0xF, .bit = 2 }
  42. #define F3 { .input_addr = 0xF, .bit = 3 }
  43. #define F4 { .input_addr = 0xF, .bit = 4 }
  44. #define F5 { .input_addr = 0xF, .bit = 5 }
  45. #define F6 { .input_addr = 0xF, .bit = 6 }
  46. #define F7 { .input_addr = 0xF, .bit = 7 }
  47. /* USART configuration */
  48. #ifdef BLUETOOTH_ENABLE
  49. # ifdef __AVR_ATmega32U4__
  50. # define SERIAL_UART_BAUD 9600
  51. # define SERIAL_UART_DATA UDR1
  52. # define SERIAL_UART_UBRR (F_CPU / (16UL * SERIAL_UART_BAUD) - 1)
  53. # define SERIAL_UART_RXD_VECT USART1_RX_vect
  54. # define SERIAL_UART_TXD_READY (UCSR1A & _BV(UDRE1))
  55. # define SERIAL_UART_INIT() do { \
  56. /* baud rate */ \
  57. UBRR1L = SERIAL_UART_UBRR; \
  58. /* baud rate */ \
  59. UBRR1H = SERIAL_UART_UBRR >> 8; \
  60. /* enable TX */ \
  61. UCSR1B = _BV(TXEN1); \
  62. /* 8-bit data */ \
  63. UCSR1C = _BV(UCSZ11) | _BV(UCSZ10); \
  64. sei(); \
  65. } while(0)
  66. # else
  67. # error "USART configuration is needed."
  68. #endif
  69. // I'm fairly sure these aren't needed, but oh well - Jack
  70. /*
  71. * PS/2 Interrupt configuration
  72. */
  73. #ifdef PS2_USE_INT
  74. /* uses INT1 for clock line(ATMega32U4) */
  75. #define PS2_CLOCK_PORT PORTD
  76. #define PS2_CLOCK_PIN PIND
  77. #define PS2_CLOCK_DDR DDRD
  78. #define PS2_CLOCK_BIT 1
  79. #define PS2_DATA_PORT PORTD
  80. #define PS2_DATA_PIN PIND
  81. #define PS2_DATA_DDR DDRD
  82. #define PS2_DATA_BIT 0
  83. #define PS2_INT_INIT() do { \
  84. EICRA |= ((1<<ISC11) | \
  85. (0<<ISC10)); \
  86. } while (0)
  87. #define PS2_INT_ON() do { \
  88. EIMSK |= (1<<INT1); \
  89. } while (0)
  90. #define PS2_INT_OFF() do { \
  91. EIMSK &= ~(1<<INT1); \
  92. } while (0)
  93. #define PS2_INT_VECT INT1_vect
  94. #endif
  95. /*
  96. * PS/2 Busywait configuration
  97. */
  98. #ifdef PS2_USE_BUSYWAIT
  99. #define PS2_CLOCK_PORT PORTD
  100. #define PS2_CLOCK_PIN PIND
  101. #define PS2_CLOCK_DDR DDRD
  102. #define PS2_CLOCK_BIT 1
  103. #define PS2_DATA_PORT PORTD
  104. #define PS2_DATA_PIN PIND
  105. #define PS2_DATA_DDR DDRD
  106. #define PS2_DATA_BIT 0
  107. #endif
  108. #endif
  109. #endif