STM32 串口通讯 发送 接收

发布者:JoyfulSunflower最新更新时间:2017-11-28 来源: eefocus关键字:STM32  串口通讯  发送  接收 手机看文章 扫描二维码
随时随地手机看文章

STM32的使用有利有弊,种类多---但是种类有太多,资料也是比较乱的,还有就是库的调用,经常忘记一些函数的使用------比如最常用的串口------


------------------------------------------------------------------------------USART ----设置-------------------------------

void USART1_Config(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);  //USART1--时钟--与对应--GPIO--时钟开启
 

 //USART1的Tx---GPIO----PA.09----复用推挽输出
        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);

 //USART1的Rx---GPIO----PA.10----浮空输入
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

 //USART1的模式配置
        USART_InitStructure.USART_BaudRate = 115200;  //波特率
        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_ClearFlag(USART1,USART_FLAG_TC);  //清除串口1发送中断,否则第一个数不会发生

        USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //接收中断使能----一般是在中断中需要用数组将接收到的数据保存起来时使用

        USART_Cmd(USART1, ENABLE);//使能USART1
}

-----------------------------------------/重定向c库函数----printf----到USART1-----------------------------------


int fputc(int ch, FILE *f)
{
        USART_SendData(USART1, (uint8_t) ch);  //发送一个字节数据到USART1 
        while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET); // 等待发送完毕

        return (ch);
}

-----------------------------------------/重定向c库函数----scanf------到USART1-----------------------
int fgetc(FILE *f)
{
        while (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET); //等待串口1输入数据 
        return (int)USART_ReceiveData(USART1);
}

------上面两个重定向----是将原来C库的函数与现在硬件的相对应---------

------我们也可以自己编写相似函数--------运用基本的两个函数----发送---USART_SendData()-----接收------USART_ReceiveData()---

-----------------************************************************-------比如--------%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%-----

void MyPrintfByte(unsigned char byte)   //串口发送一个字节
{
        USART_SendData(USART1, byte);        //通过库函数  发送数据
        while( USART_GetFlagStatus(USART1,USART_FLAG_TC)!= SET);  //等待发送完成,检测 USART_FLAG_TC 是否置1       
}

---------------------------------------------
void MyPrintfStr(unsigned char *s)   //发送字符串 函数--指针--
{
        uint8_t i=0;  //定义一个局部变量  用来 发送字符串 ++运算

        while(s[i]!='\0')  // 每个字符串结尾 都是以  \0 结尾的
        {
                USART_SendData(USART1,s[i]);       //通过库函数  发送数据
                while( USART_GetFlagStatus(USART1,USART_FLAG_TC)!= SET); //等待发送完成,检测 USART_FLAG_TC 是否置1
                 i++;                 //i++一次
        }
}

--------------------------------------------------
void MyPrintfArray(uint8_t send_array[],uint8_t num) //两个参数 一是数组内容, 二是数组长度1-255 
{
        uint8_t i=0;  //定义一个局部变量  用来 发送字符串 ++运算

         while(i        {
          USART_SendData(USART1,send_array[i]);        //通过库函数  发送数据
         while( USART_GetFlagStatus(USART1,USART_FLAG_TC)!= SET);  //等待发送完成,检测 USART_FLAG_TC 是否置1
          i++;  //加一         
        }        
}



-----------------------------------------主函数中需要定义一个数组-----用来保存接收中断时接收到的数据--------------------

uint8_t RS232_RX_BUF[24];//数组
uint8_t RS232_RX_CNT=0;//数组实时下标

--------------------------到时候直接判断或者使用这个数组中的相对应位数据----------------------------------------


-----------------------------------------中断--------接收中断--------------------

----先申明在主函数中定义接收数组-----位外部变量----------------特别注意申明外部变量时不能赋值-------------

extern uint8_t RS232_RX_BUF[24];
extern uint8_t RS232_RX_CNT;

-------------------------------------------中断函数---------------------------

void USART1_IRQHandler(void) 
{
        uint8_t res;         
        if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收到数据  
        {        
                res =USART_ReceiveData(USART1);  //读取接收到的数据   
               RS232_RX_BUF[RS232_RX_CNT]=res;  //记录接收到的值 
   

   //USART_SendData(USART1, res);//发送数据----回显

                RS232_RX_CNT++;      //接收数据增加1  
                if( RS232_RX_CNT>23)
                        RS232_RX_CNT=0;    
        }
        if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) 
        { 
                 USART_ClearITPendingBit(USART1, USART_IT_RXNE);//清除接收标志位------每次接收完成都需要清除一下
        }

}

