OpenEdv-开源电子网

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

STM32VET6,为什么UART4与UART5只发数据,无法发出???

[复制链接]

19

主题

86

帖子

0

精华

初级会员

Rank: 2

积分
182
金钱
182
注册时间
2012-11-8
在线时间
0 小时
发表于 2013-5-22 09:04:39 | 显示全部楼层 |阅读模式
启动文件已经选择大容量hd的,大神们遇到过吗???、
用我三生烟火,换你一世迷离
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

25

主题

683

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1351
金钱
1351
注册时间
2012-4-25
在线时间
195 小时
发表于 2013-5-22 09:09:30 | 显示全部楼层
时钟,中断向量,中断使能
1-1
回复 支持 反对

使用道具 举报

19

主题

86

帖子

0

精华

初级会员

Rank: 2

积分
182
金钱
182
注册时间
2012-11-8
在线时间
0 小时
 楼主| 发表于 2013-5-22 09:10:22 | 显示全部楼层
USART1、USART2、USART3只发数据都是可以在看到的,4、5就不行了
用我三生烟火,换你一世迷离
回复 支持 反对

使用道具 举报

19

主题

86

帖子

0

精华

初级会员

Rank: 2

积分
182
金钱
182
注册时间
2012-11-8
在线时间
0 小时
 楼主| 发表于 2013-5-22 09:12:11 | 显示全部楼层
回复【2楼】mygod:
---------------------------------
我就是发一组数据,不用它的接收,很奇怪,USART1、2、3都是可以的,4、5不行,
用我三生烟火,换你一世迷离
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-5-22 10:10:33 | 显示全部楼层
是不是IO口接了别的什么东西?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

19

主题

86

帖子

0

精华

初级会员

Rank: 2

积分
182
金钱
182
注册时间
2012-11-8
在线时间
0 小时
 楼主| 发表于 2013-5-22 10:17:25 | 显示全部楼层
回复【5楼】正点原子:
---------------------------------
没有呢,就是单纯的发数据,其他的啥也没有接 也没有相应的程序
用我三生烟火,换你一世迷离
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-5-22 10:25:02 | 显示全部楼层
那应该是你串口配置问题了
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

15

主题

45

帖子

0

精华

初级会员

Rank: 2

积分
134
金钱
134
注册时间
2015-7-10
在线时间
14 小时
发表于 2016-4-23 19:08:07 | 显示全部楼层
请问楼主怎么解决的,,我也遇到同样的问题,UART4 UART5 不能发送 谢谢!
回复 支持 反对

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8024
金钱
8024
注册时间
2014-8-13
在线时间
1595 小时
发表于 2016-4-23 19:16:13 | 显示全部楼层
串口1、2、3、6是同步串口,4、5是异步串口,1、2、3、6标识是USART,4、5是UART,我也遇到过4、5通讯故障问题,我猜想就是因为同步异步的设置不一样。
不过我当时片外资源不怎么紧张,改个接口了事。


楼主如果资源紧张的话,从同步异步差异分析入手,看下怎么解决吧。帮顶
回复 支持 反对

使用道具 举报

15

主题

45

帖子

0

精华

初级会员

Rank: 2

积分
134
金钱
134
注册时间
2015-7-10
在线时间
14 小时
发表于 2016-4-23 19:20:31 | 显示全部楼层
mack13013 发表于 2016-4-23 19:16
串口1、2、3、6是同步串口,4、5是异步串口,1、2、3、6标识是USART,4、5是UART,我也遇到过4、5通讯故障 ...

查问题方法么,我都查了两天了,没解决
回复 支持 反对

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8024
金钱
8024
注册时间
2014-8-13
在线时间
1595 小时
发表于 2016-4-23 19:38:31 | 显示全部楼层
ZRAINZ 发表于 2016-4-23 19:20
查问题方法么,我都查了两天了,没解决

不知道你用的寄存器还是库函数。
网上说库函数的话,cube给出了两种不同的初始化方法,
区别就在两个不同的初始化结构体UART_HandleTypeDef和USART_HandleTypeDef

还有人给出5个串口均能工作的代码。
我自己没实验,LZ自己尝试下吧
[mw_shl_code=c,true]
#include "stm32f10x_lib.h"
#include <stdio.h>


#define uchar unsigned char
#define uint unsigned int
#define ulong unsigned long


uint TimingDelay;


#define YES  1
#define NO   0


