main.c 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  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. static uint8_t hue = 0, stage = 0;
  123. if (stage == 0) {
  124. hue = Clock.Sec * 6;
  125. RTOS_SetTask(ColorCircle, 20, 20);
  126. } else if (stage > 8) {
  127. RTOS_DeleteTask(ColorCircle);
  128. stage = 0;
  129. hue ++;
  130. } else {
  131. hue ++;
  132. stage ++;
  133. }
  134. HSV2LED(hue, 255, 255);
  135. }
  136. /**
  137. * @brief Обработка кнопок.
  138. * @param : None
  139. * @retval : None
  140. */
  141. static void btnProcess(void) {
  142. /* get pin state */
  143. uint32_t pins = BTNS_STATE;
  144. int i;
  145. for (i=0; i<BTN_NUM; i++) {
  146. if ((pins & Button[i].pin) == 0) {
  147. /* button pressed */
  148. Button[i].time ++;
  149. if (Button[i].time >= (BTN_TIME_HOLDED/BTN_SCAN_PERIOD)) {
  150. Button[i].time -= (BTN_TIME_REPEATED/BTN_SCAN_PERIOD);
  151. if (Button[i].holded == Button[i].pressed) {
  152. /* if pressed and holded - same function, then button pressed auto repeat */
  153. ES_PlaceEvent(Button[i].pressed);
  154. }
  155. }
  156. } else if (Button[i].time != 0) {
  157. /* button released */
  158. if (Button[i].time >= ((BTN_TIME_HOLDED - BTN_TIME_REPEATED)/BTN_SCAN_PERIOD)) {
  159. /* process long press */
  160. ES_PlaceEvent(Button[i].holded);
  161. } else if (Button[i].time >= (BTN_TIME_PRESSED/BTN_SCAN_PERIOD)) {
  162. /* process short press */
  163. ES_PlaceEvent(Button[i].pressed);
  164. }
  165. Button[i].time = 0;
  166. RTOS_SetTask(btnProcess, BTN_SCAN_PAUSE, BTN_SCAN_PERIOD);
  167. }
  168. } /* end FOR */
  169. }
  170. /**
  171. * On/off symbols on IN-15 tube.
  172. */
  173. void in15Off(void) {
  174. IN15_OFF;
  175. TUBE_C_OFF;
  176. }
  177. void in15Minus(void) {
  178. IN15_OFF;
  179. IN15_Minus;
  180. TUBE_C_ON;
  181. }
  182. void in15Plus(void) {
  183. IN15_OFF;
  184. IN15_Plus;
  185. TUBE_C_ON;
  186. }
  187. void in15Percent(void) {
  188. IN15_OFF;
  189. IN15_Percent;
  190. TUBE_C_ON;
  191. }
  192. void in15P(void) {
  193. IN15_OFF;
  194. IN15_P;
  195. TUBE_C_ON;
  196. }
  197. /**
  198. * Show info on tubes.
  199. */
  200. void showTime(void) {
  201. in15Minus();
  202. RTOS_SetTask(in15Off, 500, 0);
  203. uint8_t buf[4];
  204. buf[Tube_A] = Clock.Hr >> 4;
  205. buf[Tube_B] = Clock.Hr & 0xf;
  206. buf[Tube_D] = Clock.Min >> 4;
  207. buf[Tube_E] = Clock.Min & 0xf;
  208. showDigits(buf);
  209. }
  210. void showWD(void) {
  211. dispWDT = DISP_WDT_TIME;
  212. IN15_OFF;
  213. uint8_t buf[4];
  214. buf[Tube_A] = 0xf;
  215. buf[Tube_B] = Clock.WD & 0xf;
  216. buf[Tube_D] = 0xf;
  217. buf[Tube_E] = 0xf;
  218. showDigits(buf);
  219. }
  220. void showDay(void) {
  221. dispWDT = DISP_WDT_TIME;
  222. IN15_OFF;
  223. uint8_t buf[4];
  224. buf[Tube_A] = Clock.Day >> 4;
  225. buf[Tube_B] = Clock.Day & 0xf;
  226. buf[Tube_D] = 0xf;
  227. buf[Tube_E] = 0xf;
  228. showDigits(buf);
  229. }
  230. void showMonth(void) {
  231. dispWDT = DISP_WDT_TIME;
  232. IN15_OFF;
  233. uint8_t buf[4];
  234. buf[Tube_A] = 0xf;
  235. buf[Tube_B] = 0xf;
  236. buf[Tube_D] = Clock.Mon >> 4;
  237. buf[Tube_E] = Clock.Mon & 0xf;
  238. showDigits(buf);
  239. }
  240. void showDayMon(void) {
  241. dispWDT = DISP_WDT_TIME;
  242. IN15_OFF;
  243. uint8_t buf[4];
  244. buf[Tube_A] = Clock.Day >> 4;
  245. buf[Tube_B] = Clock.Day & 0xf;
  246. buf[Tube_D] = Clock.Mon >> 4;
  247. buf[Tube_E] = Clock.Mon & 0xf;
  248. showDigits(buf);
  249. }
  250. void showYear(void) {
  251. dispWDT = DISP_WDT_TIME;
  252. IN15_OFF;
  253. uint8_t buf[4];
  254. buf[Tube_A] = 2;
  255. buf[Tube_B] = 0;
  256. buf[Tube_D] = Clock.Year >> 4;
  257. buf[Tube_E] = Clock.Year & 0xf;
  258. showDigits(buf);
  259. }
  260. void showHumidity(void) {
  261. dispWDT = DISP_WDT_TIME;
  262. in15Percent();
  263. uint8_t buf[4];
  264. buf[Tube_A] = Humidity / 10;
  265. buf[Tube_B] = Humidity % 10;
  266. buf[Tube_D] = 0xf;
  267. buf[Tube_E] = 0xf;
  268. showDigits(buf);
  269. }
  270. void showTemperature(void) {
  271. dispWDT = DISP_WDT_TIME;
  272. in15Plus();
  273. uint8_t buf[4];
  274. buf[Tube_A] = 0xf;
  275. buf[Tube_B] = 0xf;
  276. buf[Tube_D] = Temperature / 10;
  277. buf[Tube_E] = Temperature % 10;
  278. showDigits(buf);
  279. }
  280. void showPressure(void) {
  281. dispWDT = DISP_WDT_TIME;
  282. in15P();
  283. uint8_t buf[4];
  284. int tmp;
  285. buf[Tube_A] = 0xf;
  286. buf[Tube_B] = Pressure / 100;
  287. tmp = Pressure % 100;
  288. buf[Tube_D] = tmp / 10;
  289. buf[Tube_E] = tmp % 10;
  290. showDigits(buf);
  291. }
  292. /* Simple function for cyclic show all sensor data */
  293. void showSensorData(void) {
  294. ES_SetState(stShowSensorData);
  295. RTOS_DeleteTask(in15Off);
  296. showTemperature();
  297. tdelay_ms(3000);
  298. showHumidity();
  299. tdelay_ms(3000);
  300. showPressure();
  301. tdelay_ms(3000);
  302. ES_SetState(stShowTime);
  303. showTime();
  304. }
  305. /* USER CODE END 4 */
  306. /**
  307. * @brief This function is executed in case of error occurrence.
  308. * @retval None
  309. */
  310. void Error_Handler(void)
  311. {
  312. /* USER CODE BEGIN Error_Handler_Debug */
  313. /* User can add his own implementation to report the HAL error return state */
  314. __disable_irq();
  315. while (1)
  316. {
  317. }
  318. /* USER CODE END Error_Handler_Debug */
  319. }
  320. #ifdef USE_FULL_ASSERT
  321. /**
  322. * @brief Reports the name of the source file and the source line number
  323. * where the assert_param error has occurred.
  324. * @param file: pointer to the source file name
  325. * @param line: assert_param error line source number
  326. * @retval None
  327. */
  328. void assert_failed(uint8_t *file, uint32_t line)
  329. {
  330. /* USER CODE BEGIN 6 */
  331. /* User can add his own implementation to report the file name and line number,
  332. ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  333. /* USER CODE END 6 */
  334. }
  335. #endif /* USE_FULL_ASSERT */
  336. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/