OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3344|回复: 7

奇怪的串口程序,请看一楼二楼,求解;

[复制链接]

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2017-3-22
在线时间
8 小时
发表于 2017-4-4 22:31:43 | 显示全部楼层 |阅读模式
1金钱
下面的程序执行串口数据传输没有问题;但是当标示的程序被释放以后,串口程序就不能正常工作了,这是为什么的啊?请指教(如果你们编译不成功,将SYSTEM下的usart.c移除项目)

#include "stm32f10x.h"
void tim5_init(u16 cout,u16 pre,u32 bound)
{
        GPIO_InitTypeDef GPIO_Initstrue;                               
//        TIM_TimeBaseInitTypeDef TIM_TimeBaseInitstrue;       
//        TIM_ICInitTypeDef TIM_ICInitstrue;
        USART_InitTypeDef USART_Initstrue;//
        NVIC_InitTypeDef NVIC_Initstrue;
       
//        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5,ENABLE);        //开定时器5时钟
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);//开GPIO,USART1时钟
       
//        GPIO_Initstrue.GPIO_Mode=GPIO_Mode_IPD;                                //PA.0下拉;
//        GPIO_Initstrue.GPIO_Pin=GPIO_Pin_0;
//        GPIO_Initstrue.GPIO_Speed=GPIO_Speed_50MHz;
//        GPIO_Init(GPIOA,&GPIO_Initstrue);
       
        GPIO_Initstrue.GPIO_Mode=GPIO_Mode_AF_PP;                        //PA.9复用输出;
        GPIO_Initstrue.GPIO_Pin=GPIO_Pin_9;
        GPIO_Initstrue.GPIO_Speed=GPIO_Speed_50MHz;//
        GPIO_Init(GPIOA,&GPIO_Initstrue);
       
        GPIO_Initstrue.GPIO_Mode=GPIO_Mode_IN_FLOATING;                //PA.10浮动输入;
        GPIO_Initstrue.GPIO_Pin=GPIO_Pin_10;
        GPIO_Initstrue.GPIO_Speed=GPIO_Speed_50MHz;//
        GPIO_Init(GPIOA,&GPIO_Initstrue);
       
//        TIM_TimeBaseInitstrue.TIM_ClockDivision=TIM_CKD_DIV1;
//        TIM_TimeBaseInitstrue.TIM_Period=cout;
//        TIM_TimeBaseInitstrue.TIM_CounterMode=TIM_CounterMode_Up;
//        TIM_TimeBaseInitstrue.TIM_Prescaler=pre;
//        TIM_TimeBaseInit(TIM5,&TIM_TimeBaseInitstrue);                //定时器5初始化;
//       
//        TIM_ICInitstrue.TIM_Channel=TIM_Channel_1;
//        TIM_ICInitstrue.TIM_ICFilter=0X00;
//        TIM_ICInitstrue.TIM_ICPolarity=TIM_ICPolarity_Rising;
//        TIM_ICInitstrue.TIM_ICPrescaler=TIM_ICPSC_DIV1;
//        TIM_ICInitstrue.TIM_ICSelection=TIM_ICSelection_DirectTI; //捕获输入初始化;
//        TIM_ICInit(TIM5,&TIM_ICInitstrue);
//       
        USART_Initstrue.USART_BaudRate=bound;
        USART_Initstrue.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
        USART_Initstrue.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;
        USART_Initstrue.USART_Parity=USART_Parity_No;
        USART_Initstrue.USART_StopBits=USART_StopBits_1;
        USART_Initstrue.USART_WordLength=USART_WordLength_8b;       //USART1初始化
        USART_Init(USART1,&USART_Initstrue);
       
//        TIM_ITConfig(TIM5,TIM_IT_Update,ENABLE);
        USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);//
       
//        NVIC_Initstrue.NVIC_IRQChannel=TIM5_IRQn;
//        NVIC_Initstrue.NVIC_IRQChannelCmd=ENABLE;
//        NVIC_Initstrue.NVIC_IRQChannelPreemptionPriority=3;                        //中断优先级
//        NVIC_Initstrue.NVIC_IRQChannelSubPriority=0;
//        NVIC_Init(&NVIC_Initstrue);

        NVIC_Initstrue.NVIC_IRQChannel=USART1_IRQn;
        NVIC_Initstrue.NVIC_IRQChannelCmd=ENABLE;
        NVIC_Initstrue.NVIC_IRQChannelPreemptionPriority=2;                        //中断优先级
        NVIC_Initstrue.NVIC_IRQChannelSubPriority=2;
        NVIC_Init(&NVIC_Initstrue);
       
//        TIM_Cmd(TIM5,ENABLE);
        USART_Cmd(USART1,ENABLE);

}

void USART1_IRQHandler(void)                                                                        //串行中断服务程序
{
        u16 res;
        if(USART_GetITStatus(USART1,USART_IT_RXNE))
        {
                res=USART_ReceiveData(USART1);
                USART_SendData(USART1,res);
        }
}

int main()
{       
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
        tim5_init(299,7199,115200);
        while(1);       
}       


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2017-3-22
在线时间
8 小时
 楼主| 发表于 2017-4-4 22:32:59 | 显示全部楼层
