master/fsm_master.h
changeset 2589 2b9c78543663
parent 2094 83e9160319ec
--- a/master/fsm_master.h	Thu Sep 06 14:21:02 2012 +0200
+++ b/master/fsm_master.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.
  *
@@ -39,7 +39,6 @@
 
 #include "globals.h"
 #include "datagram.h"
-#include "mailbox.h"
 #include "foe_request.h"
 #include "sdo_request.h"
 #include "soe_request.h"
@@ -58,67 +57,8 @@
     size_t nwords; /**< Number of words. */
     const uint16_t *words; /**< Pointer to the data words. */
     ec_internal_request_state_t state; /**< State of the request. */
-    struct kref refcount;
 } ec_sii_write_request_t;
 
-void ec_master_sii_write_request_release(struct kref *);
-
-/*****************************************************************************/
-
-/** Register request.
- */
-typedef struct {
-    struct list_head list; /**< List head. */
-    ec_slave_t *slave; /**< EtherCAT slave. */
-    ec_direction_t dir; /**< Direction. */
-    uint16_t offset; /**< Register address. */
-    size_t length; /**< Number of bytes. */
-    uint8_t *data; /**< Data to write / memory for read data. */
-    ec_internal_request_state_t state; /**< State of the request. */
-    struct kref refcount;
-} ec_reg_request_t;
-
-void ec_master_reg_request_release(struct kref *);
-
-/*****************************************************************************/
-
-/** Slave/SDO request record for master's SDO request list.
- */
-typedef struct {
-    struct list_head list; /**< List element. */
-    ec_slave_t *slave; /**< Slave. */
-    ec_sdo_request_t req; /**< SDO request. */
-    struct kref refcount;
-} ec_master_sdo_request_t;
-
-void ec_master_sdo_request_release(struct kref *);
-
-/*****************************************************************************/
-
-/** FoE request.
- */
-typedef struct {
-    struct list_head list; /**< List head. */
-    ec_slave_t *slave; /**< EtherCAT slave. */
-    ec_foe_request_t req; /**< FoE request. */
-    struct kref refcount;
-} ec_master_foe_request_t;
-
-void ec_master_foe_request_release(struct kref *);
-
-/*****************************************************************************/
-
-/** SoE request.
- */
-typedef struct {
-    struct list_head list; /**< List head. */
-    ec_slave_t *slave; /**< EtherCAT slave. */
-    ec_soe_request_t req; /**< SoE request. */
-    struct kref refcount;
-} ec_master_soe_request_t;
-
-void ec_master_soe_request_release(struct kref *);
-
 /*****************************************************************************/
 
 typedef struct ec_fsm_master ec_fsm_master_t; /**< \see ec_fsm_master */
@@ -128,23 +68,29 @@
 struct ec_fsm_master {
     ec_master_t *master; /**< master the FSM runs on */
     ec_datagram_t *datagram; /**< datagram used in the state machine */
-    ec_mailbox_t *mbox; /**< mailbox used in the state machine */
     unsigned int retries; /**< retries on datagram timeout. */
 
     void (*state)(ec_fsm_master_t *); /**< master state function */
+    ec_device_index_t dev_idx; /**< Current device index (for scanning etc.).
+                                */
     int idle; /**< state machine is in idle phase */
     unsigned long scan_jiffies; /**< beginning of slave scanning */
-    uint8_t link_state; /**< Last main device link state. */
-    unsigned int slaves_responding; /**< number of responding slaves */
+    uint8_t link_state[EC_MAX_NUM_DEVICES]; /**< Last link state for every
+                                              device. */
+    unsigned int slaves_responding[EC_MAX_NUM_DEVICES]; /**< Number of
+                                                          responding slaves
+                                                          for every device. */
     unsigned int rescan_required; /**< A bus rescan is required. */
-    ec_slave_state_t slave_states; /**< states of responding slaves */
+    ec_slave_state_t slave_states[EC_MAX_NUM_DEVICES]; /**< AL states of
+                                                         responding slaves for
+                                                         every device. */
     ec_slave_t *slave; /**< current slave */
     ec_sii_write_request_t *sii_request; /**< SII write request */
     off_t sii_index; /**< index to SII write request data */
     ec_sdo_request_t *sdo_request; /**< SDO request to process. */
-    ec_reg_request_t *reg_request; /**< Register request to process. */
 
     ec_fsm_coe_t fsm_coe; /**< CoE state machine */
+    ec_fsm_soe_t fsm_soe; /**< SoE state machine */
     ec_fsm_pdo_t fsm_pdo; /**< PDO configuration state machine. */
     ec_fsm_change_t fsm_change; /**< State change state machine */
     ec_fsm_slave_config_t fsm_slave_config; /**< slave state machine */
@@ -157,6 +103,8 @@
 void ec_fsm_master_init(ec_fsm_master_t *, ec_master_t *, ec_datagram_t *);
 void ec_fsm_master_clear(ec_fsm_master_t *);
 
+void ec_fsm_master_reset(ec_fsm_master_t *);
+
 int ec_fsm_master_exec(ec_fsm_master_t *);
 int ec_fsm_master_idle(const ec_fsm_master_t *);