×
单片机 > 单片机程序设计 > 详情

stm32 485串口数据的收发

发布时间:2020-05-18 发布时间:
|

//串口初始化:

 

#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. 记得使能中断和串口。

具体还是看代码吧。




『本文转载自网络,版权归原作者所有,如有侵权请联系删除』

热门文章 更多
51单片机中断源的扩展方法