2019-04-29 14:39:56 +01:00
/**
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* @ file UART / UART_TwoBoards_ComDMA / Src / main . c
* @ author MCD Application Team
* @ brief This sample code shows how to use UART HAL API to transmit
* and receive a data buffer with a communication process based on
* DMA transfer .
* The communication is done using 2 Boards .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* @ attention
*
2021-12-14 09:25:05 +01:00
* Copyright ( c ) 2016 STMicroelectronics .
* All rights reserved .
2019-04-29 14:39:56 +01:00
*
2021-12-14 09:25:05 +01:00
* This software is licensed under terms that can be found in the LICENSE file
* in the root directory of this software component .
* If no LICENSE file comes with this software , it is provided AS - IS .
2019-04-29 14:39:56 +01:00
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*/
/* Includes ------------------------------------------------------------------*/
# include "main.h"
/** @addtogroup STM32F7xx_HAL_Examples
* @ {
*/
/** @addtogroup UART_TwoBoards_ComDMA
* @ {
*/
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
# define TRANSMITTER_BOARD
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
/* UART handler declaration */
UART_HandleTypeDef UartHandle ;
__IO ITStatus UartReady = RESET ;
__IO uint32_t UserButtonStatus = 0 ; /* set to 1 after User Button interrupt */
/* Buffer used for transmission */
uint8_t aTxBuffer [ ] = " ****UART_TwoBoards communication based on DMA**** ****UART_TwoBoards communication based on DMA**** ****UART_TwoBoards communication based on DMA**** " ;
/* Buffer used for reception */
uint8_t aRxBuffer [ RXBUFFERSIZE ] ;
/* Private function prototypes -----------------------------------------------*/
2021-12-14 09:25:05 +01:00
static void MPU_Config ( void ) ;
2019-04-29 14:39:56 +01:00
static void SystemClock_Config ( void ) ;
static void Error_Handler ( void ) ;
static uint16_t Buffercmp ( uint8_t * pBuffer1 , uint8_t * pBuffer2 , uint16_t BufferLength ) ;
static void CPU_CACHE_Enable ( void ) ;
/* Private functions ---------------------------------------------------------*/
/**
* @ brief Main program
* @ param None
* @ retval None
*/
int main ( void )
{
2021-12-14 09:25:05 +01:00
/* Configure the MPU attributes */
MPU_Config ( ) ;
2019-04-29 14:39:56 +01:00
/* Enable the CPU Cache */
CPU_CACHE_Enable ( ) ;
/* STM32F7xx 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 1 ms 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 216 MHz */
SystemClock_Config ( ) ;
/* Configure LED1, LED2 and LED3 */
BSP_LED_Init ( LED1 ) ;
BSP_LED_Init ( LED2 ) ;
BSP_LED_Init ( LED3 ) ;
/*##-1- Configure the UART peripheral ######################################*/
/* Put the USART peripheral in the Asynchronous mode (UART Mode) */
/* UART configured as follows:
- Word Length = 8 Bits
- Stop Bit = One Stop bit
- Parity = None
- BaudRate = 9600 baud
- Hardware flow control disabled ( RTS and CTS signals ) */
UartHandle . Instance = USARTx ;
UartHandle . Init . BaudRate = 9600 ;
UartHandle . Init . WordLength = UART_WORDLENGTH_8B ;
UartHandle . Init . StopBits = UART_STOPBITS_1 ;
UartHandle . Init . Parity = UART_PARITY_NONE ;
UartHandle . Init . HwFlowCtl = UART_HWCONTROL_NONE ;
UartHandle . Init . Mode = UART_MODE_TX_RX ;
if ( HAL_UART_DeInit ( & UartHandle ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
if ( HAL_UART_Init ( & UartHandle ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
# ifdef TRANSMITTER_BOARD
/* Configure User push-button in Interrupt mode */
BSP_PB_Init ( BUTTON_USER , BUTTON_MODE_EXTI ) ;
/* Wait for User push-button press before starting the Communication.
In the meantime , LED_GREEN is blinking */
while ( UserButtonStatus = = 0 )
{
/* Toggle LED_GREEN*/
BSP_LED_Toggle ( LED_GREEN ) ;
HAL_Delay ( 100 ) ;
}
BSP_LED_Off ( LED_GREEN ) ;
/* The board sends the message and expects to receive it back */
/*##-2- Start the transmission process #####################################*/
/* While the UART in reception process, user can transmit data through
" aTxBuffer " buffer */
if ( HAL_UART_Transmit_DMA ( & UartHandle , ( uint8_t * ) aTxBuffer , TXBUFFERSIZE ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
/*##-3- Wait for the end of the transfer ###################################*/
while ( UartReady ! = SET )
{
}
/* Reset transmission flag */
UartReady = RESET ;
/*##-4- Put UART peripheral in reception process ###########################*/
if ( HAL_UART_DeInit ( & UartHandle ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
if ( HAL_UART_Init ( & UartHandle ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
if ( HAL_UART_Receive_DMA ( & UartHandle , ( uint8_t * ) aRxBuffer , RXBUFFERSIZE ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
# else
/* The board receives the message and sends it back */
/*##-2- Put UART peripheral in reception process ###########################*/
if ( HAL_UART_Receive_DMA ( & UartHandle , ( uint8_t * ) aRxBuffer , RXBUFFERSIZE ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
/*##-3- Wait for the end of the transfer ###################################*/
/* While waiting for message to come from the other board, LED_GREEN is
blinking according to the following pattern : a double flash every half - second */
while ( UartReady ! = SET )
{
BSP_LED_On ( LED_GREEN ) ;
HAL_Delay ( 100 ) ;
BSP_LED_Off ( LED_GREEN ) ;
HAL_Delay ( 100 ) ;
BSP_LED_On ( LED_GREEN ) ;
HAL_Delay ( 100 ) ;
BSP_LED_Off ( LED_GREEN ) ;
HAL_Delay ( 500 ) ;
}
/* Reset transmission flag */
UartReady = RESET ;
BSP_LED_Off ( LED_GREEN ) ;
/*##-4- Start the transmission process #####################################*/
/* While the UART in reception process, user can transmit data through
" aTxBuffer " buffer */
if ( HAL_UART_DeInit ( & UartHandle ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
if ( HAL_UART_Init ( & UartHandle ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
if ( HAL_UART_Transmit_DMA ( & UartHandle , ( uint8_t * ) aTxBuffer , TXBUFFERSIZE ) ! = HAL_OK )
{
Error_Handler ( ) ;
}
# endif /* TRANSMITTER_BOARD */
/*##-5- Wait for the end of the transfer ###################################*/
while ( UartReady ! = SET )
{
}
/* Reset transmission flag */
UartReady = RESET ;
/*##-6- Compare the sent and received buffers ##############################*/
if ( Buffercmp ( ( uint8_t * ) aTxBuffer , ( uint8_t * ) aRxBuffer , RXBUFFERSIZE ) )
{
Error_Handler ( ) ;
}
/* Turn on LED_GREEN if test passes then enter infinite loop */
BSP_LED_On ( LED_GREEN ) ;
/* Infinite loop */
while ( 1 )
{
}
}
/**
* @ brief System Clock Configuration
* The system Clock is configured as follow :
* System Clock source = PLL ( HSE )
* SYSCLK ( Hz ) = 216000000
* HCLK ( Hz ) = 216000000
* AHB Prescaler = 1
* APB1 Prescaler = 4
* APB2 Prescaler = 2
* HSE Frequency ( Hz ) = 8000000
* PLL_M = 8
* PLL_N = 432
* PLL_P = 2
* PLL_Q = 9
* VDD ( V ) = 3.3
* Main regulator output voltage = Scale1 mode
* Flash Latency ( WS ) = 7
* @ param None
* @ retval None
*/
static void SystemClock_Config ( void )
{
RCC_ClkInitTypeDef RCC_ClkInitStruct ;
RCC_OscInitTypeDef RCC_OscInitStruct ;
/* Enable HSE Oscillator and activate PLL with HSE as source
Note : Since there is no oscillator on board , HSE clock is derived from STLink */
RCC_OscInitStruct . OscillatorType = RCC_OSCILLATORTYPE_HSE ;
RCC_OscInitStruct . HSEState = RCC_HSE_BYPASS ;
RCC_OscInitStruct . HSIState = RCC_HSI_OFF ;
RCC_OscInitStruct . PLL . PLLState = RCC_PLL_ON ;
RCC_OscInitStruct . PLL . PLLSource = RCC_PLLSOURCE_HSE ;
RCC_OscInitStruct . PLL . PLLM = 8 ;
RCC_OscInitStruct . PLL . PLLN = 432 ;
RCC_OscInitStruct . PLL . PLLP = RCC_PLLP_DIV2 ;
RCC_OscInitStruct . PLL . PLLQ = 9 ;
if ( HAL_RCC_OscConfig ( & RCC_OscInitStruct ) ! = HAL_OK )
{
while ( 1 ) { } ;
}
/* Activate the OverDrive to reach the 216 Mhz Frequency */
if ( HAL_PWREx_EnableOverDrive ( ) ! = 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_DIV4 ;
RCC_ClkInitStruct . APB2CLKDivider = RCC_HCLK_DIV2 ;
if ( HAL_RCC_ClockConfig ( & RCC_ClkInitStruct , FLASH_LATENCY_7 ) ! = HAL_OK )
{
while ( 1 ) { } ;
}
}
/**
* @ brief Tx Transfer completed callback
* @ param UartHandle : UART handle .
* @ note This example shows a simple way to report end of DMA Tx transfer , and
* you can add your own implementation .
* @ retval None
*/
void HAL_UART_TxCpltCallback ( UART_HandleTypeDef * UartHandle )
{
/* Set transmission flag: transfer complete */
UartReady = SET ;
# ifdef TRANSMITTER_BOARD
/* Turn LED_BLUE on: Transfer in transmission process is correct */
BSP_LED_On ( LED_BLUE ) ;
# else
/* Turn LED_BLUE off: Transfer in transmission process is correct */
BSP_LED_Off ( LED_BLUE ) ;
# endif /* TRANSMITTER_BOARD */
}
/**
* @ brief Rx Transfer completed callback
* @ param UartHandle : UART handle
* @ note This example shows a simple way to report end of DMA Rx transfer , and
* you can add your own implementation .
* @ retval None
*/
void HAL_UART_RxCpltCallback ( UART_HandleTypeDef * UartHandle )
{
/* Set transmission flag: transfer complete */
UartReady = SET ;
# ifdef TRANSMITTER_BOARD
/* Turn LED_BLUE off: Transfer in reception process is correct */
BSP_LED_Off ( LED_BLUE ) ;
# else
/* Turn LED_BLUE on: Transfer in reception process is correct */
BSP_LED_On ( LED_BLUE ) ;
# endif /* TRANSMITTER_BOARD */
}
/**
* @ brief UART error callbacks
* @ param UartHandle : UART handle
* @ note This example shows a simple way to report transfer error , and you can
* add your own implementation .
* @ retval None
*/
void HAL_UART_ErrorCallback ( UART_HandleTypeDef * UartHandle )
{
Error_Handler ( ) ;
}
/**
* @ brief EXTI line detection callbacks
* @ param GPIO_Pin : Specifies the pins connected EXTI line
* @ retval None
*/
void HAL_GPIO_EXTI_Callback ( uint16_t GPIO_Pin )
{
if ( GPIO_Pin = = USER_BUTTON_PIN )
{
UserButtonStatus = 1 ;
}
}
/**
* @ brief Compares two buffers .
* @ param pBuffer1 , pBuffer2 : buffers to be compared .
* @ param BufferLength : buffer ' s length
* @ retval 0 : pBuffer1 identical to pBuffer2
* > 0 : pBuffer1 differs from pBuffer2
*/
static uint16_t Buffercmp ( uint8_t * pBuffer1 , uint8_t * pBuffer2 , uint16_t BufferLength )
{
while ( BufferLength - - )
{
if ( ( * pBuffer1 ) ! = * pBuffer2 )
{
return BufferLength ;
}
pBuffer1 + + ;
pBuffer2 + + ;
}
return 0 ;
}
/**
* @ brief This function is executed in case of error occurrence .
* @ param None
* @ retval None
*/
static void Error_Handler ( void )
{
/* Turn LED_RED on */
BSP_LED_On ( LED_RED ) ;
while ( 1 )
{
}
}
2021-12-14 09:25:05 +01:00
/**
* @ brief Configure the MPU attributes
* @ param None
* @ retval None
*/
static void MPU_Config ( void )
{
MPU_Region_InitTypeDef MPU_InitStruct ;
/* Disable the MPU */
HAL_MPU_Disable ( ) ;
/* Configure the MPU as Strongly ordered for not defined regions */
MPU_InitStruct . Enable = MPU_REGION_ENABLE ;
MPU_InitStruct . BaseAddress = 0x00 ;
MPU_InitStruct . Size = MPU_REGION_SIZE_4GB ;
MPU_InitStruct . AccessPermission = MPU_REGION_NO_ACCESS ;
MPU_InitStruct . IsBufferable = MPU_ACCESS_NOT_BUFFERABLE ;
MPU_InitStruct . IsCacheable = MPU_ACCESS_NOT_CACHEABLE ;
MPU_InitStruct . IsShareable = MPU_ACCESS_SHAREABLE ;
MPU_InitStruct . Number = MPU_REGION_NUMBER0 ;
MPU_InitStruct . TypeExtField = MPU_TEX_LEVEL0 ;
MPU_InitStruct . SubRegionDisable = 0x87 ;
MPU_InitStruct . DisableExec = MPU_INSTRUCTION_ACCESS_DISABLE ;
HAL_MPU_ConfigRegion ( & MPU_InitStruct ) ;
/* Enable the MPU */
HAL_MPU_Enable ( MPU_PRIVILEGED_DEFAULT ) ;
}
2019-04-29 14:39:56 +01:00
# 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
/**
* @ brief CPU L1 - Cache enable .
* @ param None
* @ retval None
*/
static void CPU_CACHE_Enable ( void )
{
/* Enable I-Cache */
SCB_EnableICache ( ) ;
/* Enable D-Cache */
SCB_EnableDCache ( ) ;
}
/**
* @ }
*/
/**
* @ }
*/