这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界» 论坛首页» 嵌入式开发» STM32» 【转载】stm32串口通信程序:中断方式----from三叶

共5条 1/1 1 跳转至

【转载】stm32串口通信程序:中断方式----from三叶

工程师
2023-12-19 22:04:38 打赏

经过调试在stm32F101CBT6中实现通信。注意还要配一个TTL转usb接口,才能进行通信。实现字符串回发
#include"stm32f10x_it.h"
#include "stm32f10x_conf.h"
void RCC_Configuration(void); //时钟配置
void USART_Configuration(void); //定义串口初始化函数
void NVIC_Configuration( void);
void Uart1_PutChar(u8 ch);
void Uart1_PutString(u8* buf , u8 len);
void GPIO1_Configuration(void);
void GPIO_Configuration(void);
int USART_RX_BUF[64]=0;
int USART_RX_STA=0;
void RCC_Configuration(void)
{
ErrorStatusHSEStartUpStatus;

//使能外部晶振
RCC_HSEConfig(RCC_HSE_ON);
//等待外部晶振稳定
HSEStartUpStatus =RCC_WaitForHSEStartUp();
//如果外部晶振启动成功,则进行下一步操作
if(HSEStartUpStatus==SUCCESS)
{
//设置HCLK(AHB时钟)=SYSCLK
RCC_HCLKConfig(RCC_SYSCLK_Div1);
//PCLK1(APB1) = HCLK/2
RCC_PCLK1Config(RCC_HCLK_Div2);
//PCLK2(APB2) = HCLK
RCC_PCLK2Config(RCC_HCLK_Div1);
RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_4);
//启动PLL
RCC_PLLCmd(ENABLE);
//等待PLL稳定
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) ==RESET);
//系统时钟SYSCLK来自PLL输出
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
//切换时钟后等待系统时钟稳定
while(RCC_GetSYSCLKSource()!=0x08);
}

//RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
//RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2 ,ENABLE);
}
int main(void)
{
int i;
u8 len;
RCC_Configuration();
RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA |
RCC_APB2Periph_AFIO, ENABLE);//使能各部分时钟
//NVIC_Configuration(); //串口中断配置
//RCC中打开相应串口
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2 ,ENABLE);
GPIO_Configuration();
//串口1的管脚初始化
GPIO1_Configuration();
NVIC_Configuration();
USART_Configuration();
while (1)
{

GPIO_SetBits(GPIOA,GPIO_Pin_8) ;
GPIO_SetBits(GPIOA,GPIO_Pin_11) ;
GPIO_SetBits(GPIOA,GPIO_Pin_15) ;
if(USART_RX_STA&0x80)

{
len=USART_RX_STA&0x3f;//得到此次接收到的数据长度
USART2->DR=len;
while(USART_GetFlagStatus(USART2,USART_FLAG_TC) == RESET);
for(i=0;i
{USART2->DR=USART_RX_BUF[i];
while(USART_GetFlagStatus(USART2,USART_FLAG_TC) == RESET);//等待发送结束}
}
USART_RX_STA=0;
}
for(i=0;i<1000000;i++);
GPIO_ResetBits(GPIOA,GPIO_Pin_11);
GPIO_ResetBits(GPIOA,GPIO_Pin_15);
for(i=0;i<1000000;i++);

}
}
void GPIO_Configuration(void)
{

GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_8|GPIO_Pin_11|GPIO_Pin_15;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
GPIO_Init(GPIOA,&GPIO_InitStructure);
}
voidGPIO1_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; //管脚2
GPIO_InitStructure.GPIO_Speed =GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode =GPIO_Mode_AF_PP; //复用推挽输出
GPIO_Init(GPIOA,&GPIO_InitStructure); //TX初始化

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3; //管脚3
GPIO_InitStructure.GPIO_Speed =GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode =GPIO_Mode_IN_FLOATING; //浮空输入
GPIO_Init(GPIOA,&GPIO_InitStructure); //RX初始化

}

void USART_Configuration(void)//串口初始化函数

{
USART_ClockInitTypeDefUSART_ClockInitStructure;
//串口参数初始化
USART_InitTypeDef USART_InitStructure;//串口设置恢复默认参数
//初始化参数设置
USART_InitStructure.USART_BaudRate = 9600;//波特率9600
USART_InitStructure.USART_WordLength =USART_WordLength_8b; //字长8位
USART_InitStructure.USART_StopBits =USART_StopBits_1; //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;//打开Rx接收和Tx发送功能
USART_Init(USART2,&USART_InitStructure); //初始化
//USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//使能接受中断,在接受移位 寄存器中有数据是产生
USART_ClockInitStructure.USART_Clock =USART_Clock_Disable;
USART_ClockInitStructure.USART_CPOL =USART_CPOL_Low;
USART_ClockInitStructure.USART_CPHA =USART_CPHA_2Edge;
USART_ClockInitStructure.USART_LastBit =USART_LastBit_Disable;
USART_ClockInit(USART2,&USART_ClockInitStructure);
USART_Cmd(USART2,ENABLE); //启动串口
USART_ITConfig(USART2,USART_IT_RXNE, ENABLE);
}
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);//选择分组方式0

NVIC_InitStructure.NVIC_IRQChannel =USART2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd =ENABLE;
NVIC_Init(&NVIC_InitStructure);
}

在stm32f10x_it.c
void USART2_IRQHandler(void); //放在头文件里面也可以
extern intUSART_RX_BUF[64];//声明全局变量,此处不能够赋值
extern int USART_RX_STA;//声明全局变量,此处不能够赋值

void USART2_IRQHandler(void)

{

unsigned intres;
if(USART_GetFlagStatus(USART2,USART_IT_RXNE)==SET)
{
res =USART_ReceiveData(USART2);
if((USART_RX_STA&0x80)==0)//接收未完成
{
USART_RX_BUF[USART_RX_STA]=res;
USART_RX_STA++;
if(USART_RX_STA>63)
USART_RX_STA=0;
if(res=='//m.amcfsurvey.com/forum/thread/378846/#')
USART_RX_STA|=0x80;
}
}

if(USART_GetITStatus(USART2, USART_IT_RXNE) !=RESET)

{


USART_ClearITPendingBit(USART2,USART_IT_RXNE);

}

}

来源: 整理文章为传播相关技术,网络版权归原作者所有,如有侵权,请联系删除。


高工
2023-12-20 00:08:04 打赏
2楼

谢谢分享


院士
2023-12-20 07:02:08 打赏
3楼

谢谢楼主的分享~!



高工
2023-12-20 10:56:49 打赏
4楼

现在stm32f101 这款型号是不是特别贵了啊


高工
2024-01-17 08:43:50 打赏
5楼

学习一下


共5条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册]