就像下面的这个程序就不能正常执行了;
#include "stm32f10x.h"
void tim5_init(u16 cout,u16 pre,u32 bound)
{
        GPIO_InitTypeDef GPIO_Initstrue;                               
        TIM_TimeBaseInitTypeDef TIM_TimeBaseInitstrue;       
        TIM_ICInitTypeDef TIM_ICInitstrue;
        USART_InitTypeDef USART_Initstrue;//
        NVIC_InitTypeDef NVIC_Initstrue;
       
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5,ENABLE);        //开定时器5时钟
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);//开GPIO,USART1时钟
       
        GPIO_Initstrue.GPIO_Mode=GPIO_Mode_IPD;                                //PA.0下拉;
        GPIO_Initstrue.GPIO_Pin=GPIO_Pin_0;
        GPIO_Initstrue.GPIO_Speed=GPIO_Speed_50MHz;
        GPIO_Init(GPIOA,&GPIO_Initstrue);
       
        GPIO_Initstrue.GPIO_Mode=GPIO_Mode_AF_PP;                        //PA.9复用输出;
        GPIO_Initstrue.GPIO_Pin=GPIO_Pin_9;
        GPIO_Initstrue.GPIO_Speed=GPIO_Speed_50MHz;//
        GPIO_Init(GPIOA,&GPIO_Initstrue);
       
        GPIO_Initstrue.GPIO_Mode=GPIO_Mode_IN_FLOATING;                //PA.10浮动输入;
        GPIO_Initstrue.GPIO_Pin=GPIO_Pin_10;
        GPIO_Initstrue.GPIO_Speed=GPIO_Speed_50MHz;//
        GPIO_Init(GPIOA,&GPIO_Initstrue);
       
        TIM_TimeBaseInitstrue.TIM_ClockDivision=TIM_CKD_DIV1;
        TIM_TimeBaseInitstrue.TIM_Period=cout;
        TIM_TimeBaseInitstrue.TIM_CounterMode=TIM_CounterMode_Up;
        TIM_TimeBaseInitstrue.TIM_Prescaler=pre;
        TIM_TimeBaseInit(TIM5,&TIM_TimeBaseInitstrue);                //定时器5初始化;
       
        TIM_ICInitstrue.TIM_Channel=TIM_Channel_1;
        TIM_ICInitstrue.TIM_ICFilter=0X00;
        TIM_ICInitstrue.TIM_ICPolarity=TIM_ICPolarity_Rising;
        TIM_ICInitstrue.TIM_ICPrescaler=TIM_ICPSC_DIV1;
        TIM_ICInitstrue.TIM_ICSelection=TIM_ICSelection_DirectTI; //捕获输入初始化;
        TIM_ICInit(TIM5,&TIM_ICInitstrue);
       
        USART_Initstrue.USART_BaudRate=bound;
        USART_Initstrue.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
        USART_Initstrue.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;
        USART_Initstrue.USART_Parity=USART_Parity_No;
        USART_Initstrue.USART_StopBits=USART_StopBits_1;
        USART_Initstrue.USART_WordLength=USART_WordLength_8b;       //USART1初始化
        USART_Init(USART1,&USART_Initstrue);
       
        TIM_ITConfig(TIM5,TIM_IT_Update,ENABLE);
        USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);//
       
        NVIC_Initstrue.NVIC_IRQChannel=TIM5_IRQn;
        NVIC_Initstrue.NVIC_IRQChannelCmd=ENABLE;
        NVIC_Initstrue.NVIC_IRQChannelPreemptionPriority=3;                        //中断优先级
        NVIC_Initstrue.NVIC_IRQChannelSubPriority=0;
        NVIC_Init(&NVIC_Initstrue);

        NVIC_Initstrue.NVIC_IRQChannel=USART1_IRQn;
        NVIC_Initstrue.NVIC_IRQChannelCmd=ENABLE;
        NVIC_Initstrue.NVIC_IRQChannelPreemptionPriority=2;                        //中断优先级
        NVIC_Initstrue.NVIC_IRQChannelSubPriority=2;
        NVIC_Init(&NVIC_Initstrue);
       
        TIM_Cmd(TIM5,ENABLE);
        USART_Cmd(USART1,ENABLE);

}

void USART1_IRQHandler(void)                                                                        //串行中断服务程序
{
        u16 res;
        if(USART_GetITStatus(USART1,USART_IT_RXNE))
        {
                res=USART_ReceiveData(USART1);
                USART_SendData(USART1,res);
        }
}

int main()
{       
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
        tim5_init(299,7199,115200);
        while(1);       
}       
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2017-3-22
在线时间
8 小时
 楼主| 发表于 2017-4-5 08:07:58 | 显示全部楼层
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
12226
金钱
12226
注册时间
2013-3-8
在线时间
1297 小时
发表于 2017-4-5 10:09:21 | 显示全部楼层
定时器中断优先级比串口中断优先级高,并且是可抢占中断。如果定时器中断里面处理时间长,就会出现这种问题。两种解决办法,一个提升串口中断优先级,一种减少定时器中断处理程序执行时间
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2017-3-22
在线时间
8 小时
 楼主| 发表于 2017-4-5 10:36:26 | 显示全部楼层
augustedward 发表于 2017-4-5 10:09
定时器中断优先级比串口中断优先级高,并且是可抢占中断。如果定时器中断里面处理时间长,就会出现这种问题 ...

把优先级改了也还是不行
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
12226
金钱
12226
注册时间
2013-3-8
在线时间
1297 小时
发表于 2017-4-5 11:35:08 | 显示全部楼层
VU情 发表于 2017-4-5 10:36
把优先级改了也还是不行

把串口的优先级与定时器优先级换一下。你是不是单片机发送不正常啊!
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2017-3-22
在线时间
8 小时
 楼主| 发表于 2017-4-5 13:15:59 | 显示全部楼层
augustedward 发表于 2017-4-5 11:35
把串口的优先级与定时器优先级换一下。你是不是单片机发送不正常啊!

正常的,运行一楼程序没问题,运行二楼程序就不行了
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-4-5 19:09:47 | 显示全部楼层
VU情 发表于 2017-4-5 13:15
正常的,运行一楼程序没问题,运行二楼程序就不行了

仿真,对比寄存器状态,找问题
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-8-22 10:02

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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