fp@238: /****************************************************************************** fp@238: * fp@238: * $Id$ fp@238: * fp@238: * Copyright (C) 2006 Florian Pose, Ingenieurgemeinschaft IgH fp@238: * fp@238: * This file is part of the IgH EtherCAT Master. fp@238: * fp@238: * The IgH EtherCAT Master is free software; you can redistribute it fp@238: * and/or modify it under the terms of the GNU General Public License fp@246: * as published by the Free Software Foundation; either version 2 of the fp@246: * License, or (at your option) any later version. fp@238: * fp@238: * The IgH EtherCAT Master is distributed in the hope that it will be fp@238: * useful, but WITHOUT ANY WARRANTY; without even the implied warranty of fp@238: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the fp@238: * GNU General Public License for more details. fp@238: * fp@238: * You should have received a copy of the GNU General Public License fp@238: * along with the IgH EtherCAT Master; if not, write to the Free Software fp@238: * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA fp@238: * fp@246: * The right to use EtherCAT Technology is granted and comes free of fp@246: * charge under condition of compatibility of product made by fp@246: * Licensee. People intending to distribute/sell products based on the fp@246: * code, have to sign an agreement to guarantee that products using fp@246: * software based on IgH EtherCAT master stay compatible with the actual fp@246: * EtherCAT specification (which are released themselves as an open fp@246: * standard) as the (only) precondition to have the right to use EtherCAT fp@246: * Technology, IP and trade marks. fp@246: * fp@238: *****************************************************************************/ fp@238: fp@238: /** fp@238: \file fp@238: EtherCAT finite state machines. fp@238: */ fp@238: fp@238: /*****************************************************************************/ fp@238: fp@528: #ifndef __EC_FSM_MASTER__ fp@528: #define __EC_FSM_MASTER__ fp@238: fp@325: #include "globals.h" fp@238: #include "../include/ecrt.h" fp@293: #include "datagram.h" fp@238: #include "slave.h" fp@409: #include "canopen.h" fp@238: fp@528: #include "fsm_slave.h" fp@433: fp@238: /*****************************************************************************/ fp@238: fp@601: /** fp@601: * EEPROM request state. fp@601: */ fp@601: fp@601: typedef enum fp@601: { fp@601: EC_EEPROM_REQ_QUEUED, fp@601: EC_EEPROM_REQ_COMPLETED, fp@601: EC_EEPROM_REQ_ERROR fp@601: } fp@601: ec_eeprom_request_state_t; fp@601: fp@601: /*****************************************************************************/ fp@601: fp@601: /** fp@601: * EEPROM write request. fp@601: */ fp@601: fp@601: typedef struct fp@601: { fp@601: struct list_head list; fp@601: ec_slave_t *slave; fp@601: off_t offset; fp@601: size_t size; fp@601: const uint16_t *words; fp@601: ec_eeprom_request_state_t state; fp@601: } fp@601: ec_eeprom_write_request_t; fp@601: fp@601: /*****************************************************************************/ fp@601: fp@528: typedef struct ec_fsm_master ec_fsm_master_t; /**< \see ec_fsm_master */ fp@238: fp@238: /** fp@238: Finite state machine of an EtherCAT master. fp@238: */ fp@238: fp@528: struct ec_fsm_master fp@238: { fp@238: ec_master_t *master; /**< master the FSM runs on */ fp@528: ec_datagram_t *datagram; /**< datagram used in the state machine */ fp@505: unsigned int retries; /**< retries on datagram timeout. */ fp@238: fp@528: void (*state)(ec_fsm_master_t *); /**< master state function */ fp@528: unsigned int slaves_responding; /**< number of responding slaves */ fp@553: unsigned int topology_change_pending; /**< bus topology changed */ fp@528: ec_slave_state_t slave_states; /**< states of responding slaves */ fp@528: unsigned int validate; /**< non-zero, if validation to do */ fp@528: ec_slave_t *slave; /**< current slave */ fp@601: ec_eeprom_write_request_t *eeprom_request; /**< EEPROM write request */ fp@601: off_t eeprom_index; /**< index to EEPROM write request data */ fp@528: ec_sdo_request_t *sdo_request; /**< SDO request to process */ fp@238: fp@528: ec_fsm_slave_t fsm_slave; /**< slave state machine */ fp@433: ec_fsm_sii_t fsm_sii; /**< SII state machine */ fp@434: ec_fsm_change_t fsm_change; /**< State change state machine */ fp@436: ec_fsm_coe_t fsm_coe; /**< CoE state machine */ fp@238: }; fp@238: fp@238: /*****************************************************************************/ fp@238: fp@528: void ec_fsm_master_init(ec_fsm_master_t *, ec_master_t *, ec_datagram_t *); fp@528: void ec_fsm_master_clear(ec_fsm_master_t *); fp@446: fp@528: int ec_fsm_master_exec(ec_fsm_master_t *); fp@528: int ec_fsm_master_running(ec_fsm_master_t *); fp@528: int ec_fsm_master_success(ec_fsm_master_t *); fp@456: fp@238: /*****************************************************************************/ fp@238: fp@238: #endif