程序實現了簡單的串口通信應用。在串口調試助手界面,打開串口,配置相應的參數,在發送框中輸入十六進制數63,串口接收界面顯示十六進制數77 97。
程序比較簡單易懂,需要的朋友可以參考一下。新手上路,大家相互學習。
360反饋意見截圖1827061889112113.png (40.03 KB, 下載次數: 64)
下載附件
部分程序截圖
2017-7-15 14:47 上傳
STM32單片機庫函數實現的串口通信程序源程序如下:
- #include "stm32f10x.h"
- #include <stdio.h>
- /*************************************************
- 函數: void RCC_Configuration(void)
- 功能: 復位和時鐘控制 配置
- 參數: 無
- 返回: 無
- **************************************************/
- void RCC_Configuration(void)
- {
- ErrorStatus HSEStartUpStatus; //定義外部高速晶體啟動狀態枚舉變量
- RCC_DeInit(); //復位RCC外部設備寄存器到默認值
- RCC_HSEConfig(RCC_HSE_ON); //打開外部高速晶振
- HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等待外部高速時鐘準備好
- if(HSEStartUpStatus == SUCCESS) //外部高速時鐘已經準別好
- {
- FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //開啟FLASH預讀緩沖功能,加速FLASH的讀取。所有程序中必須的用法.位置:RCC初始化子函數里面,時鐘起振之后
- FLASH_SetLatency(FLASH_Latency_2); //flash操作的延時
-
- RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置AHB(HCLK)時鐘等于==SYSCLK
- RCC_PCLK2Config(RCC_HCLK_Div1); //配置APB2(PCLK2)鐘==AHB時鐘
- RCC_PCLK1Config(RCC_HCLK_Div2); //配置APB1(PCLK1)鐘==AHB1/2時鐘
-
- RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //配置PLL時鐘 == 外部高速晶體時鐘 * 9 = 72MHz
- RCC_PLLCmd(ENABLE); //使能PLL時鐘
-
- while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) //等待PLL時鐘就緒
- {
- }
- RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //配置系統時鐘 = PLL時鐘
- while(RCC_GetSYSCLKSource() != 0x08) //檢查PLL時鐘是否作為系統時鐘
- {
- }
- }
- }
- /*******************************************************************************
- * Function Name : NVIC_Configuration
- * Description : Configures NVIC and Vector Table base location.
- * Input : None
- * Output : None
- * Return : None
- *******************************************************************************/
- void NVIC_Configuration(void)
- {
- NVIC_InitTypeDef NVIC_InitStructure;
-
- /* Set the Vector Table base location at 0x08000000 */
- NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
-
- /* Configure the NVIC Preemption Priority Bits */
- NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
-
- /* Enable the USART1 Interrupt */
- NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //通道設置為串口1中斷
- NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //中斷響應優先級0
- NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //打開中斷
- NVIC_Init(&NVIC_InitStructure); //初始化
- }
- /*******************************************************************************
- 函數名:USART1_Configuration
- 輸 入:
- 輸 出:
- 功能說明:
- 初始化串口硬件設備,啟用中斷
- 配置步驟:
- (1)打開GPIO和USART1的時鐘
- (2)設置USART1兩個管腳GPIO模式
- (3)配置USART1數據格式、波特率等參數
- (4)使能USART1接收中斷功能
- (5)最后使能USART1功能
- */
- void USART1_Configuration(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
- USART_InitTypeDef USART_InitStructure;
- /* 第1步:打開GPIO和USART部件的時鐘 */
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
- /* 第2步:將USART Tx的GPIO配置為推挽復用模式 */
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
- GPIO_Init(GPIOA, &GPIO_InitStructure);
- /* 第3步:將USART Rx的GPIO配置為浮空輸入模式
- 由于CPU復位后,GPIO缺省都是浮空輸入模式,因此下面這個步驟不是必須的
- 但是,我還是建議加上便于閱讀,并且防止其它地方修改了這個口線的設置參數
- */
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
- GPIO_Init(GPIOA, &GPIO_InitStructure);
- /* 第3步已經做了,因此這步可以不做
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
- */
- //GPIO_Init(GPIOA, &GPIO_InitStructure);
- /* 第4步:配置USART1參數
- - BaudRate = 9600 baud
- - Word Length = 8 Bits
- - One Stop Bit
- - No parity
- - Hardware flow control disabled (RTS and CTS signals)
- - Receive and transmit enabled
- */
- USART_InitStructure.USART_BaudRate = 9600;
- USART_InitStructure.USART_WordLength = USART_WordLength_8b;
- USART_InitStructure.USART_StopBits = USART_StopBits_1;
- USART_InitStructure.USART_Parity = USART_Parity_No;
- USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
- USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
- USART_Init(USART1, &USART_InitStructure);
- /* 若接收數據寄存器滿,則產生中斷 */
- USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
- /* 第5步:使能 USART1, 配置完畢 */
- USART_Cmd(USART1, ENABLE);
- /* 如下語句解決第1個字節無法正確發送出去的問題 */
- USART_ClearFlag(USART1, USART_FLAG_TC); // 清標志
- }
- /*******************************************************************/
- /* */
- /* STM32向串口1發送1字節 */
- /* */
- /* */
- /*******************************************************************/
- void Uart1_PutChar(u8 ch)
- {
- USART_SendData(USART1, (u8) ch);
- while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
- }
- /*******************************************************************/
- /* */
- /* STM32在串口1接收1字節 */
- /* 說明:串口1接收中斷 */
- /* */
- /*******************************************************************/
- void USART1_IRQHandler(void) //在中斷服務程序中,由于主機響應中斷時并不知道是哪個中斷源發出中斷請求,因此必須在中斷服務程序中對中斷源進行判別,然后分別進行處理。當然,如果只涉及到一個中斷請求,是不用做上述判別的。但是無論什么情況,做上述判別是個好習慣
- {
- u8 dat;
-
- if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //若接收數據寄存器滿
- {
- dat = USART_ReceiveData(USART1);
-
- if(dat == 0x63)
- {
- dat = 0;
-
- ……………………
- …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
所有資料51hei提供下載:
STM32 串口通信(庫函數).rar
(349.42 KB, 下載次數: 78)
2017-7-15 16:04 上傳
點擊文件名下載附件
附件 下載積分: 黑幣 -5
|