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

2019-08-22 16:36发布

下面的程序执行串口数据传输没有问题;但是当标示的程序被释放以后,串口程序就不能正常工作了,这是为什么的啊?请指教(如果你们编译不成功,将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);       
}       


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
7条回答
VU情
1楼-- · 2019-08-22 17:05
就像下面的这个程序就不能正常执行了;
#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);       
}       
VU情
2楼-- · 2019-08-22 18:09
 精彩回答 2  元偷偷看……
augustedward
3楼-- · 2019-08-22 23:43
定时器中断优先级比串口中断优先级高,并且是可抢占中断。如果定时器中断里面处理时间长,就会出现这种问题。两种解决办法,一个提升串口中断优先级,一种减少定时器中断处理程序执行时间
VU情
4楼-- · 2019-08-23 04:19
augustedward 发表于 2017-4-5 10:09
定时器中断优先级比串口中断优先级高,并且是可抢占中断。如果定时器中断里面处理时间长,就会出现这种问题 ...

把优先级改了也还是不行
augustedward
5楼-- · 2019-08-23 06:52
VU情 发表于 2017-4-5 10:36
把优先级改了也还是不行

把串口的优先级与定时器优先级换一下。你是不是单片机发送不正常啊!
VU情
6楼-- · 2019-08-23 12:13
augustedward 发表于 2017-4-5 11:35
把串口的优先级与定时器优先级换一下。你是不是单片机发送不正常啊!

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

一周热门 更多>