OpenEdv-开源电子网

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

看了串口1的视频,想用串口2试一下,发现不行。哪里出错了?

[复制链接]

5

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2018-12-5
在线时间
27 小时
发表于 2018-12-11 23:02:09 | 显示全部楼层 |阅读模式

//usart2.c//

#include "sys.h"
#include "usart2.h"
//////////////////////////////////////////////////////////////////////////////////          
//èç1ûê1óÃucos,Ôò°üà¨ÏÂÃæμÄí·Îļt¼′¿é.
#if SYSTEM_SUPPORT_OS
#include "includes.h"                                        //ucos ê1óà         
#endif

#if 1
#pragma import(__use_no_semihosting)            
//±ê×¼¿aDèòaμÄÖ§3Öoˉêy                 
struct __FILE
{
        int handle;
};

//FILE __stdout;      
////¶¨òå_sys_exit()òÔ±üÃaê1óðëÖ÷»úģ꽠  
//_sys_exit(int x)
//{
//        x = x;
//}
////ÖØ¶¨òåfputcoˉêy
//int fputc2(int ch, FILE *f)
//{        
//        while((USART2->SR&0X40)==0);//Ñ-»··¢Ëí,Ö±μ½·¢Ëííê±Ï   
//        USART2->DR = (u8) ch;      
//        return ch;
//}
#endif

#if EN_USART2_RX   //èç1ûê1Äüá˽óêÕ
         
u8 USART2_RX_BUF[USART2_REC_LEN];     //½óêÕ»o3å,×î′óUSART_REC_LEN¸ö×Ö½ú.

u16 USART2_RX_STA=0;       //½óêÕ×′쬱ê¼Ç       



void uart2_init(u32 bound){
   //GPIO¶Ë¿úéèÖÃ
  GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
        NVIC_InitTypeDef NVIC_InitStructure;
       
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //ê1ÄüGPIOAê±Öó
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//ê1ÄüUSART1ê±Öó

        //′®¿ú1¶Ôó|òy½Å¸′óÃó3éä
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource2,GPIO_AF_USART2); //GPIOA9¸′óÃÎaUSART1
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_USART2); //GPIOA10¸′óÃÎaUSART1
       
        //USART1¶Ë¿úÅäÖÃ
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2 | GPIO_Pin_3; //GPIOA9óëGPIOA10
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//¸′óÃ1|Äü
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        //Ëù¶è50MHz
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //íÆíì¸′óÃêä3ö
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //éÏà-
        GPIO_Init(GPIOA,&GPIO_InitStructure); //3õê¼»ˉPA9£&#172A10

   //USART1 3õê¼»ˉéèÖÃ
        USART_InitStructure.USART_BaudRate = bound;//2¨ìØÂêéèÖÃ
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;//×Ö3¤Îa8λêy¾Y¸ñê½
        USART_InitStructure.USART_StopBits = USART_StopBits_1;//ò»¸öí£Ö1λ
        USART_InitStructure.USART_Parity = USART_Parity_No;//ÎTÆæÅ¼D£Ñéλ
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//ÎTó2¼têy¾Yá÷¿ØÖÆ
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;        //êÕ·¢Ä£ê½
  USART_Init(USART2, &USART_InitStructure); //3õê¼»ˉ′®¿ú1
       
  USART_Cmd(USART2, ENABLE);  //ê1Äü′®¿ú1
       
        USART_ClearFlag(USART2, USART_FLAG_TC);
       
#if EN_USART2_RX       
        USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//¿aÆôÏà1ØÖD¶Ï

        //Usart1 NVIC ÅäÖÃ
  NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;//′®¿ú1ÖD¶Ïí¨μà
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;//ÇàÕ¼óÅÏè¼¶3
        NVIC_InitStructure.NVIC_IRQChannelSubPriority =3;                //×óóÅÏè¼¶3
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQí¨μàê1Äü
        NVIC_Init(&NVIC_InitStructure);        //¸ù¾YÖ¸¶¨μÄ2Îêy3õê¼»ˉVIC¼Ä′æÆ÷¡¢

#endif
       
}


