29#ifndef __EC_FSM_SOE_H__
30#define __EC_FSM_SOE_H__
EtherCAT datagram structure.
int ec_fsm_soe_success(const ec_fsm_soe_t *)
Returns, if the state machine terminated with success.
void ec_fsm_soe_init(ec_fsm_soe_t *)
Constructor.
struct ec_fsm_soe ec_fsm_soe_t
void ec_fsm_soe_clear(ec_fsm_soe_t *)
Destructor.
void ec_fsm_soe_transfer(ec_fsm_soe_t *, ec_slave_t *, ec_soe_request_t *)
Starts to transfer an IDN to/from a slave.
int ec_fsm_soe_exec(ec_fsm_soe_t *, ec_datagram_t *)
Executes the current state of the state machine.
Global definitions and macros.
struct ec_slave ec_slave_t
struct ec_soe_request ec_soe_request_t
EtherCAT slave structure.
EtherCAT SoE request structure.
Finite state machines for the Sercos over EtherCAT protocol.
void(* state)(ec_fsm_soe_t *, ec_datagram_t *)
CoE state function.
off_t offset
IDN data offset during fragmented write.
unsigned int retries
retries upon datagram timeout
ec_slave_t * slave
slave the FSM runs on
ec_datagram_t * datagram
Datagram used in the previous step.
unsigned long jiffies_start
Timestamp.
ec_soe_request_t * request
SoE request.
size_t fragment_size
Size of the current fragment.