master/datagram.h
author Florian Pose <fp@igh-essen.com>
Fri, 22 Feb 2008 12:29:30 +0000
changeset 814 a51f857b1b2d
parent 809 ec4ef8911824
child 815 002fe9ec778f
permissions -rw-r--r--
Renamed [PS]DO to [PS]do.
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     1
/******************************************************************************
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     2
 *
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     3
 *  $Id$
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     4
 *
197
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
     5
 *  Copyright (C) 2006  Florian Pose, Ingenieurgemeinschaft IgH
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
     6
 *
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
     7
 *  This file is part of the IgH EtherCAT Master.
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
     8
 *
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
     9
 *  The IgH EtherCAT Master is free software; you can redistribute it
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    10
 *  and/or modify it under the terms of the GNU General Public License
246
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    11
 *  as published by the Free Software Foundation; either version 2 of the
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    12
 *  License, or (at your option) any later version.
197
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    13
 *
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    14
 *  The IgH EtherCAT Master is distributed in the hope that it will be
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    15
 *  useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    16
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    17
 *  GNU General Public License for more details.
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    18
 *
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    19
 *  You should have received a copy of the GNU General Public License
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    20
 *  along with the IgH EtherCAT Master; if not, write to the Free Software
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    21
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
b9a6e2c22745 GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents: 195
diff changeset
    22
 *
246
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    23
 *  The right to use EtherCAT Technology is granted and comes free of
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    24
 *  charge under condition of compatibility of product made by
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    25
 *  Licensee. People intending to distribute/sell products based on the
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    26
 *  code, have to sign an agreement to guarantee that products using
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    27
 *  software based on IgH EtherCAT master stay compatible with the actual
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    28
 *  EtherCAT specification (which are released themselves as an open
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    29
 *  standard) as the (only) precondition to have the right to use EtherCAT
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    30
 *  Technology, IP and trade marks.
0bf7c769de06 Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents: 238
diff changeset
    31
 *
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    32
 *****************************************************************************/
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    33
199
04ecf40fc2e9 Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents: 197
diff changeset
    34
/**
04ecf40fc2e9 Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents: 197
diff changeset
    35
   \file
293
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
    36
   EtherCAT datagram structure.
199
04ecf40fc2e9 Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents: 197
diff changeset
    37
*/
04ecf40fc2e9 Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents: 197
diff changeset
    38
04ecf40fc2e9 Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents: 197
diff changeset
    39
/*****************************************************************************/
04ecf40fc2e9 Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents: 197
diff changeset
    40
293
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
    41
#ifndef _EC_DATAGRAM_H_
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
    42
#define _EC_DATAGRAM_H_
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    43
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    44
#include <linux/list.h>
294
feea8d850c65 Applied include patch by M. Schwerin.
Florian Pose <fp@igh-essen.com>
parents: 293
diff changeset
    45
#include <linux/time.h>
208
b7797f8a813d command timeout, EoE processing with kernel timer.
Florian Pose <fp@igh-essen.com>
parents: 199
diff changeset
    46
#include <linux/timex.h>
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    47
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    48
#include "globals.h"
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    49
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    50
/*****************************************************************************/
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    51
719
03d5b96632fb Store skipped information in datagrams; name datagrams for statistics
Florian Pose <fp@igh-essen.com>
parents: 713
diff changeset
    52
/** size of the datagram description string */
03d5b96632fb Store skipped information in datagrams; name datagrams for statistics
Florian Pose <fp@igh-essen.com>
parents: 713
diff changeset
    53
#define EC_DATAGRAM_NAME_SIZE 20
03d5b96632fb Store skipped information in datagrams; name datagrams for statistics
Florian Pose <fp@igh-essen.com>
parents: 713
diff changeset
    54
03d5b96632fb Store skipped information in datagrams; name datagrams for statistics
Florian Pose <fp@igh-essen.com>
parents: 713
diff changeset
    55
/*****************************************************************************/
03d5b96632fb Store skipped information in datagrams; name datagrams for statistics
Florian Pose <fp@igh-essen.com>
parents: 713
diff changeset
    56
809
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    57
/** EtherCAT datagram type.
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    58
 */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    59