#define  COM1_TX_EN  GPIO_ResetBits(GPIOC,GPIO_Pin_1) // GPIOC->BSRR=0xfd  //&=0xfd  //USART1 发送使能
#define  COM1_RX_EN  GPIO_SetBits(GPIOC,GPIO_Pin_1) // GPIOC->BSRR=0x02  //|=0x02  //USART1 禁止发送


#define  COM2_TX_EN  GPIO_ResetBits(GPIOC,GPIO_Pin_2) // GPIOC->BSRR=0xfd  //&=0xfd  //USART2 发送使能
#define  COM2_RX_EN  GPIO_SetBits(GPIOC,GPIO_Pin_2)


#define  COM3_TX_EN  GPIO_ResetBits(GPIOC,GPIO_Pin_3) // GPIOC->BSRR=0xfd  //&=0xfd  //USART3 发送使能
#define  COM3_RX_EN  GPIO_SetBits(GPIOC,GPIO_Pin_3) // GPIOC->BSRR=0x02  //|=0x02  //USART3 禁止发送


#define  COM4_TX_EN  GPIO_ResetBits(GPIOC,GPIO_Pin_4) // GPIOC->BSRR=0xfd  //&=0xfd  //UART4 发送使能
#define  COM4_RX_EN  GPIO_SetBits(GPIOC,GPIO_Pin_4) // GPIOC->BSRR=0x02  //|=0x02  //UART4 禁止发送

uchar ComSynFlag;          //=YES同步建立,UART0内部私有
uchar ComReceiveCounter;   //接收字节计数,UART0内部私有
uchar ComReceiveData[24];  //接收缓冲,UART0内部私有

GPIO_InitTypeDef GPIO_InitStructure;
ErrorStatus HSEStartUpStatus;
TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
TIM_OCInitTypeDef  TIM_OCInitStructure;


u16 Status; //定时器累加


void RCC_Configuration(void);
void GPIO_Configuration(void);
void NVIC_Configuration(void);
void TIM2_Configuration(void);
void UART5_Configuration(void);
void SysTick_Configuration(void)  ;
void Com3TxChar(vu8);

vu16 CCR1_Val = 0x0E10;  //360  50Hz   20ms
vu16 CCR2_Val = 0x0048;  //7200 10hz     100ms   
vu16 CCR3_Val = 0x7530;  //30000 10Hz
vu16 CCR4_Val = 0x1000;

u16 capture1 = 0;
u16 capture2 = 0;
u16 capture3 = 0;
u16 capture4 = 0;


int cnt1,cnt2,nt2=50;




#define C1_LEN    300      //缓冲区长度
uint  Com1RecCnt;          //COM1接收字节计数
uchar Com1RecDat[C1_LEN];  //COM1接收缓冲
uchar Com1AnsDat[24];
uint  Com1AnsCnt;


uint  Com2RecCnt;          //COM2接收字节计数
uchar Com2RecDat[C1_LEN];  //COM2接收缓冲
uchar Com2AnsDat[24];
uint  Com2AnsCnt;


uint  Com3RecCnt;          //COM3接收字节计数
uchar Com3RecDat[C1_LEN];  //COM3接收缓冲
uchar Com3AnsDat[24];
uint  Com3AnsCnt;


uint  Com4RecCnt;          //COM4接收字节计数
uchar Com4RecDat[C1_LEN];  //COM4接收缓冲
uchar Com4AnsDat[24];
uint  Com4AnsCnt;




uint  Time20msCnt;   //20ms定时器
uint  T20msCnt;      //20ms定时器
uint  T1sCnt;        //1s定时器




uchar RunCnt;     //RUN LED闪光频率参数


void RCC_Configuration()
{
ErrorStatus HSEStartUpStatus; //定义外部高速晶振启动状态枚举变量
RCC_DeInit(); //复位RCC外部寄存器到默认值
RCC_HSEConfig(RCC_HSE_ON); //打开外部高速晶振
HSEStartUpStatus=RCC_WaitForHSEStartUp(); //等待外部高速时钟准备好


if(HSEStartUpStatus==SUCCESS){ //外部高速时钟已经准备好


FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //开启FLASH预读缓冲功能,加速FLASH的读取。所有程序中必须的用法,位置:RCC初始化子函数里面,时钟起振之后
FLASH_SetLatency(FLASH_Latency_2); //FLASH时序延迟几个周期,等待总线同步操作。推荐按照单片机系统运行频率,0—24MHz时,取Latency=0;24—48MHz时,取Latency=1;48~72MHz时,取Latency=2。


RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置AHB(HCLK)==系统时钟/1
RCC_PCLK2Config(RCC_HCLK_Div1); //配置APB2(高速)(PCLK2)==系统时钟/1
RCC_PCLK1Config(RCC_HCLK_Div2); //配置APB1(低速)(PCLK1)==系统时钟/2
//注:AHB主要负责外部存储器时钟。APB2负责AD,I/O,高级TIM,串口1。APB1负责DA,USB,SPI,I2C,CAN,串口2345,普通TIM。




RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9); //配置PLL时钟==(外部高速晶体时钟/1)* 9 ==72MHz
RCC_PLLCmd(ENABLE); //使能PLL时钟
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET); //等待PLL时钟就绪
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //配置系统时钟==PLL时钟
while(RCC_GetSYSCLKSource()!=0x08); //等待系统时钟源的启动
}


//------------------------以下为开启外设时钟的操作-----------------------//
// RCC_AHBPeriphClockCmd (ABP2设备1 | ABP2设备2 , ENABLE); //启动AHB设备
// RCC_APB2PeriphClockCmd(ABP2设备1 | ABP2设备2 , ENABLE); //启动ABP2设备
// RCC_APB1PeriphClockCmd(ABP2设备1 | ABP2设备2 , ENABLE); //启动ABP1设备


// RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO | RCC_APB2Periph_USART1 , ENABLE); //打开APB2外设


RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO | RCC_APB2Periph_GPIOB
      |RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_UART5 |RCC_APB1Periph_UART4 |RCC_APB1Periph_USART2 |RCC_APB1Periph_USART3 | RCC_APB1Periph_TIM2,ENABLE);




}


void SysTick_Configuration(void)         //延时函数初始化
{
/* Select AHB clock(HCLK) as SysTick clock source */
  SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK);


  /* Set SysTick Priority to 3 */
  NVIC_SystemHandlerPriorityConfig(SystemHandler_SysTick, 3, 0);

  /* SysTick interrupt each 1ms with HCLK equal to 72MHz */
  SysTick_SetReload(72000);


  /* Enable the SysTick Interrupt */
  SysTick_ITConfig(ENABLE);
}






void delay(u32 nTime)
{
  /* Enable the SysTick Counter */
  SysTick_CounterCmd(SysTick_Counter_Enable);

  TimingDelay = nTime;

  while(TimingDelay != 0);

  /* Disable the SysTick Counter */
  SysTick_CounterCmd(SysTick_Counter_Disable);
  /* Clear the SysTick Counter */
  SysTick_CounterCmd(SysTick_Counter_Clear);
}


void TimingDelay_Decrement(void)
{
  if (TimingDelay != 0x00)
  {
    TimingDelay--;
  }
}


void Delay(vu32 nCount)
{
  for(; nCount != 0; nCount--);
}




void NVIC_Configuration(void )
{
NVIC_InitTypeDef NVIC_InitStructure; //定义一个中断结构体


// NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0); //设置中断向量表的起始地址为0x08000000
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0); //设置NVIC优先级分组


NVIC_InitStructure.NVIC_IRQChannel = UART5_IRQChannel; //通道设置为串口5中断
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //中断响应优先级0
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //打开中断
NVIC_Init(&NVIC_InitStructure); //初始化






//定时器2中断


NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);




/* Enable the USART1 Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);


/* Enable the USART2 Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);


/* Enable the USART3 Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);


/* Enable the UART4 Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = UART4_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);


}


void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure; //定义GPIO初始化结构体



//--------将UART5 的TX 配置为复用推挽输出 AF_PP---------------------//
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_12; //管脚位置定义,标号可以是NONE、ALL、0至15。
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz; //输出速度50MHz
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP; //推挽输出模式 Out_PP
GPIO_Init(GPIOC,&GPIO_InitStructure); //E组GPIO初始化


//--------将USART1,USART2 的TX 配置为复用推挽输出 AF_PP---------------------//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 |GPIO_Pin_2 | GPIO_Pin_0 | GPIO_Pin_6;
GPIO_Init(GPIOA, &GPIO_InitStructure);


//--------将USART3 的TX 配置为复用推挽输出 AF_PP---------------------//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_Init(GPIOB, &GPIO_InitStructure);


//--------将UART4 的TX 配置为复用推挽输出 AF_PP---------------------//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_Init(GPIOC, &GPIO_InitStructure);


//--------将UART5 的RX 配置为复用浮空输入 IN_FLOATING---------------------//
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2; //管脚位置定义
//输入模式下配置输出速度无意义
//GPIO_InitStructure.GPIO_Speed=GPIO_Speed_2MHz; //输出速度2MHz
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; //浮空输入 IN_FLOATING
GPIO_Init(GPIOD,&GPIO_InitStructure); //C组GPIO初始化


//--------将USART1 USART2 的RX 配置为复用浮空输入 IN_FLOATING---------------------//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10 |GPIO_Pin_3;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; //浮空输入 IN_FLOATING
GPIO_Init(GPIOA, &GPIO_InitStructure);


//--------将USART3 的RX 配置为复用浮空输入 IN_FLOATING---------------------//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; //浮空输入 IN_FLOATING
GPIO_Init(GPIOB, &GPIO_InitStructure);


//--------将UART4 的RX 配置为复用浮空输入 IN_FLOATING---------------------//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; //浮空输入 IN_FLOATING
GPIO_Init(GPIOC, &GPIO_InitStructure);




}




void TIM2_Configuration(void)
{
  TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;//定时器初始化结构
//TIM_ICInitTypeDef TIM_ICInitStructure;         //通道输入初始化结构
/* ---------------------------------------------------------------
TIM2 Configuration: Output Compare Toggle Mode:
    TIM2CLK = 36 MHz, Prescaler = 0x1f3(499), TIM2 counter clock = 0.072 MHz    clock =TIM2CLK/(Prescaler+1)
    CC1 update rate = TIM2 counter clock / CCR1_Val = 200 Hz  720  100Hz
    CC2 update rate = TIM2 counter clock / CCR2_Val = 1000 Hz  7200  10hz
    CC3 update rate = TIM2 counter clock / CCR3_Val = 100 Hz   30000   
    CC4 update rate = TIM2 counter clock / CCR4_Val = ?? Hz
//TIM_Period(TIM1_ARR)=X,计数器向上计数到X后产生更新事件,计数值归零
//向上计数模式
//TIM_RepetitionCounter(TIM1_RCR)=0,每次向上溢出都产生更新事件
--------------------------------------------------------------- */
   /* Time base configuration */
   RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
  TIM_TimeBaseStructure.TIM_Period = 0xffff;         
  TIM_TimeBaseStructure.TIM_Prescaler = 499;          //时钟分频
TIM_TimeBaseStructure.TIM_ClockDivision = 0x0;     //时钟分割
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  
  TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);   //基本初始化




/* Output Compare Toggle Mode configuration: Channel1 */
  TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_Toggle;
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  TIM_OCInitStructure.TIM_Pulse = CCR1_Val;
  TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  TIM_OC1Init(TIM2, &TIM_OCInitStructure);
  TIM_OC1PreloadConfig(TIM2, TIM_OCPreload_Disable);

  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  TIM_OCInitStructure.TIM_Pulse = CCR2_Val;
  TIM_OC2Init(TIM2, &TIM_OCInitStructure);
  TIM_OC2PreloadConfig(TIM2, TIM_OCPreload_Disable);
/*
    TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
    TIM_OCInitStructure.TIM_Pulse = CCR3_Val;
    TIM_OC3Init(TIM2, &TIM_OCInitStructure);
TIM_OC3PreloadConfig(TIM2, TIM_OCPreload_Disable); */
  //TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  //TIM_OCInitStructure.TIM_Pulse = 255;
  //TIM_OC4Init(TIM2, &TIM_OCInitStructure);

  /* TIM enable counter */
  TIM_Cmd(TIM2, ENABLE);


  TIM_ClearFlag(TIM2, TIM_FLAG_Update);                 /*清除更新标志位*/
TIM_ClearITPendingBit(TIM2, TIM_FLAG_Update);        //清除TIM2等待中断更新中断标志位


