/** ****************************************************************************** * @file RTC/RTC_TimeStamp/Src/main.c * @author MCD Application Team * @brief This sample code shows how to use STM32F4xx RTC HAL API to * ensure Time Stamp configuration. ****************************************************************************** * @attention * *

© COPYRIGHT(c) 2017 STMicroelectronics

* * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * 3. Neither the name of STMicroelectronics nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************** */ /* Includes ------------------------------------------------------------------*/ #include "main.h" /** @addtogroup STM32F4xx_HAL_Examples * @{ */ /** @addtogroup RTC_TimeStamp * @{ */ /* Private typedef -----------------------------------------------------------*/ typedef struct { uint8_t tab[9]; } Table_TypeDef; /* Private define ------------------------------------------------------------*/ /* Private macro -------------------------------------------------------------*/ /* Private variables ---------------------------------------------------------*/ /* RTC handler declaration */ RTC_HandleTypeDef RtcHandle; /* RTC time stamp variable declaration */ RTC_DateTypeDef sTimeStampDateget; RTC_TimeTypeDef sTimeStampget; #if !defined USE_LCD /* Buffers used for displaying Time and Date */ uint8_t aShowTime[50] = {0}, aShowTimeStamp[50] = {0}; uint8_t aShowDate[50] = {0}, aShowDateStamp[50] = {0}; #else uint8_t timestamp_event = 0; #endif /* USE_LCD */ /* Private function prototypes -----------------------------------------------*/ static void SystemClock_Config(void); static void RTC_TimeStampConfig(void); static void RTC_CalendarShow(void); #ifdef USE_LCD static Table_TypeDef RTC_Get_Time( RTC_TimeTypeDef* RTC_TimeStructure ); static void RTC_Time_display(uint8_t Line, uint32_t Color_x, Table_TypeDef table); static void RTC_TimeStampShow(void); #endif /* USE_LCD */ /* Private functions ---------------------------------------------------------*/ /** * @brief Main program * @param None * @retval None */ int main(void) { /* STM32F4xx HAL library initialization: - Configure the Flash prefetch - Systick timer is configured by default as source of time base, but user can eventually implement his proper time base source (a general purpose timer for example or other time source), keeping in mind that Time base duration should be kept 1ms since PPP_TIMEOUT_VALUEs are defined and handled in milliseconds basis. - Set NVIC Group Priority to 4 - Low Level Initialization */ HAL_Init(); /* Configure the system clock to 100 MHz */ SystemClock_Config(); /* Configure LED3 */ BSP_LED_Init(LED3); #ifdef USE_LCD BSP_LCD_Init(); BSP_LCD_Clear(LCD_COLOR_WHITE); BSP_LCD_SetBackColor(LCD_COLOR_BLUE); BSP_LCD_SetTextColor(LCD_COLOR_BLUE); BSP_LCD_SetFont(&Font24); BSP_LCD_FillRect(0, 0, BSP_LCD_GetXSize(), 60); BSP_LCD_SetTextColor(LCD_COLOR_WHITE); BSP_LCD_DisplayStringAt(0, 10, (uint8_t*) "TimeStamp", CENTER_MODE); BSP_LCD_DisplayStringAt(0, 30, (uint8_t*) "Example", CENTER_MODE); #endif /* USE_LCD */ /*##-1- Configure the RTC peripheral #######################################*/ /* Configure RTC prescaler and RTC data registers */ /* RTC configured as follow: - Hour Format = Format 12 - Asynch Prediv = Value according to source clock - Synch Prediv = Value according to source clock - OutPut = Output Disable - OutPutPolarity = High Polarity - OutPutType = Open Drain */ __HAL_RTC_RESET_HANDLE_STATE(&RtcHandle); RtcHandle.Instance = RTC; RtcHandle.Init.HourFormat = RTC_HOURFORMAT_12; RtcHandle.Init.AsynchPrediv = RTC_ASYNCH_PREDIV; RtcHandle.Init.SynchPrediv = RTC_SYNCH_PREDIV; RtcHandle.Init.OutPut = RTC_OUTPUT_DISABLE; RtcHandle.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH; RtcHandle.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN; __HAL_RTC_RESET_HANDLE_STATE(&RtcHandle); if(HAL_RTC_Init(&RtcHandle) != HAL_OK) { /* Initialization Error */ Error_Handler(); } /*##-2- Configure RTC Timestamp ############################################*/ RTC_TimeStampConfig(); /* Infinite loop */ while (1) { /*##-3- Display the updated Time and Date ################################*/ RTC_CalendarShow(); #ifdef USE_LCD /*##-4- Display the time stamp ################################*/ /* Checks whether the time stamp event occured or not */ if (timestamp_event == 1) { RTC_TimeStampShow(); timestamp_event = 0; } #endif /* USE_LCD */ } } /** * @brief This function is executed in case of error occurrence. * @param None * @retval None */ void Error_Handler(void) { while(1) { /* Toggle LED3 */ BSP_LED_Toggle(LED3); /* Delay */ HAL_Delay(100); } } /** * @brief System Clock Configuration * The system Clock is configured as follow : * System Clock source = PLL (HSE) * SYSCLK(Hz) = 100000000 * HCLK(Hz) = 100000000 * AHB Prescaler = 1 * APB1 Prescaler = 2 * APB2 Prescaler = 1 * HSE Frequency(Hz) = 8000000 * PLL_M = 8 * PLL_N = 200 * PLL_P = 2 * PLL_Q = 7 * PLL_R = 2 * VDD(V) = 3.3 * Main regulator output voltage = Scale1 mode * Flash Latency(WS) = 3 * @param None * @retval None */ static void SystemClock_Config(void) { RCC_ClkInitTypeDef RCC_ClkInitStruct; RCC_OscInitTypeDef RCC_OscInitStruct; HAL_StatusTypeDef ret = HAL_OK; /* Enable Power Control clock */ __HAL_RCC_PWR_CLK_ENABLE(); /* The voltage scaling allows optimizing the power consumption when the device is clocked below the maximum system frequency, to update the voltage scaling value regarding system frequency refer to product datasheet. */ __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1); /* Enable HSE Oscillator and activate PLL with HSE as source */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; RCC_OscInitStruct.HSEState = RCC_HSE_ON; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; RCC_OscInitStruct.PLL.PLLM = 8; RCC_OscInitStruct.PLL.PLLN = 200; RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2; RCC_OscInitStruct.PLL.PLLQ = 7; RCC_OscInitStruct.PLL.PLLR = 2; ret = HAL_RCC_OscConfig(&RCC_OscInitStruct); if(ret != HAL_OK) { while(1) { ; } } /* Select PLL as system clock source and configure the HCLK, PCLK1 and PCLK2 clocks dividers */ RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2); RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; ret = HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3); if(ret != HAL_OK) { while(1) { ; } } } /** * @brief Configure the current time and date and activate timestamp. * @param None * @retval None */ static void RTC_TimeStampConfig(void) { RTC_DateTypeDef sdatestructure; RTC_TimeTypeDef stimestructure; /*##-1- Configure the Time Stamp peripheral ################################*/ /* RTC TimeStamp generation: TimeStamp Rising Edge on PA.00 Pin */ HAL_RTCEx_SetTimeStamp_IT(&RtcHandle, RTC_TIMESTAMPEDGE_RISING, RTC_TIMESTAMPPIN_PC13); /*##-2- Configure the Date #################################################*/ /* Set Date: Monday February 01 2016 */ sdatestructure.Year = 0x16; sdatestructure.Month = RTC_MONTH_FEBRUARY; sdatestructure.Date = 0x01; sdatestructure.WeekDay = RTC_WEEKDAY_MONDAY; if(HAL_RTC_SetDate(&RtcHandle,&sdatestructure,RTC_FORMAT_BCD) != HAL_OK) { /* Initialization Error */ Error_Handler(); } /*##-3- Configure the Time #################################################*/ /* Set Time: 08:10:00 */ stimestructure.Hours = 0x08; stimestructure.Minutes = 0x10; stimestructure.Seconds = 0x00; stimestructure.SubSeconds = 0x00; stimestructure.TimeFormat = RTC_HOURFORMAT12_AM; stimestructure.DayLightSaving = RTC_DAYLIGHTSAVING_NONE ; stimestructure.StoreOperation = RTC_STOREOPERATION_RESET; if(HAL_RTC_SetTime(&RtcHandle,&stimestructure,RTC_FORMAT_BCD) != HAL_OK) { /* Initialization Error */ Error_Handler(); } } /** * @brief Timestamp callback * @param hrtc : hrtc handle * @retval None */ void HAL_RTCEx_TimeStampEventCallback(RTC_HandleTypeDef *hrtc) { #if !defined (USE_LCD) HAL_RTCEx_GetTimeStamp(&RtcHandle, &sTimeStampget, &sTimeStampDateget, RTC_FORMAT_BIN); /* Display time Format : hh:mm:ss */ sprintf((char*)aShowTimeStamp,"%.2d:%.2d:%.2d", sTimeStampget.Hours, sTimeStampget.Minutes, sTimeStampget.Seconds); /* Display date Format : mm-dd */ sprintf((char*)aShowDateStamp,"%.2d-%.2d-%.2d", sTimeStampDateget.Month, sTimeStampDateget.Date, 2016); #else HAL_RTCEx_GetTimeStamp(&RtcHandle, &sTimeStampget, &sTimeStampDateget, RTC_FORMAT_BCD); /* Set time stamp event */ timestamp_event = 1; #endif /* USE_LCD */ } /** * @brief Display the current time and date. * @param showtime : pointer to buffer * @param showdate : pointer to buffer * @retval None */ static void RTC_CalendarShow(void) { RTC_DateTypeDef sdatestructureget; RTC_TimeTypeDef stimestructureget; #ifdef USE_LCD /* Get the RTC current Time */ HAL_RTC_GetTime(&RtcHandle, &stimestructureget, RTC_FORMAT_BCD); /* Get the RTC current Date */ HAL_RTC_GetDate(&RtcHandle, &sdatestructureget, RTC_FORMAT_BCD); /* Set the font Size */ BSP_LCD_SetFont(&Font16); /* Set the Back Color */ BSP_LCD_SetBackColor(LCD_COLOR_WHITE); /* Set the Text Color */ BSP_LCD_SetTextColor(LCD_COLOR_BLUE); /* Display Text */ BSP_LCD_DisplayStringAtLine(7, (uint8_t *)"Current Time Display"); RTC_Time_display(LINE(8), LCD_COLOR_BLACK , RTC_Get_Time(&stimestructureget)); #else /* Get the RTC current Time */ HAL_RTC_GetTime(&RtcHandle, &stimestructureget, RTC_FORMAT_BIN); /* Get the RTC current Date */ HAL_RTC_GetDate(&RtcHandle, &sdatestructureget, RTC_FORMAT_BIN); /* Display time Format : hh:mm:ss */ sprintf((char*)aShowTime,"%.2d:%.2d:%.2d", stimestructureget.Hours, stimestructureget.Minutes, stimestructureget.Seconds); /* Display date Format : mm-dd-yy */ sprintf((char*)aShowDate,"%.2d-%.2d-%.2d", sdatestructureget.Month, sdatestructureget.Date, 2000 + sdatestructureget.Year); #endif /* USE_LCD */ } #ifdef USE_LCD /** * @brief Returns the current time and sub second. * @param Secondfraction: the sub second fraction. * @param RTC_TimeStructure : pointer to a RTC_TimeTypeDef structure that * contains the current time values. * @retval table : return current time and sub second in a table form */ static Table_TypeDef RTC_Get_Time( RTC_TimeTypeDef* RTC_TimeStructure ) { Table_TypeDef table2; /* Fill the table2 fields with the current Time*/ table2.tab[0] = (((uint8_t)(RTC_TimeStructure->Hours & 0xF0) >> 0x04) + 0x30); table2.tab[1] = (((uint8_t)(RTC_TimeStructure->Hours & 0x0F))+ 0x30); table2.tab[2] = 0x3A; table2.tab[3] = (((uint8_t)(RTC_TimeStructure->Minutes & 0xF0) >> 0x04) + 0x30); table2.tab[4] = (((uint8_t)(RTC_TimeStructure->Minutes & 0x0F))+ (uint8_t)0x30); table2.tab[5] = 0x3A; table2.tab[6] = (((uint8_t)(RTC_TimeStructure->Seconds & 0xF0) >> 0x04)+ 0x30); table2.tab[7] = (((uint8_t)(RTC_TimeStructure->Seconds & 0x0F)) + 0x30); table2.tab[8] = 0x00; /* Return table2 */ return table2; } /** * @brief Displays the current Time on the LCD. * @param Line: the Line where to display the Current time . * This parameter can be one of the following values: * @arg Linex: where x can be 0..21 * @param Color_x: specifies the Background Color. * @param table: the Current time and sub second. * @retval None */ static void RTC_Time_display(uint8_t Line, uint32_t Color_x, Table_TypeDef table) { uint8_t *ptr = (uint8_t *) &table; /* Set the Text Color */ BSP_LCD_SetTextColor(Color_x); /* Display Text */ BSP_LCD_DisplayStringAt(0, Line, ptr, CENTER_MODE); } /** * @brief Display the time stamp on LCD. * @retval None */ static void RTC_TimeStampShow(void) { /* Set the font Size */ BSP_LCD_SetFont(&Font16); /* Set the Back Color */ BSP_LCD_SetBackColor(LCD_COLOR_WHITE); /* Set the Text Color */ BSP_LCD_SetTextColor(LCD_COLOR_BLUE); /* Display Text */ BSP_LCD_DisplayStringAtLine(10, (uint8_t *)"TimeStamp Display"); /* Display Time Stamp */ RTC_Time_display(LINE(11), LCD_COLOR_BLACK , RTC_Get_Time(&sTimeStampget)); } #endif /* USE_LCD */ #ifdef USE_FULL_ASSERT /** * @brief Reports the name of the source file and the source line number * where the assert_param error has occurred. * @param file: pointer to the source file name * @param line: assert_param error line source number * @retval None */ void assert_failed(uint8_t* file, uint32_t line) { /* User can add his own implementation to report the file name and line number, ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */ /* Infinite loop */ while (1) { } } #endif /** * @} */ /** * @} */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/