请教下485通讯的问题

2019-08-13 21:51发布

485通讯 用单片机与PC通讯,PC端串口助手可以接受到信号;但通过串口助手给单片机发送数据,单片机却接收不到,用示波器看了下485发送数据到单片机的引脚,数据信号电压只有500mV左右
请问这个电压太小是不是导致单片机接收不到串口助手发出的数据?
单片机用的STM32F103,使用的串口2,max3485芯片
求大神解惑啊!!!
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
14条回答
ADS1993
1楼-- · 2019-08-13 22:40

两个电阻  1K 换成  4.7k




[mw_shl_code=c,true]GPIO_InitTypeDef GPIO_InitStructure;// 定义一个GPIO_InitTypeDef类型的变量
        USART_InitTypeDef USART_InitStructure;// 定义一个USART_InitTypeDef类型的变量
        NVIC_InitTypeDef NVIC_InitStructure;

        /* 允许GPIOA和USART2的时钟 */
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//使能GPIOA,G时钟
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//使能USART2时钟
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);

        /*485 EN  AND  POWER  */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_4 ; // 选择PIN1
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; // 推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 50MHz速度
        GPIO_Init(GPIOA, &GPIO_InitStructure);// 把参数带进函数配置
        //GPIO_SetBits  (GPIOA,GPIO_Pin_1);
        GPIO_ResetBits(GPIOA,GPIO_Pin_1);
        GPIO_ResetBits(GPIOA,GPIO_Pin_4);
       // GPIO_ResetBits(GPIOA,GPIO_Pin_12);
        /* 配置USART2 */
        /* 配置PA2(TXD) */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; // 选择PIN2
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; // 复用推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 50MHz速度
        GPIO_Init(GPIOA, &GPIO_InitStructure);// 把参数带进函数配置

        /* 配置PA3(RXD) */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;// 选择PIN3
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;// 选择浮空输入
        GPIO_Init(GPIOA, &GPIO_InitStructure); // 把参数带进函数配置

        /* 配置串口USART2的模式 */
        USART_InitStructure.USART_BaudRate = 19200;//115200; // 波特率1152009600
        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); //把上面配置的参数带进函数里面初始化串口

        /* 打开空闲中断 */
        USART_ITConfig(USART2, USART_IT_IDLE, ENABLE);
        /* 打开接收中断 */
        USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);

        /* 配置NVIC优先级组 */
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);

        /* 允许UART2中断 */
        NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
        NVIC_Init(&NVIC_InitStructure);

        USART_ClearFlag(USART2,USART_FLAG_TC);

        USART_Cmd(USART2, ENABLE);// 打开串口2[/mw_shl_code]





[mw_shl_code=c,true]void USART2_Send_byte(uint8_t val)
{
        __set_FAULTMASK(1);/*关闭总中断*/
        USART_SendData(USART2, val);
        while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);        //等待发送完成
        __set_FAULTMASK(0);/*关闭总中断*/
}



// 发送len个字节
void Uart2_Send(char* data, int len)
{       GPIO_SetBits(GPIOA,GPIO_Pin_1);
        GPIO_SetBits(GPIOA,GPIO_Pin_4);
        Delay_ms(10);
        __set_FAULTMASK(1);/*关闭总中断*/
        while (len--)
        {
                while (!USART_GetFlagStatus(USART2, USART_FLAG_TXE));
                USART2_Send_byte(*data++);
        }
        __set_FAULTMASK(0);/*开启总中断*/
        Delay_ms(10);
        GPIO_ResetBits(GPIOA,GPIO_Pin_4);
        GPIO_ResetBits(GPIOA,GPIO_Pin_1);
}[/mw_shl_code]



[mw_shl_code=c,true]void USART2_IRQHandler(void)
{
       // SysTick_Init();
        if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) // 如果接收到1个字节
        {
                aRxBuffer[RxCounter++] = USART2->DR;// 把接收到的字节保存,数组地址加1
        }
        else if(USART_GetITStatus(USART2, USART_IT_IDLE) != RESET)// 如果接收到1帧数据
        {
                u8 Clear=USART2->SR;// 读SR寄存器
                   Clear=USART2->DR;// 读DR寄存器(先读SR再读DR,就是为了清除IDLE中断)
                   ReceiveState=1;// 标记接收到了1帧数据
        }[/mw_shl_code]

ADS1993
2楼-- · 2019-08-14 03:37
发送完成,要设置成接收模式     调试看一下 切换 的延时时间  如果开启中断,看看有没有进入中断,
ADS1993
3楼-- · 2019-08-14 03:42
发送完成,要设置成接收模式     调试看一下 切换 的延时时间  如果开启中断,看看有没有进入中断,
守候ocean
4楼-- · 2019-08-14 06:05
ADS1993 发表于 2017-8-3 14:53
发送完成,要设置成接收模式     调试看一下 切换 的延时时间  如果开启中断,看看有没有进入中断,

我直接把发送的程序屏蔽了 现在初始化里就是接收模式 主程序里就跑个灯 我觉得是信号强度太小单片机不识别也不知道对不对 中断一直没进去 缓存里没数据
paulhe
5楼-- · 2019-08-14 10:51
 精彩回答 2  元偷偷看……
ADS1993
6楼-- · 2019-08-14 13:32
守候ocean 发表于 2017-8-3 14:59
我直接把发送的程序屏蔽了 现在初始化里就是接收模式 主程序里就跑个灯 我觉得是信号强度太小单片机不识 ...

发送数据的同时  用示波器  测量 A B  电压, 看一下  A B  差值 捕获.PNG

一周热门 更多>