----------------------------------------------------------配置中断优先级------------------------

static void NVIC_Configuration(void)
{
        NVIC_InitTypeDef NVIC_InitStructure;
  
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);//中断分组
  
        NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//中断源
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;//抢占优先级
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = ENABLE;
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//使能
        NVIC_Init(&NVIC_InitStructure);
}

---------------------------------------------------------------在主函数中的配置调用--------------------------

  

  USART1_Config();   //串口1用于输出调试信息
  NVIC_Configuration();

-----------------------------------------------------------

 printf("接收到的数据为%d \r\n",temp); 


【--------------------------------------------最后  总结------------------------------------------------】

1.GPIO与时钟设置

2.模式配置选择-------注意打开中断允许-----USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);

3.中断函数的编写

4.中断优先级的设置

5.主函数调用


------------------------------------------------------------------485通讯---同理------------------


关键字:STM32  串口通讯  发送  接收 引用地址:STM32 串口通讯 发送 接收

上一篇:STM32 485通信 自我学习总结
下一篇:LPC1788--SSP设置驱动W25Q16--以及特别注意点

推荐阅读最新更新时间:2024-03-16 15:47

万用表怎样辨别辨别红外接收
  万用表是电力电子等部门不可缺少的测量仪表,一般以测量电压、电流和电阻为主要目的。多用表按显示方式分为指针多用表和数字多用表。是一种多功能、多量程的测量仪表,一般多用表可测量直流电流、直流电压、交流电流、交流电压、电阻和音频电平等,有的还可以测交流电流、电容量、电感量及半导体的一些参数等。对于福禄克万用表怎样辨别红外接收头的方法呢?   首先把指(福禄克万用表:http://www.szkinghood.com.cn/)的针表拨到R×100档,红1黑2,红1黑3,红2黑1,红2黑3,红3黑1,红3黑2, 一共六个数值。记下最低的数值,这时红表笔接的是VCC,黑表笔接的是G,另外一脚就是output了,这个方法,准确度非常高。
[测试测量]
stm32入门——跑马灯(基于stm32f103zet6)
最近开始学stm32,着实感觉到了stm32和51之间的区别,但也有联系,总我感觉32与51之间最大的区别就是在使用某个外设之前,要对该外设进行时钟的使能(以达到降低功耗的目的),和相关配置。 刚学完跑马灯,下面对跑马灯用到的对IO口的配置相关知识分别对应官方库函数和寄存器进行总结。 如有错误或不足,请在下方留言。 文章内容基于正点原子战舰。 IO口的状态 IO口有八大模式:─ 输入浮空( GPIO_Mode_IN_FLOATING = 0x04,) ─ 输入上拉( GPIO_Mode_IPU = 0x48,) ─ 输入下拉( GPIO_Mode_IPD
[单片机]
<font color='red'>stm32</font>入门——跑马灯(基于stm32f103zet6)
stm32 ADC 使用DMA双缓存
半缓存中断 https://www.bilibili.com/read/cv5242250/
[单片机]
<font color='red'>stm32</font> ADC 使用DMA双缓存
STM32寄存器映射
我们知道,存储器本身没有地址,给存储器分配地址的过程叫存储器映射,那什么叫寄存器映射?寄存器到底是什么? 在存储器Block2 这块区域,设计的是片上外设,它们以四个字节为一个单元,共32bit,每一个单元对应不同的功能,当我们控制这些单元时就可以驱动外设工作。我们可以找到每个单元的起始地址,然后通过C 语言指针的操作方式来访问这些单元,如果每次都是通过这种地址的方式来访问,不仅不好记忆还容易出错,这时我们可以根据每个单元功能的不同,以功能为名给这个内存单元取一个别名,这个别名就是我们经常说的寄存器,这个给已经分配好地址的有特定功能的内存单元取别名的过程就叫寄存器映射。 比如,我们找到GPIOB 端口的输出数据寄存器ODR 的地址
[单片机]
<font color='red'>STM32</font>寄存器映射
stm32 时钟 pcclk ahb hclk
AHB (HCLK) 时钟 = SYSCLK = 72MHz APB2(PCLK2)时钟 = AHB时钟 = 36MHz APB1(PCLK1)时钟 = AHB 1/2时钟 = 72MHz ADC时钟 = PCLK2 1/4 = 9MHz PLL时钟 = HSE*9 = 72MHz ErrorStatus HSEStartUpStatus; //初始化RCC外部设备寄存器 RCC_DeInit(); //打开外部高速晶振 RCC_HSEConfig( RCC_HSE_ON ); //等待外部高速设备准备好 H
[单片机]
基于STM32微控制器处理先进电机控制方法
    变频器的问世和先进的电机控制方法让三相无刷电机(交流感应电机或永磁同步电机)曾经在调速应用领域取得巨大成功。这些高性能的电机驱动器过去主要用于工厂自动化系统和机器人。十年来,电子元器件的大幅降价使得这些电机驱动器能够进入对成本敏感的市场,例如:家电、空调或个人医疗设备。本文将探讨基于ARM的标准微控制器如何在一个被DSP和FPGA长期垄断的市场上打破复杂的控制模式,我们将以意法半导体的基于Cortex-M3 内核的STM32系列微控制器为例论述这个过程。     首先,我们回顾一下电机控制的基本原理。在电机控制系统内,为什么处理器非常重要?我们为什么需要非常好的计算性能?毕竟,Nicolas Tesla在一个世纪前发明
[嵌入式]
完整的GPS+蓝牙接收系统解决方案
目前,以GPS为代表的卫星导航应用产业已成为当今国际公认的八大无线产业之一。随着技术的进步、应用需求的增加,GPS以全天候、高精度、自动化、高效率等显著特点及其所独具的定位导航、授时校频、精密测量等多方面的强大功能,已涉足众多的应用领域,使GPS成为继蜂窝移动通信和互联网之后的全球第三个IT经济新增长点。 而蓝牙技术带给了人们一种全新的概念。可以说,任何应用只要涉及到两个或多个设备间短距离和I/O要求相对较低的无线通信,蓝牙都有用武之地。 图1:LEA-4H的实物图。 主模块结构及主要功能 LEA-4H是U-Blox公司推出的GPS模块,尺寸仅为17%26;#215;22mm,内
[网络通信]
基于STM32-蜂鸣器
1.蜂鸣器 蜂鸣器是一种发声设备,被广泛用于计算机、打印机、复印机、报警器、电子玩具等。后面介绍定时器是会给大家说说利用蜂鸣器实现歌曲演奏。蜂鸣器分为有源蜂鸣器和无源蜂鸣器。那么什么是有源,什么是无源呢?这里的有源不是指电源的“源”,而是指有没有自带震荡电路,有源蜂鸣器自带了震荡电路,一通电就会发声;无源蜂鸣器则没有自带震荡电路,必须外部提供 2~5Khz 左右的方波驱动才能发声。 2.硬件介绍 这里使用STM32F103实现无源蜂鸣器的交替发声,下图是硬件设计图。首先,STM32F1 的单个 IO 最大可以提供 25mA 电流(数据手册查看),而蜂鸣器的驱动电流是 30mA 。这里使用一个NPN三极管(S8050)扩
[单片机]
基于STM32-蜂鸣器
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved