stm32 485串口数据的收发

//串口初始化:

#define EN_USART2_RX  1

void RS485_Init(u32 bound)
{  
    GPIO_InitTypeDef GPIO_InitStructure;
   USART_InitTypeDef USART_InitStructure;
  NVIC_InitTypeDef NVIC_InitStructure;
 
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOG, ENABLE);
 RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);
 
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;     //  RE
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOG, &GPIO_InitStructure);
 
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;	//PA2    TX
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 
    GPIO_Init(GPIOA, &GPIO_InitStructure);
   
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;//PA3    RX
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; 
    GPIO_Init(GPIOA, &GPIO_InitStructure);  

 RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART2,ENABLE);
 RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART2,DISABLE);//í£?1?′??
 
 
 #ifdef EN_USART2_RX	 	//
 USART_InitStructure.USART_BaudRate = 9600;//波特率9600;
 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;//串口配置为收发模式

    USART_Init(USART2, &USART_InitStructure); ; 
 
 NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn; //指定中断
 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; //中断抢占优先级
 NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //′中断响应优先级
 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; // 中断函数使能
  NVIC_Init(&NVIC_InitStructure);

  USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//接收终端使能
   
    USART_Cmd(USART2, ENABLE);                    //串口使能

 #endif

 RS485_TX_EN=0;	//默认配置为接收模式  这里可以用GPIO_ResetBits(GPIOG,GPIO_Pin_9),同样置1可用GPIO_SetBits(),
}

//串口的中断函数:

void USART2_IRQHandler(void)
{
 u8 res;	   
 
  if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) 
 {
     
  res =USART_ReceiveData(USART2); 
  RS485_TX_EN = 1;
// 此处发送数据主要是为了检验中断是否进行触发
  while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
  USART_SendData(USART2,0xff);
  while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
  RS485_TX_EN = 0;
  if(RS485_RX_CNT<64)
  {
   RS485_RX_BUF[RS485_RX_CNT]=res;、
   RS485_RX_CNT++; 
  }
 }  
}

好吧,今天又被串口虐的死去活来,最开始一直怀疑是自己的程序写的有问题,纠结串口配置是不是出问题了,最后找个demo自己找问题,发现收发数据是需要控制复位引脚,进行收发控制,我这里是复位引脚置为1,则可以进行发,为0,则表示收数据,当然如果你觉得设置好复位引脚的值就可以进行发送送数据了,呵呵,你看到的还是一片白,我的数据呢??在发送数据之前你需要写这样一条代码
while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==RESET),这样我们就用USART_Send(USARTx,data); 发送数据了,之后我们同样还需要用 while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==RESET)来处理自己发送的内容,看上去复杂吧,呵呵。
下面给出具体步骤:
1. 像配置232串口一样配置rs485的引脚,使能相应的时钟。
            RX: GPIO_Mode_IN_FLOATING/GPIO_Mode_IPD
            TX: GPIO_Mode_Out_PP
            RE: GPIO_Mode_Out_PP
2. 进行中断配置
3. 记得使能中断和串口。

具体还是看代码吧。







你可能感兴趣的:(stm32 485串口数据的收发)