IgH EtherCAT Master  1.5.2
fsm_eoe.h
Go to the documentation of this file.
1 /*****************************************************************************
2  *
3  * $Id$
4  *
5  * Copyright (C) 2006-2014 Florian Pose, Ingenieurgemeinschaft IgH
6  *
7  * This file is part of the IgH EtherCAT Master.
8  *
9  * The IgH EtherCAT Master is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License version 2, as
11  * published by the Free Software Foundation.
12  *
13  * The IgH EtherCAT Master is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
16  * Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License along
19  * with the IgH EtherCAT Master; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21  *
22  * ---
23  *
24  * The license mentioned above concerns the source code only. Using the
25  * EtherCAT technology and brand is only permitted in compliance with the
26  * industrial property and similar rights of Beckhoff Automation GmbH.
27  *
28  ****************************************************************************/
29 
35 /****************************************************************************/
36 
37 #ifndef __EC_FSM_EOE_H__
38 #define __EC_FSM_EOE_H__
39 
40 #include "globals.h"
41 #include "datagram.h"
42 #include "slave.h"
43 #include "eoe_request.h"
44 
45 /****************************************************************************/
46 
47 typedef struct ec_fsm_eoe ec_fsm_eoe_t;
51 struct ec_fsm_eoe {
53  unsigned int retries;
57  unsigned long jiffies_start;
59 };
60 
61 /****************************************************************************/
62 
65 
68 
70 int ec_fsm_eoe_success(const ec_fsm_eoe_t *);
71 
72 /****************************************************************************/
73 
74 #endif
ec_slave_t * slave
slave the FSM runs on
Definition: fsm_eoe.h:52
EtherCAT slave structure.
EtherCAT datagram.
Definition: datagram.h:88
ec_eoe_request_t * request
EoE request.
Definition: fsm_eoe.h:58
void ec_fsm_eoe_clear(ec_fsm_eoe_t *)
Destructor.
Definition: fsm_eoe.c:79
Global definitions and macros.
unsigned long jiffies_start
Timestamp.
Definition: fsm_eoe.h:57
EtherCAT slave.
Definition: slave.h:214
int ec_fsm_eoe_exec(ec_fsm_eoe_t *, ec_datagram_t *)
Executes the current state of the state machine.
Definition: fsm_eoe.c:106
EtherCAT EoE request structure.
void ec_fsm_eoe_init(ec_fsm_eoe_t *)
Constructor.
Definition: fsm_eoe.c:63
void ec_fsm_eoe_set_ip_param(ec_fsm_eoe_t *, ec_slave_t *, ec_eoe_request_t *)
Starts to set the EoE IP partameters of a slave.
Definition: fsm_eoe.c:89
void(* state)(ec_fsm_eoe_t *, ec_datagram_t *)
EoE state function.
Definition: fsm_eoe.h:55
EtherCAT datagram structure.
Ethernet-over-EtherCAT set IP parameter request.
Definition: eoe_request.h:49
int ec_fsm_eoe_success(const ec_fsm_eoe_t *)
Returns, if the state machine terminated with success.
Definition: fsm_eoe.c:131
unsigned int retries
retries upon datagram timeout
Definition: fsm_eoe.h:53
Finite state machines for the Ethernet over EtherCAT protocol.
Definition: fsm_eoe.h:51
ec_datagram_t * datagram
Datagram used in the previous step.
Definition: fsm_eoe.h:56