void USART2_IRQHandler(void)                        //′®¿ú1ÖD¶Ï·tÎñ3ìDò
{
        u8 Res;
#if SYSTEM_SUPPORT_OS                 //èç1ûSYSTEM_SUPPORT_OSÎaÕæ£¬ÔòDèòaÖ§3ÖOS.
        OSIntEnter();   
#endif
        if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)  //½óêÕÖD¶Ï(½óêÕμ½μÄêy¾Y±ØDëêÇ0x0d 0x0a½áÎ2)
        {
               
                Res =USART_ReceiveData(USART2);//(USART1->DR);       
               
                if((USART2_RX_STA&0x8000)==0)//½óêÕÎ′íê3é
                {
                        if(USART2_RX_STA&0x4000)//½óêÕμ½áË0x0d
                        {
                                if(Res!=0x0a)USART2_RX_STA=0;//½óêÕ′íÎó,ÖØD¿aê¼
                                else USART2_RX_STA|=0x8000;        //½óêÕíê3éáË
                        }
                        else //»1ûêÕμ½0X0D
                        {       
                                if(Res==0x0d)USART2_RX_STA|=0x4000;
                                else
                                {
                                        USART2_RX_BUF[USART2_RX_STA&0X3FFF]=Res ;
                                        USART2_RX_STA++;
                                        if(USART2_RX_STA>(USART2_REC_LEN-1))USART2_RX_STA=0;          
                                }                 
                        }
                }                    
  }
#if SYSTEM_SUPPORT_OS        
        OSIntExit();                                                                                           
#endif
}
#endif       

//main.c//

#include "sys.h"
#include "delay.h"
#include "usart2.h"
//#include "usart.h"
#include "led.h"
#include "beep.h"
#include "key.h"

int main(void)
{

        u8 t;
        u8 len;       
        u16 times=0;  
        //NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//éèÖÃÏμí3ÖD¶ÏóÅÏè¼¶·Ö×é2
        delay_init(168);                //Ñóê±3õê¼»ˉ
        //uart_init(115200);        //′®¿ú3õê¼»ˉ2¨ìØÂêÎa115200
                uart2_init(115200);        //′®¿ú3õê¼»ˉ2¨ìØÂêÎa115200
        LED_Init();                                  //3õê¼»ˉóëLEDᬽóμÄó2¼t½ó¿ú  
        while(1)
        {
                if(USART2_RX_STA&0x8000)
                {                                          
                        len=USART2_RX_STA&0x3fff;//μÃμ½′Ë′νóêÕμ½μÄêy¾Y3¤¶è
                        printf("\r\nÄú·¢ËíμÄÏûÏ¢Îa:\r\n");
                        for(t=0;t<len;t++)
                        {
                                USART_SendData(USART2, USART2_RX_BUF[t]);         //&#207;ò′&#174;&#191;ú1·¢&#203;íêy&#190;Y
                                while(USART_GetFlagStatus(USART2,USART_FLAG_TC)!=SET);//μè′y·¢&#203;í&#189;áê&#248;
                        }
                        printf("\r\n\r\n");//2&#229;è&#235;&#187;&#187;DD
                        USART2_RX_STA=0;
                }else
                {
                        times++;
                        if(times%5000==0)
                        {
                                printf("\r\nALIENTEK ì&#189;&#203;÷&#213;&#223;STM32F407&#191;a·¢°&#229; ′&#174;&#191;úêμ&#209;é\r\n");
                                printf("&#213;yμ&#227;&#212;-×ó@ALIENTEK\r\n\r\n\r\n");
                        }
                        if(times%200==0)printf("&#199;&#235;ê&#228;è&#235;êy&#190;Y,ò&#212;&#187;&#216;3μ&#188;ü&#189;áê&#248;\r\n");  
                        if(times%30==0)LED0=!LED0;//éá&#203;&#184;LED,ìáê&#190;&#207;μí3&#213;y&#212;ú&#212;&#203;DD.
                        delay_ms(10);   
                }
        }
}










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

使用道具 举报

0

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
181
金钱
181
注册时间
2017-12-13
在线时间
46 小时
发表于 2018-12-12 10:58:55 | 显示全部楼层
#include "uart2.h"

#if SYSTEM_SUPPORT_OS
#include "includes.h"                                        //ucos 使用          
#endif

