fp@39: /****************************************************************************** fp@0: * fp@39: * $Id$ fp@0: * fp@1618: * Copyright (C) 2006 Florian Pose, Ingenieurgemeinschaft IgH fp@1618: * fp@1618: * This file is part of the IgH EtherCAT Master. fp@1618: * fp@1618: * The IgH EtherCAT Master is free software; you can redistribute it fp@1618: * and/or modify it under the terms of the GNU General Public License fp@1618: * as published by the Free Software Foundation; version 2 of the License. fp@1618: * fp@1618: * The IgH EtherCAT Master is distributed in the hope that it will be fp@1618: * useful, but WITHOUT ANY WARRANTY; without even the implied warranty of fp@1618: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the fp@1618: * GNU General Public License for more details. fp@1618: * fp@1618: * You should have received a copy of the GNU General Public License fp@1618: * along with the IgH EtherCAT Master; if not, write to the Free Software fp@1618: * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA fp@1618: * fp@39: *****************************************************************************/ fp@0: fp@1618: /** fp@1618: \file fp@1618: Global definitions and macros. fp@1618: */ fp@1618: fp@1618: /*****************************************************************************/ fp@1618: fp@0: #ifndef _EC_GLOBALS_ fp@0: #define _EC_GLOBALS_ fp@0: fp@152: #include fp@152: fp@1617: /****************************************************************************** fp@1617: * EtherCAT master fp@1617: *****************************************************************************/ fp@41: fp@1618: /** master main version */ fp@1617: #define EC_MASTER_VERSION_MAIN 1 fp@1618: fp@1618: /** master sub version (after the dot) */ fp@1617: #define EC_MASTER_VERSION_SUB 0 fp@1618: fp@1618: /** master extra version (just a string) */ fp@1617: #define EC_MASTER_VERSION_EXTRA "stable" fp@1617: fp@1617: /** maximum number of FMMUs per slave */ fp@1617: #define EC_MAX_FMMUS 16 fp@1617: fp@1617: /****************************************************************************** fp@1617: * EtherCAT protocol fp@1617: *****************************************************************************/ fp@1617: fp@1617: /** maximum size of an EtherCAT frame (without header and CRC) */ fp@1617: #define EC_MAX_FRAME_SIZE 1500 fp@1617: fp@1618: /** minimum size of an EtherCAT frame (without header and CRC) */ fp@1617: #define EC_MIN_FRAME_SIZE 46 fp@1617: fp@1617: /** size of an EtherCAT frame header */ fp@1617: #define EC_FRAME_HEADER_SIZE 2 fp@1617: fp@1617: /** size of an EtherCAT command header */ fp@1617: #define EC_COMMAND_HEADER_SIZE 10 fp@1617: fp@1617: /** size of an EtherCAT command footer */ fp@1617: #define EC_COMMAND_FOOTER_SIZE 2 fp@1617: fp@1617: /** size of a sync manager configuration page */ fp@1617: #define EC_SYNC_SIZE 8 fp@1617: fp@1617: /** size of an FMMU configuration page */ fp@1617: #define EC_FMMU_SIZE 16 fp@1617: fp@1617: /** resulting maximum data size of a single command in a frame */ fp@1617: #define EC_MAX_DATA_SIZE (EC_MAX_FRAME_SIZE - EC_FRAME_HEADER_SIZE \ fp@1617: - EC_COMMAND_HEADER_SIZE - EC_COMMAND_FOOTER_SIZE) fp@0: fp@152: /*****************************************************************************/ fp@152: fp@84: #define EC_INFO(fmt, args...) \ fp@84: printk(KERN_INFO "EtherCAT: " fmt, ##args) fp@84: #define EC_ERR(fmt, args...) \ fp@84: printk(KERN_ERR "EtherCAT ERROR: " fmt, ##args) fp@84: #define EC_WARN(fmt, args...) \ fp@84: printk(KERN_WARNING "EtherCAT WARNING: " fmt, ##args) fp@84: #define EC_DBG(fmt, args...) \ fp@84: printk(KERN_DEBUG "EtherCAT DEBUG: " fmt, ##args) fp@84: fp@184: #define EC_LIT(X) #X fp@184: #define EC_STR(X) EC_LIT(X) fp@184: fp@1618: /** fp@1618: Convenience macro for defining SysFS attributes. fp@1618: */ fp@1618: fp@184: #define EC_SYSFS_READ_ATTR(NAME) \ fp@184: static struct attribute attr_##NAME = { \ fp@184: .name = EC_STR(NAME), .owner = THIS_MODULE, .mode = S_IRUGO \ fp@184: } fp@184: fp@41: /*****************************************************************************/ fp@41: fp@152: extern void ec_print_data(const uint8_t *, size_t); fp@152: extern void ec_print_data_diff(const uint8_t *, const uint8_t *, size_t); fp@152: fp@152: /*****************************************************************************/ fp@152: fp@164: /** fp@195: Code - Message pair. fp@164: Some EtherCAT commands support reading a status code to display a certain fp@164: message. This type allows to map a code to a message string. fp@164: */ fp@164: fp@164: typedef struct fp@164: { fp@195: uint32_t code; /**< code */ fp@195: const char *message; /**< message belonging to \a code */ fp@164: } fp@164: ec_code_msg_t; fp@164: fp@164: /*****************************************************************************/ fp@164: fp@0: #endif fp@73: