155 #include <asm/byteorder.h> 156 #include <linux/types.h> 157 #include <linux/time.h> 161 #include <sys/time.h> 170 #define ECRT_VER_MAJOR 1 174 #define ECRT_VER_MINOR 6 178 #define ECRT_VERSION(a, b) (((a) << 8) + (b)) 182 #define ECRT_VERSION_MAGIC ECRT_VERSION(ECRT_VER_MAJOR, ECRT_VER_MINOR) 193 #define EC_HAVE_REDUNDANCY 199 #define EC_HAVE_EMERGENCY 207 #define EC_HAVE_REG_ACCESS 211 #define EC_HAVE_SELECT_REF_CLOCK 215 #define EC_HAVE_REF_CLOCK_TIME 219 #define EC_HAVE_REG_BY_POS 223 #define EC_HAVE_SYNC_TO 227 #define EC_HAVE_FLAGS 235 #define EC_HAVE_SOE_REQUESTS 240 #define EC_HAVE_SCAN_PROGRESS 246 #ifndef EC_PUBLIC_API 247 # if defined(ethercat_EXPORTS) && !defined(__KERNEL__) 248 # define EC_PUBLIC_API __attribute__ ((visibility ("default"))) 250 # define EC_PUBLIC_API 264 #define EC_MAX_SYNC_MANAGERS 16 270 #define EC_MAX_STRING_LENGTH 64 273 #define EC_MAX_PORTS 4 283 #define EC_TIMEVAL2NANO(TV) \ 284 (((TV).tv_sec - 946684800ULL) * 1000000000ULL + (TV).tv_usec * 1000ULL) 290 #define EC_COE_EMERGENCY_MSG_SIZE 8 649 unsigned int master_index
666 unsigned int master_index
669 #endif // #ifndef __KERNEL__ 702 #endif // #ifndef __KERNEL__ 725 void (*send_cb)(
void *),
726 void (*receive_cb)(
void *),
784 uint32_t product_code
842 uint16_t slave_position,
859 uint16_t slave_position,
876 uint16_t slave_position,
892 uint16_t slave_position,
913 uint16_t slave_position,
933 uint16_t slave_position,
951 uint16_t slave_position,
970 uint16_t slave_position,
989 uint16_t slave_position,
1050 size_t send_interval
1118 unsigned int dev_idx,
1299 uint16_t watchdog_divider,
1304 uint16_t watchdog_intervals
1354 uint16_t entry_index,
1356 uint8_t entry_subindex,
1358 uint8_t entry_bit_length
1450 unsigned int n_syncs,
1476 uint16_t entry_index,
1477 uint8_t entry_subindex,
1479 unsigned int *bit_position
1499 unsigned int pdo_pos,
1500 unsigned int entry_pos,
1502 unsigned int *bit_position
1523 uint16_t assign_activate,
1524 uint32_t sync0_cycle,
1525 int32_t sync0_shift,
1526 uint32_t sync1_cycle,
1559 const uint8_t *data,
1576 uint8_t sdo_subindex,
1593 uint8_t sdo_subindex,
1610 uint8_t sdo_subindex,
1630 const uint8_t *data,
1821 const uint8_t *data,
2270 uint16_t vendor_type
2289 uint32_t *vendor_id,
2290 uint16_t *vendor_type
2518 #define EC_READ_BIT(DATA, POS) ((*((uint8_t *) (DATA)) >> (POS)) & 0x01) 2526 #define EC_WRITE_BIT(DATA, POS, VAL) \ 2528 if (VAL) *((uint8_t *) (DATA)) |= (1 << (POS)); \ 2529 else *((uint8_t *) (DATA)) &= ~(1 << (POS)); \ 2538 #if __BYTE_ORDER == __LITTLE_ENDIAN 2540 #define le16_to_cpu(x) x 2541 #define le32_to_cpu(x) x 2542 #define le64_to_cpu(x) x 2544 #define cpu_to_le16(x) x 2545 #define cpu_to_le32(x) x 2546 #define cpu_to_le64(x) x 2548 #elif __BYTE_ORDER == __BIG_ENDIAN 2552 (((uint16_t)(x) & 0x00ffU) << 8) | \ 2553 (((uint16_t)(x) & 0xff00U) >> 8) )) 2556 (((uint32_t)(x) & 0x000000ffUL) << 24) | \ 2557 (((uint32_t)(x) & 0x0000ff00UL) << 8) | \ 2558 (((uint32_t)(x) & 0x00ff0000UL) >> 8) | \ 2559 (((uint32_t)(x) & 0xff000000UL) >> 24) )) 2562 (((uint64_t)(x) & 0x00000000000000ffULL) << 56) | \ 2563 (((uint64_t)(x) & 0x000000000000ff00ULL) << 40) | \ 2564 (((uint64_t)(x) & 0x0000000000ff0000ULL) << 24) | \ 2565 (((uint64_t)(x) & 0x00000000ff000000ULL) << 8) | \ 2566 (((uint64_t)(x) & 0x000000ff00000000ULL) >> 8) | \ 2567 (((uint64_t)(x) & 0x0000ff0000000000ULL) >> 24) | \ 2568 (((uint64_t)(x) & 0x00ff000000000000ULL) >> 40) | \ 2569 (((uint64_t)(x) & 0xff00000000000000ULL) >> 56) )) 2571 #define le16_to_cpu(x) swap16(x) 2572 #define le32_to_cpu(x) swap32(x) 2573 #define le64_to_cpu(x) swap64(x) 2575 #define cpu_to_le16(x) swap16(x) 2576 #define cpu_to_le32(x) swap32(x) 2577 #define cpu_to_le64(x) swap64(x) 2581 #define le16_to_cpup(x) le16_to_cpu(*((uint16_t *)(x))) 2582 #define le32_to_cpup(x) le32_to_cpu(*((uint32_t *)(x))) 2583 #define le64_to_cpup(x) le64_to_cpu(*((uint64_t *)(x))) 2595 #define EC_READ_U8(DATA) \ 2596 ((uint8_t) *((uint8_t *) (DATA))) 2603 #define EC_READ_S8(DATA) \ 2604 ((int8_t) *((uint8_t *) (DATA))) 2611 #define EC_READ_U16(DATA) \ 2612 ((uint16_t) le16_to_cpup((void *) (DATA))) 2619 #define EC_READ_S16(DATA) \ 2620 ((int16_t) le16_to_cpup((void *) (DATA))) 2627 #define EC_READ_U32(DATA) \ 2628 ((uint32_t) le32_to_cpup((void *) (DATA))) 2635 #define EC_READ_S32(DATA) \ 2636 ((int32_t) le32_to_cpup((void *) (DATA))) 2643 #define EC_READ_U64(DATA) \ 2644 ((uint64_t) le64_to_cpup((void *) (DATA))) 2651 #define EC_READ_S64(DATA) \ 2652 ((int64_t) le64_to_cpup((void *) (DATA))) 2672 #define EC_READ_REAL(DATA) ecrt_read_real(DATA) 2686 #define EC_READ_LREAL(DATA) ecrt_read_lreal(DATA) 2688 #endif // ifndef __KERNEL__ 2699 #define EC_WRITE_U8(DATA, VAL) \ 2701 *((uint8_t *)(DATA)) = ((uint8_t) (VAL)); \ 2709 #define EC_WRITE_S8(DATA, VAL) EC_WRITE_U8(DATA, VAL) 2716 #define EC_WRITE_U16(DATA, VAL) \ 2718 *((uint16_t *) (DATA)) = cpu_to_le16((uint16_t) (VAL)); \ 2726 #define EC_WRITE_S16(DATA, VAL) EC_WRITE_U16(DATA, VAL) 2733 #define EC_WRITE_U32(DATA, VAL) \ 2735 *((uint32_t *) (DATA)) = cpu_to_le32((uint32_t) (VAL)); \ 2743 #define EC_WRITE_S32(DATA, VAL) EC_WRITE_U32(DATA, VAL) 2750 #define EC_WRITE_U64(DATA, VAL) \ 2752 *((uint64_t *) (DATA)) = cpu_to_le64((uint64_t) (VAL)); \ 2760 #define EC_WRITE_S64(DATA, VAL) EC_WRITE_U64(DATA, VAL) 2773 EC_PUBLIC_API void ecrt_write_real(
void *data,
float value);
2780 #define EC_WRITE_REAL(DATA, VAL) ecrt_write_real(DATA, VAL) 2787 EC_PUBLIC_API void ecrt_write_lreal(
void *data,
double value);
2794 #define EC_WRITE_LREAL(DATA, VAL) ecrt_write_lreal(DATA, VAL) 2796 #endif // ifndef __KERNEL__ unsigned int working_counter
Value of the last working counter.
uint32_t serial_number
Serial-Number stored on the slave.
ec_slave_port_desc_t desc
Physical port type.
uint8_t subindex
PDO entry subindex.
EC_PUBLIC_API int ecrt_slave_config_emerg_clear(ec_slave_config_t *sc)
Clears CoE emergency ring buffer and the overrun counter.
uint16_t position
Slave position.
EC_PUBLIC_API int ecrt_master_deactivate(ec_master_t *master)
Deactivates the master.
uint8_t sync_count
Number of sync managers.
EC_PUBLIC_API int ecrt_slave_config_pdo_assign_clear(ec_slave_config_t *sc, uint8_t sync_index)
Clear a sync manager's PDO assignment.
EC_PUBLIC_API int ecrt_master_link_state(const ec_master_t *master, unsigned int dev_idx, ec_master_link_state_t *state)
Reads the current state of a redundant link.
unsigned int n_entries
Number of PDO entries in entries to map.
#define EC_PUBLIC_API
Symbol visibility control macro.
uint8_t bit_length
Size of the PDO entry in bit.
ec_direction_t dir
Sync manager direction.
uint8_t error_flag
Error flag for that slave.
EC_PUBLIC_API size_t ecrt_sdo_request_data_size(const ec_sdo_request_t *req)
Returns the current SDO data size.
ec_watchdog_mode_t
Watchdog mode for sync manager configuration.
EC_PUBLIC_API int ecrt_master_sync_reference_clock_to(ec_master_t *master, uint64_t sync_time)
Queues the DC reference clock drift compensation datagram for sending.
ec_slave_port_desc_t
EtherCAT slave port descriptor.
ec_pdo_info_t const * pdos
Array with PDOs to assign.
EC_PUBLIC_API int ecrt_slave_config_sdo32(ec_slave_config_t *sc, uint16_t sdo_index, uint8_t sdo_subindex, uint32_t value)
Add a configuration value for a 32-bit SDO.
ec_al_state_t
Application-layer state.
EC_PUBLIC_API int ecrt_sdo_request_timeout(ec_sdo_request_t *req, uint32_t timeout)
Set the timeout for an SDO request.
EC_PUBLIC_API int ecrt_slave_config_state(const ec_slave_config_t *sc, ec_slave_config_state_t *state)
Outputs the state of the slave configuration.
EC_PUBLIC_API int ecrt_master_scan_progress(ec_master_t *master, ec_master_scan_progress_t *progress)
Obtains network scan progress information.
EC_PUBLIC_API int ecrt_reg_request_write(ec_reg_request_t *req, uint16_t address, size_t size)
Schedule an register write operation.
EC_PUBLIC_API int ecrt_voe_handler_write(ec_voe_handler_t *voe, size_t size)
Start a VoE write operation.
EC_PUBLIC_API int ecrt_voe_handler_read(ec_voe_handler_t *voe)
Start a VoE read operation.
EC_PUBLIC_API int ecrt_soe_request_timeout(ec_soe_request_t *req, uint32_t timeout)
Set the timeout for an SoE request.
unsigned int redundancy_active
Redundant link is in use.
ec_request_state_t ecrt_sdo_request_state(const ec_sdo_request_t *req)
Get the current state of the SDO request.
EC_PUBLIC_API int ecrt_slave_config_watchdog(ec_slave_config_t *sc, uint16_t watchdog_divider, uint16_t watchdog_intervals)
Configure a slave's watchdog times.
unsigned int slave_count
Number of slaves in the network.
EC_PUBLIC_API int ecrt_domain_reg_pdo_entry_list(ec_domain_t *domain, const ec_pdo_entry_reg_t *pdo_entry_regs)
Registers a bunch of PDO entries for a domain.
EC_PUBLIC_API int ecrt_master_sdo_download_complete(ec_master_t *master, uint16_t slave_position, uint16_t index, const uint8_t *data, size_t data_size, uint32_t *abort_code)
Executes an SDO download request to write data to a slave via complete access.
EC_PUBLIC_API ec_domain_t * ecrt_master_create_domain(ec_master_t *master)
Creates a new process data domain.
uint16_t index
PDO entry index.
EC_PUBLIC_API int ecrt_master_send(ec_master_t *master)
Sends all datagrams in the queue.
EC_PUBLIC_API int ecrt_slave_config_reg_pdo_entry(ec_slave_config_t *sc, uint16_t entry_index, uint8_t entry_subindex, ec_domain_t *domain, unsigned int *bit_position)
Registers a PDO entry for process data exchange in a domain.
EC_PUBLIC_API int ecrt_reg_request_read(ec_reg_request_t *req, uint16_t address, size_t size)
Schedule a register read operation.
EC_PUBLIC_API uint8_t * ecrt_soe_request_data(const ec_soe_request_t *req)
Access to the SoE request's data.
uint32_t vendor_id
Vendor-ID stored on the slave.
ec_slave_port_link_t link
Port link state.
unsigned int slaves_responding
Sum of responding slaves on the given link.
EC_PUBLIC_API int ecrt_slave_config_sdo(ec_slave_config_t *sc, uint16_t index, uint8_t subindex, const uint8_t *data, size_t size)
Add an SDO configuration.
void ecrt_master_callbacks(ec_master_t *master, void(*send_cb)(void *), void(*receive_cb)(void *), void *cb_data)
Sets the locking callbacks.
EC_PUBLIC_API int ecrt_slave_config_sync_manager(ec_slave_config_t *sc, uint8_t sync_index, ec_direction_t direction, ec_watchdog_mode_t watchdog_mode)
Configure a sync manager.
Master scan progress information.
uint32_t delay_to_next_dc
Delay [ns] to next DC slave.
unsigned int link_up
true, if the given Ethernet link is up.
EC_PUBLIC_API int ecrt_soe_request_idn(ec_soe_request_t *req, uint8_t drive_no, uint16_t idn)
Set the request's drive and Sercos ID numbers.
EC_PUBLIC_API int ecrt_slave_config_idn(ec_slave_config_t *sc, uint8_t drive_no, uint16_t idn, ec_al_state_t state, const uint8_t *data, size_t size)
Add an SoE IDN configuration.
ec_wc_state_t wc_state
Working counter interpretation.
PDO configuration information.
Sync manager configuration information.
ec_wc_state_t
Domain working counter interpretation.
uint8_t signal_detected
Detected signal on RX port.
EtherCAT slave port information.
EC_PUBLIC_API int ecrt_slave_config_reg_pdo_entry_pos(ec_slave_config_t *sc, uint8_t sync_index, unsigned int pdo_pos, unsigned int entry_pos, ec_domain_t *domain, unsigned int *bit_position)
Registers a PDO entry using its position.
unsigned int slaves_responding
Sum of responding slaves on all Ethernet devices.
EC_PUBLIC_API int ecrt_master_sync_slave_clocks(ec_master_t *master)
Queues the DC clock drift compensation datagram for sending.
EC_PUBLIC_API int ecrt_slave_config_sdo8(ec_slave_config_t *sc, uint16_t sdo_index, uint8_t sdo_subindex, uint8_t value)
Add a configuration value for an 8-bit SDO.
void ecrt_domain_external_memory(ec_domain_t *domain, uint8_t *memory)
Provide external memory to store the domain's process data.
EC_PUBLIC_API ec_voe_handler_t * ecrt_slave_config_create_voe_handler(ec_slave_config_t *sc, size_t size)
Create an VoE handler to exchange vendor-specific data during realtime operation. ...
unsigned int link_up
true, if the network link is up.
EC_PUBLIC_API int ecrt_master_write_idn(ec_master_t *master, uint16_t slave_position, uint8_t drive_no, uint16_t idn, const uint8_t *data, size_t data_size, uint16_t *error_code)
Executes an SoE write request.
Some of the registered process data were exchanged.
EC_PUBLIC_API unsigned int ecrt_version_magic(void)
Returns the version magic of the realtime interface.
uint32_t revision_number
Revision-Number stored on the slave.
EC_PUBLIC_API int ecrt_master_sync_monitor_queue(ec_master_t *master)
Queues the DC synchrony monitoring datagram for sending.
Use the default setting of the sync manager.
EC_PUBLIC_API ec_sdo_request_t * ecrt_slave_config_create_sdo_request(ec_slave_config_t *sc, uint16_t index, uint8_t subindex, size_t size)
Create an SDO request to exchange SDOs during realtime operation.
EC_PUBLIC_API uint8_t * ecrt_domain_data(const ec_domain_t *domain)
Returns the domain's process data.
uint16_t alias
Slave alias address.
EC_PUBLIC_API int ecrt_master_reference_clock_time(const ec_master_t *master, uint32_t *time)
Get the lower 32 bit of the reference clock system time.
EC_PUBLIC_API ec_request_state_t ecrt_voe_handler_execute(ec_voe_handler_t *voe)
Execute the handler.
uint8_t loop_closed
Loop closed.
EC_PUBLIC_API uint8_t * ecrt_reg_request_data(const ec_reg_request_t *req)
Access to the register request's data.
Slave configuration state.
Request is being processed.
uint64_t app_time
Application time.
ec_watchdog_mode_t watchdog_mode
Watchdog mode.
unsigned int n_pdos
Number of PDOs in pdos.
EC_PUBLIC_API int ecrt_sdo_request_index(ec_sdo_request_t *req, uint16_t index, uint8_t subindex)
Set the SDO index and subindex.
EC_PUBLIC_API int ecrt_slave_config_emerg_overruns(const ec_slave_config_t *sc)
Read the number of CoE emergency overruns.
uint32_t vendor_id
Slave vendor ID.
unsigned int al_state
The application-layer state of the slave.
unsigned int * bit_position
Pointer to a variable to store a bit position (0-7) within the offset.
EC_PUBLIC_API int ecrt_master_reset(ec_master_t *master)
Retry configuring slaves.
EC_PUBLIC_API size_t ecrt_domain_size(const ec_domain_t *domain)
Returns the current size of the domain's process data.
unsigned int operational
The slave was brought into OP state using the specified configuration.
EC_PUBLIC_API uint8_t * ecrt_sdo_request_data(const ec_sdo_request_t *req)
Access to the SDO request's data.
EC_PUBLIC_API int ecrt_sdo_request_write(ec_sdo_request_t *req)
Schedule an SDO write operation.
EC_PUBLIC_API int ecrt_master_read_idn(ec_master_t *master, uint16_t slave_position, uint8_t drive_no, uint16_t idn, uint8_t *target, size_t target_size, size_t *result_size, uint16_t *error_code)
Executes an SoE read request.
ec_direction_t
Direction type for PDO assignment functions.
EC_PUBLIC_API int ecrt_domain_queue(ec_domain_t *domain)
(Re-)queues all domain datagrams in the master's datagram queue.
EC_PUBLIC_API ec_slave_config_t * ecrt_master_slave_config(ec_master_t *master, uint16_t alias, uint16_t position, uint32_t vendor_id, uint32_t product_code)
Obtains a slave configuration.
EC_PUBLIC_API int ecrt_master_sync_reference_clock(ec_master_t *master)
Queues the DC reference clock drift compensation datagram for sending.
EC_PUBLIC_API int ecrt_slave_config_flag(ec_slave_config_t *sc, const char *key, int32_t value)
Adds a feature flag to a slave configuration.
EC_PUBLIC_API int ecrt_slave_config_emerg_pop(ec_slave_config_t *sc, uint8_t *target)
Read and remove one record from the CoE emergency ring buffer.
Vendor specific over EtherCAT handler.
EC_PUBLIC_API size_t ecrt_soe_request_data_size(const ec_soe_request_t *req)
Returns the current IDN data size.
ec_pdo_entry_info_t const * entries
Array of PDO entries to map.
EC_PUBLIC_API int ecrt_slave_config_pdo_assign_add(ec_slave_config_t *sc, uint8_t sync_index, uint16_t index)
Add a PDO to a sync manager's PDO assignment.
EC_PUBLIC_API int ecrt_slave_config_dc(ec_slave_config_t *sc, uint16_t assign_activate, uint32_t sync0_cycle, int32_t sync0_shift, uint32_t sync1_cycle, int32_t sync1_shift)
Configure distributed clocks.
EC_PUBLIC_API ec_reg_request_t * ecrt_slave_config_create_reg_request(ec_slave_config_t *sc, size_t size)
Create a register request to exchange EtherCAT register contents during realtime operation.
int ecrt_master_send_ext(ec_master_t *master)
Sends non-application datagrams.
EC_PUBLIC_API int ecrt_master_select_reference_clock(ec_master_t *master, ec_slave_config_t *sc)
Selects the reference clock for distributed clocks.
Values read by the master.
EC_PUBLIC_API int ecrt_voe_handler_received_header(const ec_voe_handler_t *voe, uint32_t *vendor_id, uint16_t *vendor_type)
Reads the header data of a received VoE message.
unsigned int online
The slave is online.
EC_PUBLIC_API int ecrt_domain_process(ec_domain_t *domain)
Determines the states of the domain's datagrams.
EC_PUBLIC_API int ecrt_master_application_time(ec_master_t *master, uint64_t app_time)
Sets the application time.
EC_PUBLIC_API int ecrt_master(ec_master_t *master, ec_master_info_t *master_info)
Obtains master information.
EC_PUBLIC_API int ecrt_soe_request_write(ec_soe_request_t *req)
Schedule an SoE IDN write operation.
ec_request_state_t ecrt_reg_request_state(const ec_reg_request_t *req)
Get the current state of the register request.
EC_PUBLIC_API int ecrt_slave_config_pdo_mapping_clear(ec_slave_config_t *sc, uint16_t pdo_index)
Clear the mapping of a given PDO.
EC_PUBLIC_API uint32_t ecrt_master_sync_monitor_process(const ec_master_t *master)
Processes the DC synchrony monitoring datagram.
EC_PUBLIC_API int ecrt_master_get_slave(ec_master_t *master, uint16_t slave_position, ec_slave_info_t *slave_info)
Obtains slave information.
uint16_t index
PDO entry index.
uint8_t al_state
Current state of the slave.
uint8_t scan_busy
true, while the master is scanning the network.
EC_PUBLIC_API ec_master_t * ecrt_request_master(unsigned int master_index)
Requests an EtherCAT master for realtime operation.
int16_t current_on_ebus
Used current in mA.
EC_PUBLIC_API int ecrt_soe_request_read(ec_soe_request_t *req)
Schedule an SoE IDN read operation.
#define EC_MAX_PORTS
Maximum number of slave ports.
EC_PUBLIC_API int ecrt_master_sdo_download(ec_master_t *master, uint16_t slave_position, uint16_t index, uint8_t subindex, const uint8_t *data, size_t data_size, uint32_t *abort_code)
Executes an SDO download request to write data to a slave.
EC_PUBLIC_API uint8_t * ecrt_voe_handler_data(const ec_voe_handler_t *voe)
Access to the VoE handler's data.
EC_PUBLIC_API ec_soe_request_t * ecrt_slave_config_create_soe_request(ec_slave_config_t *sc, uint8_t drive_no, uint16_t idn, size_t size)
Create an SoE request to exchange SoE IDNs during realtime operation.
EC_PUBLIC_API int ecrt_slave_config_complete_sdo(ec_slave_config_t *sc, uint16_t index, const uint8_t *data, size_t size)
Add configuration data for a complete SDO.
uint16_t sdo_count
Number of SDOs.
#define EC_MAX_STRING_LENGTH
Maximum string length.
EC_PUBLIC_API int ecrt_sdo_request_read(ec_sdo_request_t *req)
Schedule an SDO read operation.
List record type for PDO entry mass-registration.
unsigned int link_up
true, if at least one Ethernet link is up.
EC_PUBLIC_API int ecrt_slave_config_pdos(ec_slave_config_t *sc, unsigned int n_syncs, const ec_sync_info_t syncs[])
Specify a complete PDO configuration.
EC_PUBLIC_API ec_request_state_t ecrt_soe_request_state(const ec_soe_request_t *req)
Get the current state of the SoE request.
unsigned int scan_index
Index of the slave that is currently scanned.
uint16_t next_slave
Ring position of next DC slave on that port.
EC_PUBLIC_API int ecrt_domain_state(const ec_domain_t *domain, ec_domain_state_t *state)
Reads the state of a domain.
No registered process data were exchanged.
All registered process data were exchanged.
unsigned int al_states
Application-layer states of all slaves.
EC_PUBLIC_API int ecrt_master_activate(ec_master_t *master)
Finishes the configuration phase and prepares for cyclic operation.
EC_PUBLIC_API size_t ecrt_voe_handler_data_size(const ec_voe_handler_t *voe)
Returns the current data size.
uint16_t alias
The slaves alias if not equal to 0.
EtherCAT slave configuration.
uint32_t product_code
Product-Code stored on the slave.
unsigned int slave_count
Number of slaves detected.
Request was processed successfully.
EC_PUBLIC_API int ecrt_master_receive(ec_master_t *master)
Fetches received frames from the hardware and processes the datagrams.
unsigned int * offset
Pointer to a variable to store the PDO entry's (byte-)offset in the process data. ...
ec_request_state_t
Request state.
PDO entry configuration information.
uint8_t index
Sync manager index.
Values written by the master.
EC_PUBLIC_API int ecrt_slave_config_sdo16(ec_slave_config_t *sc, uint16_t sdo_index, uint8_t sdo_subindex, uint16_t value)
Add a configuration value for a 16-bit SDO.
unsigned int al_states
Application-layer states of the slaves on the given link.
EC_PUBLIC_API int ecrt_slave_config_pdo_mapping_add(ec_slave_config_t *sc, uint16_t pdo_index, uint16_t entry_index, uint8_t entry_subindex, uint8_t entry_bit_length)
Add a PDO entry to the given PDO's mapping.
EC_PUBLIC_API int ecrt_slave_config_emerg_size(ec_slave_config_t *sc, size_t elements)
Set the size of the CoE emergency ring buffer.
uint16_t position
Offset of the slave in the ring.
uint32_t receive_time
Receive time on DC transmission delay measurement.
uint32_t product_code
Slave product code.
Request processing failed.
EC_PUBLIC_API int ecrt_master_set_send_interval(ec_master_t *master, size_t send_interval)
Set interval between calls to ecrt_master_send().
uint8_t link_up
Link detected.
uint8_t subindex
PDO entry subindex.
EC_PUBLIC_API int ecrt_master_state(const ec_master_t *master, ec_master_state_t *state)
Reads the current master state.
Sercos-over-EtherCAT request.
EC_PUBLIC_API void ecrt_release_master(ec_master_t *master)
Releases a requested EtherCAT master.
EC_PUBLIC_API int ecrt_master_sdo_upload(ec_master_t *master, uint16_t slave_position, uint16_t index, uint8_t subindex, uint8_t *target, size_t target_size, size_t *result_size, uint32_t *abort_code)
Executes an SDO upload request to read data from a slave.
EC_PUBLIC_API int ecrt_voe_handler_send_header(ec_voe_handler_t *voe, uint32_t vendor_id, uint16_t vendor_type)
Sets the VoE header for future send operations.
EC_PUBLIC_API int ecrt_voe_handler_read_nosync(ec_voe_handler_t *voe)
Start a VoE read operation without querying the sync manager status.