Sin descripción

sakumisu cea780af0f update: update esc register hace 2 meses
.github 72c9b3c597 ci: mark all warnings to error hace 2 meses
demo f3270f19e3 update: update lwipopt hace 2 meses
docs 8cb67b9eef docs: update readme & rst hace 2 meses
include cea780af0f update: update esc register hace 2 meses
osal e4abe2b608 fix: fix threadx sem create hace 3 meses
port dc2c878d8f feat: add renesas port hace 3 meses
scripts ee05a2b702 feat: add eni & esi parse tool hace 3 meses
src 5b22c26fba update: add delay before phy init hace 2 meses
.clang-format 53cbeb1f0e feat: add clang-format hace 3 meses
.gitattributes 3540ad7bda first commit hace 3 meses
.gitignore 3540ad7bda first commit hace 3 meses
.readthedocs.yaml 3540ad7bda first commit hace 3 meses
CMakeLists.txt 68c6303eb5 feat: enable eoe with lwip hace 2 meses
LICENSE 3540ad7bda first commit hace 3 meses
README.md b73fbd78b2 update: reduce sm info memory, change static to dynamic hace 2 meses
README_zh.md b73fbd78b2 update: reduce sm info memory, change static to dynamic hace 2 meses
SConscript 68c6303eb5 feat: enable eoe with lwip hace 2 meses
VERSION ce64632bbb docs: release v1.0.0 hace 2 meses
cherryec_config_template.h b73fbd78b2 update: reduce sm info memory, change static to dynamic hace 2 meses

README.md

English | 简体中文

CherryECAT

<a href="https://github.com/cherry-embedded/CherryECAT/releases"><img src="https://img.shields.io/github/release/cherry-embedded/CherryECAT.svg"></a>
<a href="https://github.com/cherry-embedded/CherryECAT/blob/master/LICENSE"><img src="https://img.shields.io/github/license/cherry-embedded/CherryECAT.svg?style=flat-square"></a>
<a href="https://github.com/cherry-embedded/CherryECAT/actions/workflows/build_demo.yml"><img src="https://github.com/cherry-embedded/CherryECAT/actions/workflows/build_demo.yml/badge.svg"> </a>

CherryECAT is a tiny and beautiful, high real-time and low-jitter EtherCAT master stack, specially designed for MCUs running with RTOS.

Feature

  • ~ 4K ram, ~40K flash(24K + 16K shell cmd, including log)
  • Asynchronous queue-based transfer (one transfer can carry multiple datagrams)
  • Zero-copy technology: directly use enet tx/rx buffer to fill and parse ethercat data
  • Support hot-plugging
    • Automatic scanning bus
    • Automatic updating slave information when the topology changes
  • Support automatic monitoring slave status
  • Support distributed clocks
  • Support CANopen over EtherCAT(COE)
  • Support File over EtherCAT(FOE)
  • Support Ethernet over EtherCAT(EOE)
  • Support Slave SII access
  • Support Slave register access
  • Support multi master
  • Support backup redundancy(TODO)
  • Minimum PDO cyclic time < 40 us (depends on master and slave hardware)
  • DC jitter < 3us (depends on master and slave hardware)
  • Support multi cyclic time(every slave can use different proportional cyclic time)
  • Support ethercat cmd with shell, ref to IgH

The pic shows dc jitter < 3us (hpm6800evk with flash_xip): ethercat

Hardware limitations

  • Master

    • CPU (Coremark/Mhz > 5.0, cache > 16K, memcpy speed > 100MB/s)
    • ENET must support descriptor dma and iperf with lwip > 90 Mbps
    • Must support High-Precision Timer (jitter < 1us)
    • Must support High-Precision timestamp (ARM DWT/RISC-V MCYCLE)
    • Must support long long print
  • Slave

    • Must support COE
    • Must support sdo complete access
    • SII must have sync manager information

Shell cmd

ethercat ethercat ethercat ethercat ethercat ethercat ethercat ethercat ethercat ethercat

Tool

  • esi_parser

Use esi_parser.py to generate slave eeprom information and download eeprom to slave.

python ./esi_parser.py ECAT_CIA402_ESI.xml eeprom.bin eeprom.h

Parsing XML file: ECAT_CIA402_ESI.xml
Parsed XML: Vendor=0x0048504D, Product=0x00000003
Device Name: ECAT_CIA402
Mailbox RX: 0x1000(128)
Mailbox TX: 0x1080(128)
Generating EEPROM data...
✓ Successfully converted 'ECAT_CIA402_ESI.xml' to 'eeprom.bin'
✓ Generated 2048 bytes of EEPROM data
✓ Vendor ID: 0x0048504D
✓ Product Code: 0x00000003
✓ Revision: 0x00000001
✓ Device Name: ECAT_CIA402
✓ Generated C header file: eeprom.h
  • eni_parser

Use eni_parser.py to generate CherryECAT slave sync config.

python ./eni_parser.py ECAT_CIA402_ENI.xml sync_config.h

Parsing ENI file: ECAT_CIA402_ENI.xml
Generating C code...
✓ Successfully converted 'ECAT_CIA402_ENI.xml' to 'sync_config.h'
✓ Generated C code for 1 slave(s)
✓ Slave 1:
  - RxPDO 0x1602: 3 entries
  - TxPDO 0x1A02: 3 entries

Support Boards

  • HPM6750EVK2/HPM6800EVK/HPM5E00EVK(hybrid internal)
  • RT-Thread RZN2L-EtherKit

Contact

QQ group: 563650597

License

FOE, EOE and backup redundancy features are available in Royalty-Free; other are free to use