/* TIM IT enable */
  TIM_ITConfig(TIM2, TIM_IT_CC1 |TIM_IT_CC2 , ENABLE);
}



  /**************************************************
  COM5发送一个字节
**************************************************/
void Com5TxChar( vu8 i )
  {
    USART_SendData(UART5,i); //回发给PC  
  while(USART_GetFlagStatus(UART5, USART_FLAG_TXE)==RESET);

  }

  /*******************************************
  COM5发送字符串
*******************************************/
void Com5TxStr( vu8 *pt, vu8 length )
  {   
   vu8 i;
  for( i=0;i<length;i++ ){
   Com5TxChar(*pt++);
   }
  // delay(10);   
  }

  /**************************************************
  COM1发送一个字节
**************************************************/
void Com1TxChar( vu8 i )
  {
    USART_SendData(USART1,(u8) i); //回发给PC  
  while(USART_GetFlagStatus(USART1, USART_FLAG_TXE)==RESET)
   {
   }
  //  return i;

  }
  
  void Com1TxStr( vu8 *pt, vu8 length )
  {   
    vu8 i;
   for(i=0;i<length;i++ ){
   Com1TxChar(*pt++);
   }
  //   delay(10);  
  }
  
  void Com2TxChar( vu8 i )
  {
    USART_SendData(USART2,(u8) i); //回发给PC  
  while(USART_GetFlagStatus(USART2, USART_FLAG_TXE)==RESET)
   {
   }
  //  return i;

  }
  
  void Com2TxStr( vu8 *pt, vu8 length )
  {   
    vu8 i;
   for(i=0;i<length;i++ ){
   Com2TxChar(*pt++);
   }
  //   delay(10);  
  }
  void Com3TxChar( vu8 i )
  {
    USART_SendData(USART3,(u8) i); //回发给PC  
  while(USART_GetFlagStatus(USART3, USART_FLAG_TXE)==RESET)
   {
   }
  //  return i;

  }
  
  void Com3TxStr( vu8 *pt, vu8 length )
  {   
    vu8 i;
   for(i=0;i<length;i++ ){
   Com3TxChar(*pt++);
   }
  //   delay(10);  
  }
  
  void Com4TxChar( vu8 i )
  {
    USART_SendData(UART4,(u8) i); //回发给PC   
  while(USART_GetFlagStatus(UART4, USART_FLAG_TXE)==RESET)
   {
   }
  //  return i;

  }
  
  void Com4TxStr( vu8 *pt, vu8 length )
  {   
    vu8 i;
   for(i=0;i<length;i++ ){
   Com4TxChar(*pt++);
   }
  //   delay(10);  
  }


               
  void TIM2_IRQHandler(void)
{
      vu8 i;
   /* 50Hz -- 20ms */
    if (TIM_GetITStatus(TIM2, TIM_IT_CC1) != RESET)
     {
      TIM_ClearITPendingBit(TIM2, TIM_IT_CC1);
  cnt1++;
  cnt2++;
  if(cnt1>=500)
  {
//   polling=1;
   cnt1=0;
  }
  if(cnt2>=nt2) //RUNLED,WDI
    {
   GPIO_WriteBit(GPIOA, GPIO_Pin_0, (BitAction)(1 - GPIO_ReadOutputDataBit(GPIOA, GPIO_Pin_0)));

   if(Alert_flag==1)
    {
    GPIO_WriteBit(GPIOA, GPIO_Pin_6, (BitAction)(1 - GPIO_ReadOutputDataBit(GPIOA, GPIO_Pin_6)));

    }

   cnt2=0;   
    }


  Time20msCnt++;  // 秒级 硬件延时
if( Time20msCnt>=50 && T1sCnt ){
   Time20msCnt=0;
   T1sCnt--;
  }

  if(T20msCnt){  //20ms单位延时
T20msCnt--;
  }



capture1 = TIM_GetCapture1(TIM2);
  TIM_SetCompare1(TIM2, capture1 + CCR1_Val );
     }



         /*50Hz--20ms */
   if (TIM_GetITStatus(TIM2, TIM_IT_CC2) != RESET)     
     {
      TIM_ClearITPendingBit(TIM2, TIM_IT_CC2);


  capture2 = TIM_GetCapture2(TIM2);
  TIM_SetCompare2(TIM2, capture2 + CCR2_Val );
     }
}

void UART5_Configuration(void)
{
USART_InitTypeDef USART_InitStructure; //串口设置恢复默认参数


USART_InitStructure.USART_BaudRate = 115200; //波特率115200
USART_InitStructure.USART_WordLength = USART_WordLength_8b; //字长8位
USART_InitStructure.USART_StopBits = USART_StopBits_1; //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; //打开Rx接收和Tx发送功能
USART_Init(UART5, &USART_InitStructure); //初始化


/* Enable UART5 Receive and Transmit interrupts */
USART_ITConfig(UART5,  USART_IT_RXNE, ENABLE); // 若接收数据寄存器满,则产生中断


// USART_ITConfig(UART5, USART_IT_TXE, ENABLE);


/* Enable the UART5 and USART1 */
USART_Cmd(UART5, ENABLE); //启动串口

//-----如下语句解决第1个字节无法正确发送出去的问题-----//
USART_ClearFlag(UART5, USART_FLAG_TC); // 清标志




}


