中级
30 分钟

将 UJA1162A 与 PIC32MZ2048EFM100 结合,实现高速 CAN 数据传输

无与伦比的数据传输

CAN FD 5 Click with Curiosity PIC32 MZ EF

已发布 7月 22, 2025

点击板

CAN FD 5 Click

开发板

Curiosity PIC32 MZ EF

编译器

NECTO Studio

微控制器单元

PIC32MZ2048EFM100

我们的高速CAN FD收发器将可靠性和速度结合在一起,树立了汽车通信的新标准。

A

A

硬件概览

它是如何工作的?

CAN FD 5 Click基于NXP Semiconductors的UJA1162A,这是一款“自供电”的高速(HS)CAN收发器,集成了符合ISO 11898-2:2016和SAE J2284-1至SAE J2284-5标准的CAN收发器,并具有睡眠模式。UJA1162A在CAN FD HS阶段提供高达5 Mbit/s的数据速率的可靠通信,并且可以在具有本地和总线唤醒功能的超低功耗睡眠模式下运行。各种故障安全和诊断功能提供了增强的系统可靠性和先进的电源管理。HS CAN收发器UJA1162A包括一个接收器和一个发射器单元,使收发器能够同时向总线介质发送数据和监控来自总线介质的数据。UJA1162A支持五种工作模式:正常模式、待机模式、睡眠模式、过温模式和关闭模式。每

种模式在静态电流、数据传输或故障诊断方面具有特定的特性。当收发器处于睡眠模式时,连接到Click板™背面的外部稳压器TLS850B0TBV33的引脚将被关闭,从而减少外部元件的功耗。这些LDO的输出通过可以填充的SMD跳线进行路由,以便这些LDO可以用于为mikroBUS™的3.3V和5V电源轨供电。然而,需要注意的是,MikroE不建议以这种方式为其系统供电,因此默认情况下这些跳线未填充。CAN FD 5 Click使用UART接口与MCU通信,默认波特率为9600 bps用于数据传输,而此Click板™上的GPIO引脚用于睡眠模式控制、本地唤醒和CAN收发器状态的中断。mikroBUS™插座上的CS引脚标记为SLP,可

以通过切换此引脚在正常模式和待机/睡眠模式之间切换。它还具有本地唤醒功能,路由到mikroBUS™上的PWM引脚,标记为WAK,这将使UJA1162A从待机/睡眠模式转换到正常模式。除了这些引脚,此Click板™还具有标记为CTS的中断引脚,指示MCU收发器已完全启用,可以通过UART TX/RX引脚传输和接收数据。用户还可以通过板左侧的UART外部头直接连接UART通信的TX/RX信号。此Click板™设计为与3.3V和5V逻辑电压水平一起运行,可以通过VIO SEL跳线进行选择。这样,3.3V和5V的MCU都可以正确使用通信线。此外,此Click板™配备了一个包含易于使用的函数和示例代码的库,可用作进一步开发的参考。

CAN FD 5 Click hardware overview image

功能概述

开发板

Curiosity PIC32 MZ EF 开发板是一个完全集成的 32 位开发平台,特点是高性能的 PIC32MZ EF 系列(PIC32MZ2048EFM),该系列具有 2MB Flash、512KB RAM、集成的浮点单元(FPU)、加密加速器和出色的连接选项。它包括一个集成的程序员和调试器,无需额外硬件。用户可以通过 MIKROE 

mikroBUS™ Click™ 适配器板扩展功能,通过 Microchip PHY 女儿板添加以太网连接功能,使用 Microchip 扩展板添加 WiFi 连接能力,并通过 Microchip 音频女儿板添加音频输入和输出功能。这些板完全集成到 PIC32 强大的软件框架 MPLAB Harmony 中,该框架提供了一个灵活且模块化的接口

来应用开发、一套丰富的互操作软件堆栈(TCP-IP、USB)和易于使用的功能。Curiosity PIC32 MZ EF 开发板提供了扩展能力,使其成为连接性、物联网和通用应用中快速原型设计的绝佳选择。

Curiosity PIC32MZ EF double side image

微控制器概述 

MCU卡片 / MCU

default

建筑

PIC32

MCU 内存 (KB)

2048

硅供应商

Microchip

引脚数

100

RAM (字节)

524288

你完善了我!

配件

