奥奥,之前的求助已经搞定,我把程序改好了,现在贴出来。就是按照自己的理解重写了一遍原子哥的代码,以便加深印象。
#include "sys.h"
#include "delay.h"
#define LED PFout(10)
u8 flag; //串口通信标识,1表示接收完成
u8 flag_enter;
u8 USART1_RX_BUF[200]; //串口是一个字节一个字节读取接收到的信息的,因此定义存储全部字节的矩阵,矩阵的每个元素就是那个字节读取到的内容。此处定义串口每次收到1组共200个字节的信息
u8 char_num; //当前字节的序号
void LED_Init(void)
{
RCC->AHB1ENR|=1<<5;
GPIO_Set(GPIOF,PIN10,GPIO_MODE_OUT,GPIO_OTYPE_PP,GPIO_SPEED_100M,GPIO_PUPD_PU);
LED=1;
}
void USART1_IRQHandler(void) //串口中断服务函数
{
u8 receive; //表示接收到的数据
if(USART1->SR&(1<<5)) //若SR寄存器RXNE为1,即接收完毕,可以读取RDR数值时
{
receive=USART1->DR; //读RDR并赋给receive,则receive就是当前收到字节的值;由STM32F407硬件设计可知,读完DR后RXNE将自动置0
if(flag==0)
{
if(flag_enter==1)
{
if(receive!=0x0a)
{
flag=0;
flag_enter=0;
char_num=0;
}
else
flag=1;
}
else
{
if(receive==0x0d)
flag_enter=1;
else
{
USART1_RX_BUF[char_num]=receive;
char_num++;
if(char_num>(200-1)) //超出了200个字节
{
flag=0;
flag_enter=0;
char_num=0;
}
}
}
}
}
}
void uart_init(u32 pclk2,u32 bound) //串口初始化
{
float temp;
u16 mantissa;
u16 fraction;
temp=(float)(pclk2*1000000)/(bound*16);
mantissa=temp;
fraction=(temp-mantissa)*16;
mantissa<<=4;
mantissa+=fraction; //计算波特率
RCC->AHB1ENR|=1<<0; //使能PA
RCC->APB2ENR|=1<<4; //开USART1时钟
GPIO_Set(GPIOA,PIN9|PIN10,GPIO_MODE_AF,GPIO_OTYPE_PP,GPIO_SPEED_50M,GPIO_PUPD_PU);
GPIO_AF_Set(GPIOA,9,7);
GPIO_AF_Set(GPIOA,10,7);
USART1->BRR=mantissa; //写入波特率
USART1->CR1&=~(1<<15); //OVER8设为16倍采样
USART1->CR1|=1<<3; //使能发送器
USART1->CR1|=1<<2; //使能接收器
USART1->CR1|=1<<5; //使能接收中断
MY_NVIC_Init(3,3,USART1_IRQn,2);
USART1->CR1|=1<<13; //串口启动
}
int main(void)
{
u8 t;
u16 times;
Stm32_Clock_Init(336,8,2,7);
delay_init(168);
uart_init(84,115200); //波特率115200
LED_Init();
while(1) //主循环
{
if(flag==1) //接收完成
{
for(t=0;t<char_num;t++)
{
USART1->DR=USART1_RX_BUF[t]; //向TDR写入要发送的数据,即receive;由STM32F407硬件设计可知,读SR并写DR,则SR的TC位自动清0
while((USART1->SR&0X40)==0); //若SR的TC位为0,则局部循环等待,保证发送
}
flag=0;
flag_enter=0;
char_num=0;
}
else
{
times++;
if(times%30==0)
LED=!LED;
delay_ms(10);
}
}
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
一周热门 更多>