stm32f103串口1串口2收发程序

2019-10-23来源: eefocus关键字:stm32f103  串口1  串口2  收发程序

#include "stm32f10x.h"  

#include "string.h"

#include "stdio.h"  

void delay(void);  

void GPIO_Configuration(void); 

void uart_init();

extern void USART_OUT(USART_TypeDef* USARTx, uint16_t *Data,...);

void RCC_Configuration(void)  

{  

SystemInit();   

RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1|

RCC_APB2Periph_GPIOA|

RCC_APB2Periph_GPIOB|

RCC_APB2Periph_GPIOD |

RCC_APB2Periph_AFIO| 

RCC_APB2Periph_GPIOC,ENABLE); 


RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);

}

void NVIC_Configuration(void)  

{  

 

  NVIC_InitTypeDef NVIC_InitStructure;   

  

  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);       

    

  



  NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn|USART2_IRQn;     //ÉèÖô®¿Ú1ÖжϠ

  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;         //ÇÀÕ¼ÓÅÏȼ¶ 0  

  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;                //×ÓÓÅÏȼ¶Îª0  

  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                   //ʹÄÜ  

  NVIC_Init(&NVIC_InitStructure);  



}  





void UART_PutChar(USART_TypeDef* USARTx, uint8_t Data)  

{  

    USART_SendData(USARTx, Data);  

    while(USART_GetFlagStatus(USARTx, USART_FLAG_TC) == RESET){}  

}  

void UART_PutStr (USART_TypeDef* USARTx, uint8_t *str)    

{    

    while (0 != *str)    

    {    

        UART_PutChar(USARTx, *str);    

        str++;    

    }    

}





int main(void)  

{  

RCC_Configuration();

GPIO_Configuration();  

NVIC_Configuration(); 

uart_init();



while(1)  

  {  

   GPIO_ResetBits(GPIOC,GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_13);  

delay();  

   GPIO_SetBits(GPIOC,GPIO_Pin_6|GPIO_Pin_8|GPIO_Pin_13);  

   delay();  

   GPIO_ResetBits(GPIOC,GPIO_Pin_6|GPIO_Pin_8|GPIO_Pin_13); 

delay();   

   GPIO_SetBits(GPIOC,GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_13);  

   delay();   

 

//USART_SendData(USART1, '1');  

UART_PutStr(USART1,(uint8_t*)("234"));

UART_PutStr(USART2,(uint8_t*)("234"));

  }  

}  





void GPIO_Configuration(void)  

{    

  GPIO_InitTypeDef GPIO_InitStructure;    

  GPIO_InitStructure.GPIO_Pin=GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_13;     

GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;  GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;     

GPIO_Init(GPIOC,&GPIO_InitStructure);  



GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_2;                  //USART1 TX  

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;            //¸´ÓÃÍÆÍìÊä³ö  

  GPIO_Init(GPIOA, &GPIO_InitStructure);                     //A¶Ë¿Ú   

   /* Configure USART2 Rx (PA.03) as input floating */

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10|GPIO_Pin_3;                 //USART1 RX  

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;      //¸´ÓÿªÂ©ÊäÈë  

  GPIO_Init(GPIOA, &GPIO_InitStructure);                    //A¶Ë¿Ú   


}  

 

void uart_init()

{

USART_InitTypeDef USART_InitStructure;

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_Tx | USART_Mode_Rx;


USART_Init(USART1, &USART_InitStructure);  

 USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);                    //ʹÄܽÓÊÕÖжϠ 

USART_ITConfig(USART1, USART_IT_TXE, ENABLE);                     //ʹÄÜ·¢ËÍ»º³å¿ÕÖжϠ


USART_Init(USART2, &USART_InitStructure); 

USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);                    //ʹÄܽÓÊÕÖжϠ 

USART_ITConfig(USART2, USART_IT_TXE, ENABLE);                     //ʹÄÜ·¢ËÍ»º³å¿ÕÖжϠ


USART_Cmd(USART1, ENABLE);      

USART_Cmd(USART2, ENABLE);      

}



void USART1_IRQHandler(void)      //´®¿Ú1 ÖжϷþÎñ³ÌÐò  