DB9母对母(2米)电缆是建立设备之间可靠串行数据连接的必备工具。此电缆两端均配有DB9母头连接器,能够在各种设备之间实现无缝连接,如计算机、路由器、交换机和其他串行设备。其长度为2米,提供了灵活的布线方案,而不会影响数据传输质量。精心制作的电缆确保一致且可靠的数据交换,适用于工业应用、办公室环境和家庭设置。无论是配置网络设备、访问控制台端口还是使用串行外设,此电缆的耐用结构和坚固连接器都能保证稳定连接。简化您的数据通信需求,使用2米DB9母对母电缆,这是一种高效的解决方案,能够轻松高效地满足您的串行连接要求。

CAN FD 5 Click accessories image

使用的MCU引脚

mikroBUS™映射器

NC
NC
AN
NC
NC
RST
Sleep Mode Control
RPD4
CS
NC
NC
SCK
NC
NC
MISO
NC
NC
MOSI
Power Supply
3.3V
3.3V
Ground
GND
GND
Wake-Up
RPE8
PWM
CAN Status
RF13
INT
UART TX
RPD10
TX
UART RX
RPD15
RX
NC
NC
SCL
NC
NC
SDA
Power Supply
5V
5V
Ground
GND
GND
1

“仔细看看!”

Click board™ 原理图

CAN FD 5 Click Schematic schematic

一步一步来

项目组装

Curiosity PIC32MZ EF front image hardware assembly

从选择您的开发板和Click板™开始。以Curiosity PIC32 MZ EF作为您的开发板开始。

Curiosity PIC32MZ EF front image hardware assembly
GNSS2 Click front image hardware assembly
Prog-cut hardware assembly
GNSS2 Click complete accessories setup image hardware assembly
Board mapper by product7 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
Curiosity PIC32 MZ EF MCU 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

软件支持

库描述

该库包含 CAN FD 5 Click 驱动程序的 API。

关键功能:

  • canfd5_generic_write - 通用写入函数

  • canfd5_generic_read - 通用读取函数

  • canfd5_set_normal_operating_mode - 设置正常工作模式的函数

开源

代码示例

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

/*!
 * \file 
 * \brief CanFd5 Click example
 * 
 * # Description
 * This is an example that demonstrates the use of the CAN FD 5 Click board.
 *
 * The demo application is composed of two sections :
 * 
 * ## Application Init 
 * Initializes the driver and enables the Click board.
 * 
 * ## Application Task  
 * Depending on the selected mode, it reads all the received data or sends the desired message
 * every 2 seconds.
 * 
 * ## Additional Function
 * - canfd5_process ( ) - The general process of collecting the received data.
 * 
 * \author MikroE Team
 *
 */
// ------------------------------------------------------------------- INCLUDES

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

#define PROCESS_RX_BUFFER_SIZE 500

#define TEXT_TO_SEND "MikroE\r\n"

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

// #define DEMO_APP_RECEIVER
#define DEMO_APP_TRANSMITTER

static canfd5_t canfd5;
static log_t logger;

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

static void canfd5_process ( void )
{
    int32_t rsp_size;
    
    char uart_rx_buffer[ PROCESS_RX_BUFFER_SIZE ] = { 0 };
    uint8_t check_buf_cnt;
    
    rsp_size = canfd5_generic_read( &canfd5, uart_rx_buffer, PROCESS_RX_BUFFER_SIZE );

    if ( rsp_size > 0 )
    {  
        log_printf( &logger, "Received data: " );
        
        for ( check_buf_cnt = 0; check_buf_cnt < rsp_size; check_buf_cnt++ )
        {
            log_printf( &logger, "%c", uart_rx_buffer[ check_buf_cnt ] );
        }
    }
    Delay_ms ( 100 );
}

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

void application_init ( void )
{
    log_cfg_t log_cfg;
    canfd5_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.

    canfd5_cfg_setup( &cfg );
    CANFD5_MAP_MIKROBUS( cfg, MIKROBUS_1 );
    canfd5_init( &canfd5, &cfg );

    canfd5_set_normal_operating_mode( &canfd5 );
    Delay_ms ( 100 );
}

void application_task ( void )
{
#ifdef DEMO_APP_RECEIVER
    canfd5_process( );
#endif
#ifdef DEMO_APP_TRANSMITTER
    canfd5_generic_write( &canfd5, TEXT_TO_SEND, 8 );
    log_info( &logger, "--- The message is sent ---" );
    Delay_ms ( 1000 );
    Delay_ms ( 1000 );
#endif 
}

int main ( void ) 
{
    /* Do not remove this line or clock might not be set correctly. */
    #ifdef PREINIT_SUPPORTED
    preinit();
    #endif
    
    application_init( );
    
    for ( ; ; ) 
    {
        application_task( );
    }

    return 0;
}

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

额外支持

资源

喜欢这个项目吗?

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