board.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. #pragma once
  2. #ifndef _BOARD_H
  3. #define _BOARD_H
  4. /* Includes */
  5. #include "main.h"
  6. #include "gpio.h"
  7. /* Type Defs */
  8. typedef enum {
  9. Tube_All = 0xf,
  10. Tube_C = 4,
  11. Tube_A = 3,
  12. Tube_B = 2,
  13. Tube_D = 1,
  14. Tube_E = 0
  15. } tube_pos_t;
  16. typedef enum {
  17. sym_Pressure = 0x1,
  18. sym_Plus = 0x2,
  19. sym_Minus = 0x4,
  20. sym_Percent = 0x8
  21. } in15_pin_t;
  22. typedef struct {
  23. uint8_t r;
  24. uint8_t g;
  25. uint8_t b;
  26. } RGB_t;
  27. typedef struct {
  28. uint8_t h;
  29. uint8_t s;
  30. uint8_t v;
  31. } HSV_t;
  32. typedef union {
  33. uint32_t u32; /* element specifier for accessing whole u32 */
  34. uint8_t ar[4]; /* element specifier for accessing as array */
  35. struct {
  36. uint8_t tE; /* element specifier for accessing Tube_E(4) */
  37. uint8_t tD; /* element specifier for accessing Tube_D(3) */
  38. uint8_t tB; /* element specifier for accessing Tube_B(2) */
  39. uint8_t tA; /* element specifier for accessing Tube_A(1) */
  40. } s8; /* element spec. for acc. struct with tubes */
  41. } tube4_t;
  42. /* Exported macros */
  43. #define LATCH_DOWN GPIOC->BRR = 0x40
  44. #define LATCH_UP GPIOC->BSRR = 0x40
  45. #define TUBE_PWR_ON GPIOA->BRR = 0x10
  46. #define TUBE_PWR_OFF GPIOA->BSRR = 0x10
  47. #define TUBE_A_ON TIM1->CCER |= (TIM_CCER_CC1E)
  48. #define TUBE_B_ON TIM3->CCER |= (TIM_CCER_CC4E)
  49. #define TUBE_C_ON TIM3->CCER |= (TIM_CCER_CC3E)
  50. #define TUBE_D_ON TIM3->CCER |= (TIM_CCER_CC2E)
  51. #define TUBE_E_ON TIM3->CCER |= (TIM_CCER_CC1E)
  52. #define TUBE_BCDE_ON TIM3->CCER |= (TIM_CCER_CC1E | TIM_CCER_CC2E | TIM_CCER_CC3E | TIM_CCER_CC4E)
  53. #define TUBE_ALL_ON TUBE_A_ON; TUBE_BCDE_ON
  54. #define TUBE_A_OFF TIM1->CCER &= ~(TIM_CCER_CC1E)
  55. #define TUBE_B_OFF TIM3->CCER &= ~(TIM_CCER_CC4E)
  56. #define TUBE_C_OFF TIM3->CCER &= ~(TIM_CCER_CC3E)
  57. #define TUBE_D_OFF TIM3->CCER &= ~(TIM_CCER_CC2E)
  58. #define TUBE_E_OFF TIM3->CCER &= ~(TIM_CCER_CC1E)
  59. #define TUBE_BCDE_OFF TIM3->CCER &= ~(TIM_CCER_CC1E | TIM_CCER_CC2E | TIM_CCER_CC3E | TIM_CCER_CC4E)
  60. #define TUBE_ALL_OFF TUBE_A_OFF; TUBE_BCDE_OFF
  61. #define IN15_P GPIOA->BSRR = 0x1
  62. #define IN15_Plus GPIOA->BSRR = 0x2
  63. #define IN15_Minus GPIOA->BSRR = 0x4
  64. #define IN15_Percent GPIOA->BSRR = 0x8
  65. #define IN15_OFF GPIOA->BRR = 0xF
  66. #define COLOR_R(x) TIM1->CCR2 = x
  67. #define COLOR_G(x) TIM1->CCR3 = x
  68. #define COLOR_B(x) TIM1->CCR4 = x
  69. #define LEDS_OFF COLOR_R(0); COLOR_G(0); COLOR_B(0)
  70. #define TUBE_A_BRIGHT(x) TIM1->CCR1 = x
  71. #define TUBE_B_BRIGHT(x) TIM3->CCR4 = x
  72. #define TUBE_C_BRIGHT(x) TIM3->CCR3 = x
  73. #define TUBE_D_BRIGHT(x) TIM3->CCR2 = x
  74. #define TUBE_E_BRIGHT(x) TIM3->CCR1 = x
  75. #define TUBES_BRIGHT(x) TUBE_A_BRIGHT(x); TUBE_B_BRIGHT(x); TUBE_C_BRIGHT(x); TUBE_D_BRIGHT(x); TUBE_E_BRIGHT(x)
  76. /* Constants */
  77. /* PWM Timers for 250 Hz */
  78. #define TIM1_PSC (375 - 1)
  79. #define TIM1_ARR (256 - 1)
  80. #define TIM3_PSC (375 - 1)
  81. #define TIM3_ARR (256 - 1)
  82. #define PWM_TUBE_INIT_VAL 127
  83. #define PWM_LED_INIT_VAL 127
  84. #define PWM_LED_MAX_VAL TIM3_ARR
  85. #define TIM14_PSC (12000 - 1)
  86. #define TIM14_ARR (1000 - 1)
  87. #define TIM14_PULSE_VAL 500
  88. #define TIM16_PSC (24 - 1)
  89. #define TIM16_ARR (1000 - 1)
  90. #define TIM17_PSC (24 - 1)
  91. #define TIM17_ARR (1000 - 1)
  92. /* Defines */
  93. #define BTN1_GPIO_Port GPIOB
  94. #define BTN1_Pin GPIO_PIN_2
  95. #define BTN2_GPIO_Port GPIOA
  96. #define BTN2_Pin GPIO_PIN_12
  97. #define BTN3_GPIO_Port GPIOB
  98. #define BTN3_Pin GPIO_PIN_4
  99. #define BTN4_GPIO_Port GPIOA
  100. #define BTN4_Pin GPIO_PIN_5
  101. #define IRQ_EXTI_IRQn EXTI4_15_IRQn
  102. #define IRQ_GPIO_Port GPIOC
  103. #define IRQ_Pin GPIO_PIN_14
  104. #define Latch_GPIO_Port GPIOC
  105. #define Latch_Pin GPIO_PIN_6
  106. #define LC0_GPIO_Port GPIOA
  107. #define LC0_Pin GPIO_PIN_0
  108. #define LC1_GPIO_Port GPIOA
  109. #define LC1_Pin GPIO_PIN_1
  110. #define LC2_GPIO_Port GPIOA
  111. #define LC2_Pin GPIO_PIN_2
  112. #define LC3_GPIO_Port GPIOA
  113. #define LC3_Pin GPIO_PIN_3
  114. #define PWM_1_GPIO_Port GPIOA
  115. #define PWM_1_Pin GPIO_PIN_8
  116. #define PWM_2_GPIO_Port GPIOB
  117. #define PWM_2_Pin GPIO_PIN_1
  118. #define PWM_3_GPIO_Port GPIOB
  119. #define PWM_3_Pin GPIO_PIN_0
  120. #define PWM_4_GPIO_Port GPIOA
  121. #define PWM_4_Pin GPIO_PIN_7
  122. #define PWM_5_GPIO_Port GPIOA
  123. #define PWM_5_Pin GPIO_PIN_6
  124. #define PWM_B_GPIO_Port GPIOA
  125. #define PWM_B_Pin GPIO_PIN_11
  126. #define PWM_G_GPIO_Port GPIOA
  127. #define PWM_G_Pin GPIO_PIN_10
  128. #define PWM_R_GPIO_Port GPIOA
  129. #define PWM_R_Pin GPIO_PIN_9
  130. #define SHDN_GPIO_Port GPIOA
  131. #define SHDN_Pin GPIO_PIN_4
  132. #define SWCLK_GPIO_Port GPIOA
  133. #define SWCLK_Pin GPIO_PIN_14
  134. #define SWDIO_GPIO_Port GPIOA
  135. #define SWDIO_Pin GPIO_PIN_13
  136. #define UART_EN_GPIO_Port GPIOC
  137. #define UART_EN_Pin GPIO_PIN_15
  138. #define UART_ST_GPIO_Port GPIOA
  139. #define UART_ST_Pin GPIO_PIN_15
  140. /* BTNs */
  141. #define BTN_NUM 4
  142. #define BTN1_PIN GPIO_IDR_ID2
  143. #define BTN2_PIN GPIO_IDR_ID12
  144. #define BTN3_PIN GPIO_IDR_ID4
  145. #define BTN4_PIN GPIO_IDR_ID5
  146. #define BTN1_STATE (BTN1_GPIO_Port->IDR & BTN1_PIN)
  147. #define BTN2_STATE (BTN2_GPIO_Port->IDR & BTN2_PIN)
  148. #define BTN3_STATE (BTN3_GPIO_Port->IDR & BTN3_PIN)
  149. #define BTN4_STATE (BTN4_GPIO_Port->IDR & BTN4_PIN)
  150. #define BTNS1_STATE (GPIOB->IDR & (BTN1_PIN | BTN3_PIN))
  151. #define BTNS2_STATE (GPIOA->IDR & (BTN2_PIN | BTN4_PIN))
  152. #define BTNS_STATE (BTNS1_STATE | BTNS2_STATE)
  153. /* Variables */
  154. /* Exported funcions */
  155. void SystemClock_Config(void);
  156. void Board_Init(void);
  157. void Blink_Start(void);
  158. void Blink_Stop(void);
  159. void showDigits(tube4_t dig);
  160. void tube_PowerOn(tube_pos_t tube);
  161. void tube_PowerOff(tube_pos_t tube);
  162. void tube_BrightLevel(tube_pos_t tube, uint8_t bright);
  163. int Flash_Write(uint64_t * data);
  164. int Flash_Read(uint64_t * data);
  165. #endif /* _BPARD_H */