STM32M CUBE实现printf打印调试信息以及实现单字节接收
生活随笔
收集整理的這篇文章主要介紹了
STM32M CUBE实现printf打印调试信息以及实现单字节接收
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在寫單片機程序時我們一般喜歡使用printf來通過串口打印調試信息,但這個函數是不能夠直接使用的。必須做點對庫函數的修改。
具體project下載地址:?http://download.csdn.net/detail/liucheng5037/8847961
STM32M CUBE是ST官方提供的庫以及初始化工具,非常好非常強大,可是在UART方面值提供了例如以下函數:
HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout); HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout); HAL_StatusTypeDef HAL_UART_Transmit_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); HAL_StatusTypeDef HAL_UART_Receive_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); HAL_StatusTypeDef HAL_UART_Transmit_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); HAL_StatusTypeDef HAL_UART_Receive_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size);分別實現普通收發。中斷收發,DMA收發。問題是全部函數要求發送和接收的buf必需要事先知道長度,也沒有提供對單字節的收發,無法直接實現printf以及單字節接收。
事實上要實現這些還是非常easy的。首先是實現printf
在main.c 加入例如以下信息
#include <stdio.h>#ifdef __GNUC__/* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printfset to 'Yes') calls __io_putchar() */#define PUTCHAR_PROTOTYPE int __io_putchar(int ch) #else#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f) #endif /* __GNUC__ *//*** @brief Retargets the C library printf function to the USART.* @param None* @retval None*/ PUTCHAR_PROTOTYPE {/* Place your implementation of fputc here *//* e.g. write a character to the USART */huart1.Instance->DR = (uint8_t) ch;/* Loop until the end of transmission */while(__HAL_UART_GET_FLAG(&huart1, UART_FLAG_TC) == RESET){}return ch; }在這里我們實現了單字節發送函數,注意實現這樣的發送方式的前提是單字節發送的相關中斷不能打開。否則會進入無限等待,做好之后就能夠使用printf了。
void LED_Task2(void const * argument) {while(1){HAL_GPIO_TogglePin(GPIOG,GPIO_PIN_14);printf("LED_Task2\r\n");osDelay(2000);} }
然后是中斷單字節接收,改動中斷接收函數例如以下: void USART1_IRQHandler(void) {/* USER CODE BEGIN USART1_IRQn 0 */static int count=0;/* USER CODE END USART1_IRQn 0 */ // HAL_UART_IRQHandler(&huart1);/* USER CODE BEGIN USART1_IRQn 1 */if(__HAL_UART_GET_FLAG(&huart1, UART_FLAG_RXNE) == SET)//有接受到字符串{uart_recbuf[count++] = (uint8_t)(huart1.Instance->DR & (uint8_t)0x00FF);//接收huart1.Instance->DR = uart_recbuf[count-1];//發送接收的數據if(count == 100) count = 0;}/* USER CODE END USART1_IRQn 1 */ }
注意使用cube生成的代碼默認是沒有打開接收中斷使能的。要在這里打開: void HAL_UART_MspInit(UART_HandleTypeDef* huart) {GPIO_InitTypeDef GPIO_InitStruct;if(huart->Instance==USART1){/* USER CODE BEGIN USART1_MspInit 0 *//* USER CODE END USART1_MspInit 0 *//* Peripheral clock enable */__USART1_CLK_ENABLE();/**USART1 GPIO Configuration PA9 ------> USART1_TXPA10 ------> USART1_RX */GPIO_InitStruct.Pin = GPIO_PIN_9|GPIO_PIN_10;GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;GPIO_InitStruct.Pull = GPIO_PULLUP;GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;GPIO_InitStruct.Alternate = GPIO_AF7_USART1;HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);/* Peripheral interrupt init*/HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);HAL_NVIC_EnableIRQ(USART1_IRQn);/* USER CODE BEGIN USART1_MspInit 1 */huart->Instance->CR1 |= USART_CR1_RXNEIE;//使能接收中斷/* USER CODE END USART1_MspInit 1 */}}
這樣就實現了這些功能,可是之前cube的默認功能,中斷收發已經不能用了。
轉載于:https://www.cnblogs.com/zfyouxi/p/5111054.html
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的STM32M CUBE实现printf打印调试信息以及实现单字节接收的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: OC中数组排序的3种方法
- 下一篇: [转]java构造方法的访问修饰符