main.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file : main.c
  5. * @brief : Main program body
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
  10. * All rights reserved.</center></h2>
  11. *
  12. * This software component is licensed by ST under BSD 3-Clause license,
  13. * the "License"; You may not use this file except in compliance with the
  14. * License. You may obtain a copy of the License at:
  15. * opensource.org/licenses/BSD-3-Clause
  16. *
  17. ******************************************************************************
  18. */
  19. /* USER CODE END Header */
  20. /* Includes ------------------------------------------------------------------*/
  21. #include "main.h"
  22. /* Private includes ----------------------------------------------------------*/
  23. /* USER CODE BEGIN Includes */
  24. /* USER CODE END Includes */
  25. /* Private typedef -----------------------------------------------------------*/
  26. /* USER CODE BEGIN PTD */
  27. /* USER CODE END PTD */
  28. /* Private define ------------------------------------------------------------*/
  29. /* USER CODE BEGIN PD */
  30. /* Display timeout, sec */
  31. #define DISP_WDT_TIME 10
  32. /* USER CODE END PD */
  33. /* Private macro -------------------------------------------------------------*/
  34. /* USER CODE BEGIN PM */
  35. /* USER CODE END PM */
  36. /* Private variables ---------------------------------------------------------*/
  37. /* USER CODE BEGIN PV */
  38. volatile flag_t Flag = {0};
  39. static rtc_t Clock;
  40. static btn_t Button[BTN_NUM] = {
  41. {0, evBTN1Pressed, evBTN1Holded, BTN1_PIN},
  42. {0, evBTN2Pressed, evBTN2Pressed, BTN2_PIN},
  43. {0, evBTN3Pressed, evBTN3Pressed, BTN3_PIN},
  44. {0, evBTN4Pressed, evBTN4Holded, BTN4_PIN}
  45. };
  46. static volatile uint8_t dispWDT = 0;
  47. /* USER CODE END PV */
  48. /* Private function prototypes -----------------------------------------------*/
  49. /* USER CODE BEGIN PFP */
  50. static void btnProcess(void);
  51. static void Color_RGB(uint8_t r, uint8_t g, uint8_t b);
  52. static void ColorCircle(void);
  53. /* USER CODE END PFP */
  54. /* Private user code ---------------------------------------------------------*/
  55. /* USER CODE BEGIN 0 */
  56. /* USER CODE END 0 */
  57. /**
  58. * @brief The application entry point.
  59. * @retval int
  60. */
  61. int main(void)
  62. {
  63. /* Initialize onBoard Hardware */
  64. Board_Init();
  65. /* Initialize Scheduler */
  66. RTOS_Init();
  67. /* tdelay_ms() work now, I2C can work too */
  68. RTC_Init();
  69. RTC_ReadAll(&Clock);
  70. sensor_Init();
  71. /* Initialize Event State Machine */
  72. ES_Init(stShowTime);
  73. es_event_t event = eventNull;
  74. /** Set tasks for Sheduler */
  75. RTOS_SetTask(btnProcess, 1, BTN_SCAN_PERIOD);
  76. /* USER CODE BEGIN WHILE */
  77. Color_RGB(0xFF, 0x12, 0x0); // Nixie color. FF1200 or FF7E00 or FFBF00
  78. showTime();
  79. /* Infinite loop */
  80. while (1)
  81. {
  82. /* new second interrupt from RTC */
  83. if (Flag.RTC_IRQ != 0) {
  84. Flag.RTC_IRQ = 0;
  85. ColorCircle();
  86. Blink_Start(); // !!! TODO
  87. RTC_ReadAll(&Clock);
  88. if (dispWDT != 0) {
  89. dispWDT --;
  90. if (dispWDT == 0) {
  91. ES_PlaceEvent(evDisplayWDT);
  92. }
  93. }
  94. } /* end of New second */
  95. /* USER CODE END WHILE */
  96. /* USER CODE BEGIN 3 */
  97. event = ES_GetEvent();
  98. if (event) {
  99. ES_Dispatch(event);
  100. }
  101. RTOS_DispatchTask();
  102. __WFI();
  103. }
  104. /* USER CODE END 3 */
  105. } /* End of mine() */
  106. /* USER CODE BEGIN 4 */
  107. /*************************
  108. * S U B R O U T I N E S *
  109. *************************/
  110. /**
  111. * @brief Вывод HEX значений цвета в таймер.
  112. * @param : RGB value in range 0x00-0xFF
  113. * @retval : None
  114. */
  115. static void Color_RGB(uint8_t r, uint8_t g, uint8_t b) {
  116. COLOR_R(r);
  117. COLOR_G(g);
  118. COLOR_B(b);
  119. }
  120. /* cheng led color by time seconds */
  121. static void ColorCircle(void) {
  122. uint8_t hue = Clock.Sec * 6;
  123. HSV2LED(hue, 255, 255);
  124. }
  125. /**
  126. * @brief Обработка кнопок.
  127. * @param : None
  128. * @retval : None
  129. */
  130. static void btnProcess(void) {
  131. /* get pin state */
  132. uint32_t pins = BTNS_STATE;
  133. int i;
  134. for (i=0; i<BTN_NUM; i++) {
  135. if ((pins & Button[i].pin) == 0) {
  136. /* button pressed */
  137. Button[i].time ++;
  138. if (Button[i].time >= (BTN_TIME_HOLDED/BTN_SCAN_PERIOD)) {
  139. Button[i].time -= (BTN_TIME_REPEATED/BTN_SCAN_PERIOD);
  140. if (Button[i].holded == Button[i].pressed) {
  141. /* if pressed and holded - same function, then button pressed auto repeat */
  142. ES_PlaceEvent(Button[i].pressed);
  143. }
  144. }
  145. } else if (Button[i].time != 0) {
  146. /* button released */
  147. if (Button[i].time >= ((BTN_TIME_HOLDED - BTN_TIME_REPEATED)/BTN_SCAN_PERIOD)) {
  148. /* process long press */
  149. ES_PlaceEvent(Button[i].holded);
  150. } else if (Button[i].time >= (BTN_TIME_PRESSED/BTN_SCAN_PERIOD)) {
  151. /* process short press */
  152. ES_PlaceEvent(Button[i].pressed);
  153. }
  154. Button[i].time = 0;
  155. RTOS_SetTask(btnProcess, BTN_SCAN_PAUSE, BTN_SCAN_PERIOD);
  156. }
  157. } /* end FOR */
  158. }
  159. /**
  160. * On/off symbols on IN-15 tube.
  161. */
  162. void in15Off(void) {
  163. IN15_OFF;
  164. TUBE_C_OFF;
  165. }
  166. void in15Minus(void) {
  167. IN15_OFF;
  168. IN15_Minus;
  169. TUBE_C_ON;
  170. }
  171. void in15Plus(void) {
  172. IN15_OFF;
  173. IN15_Plus;
  174. TUBE_C_ON;
  175. }
  176. void in15Percent(void) {
  177. IN15_OFF;
  178. IN15_Percent;
  179. TUBE_C_ON;
  180. }
  181. void in15P(void) {
  182. IN15_OFF;
  183. IN15_P;
  184. TUBE_C_ON;
  185. }
  186. /**
  187. * Show info on tubes.
  188. */
  189. void showTime(void) {
  190. in15Minus();
  191. RTOS_SetTask(in15Off, 500, 0);
  192. uint8_t buf[4];
  193. buf[Tube_A] = Clock.Hr >> 4;
  194. buf[Tube_B] = Clock.Hr & 0xf;
  195. buf[Tube_D] = Clock.Min >> 4;
  196. buf[Tube_E] = Clock.Min & 0xf;
  197. showDigits(buf);
  198. }
  199. void showWD(void) {
  200. dispWDT = DISP_WDT_TIME;
  201. IN15_OFF;
  202. uint8_t buf[4];
  203. buf[Tube_A] = 0xf;
  204. buf[Tube_B] = Clock.WD & 0xf;
  205. buf[Tube_D] = 0xf;
  206. buf[Tube_E] = 0xf;
  207. showDigits(buf);
  208. }
  209. void showDay(void) {
  210. dispWDT = DISP_WDT_TIME;
  211. IN15_OFF;
  212. uint8_t buf[4];
  213. buf[Tube_A] = Clock.Day >> 4;
  214. buf[Tube_B] = Clock.Day & 0xf;
  215. buf[Tube_D] = 0xf;
  216. buf[Tube_E] = 0xf;
  217. showDigits(buf);
  218. }
  219. void showMonth(void) {
  220. dispWDT = DISP_WDT_TIME;
  221. IN15_OFF;
  222. uint8_t buf[4];
  223. buf[Tube_A] = 0xf;
  224. buf[Tube_B] = 0xf;
  225. buf[Tube_D] = Clock.Mon >> 4;
  226. buf[Tube_E] = Clock.Mon & 0xf;
  227. showDigits(buf);
  228. }
  229. void showDayMon(void) {
  230. dispWDT = DISP_WDT_TIME;
  231. IN15_OFF;
  232. uint8_t buf[4];
  233. buf[Tube_A] = Clock.Day >> 4;
  234. buf[Tube_B] = Clock.Day & 0xf;
  235. buf[Tube_D] = Clock.Mon >> 4;
  236. buf[Tube_E] = Clock.Mon & 0xf;
  237. showDigits(buf);
  238. }
  239. void showYear(void) {
  240. dispWDT = DISP_WDT_TIME;
  241. IN15_OFF;
  242. uint8_t buf[4];
  243. buf[Tube_A] = 2;
  244. buf[Tube_B] = 0;
  245. buf[Tube_D] = Clock.Year >> 4;
  246. buf[Tube_E] = Clock.Year & 0xf;
  247. showDigits(buf);
  248. }
  249. void showHumidity(void) {
  250. dispWDT = DISP_WDT_TIME;
  251. in15Percent();
  252. uint8_t buf[4];
  253. buf[Tube_A] = Humidity / 10;
  254. buf[Tube_B] = Humidity % 10;
  255. buf[Tube_D] = 0xf;
  256. buf[Tube_E] = 0xf;
  257. showDigits(buf);
  258. }
  259. void showTemperature(void) {
  260. dispWDT = DISP_WDT_TIME;
  261. in15Plus();
  262. uint8_t buf[4];
  263. buf[Tube_A] = 0xf;
  264. buf[Tube_B] = 0xf;
  265. buf[Tube_D] = Temperature / 10;
  266. buf[Tube_E] = Temperature % 10;
  267. showDigits(buf);
  268. }
  269. void showPressure(void) {
  270. dispWDT = DISP_WDT_TIME;
  271. in15P();
  272. uint8_t buf[4];
  273. int tmp;
  274. buf[Tube_A] = 0xf;
  275. buf[Tube_B] = Pressure / 100;
  276. tmp = Pressure % 100;
  277. buf[Tube_D] = tmp / 10;
  278. buf[Tube_E] = tmp % 10;
  279. showDigits(buf);
  280. }
  281. /* Simple function for cyclic show all sensor data */
  282. void showSensorData(void) {
  283. ES_SetState(stShowSensorData);
  284. RTOS_DeleteTask(in15Off);
  285. showTemperature();
  286. tdelay_ms(3000);
  287. showHumidity();
  288. tdelay_ms(3000);
  289. showPressure();
  290. tdelay_ms(3000);
  291. ES_SetState(stShowTime);
  292. showTime();
  293. }
  294. /* USER CODE END 4 */
  295. /**
  296. * @brief This function is executed in case of error occurrence.
  297. * @retval None
  298. */
  299. void Error_Handler(void)
  300. {
  301. /* USER CODE BEGIN Error_Handler_Debug */
  302. /* User can add his own implementation to report the HAL error return state */
  303. __disable_irq();
  304. while (1)
  305. {
  306. }
  307. /* USER CODE END Error_Handler_Debug */
  308. }
  309. #ifdef USE_FULL_ASSERT
  310. /**
  311. * @brief Reports the name of the source file and the source line number
  312. * where the assert_param error has occurred.
  313. * @param file: pointer to the source file name
  314. * @param line: assert_param error line source number
  315. * @retval None
  316. */
  317. void assert_failed(uint8_t *file, uint32_t line)
  318. {
  319. /* USER CODE BEGIN 6 */
  320. /* User can add his own implementation to report the file name and line number,
  321. ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  322. /* USER CODE END 6 */
  323. }
  324. #endif /* USE_FULL_ASSERT */
  325. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/