找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5066|回复: 3
打印 上一主题 下一主题
收起左侧

STM32串口通信程序(库函数),亲测可用

[复制链接]
跳转到指定楼层
楼主
程序实现了简单的串口通信应用。在串口调试助手界面,打开串口,配置相应的参数,在发送框中输入十六进制数63,串口接收界面显示十六进制数77 97。

程序比较简单易懂,需要的朋友可以参考一下。新手上路,大家相互学习。


STM32单片机库函数实现的串口通信程序源程序如下:


  1. #include "stm32f10x.h"
  2. #include <stdio.h>


  3. /*************************************************
  4. 函数: void RCC_Configuration(void)
  5. 功能: 复位和时钟控制 配置
  6. 参数: 无
  7. 返回: 无
  8. **************************************************/
  9. void RCC_Configuration(void)
  10. {
  11.   ErrorStatus HSEStartUpStatus;                    //定义外部高速晶体启动状态枚举变量
  12.   RCC_DeInit();                                    //复位RCC外部设备寄存器到默认值
  13.   RCC_HSEConfig(RCC_HSE_ON);                       //打开外部高速晶振
  14.   HSEStartUpStatus = RCC_WaitForHSEStartUp();      //等待外部高速时钟准备好
  15.   if(HSEStartUpStatus == SUCCESS)                  //外部高速时钟已经准别好
  16.   {
  17.     FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //开启FLASH预读缓冲功能,加速FLASH的读取。所有程序中必须的用法.位置:RCC初始化子函数里面,时钟起振之后
  18.     FLASH_SetLatency(FLASH_Latency_2);                    //flash操作的延时
  19.              
  20.     RCC_HCLKConfig(RCC_SYSCLK_Div1);               //配置AHB(HCLK)时钟等于==SYSCLK
  21.     RCC_PCLK2Config(RCC_HCLK_Div1);                //配置APB2(PCLK2)钟==AHB时钟
  22.     RCC_PCLK1Config(RCC_HCLK_Div2);                //配置APB1(PCLK1)钟==AHB1/2时钟
  23.          
  24.     RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);  //配置PLL时钟 == 外部高速晶体时钟 * 9 = 72MHz
  25.     RCC_PLLCmd(ENABLE);                                   //使能PLL时钟
  26.    
  27.     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)    //等待PLL时钟就绪
  28.     {
  29.     }
  30.     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);            //配置系统时钟 = PLL时钟
  31.     while(RCC_GetSYSCLKSource() != 0x08)                  //检查PLL时钟是否作为系统时钟
  32.     {
  33.     }
  34.   }

  35. }

  36. /*******************************************************************************
  37. * Function Name   : NVIC_Configuration
  38. * Description        : Configures NVIC and Vector Table base location.
  39. * Input                    : None
  40. * Output                 : None
  41. * Return                 : None
  42. *******************************************************************************/
  43. void NVIC_Configuration(void)
  44. {
  45.    NVIC_InitTypeDef NVIC_InitStructure;
  46.   
  47.    /* Set the Vector Table base location at 0x08000000 */
  48.    NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
  49.   
  50.    /* Configure the NVIC Preemption Priority Bits */  
  51.    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
  52.   
  53.    /* Enable the USART1 Interrupt */
  54.    NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;       //通道设置为串口1中断
  55.    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;           //中断响应优先级0
  56.    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                   //打开中断
  57.    NVIC_Init(&NVIC_InitStructure);                                                    //初始化
  58. }

  59. /*******************************************************************************
  60.         函数名:USART1_Configuration
  61.         输  入:
  62.         输  出:
  63.         功能说明:
  64.         初始化串口硬件设备,启用中断
  65.         配置步骤:
  66.         (1)打开GPIO和USART1的时钟
  67.         (2)设置USART1两个管脚GPIO模式
  68.         (3)配置USART1数据格式、波特率等参数
  69.         (4)使能USART1接收中断功能
  70.         (5)最后使能USART1功能
  71. */
  72. void USART1_Configuration(void)
  73. {
  74.         GPIO_InitTypeDef GPIO_InitStructure;
  75.         USART_InitTypeDef USART_InitStructure;

  76.         /* 第1步:打开GPIO和USART部件的时钟 */
  77.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
  78.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);

  79.         /* 第2步:将USART Tx的GPIO配置为推挽复用模式 */
  80.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  81.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  82.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  83.         GPIO_Init(GPIOA, &GPIO_InitStructure);

  84.         /* 第3步:将USART Rx的GPIO配置为浮空输入模式
  85.                 由于CPU复位后,GPIO缺省都是浮空输入模式,因此下面这个步骤不是必须的
  86.                 但是,我还是建议加上便于阅读,并且防止其它地方修改了这个口线的设置参数
  87.         */
  88.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  89.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  90.         GPIO_Init(GPIOA, &GPIO_InitStructure);
  91.         /*  第3步已经做了,因此这步可以不做
  92.                 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  93.         */
  94.         //GPIO_Init(GPIOA, &GPIO_InitStructure);


  95.         /* 第4步:配置USART1参数
  96.             - BaudRate = 9600 baud
  97.             - Word Length = 8 Bits
  98.             - One Stop Bit
  99.             - No parity
  100.             - Hardware flow control disabled (RTS and CTS signals)
  101.             - Receive and transmit enabled
  102.         */
  103.         USART_InitStructure.USART_BaudRate = 9600;
  104.         USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  105.         USART_InitStructure.USART_StopBits = USART_StopBits_1;
  106.         USART_InitStructure.USART_Parity = USART_Parity_No;
  107.         USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  108.         USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
  109.         USART_Init(USART1, &USART_InitStructure);

  110.     /* 若接收数据寄存器满,则产生中断 */
  111.     USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);

  112.         /* 第5步:使能 USART1, 配置完毕 */
  113.         USART_Cmd(USART1, ENABLE);

  114.     /* 如下语句解决第1个字节无法正确发送出去的问题 */
  115.     USART_ClearFlag(USART1, USART_FLAG_TC);     // 清标志
  116. }

  117. /*******************************************************************/
  118. /*                                                                 */
  119. /* STM32向串口1发送1字节                                           */
  120. /*                                                                 */
  121. /*                                                                 */
  122. /*******************************************************************/
  123. void Uart1_PutChar(u8 ch)
  124. {
  125.   USART_SendData(USART1, (u8) ch);
  126.   while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
  127. }

  128. /*******************************************************************/
  129. /*                                                                 */
  130. /* STM32在串口1接收1字节                                           */
  131. /* 说明:串口1接收中断                                             */
  132. /*                                                                 */
  133. /*******************************************************************/
  134. void USART1_IRQHandler(void)            //在中断服务程序中,由于主机响应中断时并不知道是哪个中断源发出中断请求,因此必须在中断服务程序中对中断源进行判别,然后分别进行处理。当然,如果只涉及到一个中断请求,是不用做上述判别的。但是无论什么情况,做上述判别是个好习惯
  135. {
  136.   u8 dat;
  137.    
  138.   if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)    //若接收数据寄存器满
  139.   {     
  140.     dat = USART_ReceiveData(USART1);  
  141.          
  142.      if(dat == 0x63)                    
  143.          {                         
  144.           dat = 0;      
  145.                   
  146. ……………………

  147. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
STM32 串口通信(库函数).rar (349.42 KB, 下载次数: 78)



分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:61002 发表于 2017-7-17 17:02 | 只看该作者
直接使用HAL库,Cube直接生成初始化代码,直接调用就可以了
回复

使用道具 举报

板凳
ID:247531 发表于 2017-11-8 23:39 | 只看该作者
来支持下
回复

使用道具 举报

地板
ID:370386 发表于 2018-7-17 11:53 | 只看该作者
学习了 支持一下 不过有些代码模块用Cube生成就好了 不过不知道你是什么芯片
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表