void USART_Configuration(void)
{
USART_InitTypeDef USART_InitStructure; //串口设置恢复默认参数


USART_InitStructure.USART_BaudRate = 1200; //波特率1200
USART_InitStructure.USART_WordLength = USART_WordLength_8b; //字长8位
USART_InitStructure.USART_StopBits = USART_StopBits_1; //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; //打开Rx接收和Tx发送功能
/* Configure USART1,USART2,USART3,UART4 */
USART_Init(USART1, &USART_InitStructure);
USART_Init(USART2, &USART_InitStructure);
USART_Init(USART3, &USART_InitStructure);
USART_Init(UART4 , &USART_InitStructure);


/* Enable USART1,USART2,USART3,UART4 Receive and Transmit interrupts */                    
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);// 若接收数据寄存器满,则产生中断
USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);
USART_ITConfig(UART4 , USART_IT_RXNE, ENABLE);


/* Enable the UART1 and USART2,USART3,UART4 */
USART_Cmd(USART1, ENABLE); //启动串口
USART_Cmd(USART2, ENABLE);
USART_Cmd(USART3, ENABLE);
USART_Cmd(UART4, ENABLE);


//-----如下语句解决第1个字节无法正确发送出去的问题-----//
USART_ClearFlag(USART1, USART_FLAG_TC);// 清标志
USART_ClearFlag(USART2, USART_FLAG_TC);
USART_ClearFlag(USART3, USART_FLAG_TC);
USART_ClearFlag(UART4 , USART_FLAG_TC);


}
void UART5_IRQHandler(void)
{
uchar x,y,z;
uint checksum1,checksum2;


if(USART_GetITStatus(UART5, USART_IT_RXNE) != RESET) //若接收数据寄存器满
{
x=USART_ReceiveData(UART5);
}


Com5TxChar(x);


}


void USART1_IRQHandler(void)
{
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //若接收数据寄存器满
{
Com1RecDat[Com1RecCnt]=USART_ReceiveData(USART1);
  }
  Com1RecCnt++;
  Com1RecCnt%=C1_LEN;


   Com1TxChar(USART_ReceiveData(USART1));
}


void USART2_IRQHandler(void)
{
if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) //若接收数据寄存器满
{
Com2RecDat[Com2RecCnt]=USART_ReceiveData(USART2);
  }
  Com2RecCnt++;
  Com2RecCnt%=C1_LEN;
  Com2TxChar(USART_ReceiveData(USART2));
}


void USART3_IRQHandler(void)
{
if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET) //若接收数据寄存器满
{
Com3RecDat[Com3RecCnt]=USART_ReceiveData(USART3);
  }
  Com3RecCnt++;
  Com3RecCnt%=C1_LEN;
  Com3TxChar(USART_ReceiveData(USART3));
}


void UART4_IRQHandler(void)
{
if(USART_GetITStatus(UART4, USART_IT_RXNE) != RESET) //若接收数据寄存器满
{
Com4RecDat[Com4RecCnt]=USART_ReceiveData(UART4);
  }
  Com4RecCnt++;
  Com4RecCnt%=C1_LEN;
  Com4TxChar(USART_ReceiveData(UART4));
}

int main(void)
{
u8 ld[69]=0;
u8 i;


RCC_Configuration();
GPIO_Configuration();
NVIC_Configuration();
UART5_Configuration();
USART_Configuration();
TIM2_Configuration();
    SysTick_Configuration();


for(i=0;i<69;i++)
  {
   ld=i;
  }

Com1TxStr(ld,69);
Com2TxStr(ld,69);
Com3TxStr(ld,69);
Com4TxStr(ld,69);
Com5TxStr(ld,69);

while(1){



  }
}
[/mw_shl_code]


回复 支持 反对

使用道具 举报

15

主题

45

帖子

0

精华

初级会员

Rank: 2

积分
134
金钱
134
注册时间
2015-7-10
在线时间
14 小时
发表于 2016-4-24 11:37:45 | 显示全部楼层
mack13013 发表于 2016-4-23 19:38
不知道你用的寄存器还是库函数。
网上说库函数的话,cube给出了两种不同的初始化方法,
区别就在两个 ...

太奇怪了,真心不知道什么原因,是不是跟时钟有关系,但是123都正常
回复 支持 反对

使用道具 举报

15

主题

45

帖子

0

精华

初级会员

Rank: 2

积分
134
金钱
134
注册时间
2015-7-10
在线时间
14 小时
发表于 2016-4-24 15:29:34 | 显示全部楼层
你解决了么楼主
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-16 16:29

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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