{  

static u8 RX_dat[256]={0};static int i;     

if(USART_GetITStatus(USART1,USART_IT_RXNE)==SET)//USART_IT_RXNE£º½ÓÊÕÖжϠ 

{   

USART_ClearITPendingBit(USART1,USART_IT_RXNE); 

RX_dat[i++]=USART_ReceiveData(USART1);    

  }

if(RX_dat[0]=='{' &&  RX_dat[i-1]=='}')

{

//UART_PutStr(USART2,"fdg");

}

}  

void USART2_IRQHandler(void)      //´®¿Ú2 ÖжϷþÎñ³ÌÐò  

{  

  unsigned int i;  

    

}  



关键字:stm32f103  串口1  串口2  收发程序 编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic478056.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:stm32f103之串口实验
下一篇:STM32串口USART1程序

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

stm32f103 c6t6 CAN总线的配置
KEIl5 环境下 中文显示复制过来有问题又懒得打字
发表于 2019-11-13
stm32f103 c6t6 CAN总线的配置
STM8L051F3_01_GPIO应用
本章介绍STM8L051F3的GPIO相关知识。内容分为以下几部分:GPIO简介点亮LED1、GPIO简介GPIO:通用输入/输出口,用于芯片与外部进行数据传输;STM8L051F3的一个I/O端口最多可以有8个Pins(引脚),每个引脚可以独立地配置为数字输入或数字输出。此外,一些I/O端口可能有一些复用功能如模拟输入、外部中断、片上外设的输入输出等,一个引脚不能同时使用多种复用功能。每个I/O端口都分配有一个输出数据寄存器、输入数据寄存器、数据方向寄存器、两个配置寄存器,一个I/O端口工作在输入或输出状态取决于数据方向寄存器。STM8L051F3的GPIO主要性能如下:端口的位(引脚)能独立配置可选择的输入模式:浮空输入
发表于 2019-11-13
STM32F0x2 IWDG(独立看门狗)
单片机系统在外界的干扰下会出现程序跑飞的现象导致出现死循环,看门狗电路就是为了避免这种情况的发生。看门狗的作用就是在一定时间内(通过定时计数器实现)没有接收喂狗信号(表示 MCU 已经挂了),便实现处理器的自动复位重启(发送复位信号)。 以下为stm32f042单片机独立看门狗相关代码:/***********************************************************函数描述:初始化独立看门狗,timeout为1s*函数:void IWDG_Init(unsigned char usb_sw) *参数:无*作者:*日期
发表于 2019-11-12
STM32F1小白系列之四、独立看门狗(IWDG)
:T(ms) == [(4 * 2^pre_Scaler) * reload] / 40;    IWDG_ReloadCounter();//第一次喂狗    IWDG_Enable();//使能看门狗}//喂狗APIvoid feed_iwdg(void){    IWDG_ReloadCounter();//喂狗,使STM32重新加载【IWDG_RLR中的值】到【看门狗计数器里面】。}2、直接配置寄存器/*    函数功能:初始化独立看门狗    函数名:init_iwdg    返回值:void 
发表于 2019-11-12
stm32f0 hal adc配置
Clock Prescaler:和系统时钟同步并且二分频Sampling Time :采样时间,采样时间是你通过寄存器告诉STM32采样模拟量的时间,设置越长越精确
发表于 2019-11-11
stm32f0 hal adc配置
STM32F0xx_看门狗(独立+窗口)配置详细过程
Ⅰ、概述对于看门狗,我觉得做单片机或者嵌入式开发的人员来说并不陌生,今天总结STM32F0看门狗的功能,F0的看门狗有两种:独立和窗口看门狗。今天提供两种看门狗的软件工程实例,供大家下载。两种看门狗各有各的特点,应用在不同的场合,下面将分别简单总结一下独立和窗口看门狗的功能。Ⅱ、下载文章提供的“软件工程”都是在硬件板子上进行多次测试、并保证没问题才上传至360云盘,请放心下载测试,如有问题请检查一下你的板子是否有问题。ST标准外设库和参考手册、数据手册等都可以在ST官网下载,你也可以到我的360云盘下载。关于F0系列芯片的参考手册有多个版本(针对F0不同芯片),但有一个通用版本,就是“STM32F0x128参考手册V8(英文
发表于 2019-11-08
STM32F0xx_看门狗(独立+窗口)配置详细过程
小广播
何立民专栏 单片机及嵌入式宝典

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

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved