.. _ecat_cia402: ECAT_CiA402 ====================== 1. 概述 --------- ECAT_CIA402示例演示使用ESC外设, 基于ETG从站协议栈代码(SSC)实现CANOPEN CiA402协议控制电机的功能。 该例程程序支持对ESC的EEPROM数据进行初始化,能够简化更新ESC的EEPROM的步骤。 如果程序代码中包含由SSC Tool生成的EEPROM数据(eeprom.h), 会检查ESC的EEPROM中存储的数据并根据条件进行更新。 如果EEPROM中的EtherCAT Slave Controller Configuration Area(前8个Word)的数据checksum校验失败,则会使用eeprom.h中的数据初始化EEPROM。 如果EEPROM中的EtherCAT Slave Controller Configuration Area(前8个Word)的数据checksum校验成功,则会进一步校验EEPROM数据中的Product Code和Revision Code。 当Product Code不同或eeprom.h中的Revision Number大于当前已经存储的EEPROM数据的Revision Number时,则会使用eeprom.h中的数据初始化EEPROM。 该方法能够解决初次使用时EEPROM为空情况下checksum校验失败的问题,能够对EEPROM进行初始化。在程序升级阶段,新的程序代码包含的eeprom.h中的Revision Number大于当前已经存储的EEPROM数据的Revision Number时,会使用新程序中的eeprom.h初始化EEPROM,而无需通过主站工具如TwinCAT等去更新EEPROM。 2. 准备 --------- 请参照ECAT_IO的README - 本例程电机使用的是雷赛智能的 **BLM57050-1000** 无刷电机,电机具体参数请参考 `雷赛智能官网 `_ 。 - 板子设置参考开发板文档 :ref:`Motor Pin ` 相关内容 - 完成上述过程后,给驱动板上电观察电流无异常后,给核心板上电,再次确认电流无异常后,就可以烧录程序,观察运行现象。 3. 工程设置 --------------- 3.1 使用Flash模拟EEPROM ~~~~~~~~~~~~~~~~~~~~~~~~~~~ 请参照ECAT_IO的README **注意** : 使用FLASH模拟EEPROM功能时,需要为FLASH_EEPROM内容分配合适的flash空间, 避免与其他的flash内容产生冲突。 3.2 使用虚拟电机 ~~~~~~~~~~~~~~~~~~~~~~ 默认使用实际电机进行运动控制,如果需要使用虚拟电机, 在文件`CMakeLists.txt`中, 设置"set(CONFIG_CIA402_USING_ACTUAL_MOTOR 0)"。 4. 生成从站协议栈代码 ------------------------------ 由于许可问题, HPM_SDK不提供EtherCAT从站协议栈代码(SSC), 用户须从倍福官网下载SSC Tool并生成从站协议栈代码。 4.1. 下载SSC Tool ~~~~~~~~~~~~~~~~~~~ 请参照ECAT_IO的README 4.2 SSC Tool中导入配置文件 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 请参考ECAT_IO的README描述, 配置文件路径为: /samples/ethercat/ecat_foe/SSC/Config/HPM_ECAT_CIA402_Config.xml 4.3 SSC Tool生成协议栈代码 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1. 创建新工程, 选择指定的配置文件 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/ssc_create_project.png :alt: 2. 指定输出路径,生成协议栈代码 4.4 SSC协议栈代码修改 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 通过打patch的方式添加电机控制相关代码到SSC生成的代码。 在SSC目录下的命令行窗口执行:patch -d Src < ssc_cia402.patch .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/ssc_patch.png :alt: **注意** :如果你的电脑上没有安装patch命令,你需要安装2.5.9版或更高版本的GNU patch。如果已安装,请跳过此步骤。从 `网站 `_ 下载patch命令(当前版本为2.5.9),并将"patch.exe"的安装路径添加到系统环境变量中以便能在命令行窗口中执行patch命令。 5. TwinCAT工程设置 ---------------------- 5.1. 添加ESI文件 ~~~~~~~~~~~~~~~~~~~~ 1. 请根据实际硬件端口数目修改SSC工具生成的ESI文件中的设备的属性(), 默认生成的属性为"YY",表示实现了Port0和Port1两个端口。如实际实现了Port0, Port1和Port2三个端口,请手动修改属性为"YYY"。 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/esc_device_physics_cia402.png :alt: 2. 将ESI文件复制到TwinCAT的安装目录下(如: **C:/TwinCAT/3.1/Config/Io/EtherCAT** )。 5.2 创建工程 ~~~~~~~~~~~~~~~~ 请参照ECAT_IO的README 5.3 软件配置 ~~~~~~~~~~~~~~~~ 请参照ECAT_IO的README 5.4 扫描设备 ~~~~~~~~~~~~~~~~ 请参照ECAT_IO的README 5.5 更新EEPROM ~~~~~~~~~~~~~~~~ 请参照ECAT_IO的README, 选择正确的ESI文件更新EEPROM内容 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_eeprom_update_cia402.png :alt: 5.6 NC轴控制操作 ~~~~~~~~~~~~~~~~~~~~~ 1. 扫描设备,建立NC轴, 从站默认工作在csv模式: .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_scan_nc.png :alt: .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_scan_result.png :alt: 2. 检查同步单元设置, DC周期会与NC-Task同步 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_device_sync_unit.png :alt: 3. 检查NC Axis与Device的链接关系 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_check_link.png :alt: 4. 检查NC Axis的Enc参数 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_enc_parameter.png :alt: 5. 设置NC Task周期, DC周期应与该值相同。 此处可以设置大一些的周期时间, 避免使用PC做TwinCAT主站时, 由于PC实时性较差造成通信抖动引起"0x1a Synchronnization error". .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_task_cycle.png :alt: 6. 设置DC模式 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_slave_dc_setting.png :alt: .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_device_dc_setting.png :alt: 7. 设置NC轴参数, 关闭主站的软件限位设置,避免测试操作中报错。 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis.png :alt: 8. 激活配置,进入运行模式 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_active_configuration.png :alt: 9. NC轴控制页面选项说明 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_online_0.png :alt: 10. 在线控制NC轴运动 a. 在"Enabling"选项中点击"Set->All",启动控制器 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_enable.png :alt: b. 设置目标位置和速度, 注意目标速度值不应超过7mm/s(虚拟电机没有速度限制), 设置后点击"F5"启动 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_setting.png :alt: c. 查看目标实际位置和速度 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_csv_run.png :alt: .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_csv_stop.png :alt: 11. 更改NC轴控制模式为csp .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_slave_cfg_to_csp.png :alt: 12. 将NC Axis与Device重新链接 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_link.png :alt: 13. 参考步骤8, 重新激活配置 14. 按照上诉步骤使能控制器, 设置新的目标位置和速度, 观察实际位置和速度的变化 a. 参考步骤10.a, 使能控制器 b. 设置新的目标位置和速度,注意目标速度值不应超过7mm/s, 设置后点击"F5"启动 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_csp_setting.png :alt: c. 查看目标实际位置和速度 .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_csp_run.png :alt: .. image:: ../../../../../samples/ethercat/ecat_cia402/doc/twincat_nc_axis_csp_stop.png :alt: 6. 运行现象 --------------- 当工程正确运行后, 串口终端会输出如下信息, 通过TwinCAT NC Axis控制页面可以控制电机运动: 当需要初始化EEPROM数据时,log如下: .. code-block:: console EtherCAT CiA402 motor sample Init EEPROM content. Init EEPROM content successful. EEPROM loading successful, no checksum error. 当不需初始化EEPROM数据时,log如下: .. code-block:: console EtherCAT CiA402 motor sample No need to init EEPROM content. EEPROM loading successful, no checksum error.