中级
30 分钟

使用MAX3471和STM32F031K6在恶劣环境中确保无误且稳健的RS485数据传输

简化、优化、变革:数据通信的未来!

RS485 2 Click with Nucleo 32 with STM32F031K6 MCU

已发布 10月 01, 2024

点击板

RS485 2 Click

开发板

Nucleo 32 with STM32F031K6 MCU

编译器

NECTO Studio

微控制器单元

STM32F031K6

我们的解决方案无缝地将UART信号转换为RS485,为工业自动化系统提供更快、更可靠的数据通信。

A

A

硬件概览

它是如何工作的?

RS485 2 Click 基于 MAX3471,这是 Analog Devices 生产的 RS-422/485 半双工差分收发器,适用于电池供电系统。此 Click 设计用作物理层设备,通常称为 PHY,为 MCU TTL 级 UART 线与 RS422/485 总线提供物理接口。它非常适合使用屏蔽差分对传输小块数据到远距离,实现 TX 和 RX 信号的半双工异步通信。MAX3471 收发器由单独的驱动器和接收器部分组成,有驱动器启用和接收器启用引脚(#RE 和 DE),用于启用相应部分。驱动器部分用于将 UART RX 线(在 IC 上标记为 RO)接收到的信号驱动 RS422/485 总线,而接收器部分则将总线数据通过 UART TX 线(在 IC 上标记为 DI)返回给 MCU。RS422/485 标准只规定了发射器和接收器的电气特性,并未规定或推荐任何通信协议,只有物理层。可以使用顶层通信协议,如 MODBUS 或类似协议。因此,RS485 2 Click 提供 UART RX 和 TX 引脚,路由到相应的 mikroBUS™ TX 和 RX UART 引脚。这些引脚由 MCU 使用,以用户协议确定的形式将数据发送到 RS485 总线。额外的 DE 和 RE 引脚分别路由到 mikroBUS™ 的 CS 和 PWM 引脚。这些引脚在 Click 

board™ 上标记为 DE 和 RE,与 IC 本身相同。悬空时,使用上拉和下拉来确定这些引脚的状态。MAX3471 IC 允许数据速率高达 64kbps。通常,最大传输速度由总线长度决定:较长的总线线将导致较低的传输速度。RS485/422 总线需要在两端用等于使用电缆的特性阻抗的电阻终止,以防止线路反射。然而,MAX3471 IC 具有降低的驱动器输出斜率,导致速度较慢,但同时信号更为强健,能抵抗长线或连接存根(未终止的总线部分)出现的 EMI 和其他类型的干扰。这款 IC 也能在未终止的总线上工作,这在低速和低功耗系统中很常见。RS-485 标准规定,符合标准的驱动器必须能够驱动 32 个单元负载(UL),其中 1 个单元负载代表大约 12 kΩ 的负载阻抗。由于 MAX3471 IC 设备是 1/8 UL,单个驱动器可支持多达 256 个此类接收器。当 RS485/422 总线电压接近 2.5V 时,该设备能够驱动多达 8 个负载,这意味着它可以驱动多达 64 个接收器。随着总线电压的上升,可以添加更多的驱动器,以便在 5V 时,该设备可以驱动标准规定的设备数量。在 RS485/422 总线上,可能出现导致通过驱动器输出的电流增加的差分电压情况,这种

状态称为总线争用,通常出现在初始化、总线故障条件或多个节点同时激活其驱动器时。MAX3471 IC 提供驱动器输出保护,限制这种电流并防止对驱动器输出级造成损害。MAX3471 接收器采用输入滤波和输入滞回以增强噪声抑制,当差分信号的上升和下降时间非常慢时。MAX3471 IC 具有真正的失效安全接收器输入,保证在接收器输入开路、短路或连接到所有驱动器均已禁用的终止传输线时,接收器输出为逻辑高电平。板上有一个四极螺丝端子(VCC, RX, TX, GND)用于连接 RS422/485 总线双绞线电缆,以及 GND 和 VCC。跳线标记为 VCC SEL,用于将 Click board™ 的操作电压设置为 3.3V 或 5V。GND 和 VCC 轨道可用于为另一个节点提供电源。注意,VCC 端子直接路由到 mikroBUS™ 的 3.3V 或 5V 轨道,具体取决于 VCC SEL 跳线的位置。MikroElektronika 提供一个库,其中包含与 MikroElektronika 编译器兼容的函数,可用于操作 RS485 2 Click。库还包含一个示例应用程序,演示了它们的使用。这个示例应用程序可以作为自定义设计的参考。

RS485 2 Click top side image
RS485 2 Click bottom side image

功能概述

开发板

Nucleo 32开发板搭载STM32F031K6 MCU,提供了一种经济且灵活的平台,适用于使用32引脚封装的STM32微控制器进行实验。该开发板具有Arduino™ Nano连接性,便于通过专用扩展板进行功能扩展,并且支持mbed,使其能够无缝集成在线资源。板载集成

ST-LINK/V2-1调试器/编程器,支持通过USB重新枚举,提供三种接口:虚拟串口(Virtual Com port)、大容量存储和调试端口。该开发板的电源供应灵活,可通过USB VBUS或外部电源供电。此外,还配备了三个LED指示灯(LD1用于USB通信,LD2用于电源

指示,LD3为用户可控LED)和一个复位按钮。STM32 Nucleo-32开发板支持多种集成开发环境(IDEs),如IAR™、Keil®和基于GCC的IDE(如AC6 SW4STM32),使其成为开发人员的多功能工具。

Nucleo 32 with STM32F031K6 MCU double side image

微控制器概述 

MCU卡片 / MCU

default

建筑

ARM Cortex-M0

MCU 内存 (KB)

32

硅供应商

STMicroelectronics

引脚数

32

RAM (字节)

4096

你完善了我!

配件

Click Shield for Nucleo-32是扩展您的开发板功能的理想选择,专为STM32 Nucleo-32引脚布局设计。Click Shield for Nucleo-32提供了两个mikroBUS™插座,可以添加来自我们不断增长的Click板™系列中的任何功能。从传感器和WiFi收发器到电机控制和音频放大器,我们应有尽有。Click Shield for Nucleo-32与STM32 Nucleo-32开发板兼容,为用户提供了一种经济且灵活的方式,使用任何STM32微控制器快速创建原型,并尝试各种性能、功耗和功能的组合。STM32 Nucleo-32开发板无需任何独立的探针,因为它集成了ST-LINK/V2-1调试器/编程器,并随附STM32全面的软件HAL库和各种打包的软件示例。这个开发平台为用户提供了一种简便且通用的方式,将STM32 Nucleo-32兼容开发板与他们喜欢的Click板™结合,应用于即将开展的项目中。

Click Shield for Nucleo-32 accessories 1 image

使用的MCU引脚

mikroBUS™映射器

NC
NC
AN
NC
NC
RST
Driver Output Enable
PA4
CS
NC
NC
SCK
NC
NC
MISO
NC
NC
MOSI
Power Supply
3.3V
3.3V
Ground
GND
GND
Receiver Output Enable
PA8
PWM
NC
NC
INT
UART TX
PA10
TX
UART RX
PA9
RX
NC
NC
SCL
NC
NC
SDA
Power Supply
5V
5V
Ground
GND
GND
1

“仔细看看!”

Click board™ 原理图

RS485 2 Click Schematic schematic

一步一步来

项目组装

Click Shield for Nucleo-144 front image hardware assembly

从选择您的开发板和Click板™开始。以Nucleo 32 with STM32F031K6 MCU作为您的开发板开始。

Click Shield for Nucleo-144 front image hardware assembly
Nucleo 144 with STM32L4A6ZG MCU front image hardware assembly
Stepper 22 Click front image hardware assembly
Prog-cut hardware assembly
Stepper 22 Click complete accessories setup image hardware assembly
Nucleo-32 with STM32 MCU Access MB 1 - upright/background hardware assembly
Necto image step 2 hardware assembly
Necto image step 3 hardware assembly
Necto image step 4 hardware assembly
Necto image step 5 hardware assembly
Necto image step 6 hardware assembly
STM32 M4 Clicker HA MCU/Select Step hardware assembly
Necto No Display image step 8 hardware assembly
Necto image step 9 hardware assembly
Necto image step 10 hardware assembly
Debug Image Necto Step hardware assembly

实时跟踪您的结果

应用程序输出

1. 应用程序输出 - 在调试模式下,“应用程序输出”窗口支持实时数据监控,直接提供执行结果的可视化。请按照提供的教程正确配置环境,以确保数据正确显示。

2. UART 终端 - 使用UART Terminal通过USB to UART converter监视数据传输,实现Click board™与开发系统之间的直接通信。请根据项目需求配置波特率和其他串行设置,以确保正常运行。有关分步设置说明,请参考提供的教程

3. Plot 输出 - Plot功能提供了一种强大的方式来可视化实时传感器数据,使趋势分析、调试和多个数据点的对比变得更加直观。要正确设置,请按照提供的教程,其中包含使用Plot功能显示Click board™读数的分步示例。在代码中使用Plot功能时,请使用以下函数:plot(insert_graph_name, variable_name);。这是一个通用格式,用户需要将“insert_graph_name”替换为实际图表名称,并将“variable_name”替换为要显示的参数。

软件支持

库描述

这个库包含了RS485 2 Click驱动的API。

关键功能:

  • rs4852_generic_read - 通用读取功能。

  • rs4852_generic_write - 通用写入功能。

  • rs4852_set_de_pin - 设置DE(cs)引脚状态。

开源

代码示例

完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio 应用程序代码也可以在MIKROE的GitHub账户中找到。

/*!
 * \file 
 * \brief Rs4852 Click example
 * 
 * # Description
 * This example reads and processes data from RS485 2 clicks.
 *
 * The demo application is composed of two sections :
 * 
 * ## Application Init 
 * Initializes the driver and enables the selected mode.
 * 
 * ## Application Task  
 * Depending on the selected mode, it reads all the received data or sends the desired message
 * every 2 seconds.
 * 
 * ## Additional Function
 * - rs4852_process ( ) - The general process of collecting the received data.
 * 
 * \author MikroE Team
 *
 */
// ------------------------------------------------------------------- INCLUDES

#include "board.h"
#include "log.h"
#include "rs4852.h"
#include "string.h"

#define PROCESS_RX_BUFFER_SIZE 500

#define TEXT_TO_SEND "MikroE - RS485 2 click board\r\n"

// #define DEMO_APP_RECEIVER
#define DEMO_APP_TRANSMITTER

// ------------------------------------------------------------------ VARIABLES

static rs4852_t rs4852;
static log_t logger;

// ------------------------------------------------------- ADDITIONAL FUNCTIONS

static void rs4852_process ( void )
{
    int32_t rsp_size;
    
    char uart_rx_buffer[ PROCESS_RX_BUFFER_SIZE ] = { 0 };
    uint8_t check_buf_cnt;
    
    rsp_size = rs4852_generic_read( &rs4852, uart_rx_buffer, PROCESS_RX_BUFFER_SIZE );

    if ( rsp_size > 0 )
    {  
        for ( uint8_t cnt = 0; cnt < rsp_size; cnt++ )
        {
            log_printf( &logger, "%c", uart_rx_buffer[ cnt ] );
            if ( uart_rx_buffer[ cnt ] == '\n' )
            {
                log_printf( &logger, "--------------------------------\r\n" );
            }
        }
    }
}

// ------------------------------------------------------ APPLICATION FUNCTIONS

void application_init ( void )
{
    log_cfg_t log_cfg;
    rs4852_cfg_t cfg;

    /** 
     * Logger initialization.
     * Default baud rate: 115200
     * Default log level: LOG_LEVEL_DEBUG
     * @note If USB_UART_RX and USB_UART_TX 
     * are defined as HAL_PIN_NC, you will 
     * need to define them manually for log to work. 
     * See @b LOG_MAP_USB_UART macro definition for detailed explanation.
     */
    LOG_MAP_USB_UART( log_cfg );
    log_init( &logger, &log_cfg );
    log_info( &logger, "---- Application Init ----" );

    //  Click initialization.

    rs4852_cfg_setup( &cfg );
    RS4852_MAP_MIKROBUS( cfg, MIKROBUS_1 );
    rs4852_init( &rs4852, &cfg );
    Delay_ms( 100 );
    
#ifdef DEMO_APP_RECEIVER
    rs4852_set_re_pin( &rs4852, RS4852_ENABLE_RE );
    rs4852_set_de_pin( &rs4852, RS4852_DISABLE_DE );
    log_info( &logger, "---- Receiver mode ----" );
#endif    
#ifdef DEMO_APP_TRANSMITTER
    rs4852_set_de_pin( &rs4852, RS4852_ENABLE_DE );
    rs4852_set_re_pin( &rs4852, RS4852_DISABLE_RE );
    log_info( &logger, "---- Transmitter mode ----" );
#endif    
    Delay_ms( 100 );
}

void application_task ( void )
{
#ifdef DEMO_APP_RECEIVER
    rs4852_process( );
#endif    
    
#ifdef DEMO_APP_TRANSMITTER
    rs4852_generic_write( &rs4852, TEXT_TO_SEND, strlen( TEXT_TO_SEND ) );
    log_info( &logger, "---- Data sent ----" );
    Delay_ms( 2000 );
#endif   
}

void main ( void )
{
    application_init( );

    for ( ; ; )
    {
        application_task( );
    }
}

// ------------------------------------------------------------------------ END

额外支持

资源

喜欢这个项目吗?

'购买此套件' 按钮会直接带您进入购物车,您可以在购物车中轻松添加或移除产品。