你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

stm32 485串口数据的收发

[复制链接]
yuxin-366840 发布时间:2017-8-23 19:57
  1. [cpp] view plain copy
  2. //串口初始化:  
  3.   
  4. #define EN_USART2_RX  1  
  5.   
  6. void RS485_Init(u32 bound)  
  7. {   
  8.     GPIO_InitTypeDef GPIO_InitStructure;  
  9.    USART_InitTypeDef USART_InitStructure;  
  10.   NVIC_InitTypeDef NVIC_InitStructure;  
  11.    
  12. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOG, ENABLE);  
  13. RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);  
  14. RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);  
  15.    
  16. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;     //  RE  
  17.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  
  18.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;  
  19.   GPIO_Init(GPIOG, &GPIO_InitStructure);  
  20.    
  21. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;  //PA2    TX  
  22.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;   
  23.     GPIO_Init(GPIOA, &GPIO_InitStructure);  
  24.      
  25.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;//PA3    RX  
  26.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;   
  27.     GPIO_Init(GPIOA, &GPIO_InitStructure);   
  28.   
  29. RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART2,ENABLE);  
  30. RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART2,DISABLE);//í£?1?′??  
  31.    
  32.    
  33. #ifdef EN_USART2_RX        //  
  34. USART_InitStructure.USART_BaudRate = 9600;//波特率9600;  
  35. USART_InitStructure.USART_WordLength = USART_WordLength_8b;//8位数据位  
  36. USART_InitStructure.USART_StopBits = USART_StopBits_1;//停止位1位  
  37. USART_InitStructure.USART_Parity = USART_Parity_No;//奇偶校验无  
  38. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制  
  39. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//串口配置为收发模式  
  40.   
  41.     USART_Init(USART2, &USART_InitStructure); ;   
  42.    
  43. NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn; //指定中断  
  44. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; //中断抢占优先级  
  45. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //′中断响应优先级  
  46. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; // 中断函数使能  
  47.   NVIC_Init(&NVIC_InitStructure);  
  48.   
  49.   USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//接收终端使能  
  50.      
  51.     USART_Cmd(USART2, ENABLE);                    //串口使能  
  52.   
  53. #endif  
  54.   
  55. RS485_TX_EN=0; //默认配置为接收模式  这里可以用GPIO_ResetBits(GPIOG,GPIO_Pin_9),同样置1可用GPIO_SetBits(),  
  56. }  
  57.   
  58. //串口的中断函数:  
  59.   
  60. void USART2_IRQHandler(void)  
  61. {  
  62. u8 res;         
  63.    
  64.   if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)   
  65. {  
  66.       
  67.   res =USART_ReceiveData(USART2);   
  68.   RS485_TX_EN = 1;  
  69. // 此处发送数据主要是为了检验中断是否进行触发  
  70.   while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);  
  71.   USART_SendData(USART2,0xff);  
  72.   while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);  
  73.   RS485_TX_EN = 0;  
  74.   if(RS485_RX_CNT<64)  
  75.   {  
  76.    RS485_RX_BUF[RS485_RX_CNT]=res;、  
  77.    RS485_RX_CNT++;   
  78.   }  
  79. }   
  80. }  
复制代码



好吧,今天又被串口虐的死去活来,最开始一直怀疑是自己的程序写的有问题,纠结串口配置是不是出问题了,最后找个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. 记得使能中断和串口。

具体还是看代码吧。

收藏 评论0 发布时间:2017-8-23 19:57

举报

0个回答

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版