最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

sp3485调试总结

来源:动视网 责编:小OO 时间:2025-10-03 04:24:54
文档

sp3485调试总结

TM32调试sp3485技术总结窗体顶端窗体底端1.首先说明一下本人这次使用的STM32芯片是STM32F103RB,使用的资源是片内的USART1。 2.下面是我的电路连接图: 做一下简单的说明: (1)PA8是sp3485的发送/接收使能端,sp3485只能支持半双工的通信,所以这个引脚就是来控制这个芯片到底是收数据还是发数据的。 (2)在有些电路连接中,sp3485的A和B端会一个被连接一个上拉电阻到3.3V,另一个会连接一个下拉电阻到GND,这样做的目的是当本sp3485不参与通信时不
推荐度:
导读TM32调试sp3485技术总结窗体顶端窗体底端1.首先说明一下本人这次使用的STM32芯片是STM32F103RB,使用的资源是片内的USART1。 2.下面是我的电路连接图: 做一下简单的说明: (1)PA8是sp3485的发送/接收使能端,sp3485只能支持半双工的通信,所以这个引脚就是来控制这个芯片到底是收数据还是发数据的。 (2)在有些电路连接中,sp3485的A和B端会一个被连接一个上拉电阻到3.3V,另一个会连接一个下拉电阻到GND,这样做的目的是当本sp3485不参与通信时不

TM32调试sp3485技术总结

窗体顶端

窗体底端

1.首先说明一下本人这次使用的STM32芯片是STM32F103RB,使用的资源是片内的USART1。 

2.下面是我的电路连接图: 

做一下简单的说明: 

(1)PA8是sp3485的发送/接收使能端,sp3485只能支持半双工的通信,所以这个引脚就是来控制这个芯片到底是收数据还是发数据的。 

(2)在有些电路连接中,sp3485的A和B端会一个被连接一个上拉电阻到3.3V,另一个会连接一个下拉电阻到GND,这样做的目的是当本sp3485不参与通信时不会影响网络的稳定性。 

3.本次调试方式 

PC机——USB转232转换头——RS232/RS485双向转换头——sp3485——STM32,因为是第一次调试sp3485芯片,所以当然没有太大意,先拿电脑调试,调试通了再看板子和板子之间的通信了。 

4.本次试验的代码: 

main函数: 

int main(void)

    /* Configure the system clocks */

    RCC_Configuration();

      

    /* NVIC Configuration */

    NVIC_Configuration(); 

    /* Configure the GPIOs */

    GPIO_Configuration();

  

    /* Configure the USART1 */

    USART_Configuration(); 

    GPIO_SetBits(GPIOA, GPIO_Pin_8);  //PA8是sp3485发送/接收控制端,这里先设置为发送(实现的功能就是上电之后STM32先向PC发送一个4和一个3) 

    delay_ms(2);//稍稍延时一下,原因去查看sp3485的手册吧

    USART_ClearFlag(USART1,USART_FLAG_TC);//这一句很关键,如果没有这一句这个4会发送不成功或者发送错误的, 

                                                                                           //其实手册上讲了使能发送位后会发送一个无用的帧,所以那个帧发送完了这个 

                                                                                           //发送完成的标志位USART_FLAG_TC当然也被置位了。

    USART_SendData(USART1, 4);

    while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);//上面清除了发送完成标志位,那么这里就可以等待发送完成标志位被置位来判断这一帧是否发完了 

    USART_SendData(USART1, 3);

    while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET); 

    while(1)

    {  

       GPIO_ResetBits(GPIOA, GPIO_Pin_8);//现在把PA8清零,试试接收PC机发送过来的数据 

       delay_ms(2);//稍稍延时一下,原因去查看sp3485的手册吧

       USART_ClearFlag(USART1,USART_FLAG_RXNE);//既然上面开始发送之前都将发送完成标志位清零,这里也将接收完成标志位清下零,就当是一个好习惯吧

       while(1)

      {

          if(USART_GetFlagStatus(USART1,USART_FLAG_RXNE)==SET)//判断是否有一帧数据接收完成

          {            

               buf[j++] = USART_ReceiveData(USART1); //接收完成的话就直接放到缓存区域里  

          }

         if(10 == j)//接收完成10个之后就跳出去,不再接收了,有个意思就OK了

         break;

      }

    j = 0;//清零一下j变量,使得实验可以反复接收PC发过来的10个数据

   GPIO_SetBits(GPIOA, GPIO_Pin_8);//将sp3485设置为发送数据

    while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);

   delay_ms(2);//稍稍延时一下,原因去查看sp3485的手册吧

    for(i = 0; i < 10; i++)

   {

        USART_SendData(USART1, buf[i]);//将数据依次发送出去

        while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET); 

    }

 }

