OpenEdv-开源电子网

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

STM32F030串口通信问题快把我逼疯了,忘大神赐教

[复制链接]

26

主题

60

帖子

0

精华

初级会员

Rank: 2

积分
149
金钱
149
注册时间
2018-9-19
在线时间
25 小时
发表于 2019-5-7 17:27:05 | 显示全部楼层 |阅读模式
1金钱
主程序
/******************** (C) COPYRIGHT 2012 Çà·çμç×ó ********************
* ÎļtÃû  £omain
* Ãèêö    £o         
* êμÑ鯽쨣oÇà·çstm32f051¿a·¢°å
* Ãèêö    £o°′¼üÖD¶Ï
* ×÷Õß    £oÇà·ç
* μêÆì    £oqfv5.taobao.com
**********************************************************************/
#include "stm32f0xx.h"
#include  "led.h"
#include  "exit.h"
#include  "uart.h"
unsigned int keyflag=0;
unsigned int downswitchflag=0;
unsigned int upwaterflag=0;
unsigned int RXD_OK_flag=0;
unsigned int AnswerData[7];
int main(void)
{
        SystemInit();
        LED_Init();
  LED_Init1();
        USART_Configuration();
        AnswerData[1]=0XED;                        //**μ±Ç°½úμãoÅ****//
  AnswerData[2]=0X27;             //**é趨½Ç¶èÖμ****//
  AnswerData[3]=0X10;             //**é趨½Ç¶èÖμ****//
        AnswerData[4]=0XEA;             //**é趨½Ç¶èÖμ****//
        //EXIT_KEY_Init();

        while(1)
        {
                if(RXD_OK_flag==1)
                {
                         USART_SendData(USART1,AnswerData[1]);
                         USART_SendData(USART1,AnswerData[2]);
                         USART_SendData(USART1,AnswerData[3]);
                         USART_SendData(USART1,AnswerData[4]);
                         RXD_OK_flag=0;
                         GPIO_ResetBits(GPIOA, GPIO_Pin_3);
                         GPIO_SetBits(GPIOA, GPIO_Pin_4);
                }
        }
}
串口配置程序
#include "uart.h"
#include <stdio.h>
//&#189;óê&#213;×′ì&#172;
//bit15£&#172;        &#189;óê&#213;íê3é±ê&#214;&#190;
//bit14£&#172;        &#189;óê&#213;μ&#189;0x0d
//bit13~0£&#172;        &#189;óê&#213;μ&#189;μ&#196;óDD§×&#214;&#189;úêy&#196;&#191;

unsigned int i0=1;
unsigned int tmp;
unsigned int CommandFromPc[7];
unsigned int ADD;
extern unsigned int RXD_OK_flag;
extern unsigned int AnswerData[7];
void USART_Configuration(void)//′&#174;&#191;ú3&#245;ê&#188;&#187;ˉoˉêy
{  

        GPIO_InitTypeDef  GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
                    NVIC_InitTypeDef    NVIC_InitStructure;

        RCC_AHBPeriphClockCmd( RCC_AHBPeriph_GPIOA, ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE );

        GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_1);
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_1);        
        /*
        *  USART1_TX -> PA9 , USART1_RX ->        PA10
        */                                
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10;                 
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);        

        USART_InitStructure.USART_BaudRate = 9600;//éè&#214;&#195;′&#174;&#191;ú2¨ì&#216;&#194;ê
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;//éè&#214;&#195;êy&#190;Y&#206;&#187;
        USART_InitStructure.USART_StopBits = USART_StopBits_1;//éè&#214;&#195;í£&#214;1&#206;&#187;
        USART_InitStructure.USART_Parity = USART_Parity_No;//éè&#214;&#195;D§&#209;é&#206;&#187;
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//éè&#214;&#195;á÷&#191;&#216;&#214;&#198;
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//éè&#214;&#195;1¤×÷&#196;£ê&#189;
        USART_Init(USART1, &USART_InitStructure); //&#197;&#228;&#214;&#195;è&#235;&#189;á11ì&#229;

                                USART_ClearFlag(USART1,USART_FLAG_TC);
        USART_ITConfig(USART1,USART_IT_TC,ENABLE);
        USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);
        USART_Cmd(USART1,ENABLE);      
                               
                                NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPriority = 1;
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
        NVIC_Init(&NVIC_InitStructure);     
}                       
void USART1_IRQHandler(void)                       
{
       
  //unsigned int m;
        if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  
        {
                USART_ClearITPendingBit(USART1,USART_IT_RXNE);
                tmp=USART_ReceiveData(USART1);
                //USART_SendData(USART1,tmp);
                if(tmp==0xED)
                {
                     RXD_OK_flag=1;
     }
         }

}


原代码在附件中,目前的现象是如果在接收中断里做应答,自发自收,用串口调试器是可以实现的;但是像现在这样,在串口接收中断里做一个标志位,将标志位传递给主函数,主函数查询到标志位再应答就是不行。我也不知道为什么?好奇怪,请高手能不能帮忙看看,代码不长,就十几行,死活找不到原因,初步分析是接收中断的参数变化没有传递到主函数去。

20190507带休眠.rar

2.2 MB, 下载次数: 244

最佳答案

查看完整内容[请看2#楼]

在串口配置函数中把 USART_ITConfig(USART1,USART_IT_TC,ENABLE); 这句去了,不开发送中断。主函数中在每个发送 USART_SendData函数后加条 while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);就OK了,发送函数没必要开中断的。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

79

帖子

0

精华

高级会员

Rank: 4

积分
727
金钱
727
注册时间
2016-5-27
在线时间
91 小时
发表于 2019-5-7 17:27:06 | 显示全部楼层
在串口配置函数中把 USART_ITConfig(USART1,USART_IT_TC,ENABLE); 这句去了,不开发送中断。主函数中在每个发送 USART_SendData函数后加条 while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);就OK了,发送函数没必要开中断的。
回复

使用道具 举报

0

主题

6

帖子

0

精华

新手入门

积分
3
金钱
3
注册时间
2019-5-7
在线时间
1 小时
发表于 2019-5-7 19:11:13 | 显示全部楼层
写得不错,加油!
回复

使用道具 举报

26

主题

60

帖子

0

精华

初级会员

Rank: 2

积分
149
金钱
149
注册时间
2018-9-19
在线时间
25 小时
 楼主| 发表于 2019-5-7 20:37:30 | 显示全部楼层
真心谢谢大神指点,小弟在此跪谢了!
今天下午郁闷了一下午,好歹也是玩过F103了,没想到被F030给半了!
还是您们厉害,一眼就看出问题所在,小弟在此感激不尽!!!
回复

使用道具 举报

2

主题

7

帖子

0

精华

新手上路

积分
20
金钱
20
注册时间
2019-8-15
在线时间
3 小时
发表于 2019-9-19 18:47:42 | 显示全部楼层
666666666666666666666
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-29 00:33

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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