//////////////////////////////////////////////////////////////////
//加入以下代码,支持printf函数,而不需要选择use MicroLIB          
//#if 1
//#pragma import(__use_no_semihosting)            
////标准库需要的支持函数                 
//struct __FILE
//{
//        int handle;
//};

//FILE __stdout;      
////定义_sys_exit()以避免使用半主机模式   
//void _sys_exit(int x)
//{
//        x = x;
//}
////重定义fputc函数
//int fputc(int ch, FILE *f)
//{        
//        while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
//        USART1->DR = (u8) ch;      
//        return ch;
//}
//#endif

#if EN_USART2_RX   //如果使能了接收
//串口2中断服务程序
//注意,读取USARTx->SR能避免莫名其妙的错误          
u8 USART2_RX_BUF[USART_REC_LEN];     //接收缓冲,最大USART_REC_LEN个字节.
//接收状态
//bit15,        接收完成标志
//bit14,        接收到0x0d
//bit13~0,        接收到的有效字节数目
u16 USART2_RX_STA=0;       //接收状态标记       

//初始化IO 串口2
//bound:波特率
void uart2_init(u32 bound){
   //GPIO端口设置
  GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
        NVIC_InitTypeDef NVIC_InitStructure;
       
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //使能GPIOA时钟
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//使能USART2时钟

        //串口2对应引脚复用映射
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource2,GPIO_AF_USART2); //GPIOA2复用为USART2
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_USART2); //GPIOA3复用为USART2
       
        //USART2端口配置
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2 | GPIO_Pin_3; //GPIOA2与GPIOA3
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用功能
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        //速度50MHz
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //推挽复用输出
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //上拉
        GPIO_Init(GPIOA,&GPIO_InitStructure); //初始化PA2,PA3

   //USART2 初始化设置
        USART_InitStructure.USART_BaudRate = bound;//波特率设置
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
        USART_InitStructure.USART_StopBits = USART_StopBits_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;        //收发模式
  USART_Init(USART2, &USART_InitStructure); //初始化串口2
       
  USART_Cmd(USART2, ENABLE);  //使能串口2
       
        //USART_ClearFlag(USART1, USART_FLAG_TC);
       
#if EN_USART2_RX       
        USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//开启相关中断

        //Usart2 NVIC 配置
  NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;//串口2中断通道
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;//抢占优先级3
        NVIC_InitStructure.NVIC_IRQChannelSubPriority =2;                //子优先级2
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQ通道使能
        NVIC_Init(&NVIC_InitStructure);        //根据指定的参数初始化VIC寄存器、

#endif
       
}

extern u8 flag;
u16 Re_buf[11];
void USART2_IRQHandler(void)                        //串口2中断服务程序
{
#if SYSTEM_SUPPORT_OS                 //如果SYSTEM_SUPPORT_OS为真,则需要支持OS.
        OSIntEnter();   
#endif
        if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)  //接收中断
        {
                Re_buf[USART2_RX_STA] = USART_ReceiveData(USART2);//(USART2->DR);        //读取接收到的数据
               
                if((USART2_RX_STA == 0) && (Re_buf[USART2_RX_STA] != 0x55))
                        return;
                USART2_RX_STA++;        //接收数据增加1
                if(USART2_RX_STA >10)
                {
                        USART2_RX_STA = 0;
                        flag = 1;
                }
//                if((USART2_RX_STA&0x8000)==0)//接收未完成
//                {
//                        if(USART2_RX_STA&0x4000)//接收到了0x0d
//                        {
//                                if(Res!=0x0a)USART2_RX_STA=0;//接收错误,重新开始
//                                else USART2_RX_STA|=0x8000;        //接收完成了
//                        }
//                        else //还没收到0X0D
//                        {       
//                                if(Res==0x0d)USART2_RX_STA|=0x4000;
//                                else
//                                {
//                                        USART2_RX_BUF[USART2_RX_STA&0X3FFF]=Res ;
//                                        USART2_RX_STA++;
//                                        if(USART_RX_STA>(USART_REC_LEN-1))USART2_RX_STA=0;//接收数据错误,重新开始接收          
//                                }                 
//                        }
//                }                    
        }