RCC设置函数: 

void RCC_Configuration(void)

{

  /* RCC system reset(for debug purpose) */

  RCC_DeInit(); 

  /* Enable HSE */

  RCC_HSEConfig(RCC_HSE_ON); 

  /* Wait till HSE is ready */

  HSEStartUpStatus = RCC_WaitForHSEStartUp(); 

  if(HSEStartUpStatus == SUCCESS)

  {

    /* HCLK = SYSCLK */

    RCC_HCLKConfig(RCC_SYSCLK_Div1); 

  

    /* PCLK2 = HCLK */

    RCC_PCLK2Config(RCC_HCLK_Div1); 

    /* PCLK1 = HCLK/2 */

    RCC_PCLK1Config(RCC_HCLK_Div2); 

    /* Flash 2 wait state */

    FLASH_SetLatency(FLASH_Latency_2);

    /* Enable Prefetch Buffer */

    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); 

    /* PLLCLK = 8MHz * 9 = 72 MHz */

    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); 

    /* Enable PLL */ 

    RCC_PLLCmd(ENABLE); 

    /* Wait till PLL is ready */

    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)

    {

    } 

    /* Select PLL as system clock source */

    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); 

    /* Wait till PLL is used as system clock source */

    while(RCC_GetSYSCLKSource() != 0x08)

    {

    }

  }

   

  /* Enable USART1 and GPIOA clock */

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOC, ENABLE);

GPIO设置函数: 

void GPIO_Configuration(void)

{

  GPIO_InitTypeDef GPIO_InitStructure; 

  /* Configure USART1 Tx (PA.09) as alternate function push-pull */

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_Init(GPIOA, &GPIO_InitStructure);

    

  /* Configure USART1 Rx (PA.10) as input floating */

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;

  GPIO_Init(GPIOA, &GPIO_InitStructure); 

 /* Configure PC. as Output push-pull */

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;

 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//GPIO_Mode_Out_PP = 0x10

 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

 GPIO_Init(GPIOA, &GPIO_InitStructure); 

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;

 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//GPIO_Mode_Out_PP = 0x10

 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

 GPIO_Init(GPIOC, &GPIO_InitStructure);

USART设置函数: 

void USART_Configuration(void)

{

  USART_InitTypeDef USART_InitStructure;

  USART_ClockInitTypeDef  USART_ClockInitStructure; 

USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;

USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;

USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;

USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;

/* Configure the USART1 synchronous paramters */

USART_ClockInit(USART1, &USART_ClockInitStructure); 

USART_InitStructure.USART_BaudRate = 9600;

USART_InitStructure.USART_WordLength = USART_WordLength_8b;

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;

/* Configure USART1 basic and asynchronous paramters */

USART_Init(USART1, &USART_InitStructure);

    

  /* Enable USART1 */

USART_Cmd(USART1, ENABLE);

NVIC设置函数: 

void NVIC_Configuration(void)

{

#ifdef  VECT_TAB_RAM  

  /* Set the Vector Table base location at 0x20000000 */ 

  NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0); 

#else  /* VECT_TAB_FLASH  */

  /* Set the Vector Table base location at 0x08000000 */ 

  NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);   

#endif

5.实验结果 

不成功,找了很久的原因,首先请检查sp3485与232/485双向转换头的连接线,我得到的最终的正确的连接办法是sp3485的A连接到T/R+,而sp3485的B连接到T/R-。 

更改连接顺序之后还是出现了很奇怪的现象,每次上电之后PC的串口调试助手都会接收到04 03 00,都要多一个00(十六进制),还有更奇怪的现象,当在PC机上输入十个数据,点击发送之后,返回来居然是20个数据,前10个数据是错误的,后10个才是我发送过去的数据。。 

这个现象非常奇怪,将程序反复修改,还是不能解决问题,甚至一度怀疑sp3485坏掉了,最后弄了一整天,将sp3485A和B引脚之间的120欧姆的电阻去掉,一切恢复正常了! 

说明一下:我的sp3485和232/485互转器之间的距离20cm左右,所以这个距离应该是不用接120欧姆的匹配电阻的。 

更多

文档

sp3485调试总结

TM32调试sp3485技术总结窗体顶端窗体底端1.首先说明一下本人这次使用的STM32芯片是STM32F103RB,使用的资源是片内的USART1。 2.下面是我的电路连接图: 做一下简单的说明: (1)PA8是sp3485的发送/接收使能端,sp3485只能支持半双工的通信,所以这个引脚就是来控制这个芯片到底是收数据还是发数据的。 (2)在有些电路连接中,sp3485的A和B端会一个被连接一个上拉电阻到3.3V,另一个会连接一个下拉电阻到GND,这样做的目的是当本sp3485不参与通信时不
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top