--- a/master/fsm_slave.h Thu Sep 06 14:21:02 2012 +0200
+++ b/master/fsm_slave.h Mon Nov 03 15:20:05 2014 +0100
@@ -2,7 +2,7 @@
*
* $Id$
*
- * Copyright (C) 2006-2008 Florian Pose, Ingenieurgemeinschaft IgH
+ * Copyright (C) 2006-2012 Florian Pose, Ingenieurgemeinschaft IgH
*
* This file is part of the IgH EtherCAT Master.
*
@@ -29,20 +29,23 @@
/**
\file
- EtherCAT slave request (SDO) state machine.
+ EtherCAT slave request state machine.
*/
/*****************************************************************************/
+
#ifndef __EC_FSM_SLAVE_H__
#define __EC_FSM_SLAVE_H__
#include "globals.h"
#include "datagram.h"
#include "sdo_request.h"
+#include "reg_request.h"
#include "fsm_coe.h"
#include "fsm_foe.h"
#include "fsm_soe.h"
-#include "fsm_master.h"
+
+/*****************************************************************************/
typedef struct ec_fsm_slave ec_fsm_slave_t; /**< \see ec_fsm_slave */
@@ -50,26 +53,29 @@
*/
struct ec_fsm_slave {
ec_slave_t *slave; /**< slave the FSM runs on */
- ec_mailbox_t *mbox; /**< mailbox used in the state machine */
+ struct list_head list; /**< Used for execution list. */
- void (*state)(ec_fsm_slave_t *); /**< master state function */
- ec_master_sdo_request_t *sdo_request; /**< SDO request to process. */
- ec_master_foe_request_t *foe_request; /**< FoE request to process. */
- off_t foe_index; /**< index to FoE write request data */
- ec_master_soe_request_t *soe_request; /**< SoE request to process. */
+ void (*state)(ec_fsm_slave_t *, ec_datagram_t *); /**< State function. */
+ ec_datagram_t *datagram; /**< Previous state datagram. */
+ ec_sdo_request_t *sdo_request; /**< SDO request to process. */
+ ec_reg_request_t *reg_request; /**< Register request to process. */
+ ec_foe_request_t *foe_request; /**< FoE request to process. */
+ off_t foe_index; /**< Index to FoE write request data. */
+ ec_soe_request_t *soe_request; /**< SoE request to process. */
- ec_fsm_coe_t fsm_coe; /**< CoE state machine */
- ec_fsm_foe_t fsm_foe; /**< FoE state machine */
- ec_fsm_soe_t fsm_soe; /**< SoE state machine */
+ ec_fsm_coe_t fsm_coe; /**< CoE state machine. */
+ ec_fsm_foe_t fsm_foe; /**< FoE state machine. */
+ ec_fsm_soe_t fsm_soe; /**< SoE state machine. */
};
/*****************************************************************************/
-void ec_fsm_slave_init(ec_fsm_slave_t *, ec_slave_t *, ec_mailbox_t *);
+void ec_fsm_slave_init(ec_fsm_slave_t *, ec_slave_t *);
void ec_fsm_slave_clear(ec_fsm_slave_t *);
-int ec_fsm_slave_exec(ec_fsm_slave_t *);
-void ec_fsm_slave_ready(ec_fsm_slave_t *);
+int ec_fsm_slave_exec(ec_fsm_slave_t *, ec_datagram_t *);
+void ec_fsm_slave_set_ready(ec_fsm_slave_t *);
+int ec_fsm_slave_is_ready(const ec_fsm_slave_t *);
/*****************************************************************************/