#if SYSTEM_SUPPORT_OS         //如果SYSTEM_SUPPORT_OS为真,则需要支持OS.
        OSIntExit();                                                                                           
#endif
}
#endif

板子是正点原子的F4探索者,我这个串口2是用来接收传感器数据的,中断那边你自己根据你的需求改一下,头文件和uart1.h是差不多的

回复 支持 1 反对 0

使用道具 举报

109

主题

5564

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10571
金钱
10571
注册时间
2017-2-18
在线时间
1914 小时
发表于 2018-12-12 00:51:37 | 显示全部楼层
这乱码看的难受,你用的是啥板子?我看我这有程序可以给你参考不
回复 支持 反对

使用道具 举报

5

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2018-12-5
在线时间
27 小时
 楼主| 发表于 2018-12-12 10:10:35 | 显示全部楼层
peng1554 发表于 2018-12-12 00:51
这乱码看的难受,你用的是啥板子?我看我这有程序可以给你参考不

stm32f4探索者  谢谢
回复 支持 反对

使用道具 举报

5

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2018-12-5
在线时间
27 小时
 楼主| 发表于 2018-12-12 11:51:11 | 显示全部楼层
本帖最后由 lyl251495 于 2018-12-12 11:53 编辑
171 发表于 2018-12-12 10:58
#include "uart2.h"

#if SYSTEM_SUPPORT_OS

串口2的中断进不去,能帮是我看看哪里错了吗
#include "stm32f4xx.h"
#include "usart.h"
#include "delay.h"
void My_USART2_Init(void)
{
          GPIO_InitTypeDef  GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
        NVIC_InitTypeDef NVIC_InitStructure;
        
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//&Ecirc;&sup1;&Auml;&Uuml;USART1&Ecirc;±&Ouml;&Oacute;
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);
        
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource2,GPIO_AF_USART2);
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_USART2);

          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
        
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
        
        USART_InitStructure.USART_BaudRate=115200;
        USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
        USART_InitStructure.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;
        USART_InitStructure.USART_Parity=USART_Parity_No;
        USART_InitStructure.USART_StopBits=USART_StopBits_1;
        USART_InitStructure.USART_WordLength=USART_WordLength_8b;
        
        USART_Init(USART2,&USART_InitStructure);
        USART_Cmd(USART2,ENABLE);
  
        USART_ITConfig(USART2,USART_IT_RXNE,ENABLE);
        
        NVIC_InitStructure.NVIC_IRQChannel=USART2_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=1;
        NVIC_InitStructure.NVIC_IRQChannelSubPriority=1;
        NVIC_Init(&NVIC_InitStructure);
        
        
}

void USART2_IRQHandler(void)
{
        u8 res;
        if(USART_GetITStatus(USART2,USART_IT_RXNE)){
               
                res=USART_ReceiveData(USART2);
                USART_SendData(USART2,res);
        }

}
int main(void)
{
   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
        My_USART2_Init();
        while(1);
}
回复 支持 反对

使用道具 举报

0

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
181
金钱
181
注册时间
2017-12-13
在线时间
46 小时
发表于 2018-12-13 09:30:20 | 显示全部楼层
lyl251495 发表于 2018-12-12 11:51
串口2的中断进不去,能帮是我看看哪里错了吗
#include "stm32f4xx.h"
#include "usart.h"

你看看你串口跳线帽那边是不是接对了(PA2,PA3要接com2而不是485)
程序没看出啥问题,要结合你板子实验看的(我也是新手,估计有问题也没看出来,哈哈哈哈)
回复 支持 反对

使用道具 举报

5

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2018-12-5
在线时间
27 小时
 楼主| 发表于 2018-12-13 11:34:17 | 显示全部楼层
171 发表于 2018-12-13 09:30
你看看你串口跳线帽那边是不是接对了(PA2,PA3要接com2而不是485)
程序没看出啥问题,要结合你板子实 ...

接对了啊
回复 支持 反对

使用道具 举报

21

主题

151

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
423
金钱
423
注册时间
2017-4-1
在线时间
73 小时
发表于 2018-12-16 00:43:26 | 显示全部楼层
我瞎说一句,不知引脚映射对不对,因为有些端口不止一个。
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 04:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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