IgH EtherCAT Master  1.5.3
fsm_slave_config.h
Go to the documentation of this file.
1 /******************************************************************************
2  *
3  * Copyright (C) 2006-2023 Florian Pose, Ingenieurgemeinschaft IgH
4  *
5  * This file is part of the IgH EtherCAT Master.
6  *
7  * The IgH EtherCAT Master is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License version 2, as
9  * published by the Free Software Foundation.
10  *
11  * The IgH EtherCAT Master is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
14  * Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License along
17  * with the IgH EtherCAT Master; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19  *
20  * ---
21  *
22  * The license mentioned above concerns the source code only. Using the
23  * EtherCAT technology and brand is only permitted in compliance with the
24  * industrial property and similar rights of Beckhoff Automation GmbH.
25  *
26  *****************************************************************************/
27 
33 /*****************************************************************************/
34 
35 #ifndef __EC_FSM_SLAVE_CONFIG_H__
36 #define __EC_FSM_SLAVE_CONFIG_H__
37 
38 #include "globals.h"
39 #include "slave.h"
40 #include "datagram.h"
41 #include "fsm_change.h"
42 #include "fsm_coe.h"
43 #include "fsm_pdo.h"
44 
45 /*****************************************************************************/
46 
49 
53 {
62  unsigned int retries;
67  unsigned long jiffies_start;
68  unsigned int take_time;
69  unsigned long wait_ms;
70 };
71 
72 /*****************************************************************************/
73 
77 
79 
82 
83 /*****************************************************************************/
84 
85 #endif
void ec_fsm_slave_config_start(ec_fsm_slave_config_t *, ec_slave_t *)
Start slave configuration state machine.
Finite state machines for the Sercos over EtherCAT protocol.
Definition: fsm_soe.h:51
int ec_fsm_slave_config_success(const ec_fsm_slave_config_t *)
ec_sdo_request_t * request
SDO request for SDO configuration.
EtherCAT state change FSM.
ec_fsm_change_t * fsm_change
State change state machine.
CANopen SDO request.
Definition: sdo_request.h:46
EtherCAT slave structure.
EtherCAT datagram.
Definition: datagram.h:87
EtherCAT PDO configuration state machine structures.
void ec_fsm_slave_config_clear(ec_fsm_slave_config_t *)
Destructor.
void ec_fsm_slave_config_init(ec_fsm_slave_config_t *, ec_datagram_t *, ec_fsm_change_t *, ec_fsm_coe_t *, ec_fsm_soe_t *, ec_fsm_pdo_t *)
Constructor.
ec_sdo_request_t request_copy
Copied SDO request.
Global definitions and macros.
EtherCAT CoE state machines.
EtherCAT slave.
Definition: slave.h:176
ec_fsm_pdo_t * fsm_pdo
PDO configuration state machine.
ec_datagram_t * datagram
Datagram used in the state machine.
unsigned long wait_ms
Wait time (used to wait before SAFEOP).
void(* state)(ec_fsm_slave_config_t *)
State function.
int ec_fsm_slave_config_exec(ec_fsm_slave_config_t *)
Executes the current state of the state machine.
EtherCAT datagram structure.
ec_fsm_coe_t * fsm_coe
CoE state machine.
PDO configuration state machine.
Definition: fsm_pdo.h:54
ec_fsm_soe_t * fsm_soe
SoE state machine.
unsigned int take_time
Store jiffies after datagram reception.
Finite state machine to configure an EtherCAT slave.
ec_slave_t * slave
Slave the FSM runs on.
ec_soe_request_t soe_request_copy
Copied SDO request.
ec_soe_request_t * soe_request
SDO request for SDO configuration.
Sercos-over-EtherCAT request.
Definition: soe_request.h:48
EtherCAT state change FSM.
Definition: fsm_change.h:64
unsigned long jiffies_start
For timeout calculations.
Finite state machines for the CANopen over EtherCAT protocol.
Definition: fsm_coe.h:52
unsigned int retries
Retries on datagram timeout.