typedef enum {
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    60
    EC_DATAGRAM_NONE = 0x00, /**< Dummy. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    61
    EC_DATAGRAM_APRD = 0x01, /**< Auto-increment physical read. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    62
    EC_DATAGRAM_APWR = 0x02, /**< Auto-increment physical write. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    63
    EC_DATAGRAM_NPRD = 0x04, /**< Node-addressed physical read. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    64
    EC_DATAGRAM_NPWR = 0x05, /**< Node-addressed physical write. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    65
    EC_DATAGRAM_BRD  = 0x07, /**< Broadcast read. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    66
    EC_DATAGRAM_BWR  = 0x08, /**< Broadcast write. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    67
    EC_DATAGRAM_LRW  = 0x0C  /**< Logical read/write. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    68
} ec_datagram_type_t;
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    69
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    70
/*****************************************************************************/
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    71
809
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    72
/** EtherCAT datagram state.
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    73
 */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    74
typedef enum {
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    75
    EC_DATAGRAM_INIT,      /**< Initial state of a new datagram. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    76
    EC_DATAGRAM_QUEUED,    /**< Queued for sending. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    77
    EC_DATAGRAM_SENT,      /**< Sent (still in the queue). */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    78
    EC_DATAGRAM_RECEIVED,  /**< Received (dequeued). */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    79
    EC_DATAGRAM_TIMED_OUT, /**< Timed out (dequeued). */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    80
    EC_DATAGRAM_ERROR      /**< Error while sending/receiving (dequeued). */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    81
} ec_datagram_state_t;
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    82
809
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    83
/*****************************************************************************/
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    84
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    85
/** EtherCAT datagram.
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    86
 */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    87
typedef struct {
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    88
    struct list_head list; /**< Needed by domain datagram lists. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    89
    struct list_head queue; /**< Master datagram queue item. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    90
    struct list_head sent; /**< Master list item for sent datagrams. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    91
    ec_datagram_type_t type; /**< Datagram type (APRD, BWR, etc.). */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    92
    uint8_t address[EC_ADDR_LEN]; /**< Recipient address. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    93
    uint8_t *data; /**< Datagram payload. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    94
    ec_origin_t data_origin; /**< Origin of the \a data memory. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    95
    size_t mem_size; /**< Datagram \a data memory size. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    96
    size_t data_size; /**< Size of the data in \a data. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    97
    uint8_t index; /**< Index (set by master). */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    98
    uint16_t working_counter; /**< Working counter. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
    99
    ec_datagram_state_t state; /**< State. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   100
    cycles_t cycles_sent; /**< Time, when the datagram was sent. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   101
    unsigned long jiffies_sent; /**< Jiffies, when the datagram was sent. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   102
    cycles_t cycles_received; /**< Time, when the datagram was received. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   103
    unsigned long jiffies_received; /**< Jiffies, when the datagram was
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   104
                                      received. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   105
    unsigned int skip_count; /**< Number of requeues when not yet received. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   106
    unsigned long stats_output_jiffies; /**< Last statistics output. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   107
    char name[EC_DATAGRAM_NAME_SIZE]; /**< Description of the datagram. */
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   108
} ec_datagram_t;
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   109
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   110
/*****************************************************************************/
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   111
293
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   112
void ec_datagram_init(ec_datagram_t *);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   113
void ec_datagram_clear(ec_datagram_t *);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   114
int ec_datagram_prealloc(ec_datagram_t *, size_t);
144
fdc24bf62f80 Dynamischer Kommandospeicher, Domain-Kommandos als Liste.
Florian Pose <fp@igh-essen.com>
parents: 98
diff changeset
   115
293
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   116
int ec_datagram_nprd(ec_datagram_t *, uint16_t, uint16_t, size_t);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   117
int ec_datagram_npwr(ec_datagram_t *, uint16_t, uint16_t, size_t);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   118
int ec_datagram_aprd(ec_datagram_t *, uint16_t, uint16_t, size_t);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   119
int ec_datagram_apwr(ec_datagram_t *, uint16_t, uint16_t, size_t);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   120
int ec_datagram_brd(ec_datagram_t *, uint16_t, size_t);
14aeb79aa992 Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents: 246
diff changeset
   121
int ec_datagram_bwr(ec_datagram_t *, uint16_t, size_t);
809
ec4ef8911824 External domain memory.
Florian Pose <fp@igh-essen.com>
parents: 719
diff changeset
   122
int ec_datagram_lrw(ec_datagram_t *, uint32_t, size_t, uint8_t *);
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   123
713
ae41cadd25b6 Better handling of unexpected working counters; introduced
Florian Pose <fp@igh-essen.com>
parents: 708
diff changeset
   124
void ec_datagram_print_wc_error(const ec_datagram_t *);
719
03d5b96632fb Store skipped information in datagrams; name datagrams for statistics
Florian Pose <fp@igh-essen.com>
parents: 713
diff changeset
   125
void ec_datagram_output_stats(ec_datagram_t *datagram);
713
ae41cadd25b6 Better handling of unexpected working counters; introduced
Florian Pose <fp@igh-essen.com>
parents: 708
diff changeset
   126
98
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   127
/*****************************************************************************/
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   128
f564d0929292 MERGE branches/async 222:233 -> trunk (Kommando-Warteschlangen).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   129
#endif