使用我们先进的CAN收发器,提升高速数据交换,彻底改变汽车通信。
A
A
硬件概览
它是如何工作的?
ATA6570 Click采用的是来自Microchip的ATA6570,这是一个独立的高速CAN收发器IC,具有部分网络支持。该IC支持CAN和最近建立的CAN FD协议,分别可达1Mbit/s和5Mbit/s。CAN总线内的通信是差分的,并通过特性阻抗为120Ω的双绞线进行。CANH和CANL驱动器驱动差分线路。这提供了对电磁干扰的鲁棒性和免疫性,这些干扰通常出现在汽车系统中。ISO 11898标准定义了一根双绞线电缆的信号线作为网络拓扑,两端由特性阻抗(CAN总线120Ω)的电阻终止-以防止信号反射。主导/被动状态用于消息优先级仲裁-发送具有较高优先级的信号的节点(二进制消息标识符号越低,优先级越高)将赢得仲裁,而优先级较低的节点将中止传输,等待总线再次可用。由于CAN线上的高逻辑电平被视为被动,因此TXD线具有内部上拉电阻,使得ATA6570设备如果引脚悬空,则保持被动。当TXD引脚处于VCC电平并且工作在正常模式时,CANH和CANL引脚上的驱动器被关闭。这些引脚相对于由内部自主总线偏置电路提供的GND偏置在2.5(VCC/2)(VCC的一半),并且CAN驱动器处于被动状态。将TXD引脚拉到GND将激活CANH和CANL驱动器并设置总线到主导状态。当TXD引脚设置为低电
平时,将启动TXD主导超时定时器。如果TXD引脚的低电平状态持续时间超过预定时间,则将禁用发射器,释放总线线路到被动状态。此功能可防止硬件或软件故障驱动总线线路到永久主导状态,从而阻止所有网络通信。当设备处于休眠或未供电模式时,驱动器将变得高电阻,使得设备被动并完全被CAN总线网络忽略。虽然RXD和TXD线与微控制器接口,但SPI总线设置内部寄存器,如部分网络寄存器和其他与状态和配置相关的寄存器。提供的MikroElektronika库包含通过SPI总线轻松设置参数并与节点建立通信的功能。部分网络允许选择性唤醒ATA6570 Click。如果配置为接受这些帧,则专用预定义帧可以唤醒设备。因此,当设备处于待机或睡眠模式时,它仍将主动监视总线以查找这些帧。SPI可以设置唤醒CAN帧ID和数据。除了通过部分网络功能唤醒设备之外,还可以使用CAN总线上的远程唤醒模式或通过连接到ATA6570 IC的WAKE引脚的板载开关唤醒设备。另一个唤醒源可以是SPI命令,对于那些SPI模块处于活动状态且CAN总线上的远程唤醒模式的模式。当设备处于休眠、MCU复位或关闭模式时,INH引脚,该引脚被路由到外部调节器,将关闭,从而降低了外部元件的功耗。ATA6570 Click上的两个
LDO调节器的#SHDN(关断)引脚连接到INH引脚。这两个调节器从汽车电池连接器(VS引脚)获取电源,为自定义需求提供5V和3.3V。这些LDO的输出通过可以填充的SMD跳线路由,以便LDO可用于启动mikroBUS™ 3.3V和5V电源轨。但是,值得注意的是,MikroElektronika不建议以这种方式为其系统供电-这就是为什么这些跳线默认情况下未填充的原因。当设备的温度变得过高并且设备之前是在正常模式下工作时,会激活过温模式。ATA6570提供两级过温保护。当达到第一温度级阈值时,将发出警报,以中断RX引脚上的中断(如果设置)并设置适当的状态位。如果温度上升,设备将关闭CAN驱动器。微控制器复位模式利用集成的看门狗。当发生看门狗事件时,它将在INH引脚上触发脉冲-该引脚将在预定时间内关闭,对通过ATA6570 click LDO连接的所有设备执行电源循环复位。这是针对通过mikroBUS™插槽供电的自定义系统的电源循环复位措施。标记为VIO SEL的板载SMD跳线选择两个LDO调节器的哪个电压轨将用作逻辑电压电平(SPI、UART)。它提供了3.3V和5V之间的电压选择,以便click board™可以与3.3V和5V可兼容的MCU进行接口连接。
功能概述
开发板
EasyAVR v7 是第七代AVR开发板,专为快速开发嵌入式应用的需求而设计。它支持广泛的16位AVR微控制器,来自Microchip,并具有一系列独特功能,如强大的板载mikroProg程序员和通过USB的在线电路调试器。开发板布局合理,设计周到,使得最终用户可以在一个地方找到所有必要的元素,如开关、按钮、指示灯、连接器等。EasyAVR v7 通过每个端口的四种不同连接器,比以往更高效地连接附件板、传感器和自定义电子产品。EasyAVR v7 开发板的每个部分
都包含了使同一板块运行最高效的必要组件。一个集成的mikroProg,一个快速的USB 2.0程序员,带有mikroICD硬件在线电路调试器,提供许多有价值的编 程/调试选项和与Mikroe软件环境的无缝集成。除此之外,它还包括一个干净且调节过的开发板电源供应模块。它可以使用广泛的外部电源,包括外部12V电源供应,7-12V交流或9-15V直流通过DC连接器/螺丝端子,以及通过USB Type-B(USB-B)连接器的电源。通信选项如USB-UART和RS-232也包括在内,与
广受好评的mikroBUS™标准、三种显示选项(7段、图形和基于字符的LCD)和几种不同的DIP插座一起,覆盖了广泛的16位AVR MCU。EasyAVR v7 是Mikroe快速开发生态系统的一个组成部分。它由Mikroe软件工具原生支持,得益于大量不同的Click板™(超过一千块板),其数量每天都在增长,它涵盖了原型制作和开发的许多方面。
微控制器概述
MCU卡片 / MCU

建筑
AVR
MCU 内存 (KB)
32
硅供应商
Microchip
引脚数
40
RAM (字节)
2048
你完善了我!
配件
使用的MCU引脚
mikroBUS™映射器
“仔细看看!”
Click board™ 原理图

一步一步来
项目组装
实时跟踪您的结果
应用程序输出
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”替换为要显示的参数。

软件支持
库描述
这个库包含ATA6570 Click驱动的API。
关键函数:
ata6570_write_reg
- 写寄存器ata6570_read_reg
- 读寄存器
开源
代码示例
完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio。 应用程序代码也可以在MIKROE的GitHub账户中找到。
/*!
* \file
* \brief Ata6570 Click example
*
* # Description
* This application is interfaces a Controller Area Network (CAN) protocol controller and the physical two-wire CAN bus.
*
* The demo application is composed of two sections :
*
* ## Application Init
* In addition to this module is palced inside normal working mode cappable of tranmission and reception of data.
*
* ## Application Task
* Tranismiter/Receiver task depend on uncommented code
Receiver logging each received byte to the UART for data logging, while transmiter send message each
2 seconds.
*
*
* \author MikroE Team
*
*/
// ------------------------------------------------------------------- INCLUDES
#include "board.h"
#include "log.h"
#include "ata6570.h"
// ------------------------------------------------------------------ VARIABLES
#define PROCESS_RX_BUFFER_SIZE 500
// #define DEMO_APP_RECEIVER
#define DEMO_APP_TRANSMITER
static ata6570_t ata6570;
static log_t logger;
static char demo_message[ 9 ] = { 'M', 'i', 'k', 'r', 'o', 'E', 13, 10, 0 };
static int32_t rsp_size;
static char uart_rx_buffer[ PROCESS_RX_BUFFER_SIZE ] = { 0 };
// ------------------------------------------------------ APPLICATION FUNCTIONS
void application_init ( void )
{
log_cfg_t log_cfg;
ata6570_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.
ata6570_cfg_setup( &cfg );
ATA6570_MAP_MIKROBUS( cfg, MIKROBUS_1 );
ata6570_init( &ata6570, &cfg );
ata6570_write_reg( &ata6570, ATA6570_DMCR, ATA6570_OPMODE_NORMAL );
Delay_ms ( 500 );
}
void application_task ( void )
{
// Task implementation.
#ifdef DEMO_APP_RECEIVER
// RECEIVER - UART polling
rsp_size = ata6570_generic_read( &ata6570, uart_rx_buffer, PROCESS_RX_BUFFER_SIZE );
if ( rsp_size > 0 )
{
log_printf( &logger, "%s", uart_rx_buffer );
memset( uart_rx_buffer, 0, rsp_size );
}
#endif
#ifdef DEMO_APP_TRANSMITER
// TRANSMITER - TX each 2 sec
for( uint8_t i = 0; i < 8; i++ )
{
ata6570_generic_write( &ata6570, &demo_message[ i ], 1 );
}
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