author | Florian Pose <fp@igh-essen.com> |
Fri, 13 May 2011 15:36:46 +0200 | |
changeset 2070 | 1e2a9fcb3095 |
parent 2037 | ea0319750e13 |
child 2106 | 505871ced767 |
permissions | -rw-r--r-- |
39
6965c23a6826
likely/unlikely, Fehlermeldungen in zyklischem Code begrenzt und Kommentare ge??ndert.
Florian Pose <fp@igh-essen.com>
parents:
19
diff
changeset
|
1 |
/****************************************************************************** |
0 | 2 |
* |
39
6965c23a6826
likely/unlikely, Fehlermeldungen in zyklischem Code begrenzt und Kommentare ge??ndert.
Florian Pose <fp@igh-essen.com>
parents:
19
diff
changeset
|
3 |
* $Id$ |
0 | 4 |
* |
1326
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
5 |
* Copyright (C) 2006-2008 Florian Pose, Ingenieurgemeinschaft IgH |
197
b9a6e2c22745
GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents:
196
diff
changeset
|
6 |
* |
b9a6e2c22745
GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents:
196
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:
196
diff
changeset
|
8 |
* |
1326
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
9 |
* The IgH EtherCAT Master is free software; you can redistribute it and/or |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
10 |
* modify it under the terms of the GNU General Public License version 2, as |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
11 |
* published by the Free Software Foundation. |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
12 |
* |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
13 |
* The IgH EtherCAT Master is distributed in the hope that it will be useful, |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
14 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
15 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
16 |
* Public License for more details. |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
17 |
* |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
18 |
* You should have received a copy of the GNU General Public License along |
ef907b0b5125
merge -c1603 branches/stable-1.4: Changed licence headers to avoid conflicts with the GPL; restricted licence to GPLv2 only.
Florian Pose <fp@igh-essen.com>
parents:
1312
diff
changeset
|
19 |
* with the IgH EtherCAT Master; if not, write to the Free Software |
197
b9a6e2c22745
GPLv2 License and enhanced Doxygen output.
Florian Pose <fp@igh-essen.com>
parents:
196
diff
changeset
|
20 |
* 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:
196
diff
changeset
|
21 |
* |
1363
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1337
diff
changeset
|
22 |
* --- |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1337
diff
changeset
|
23 |
* |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1337
diff
changeset
|
24 |
* The license mentioned above concerns the source code only. Using the |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1337
diff
changeset
|
25 |
* EtherCAT technology and brand is only permitted in compliance with the |
11c0b2caa253
Improved and added license headers.
Florian Pose <fp@igh-essen.com>
parents:
1337
diff
changeset
|
26 |
* industrial property and similar rights of Beckhoff Automation GmbH. |
246
0bf7c769de06
Changed license headers and added EtherCAT license notice.
Florian Pose <fp@igh-essen.com>
parents:
228
diff
changeset
|
27 |
* |
39
6965c23a6826
likely/unlikely, Fehlermeldungen in zyklischem Code begrenzt und Kommentare ge??ndert.
Florian Pose <fp@igh-essen.com>
parents:
19
diff
changeset
|
28 |
*****************************************************************************/ |
0 | 29 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
30 |
/** \file |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
31 |
* Global definitions and macros. |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
32 |
*/ |
199
04ecf40fc2e9
Doxygen added interface modules and file documentation.
Florian Pose <fp@igh-essen.com>
parents:
197
diff
changeset
|
33 |
|
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 |
|
883
4963e22a267a
Equalized defines against duplicated header inclusion.
Florian Pose <fp@igh-essen.com>
parents:
872
diff
changeset
|
36 |
#ifndef __EC_MASTER_GLOBALS_H__ |
4963e22a267a
Equalized defines against duplicated header inclusion.
Florian Pose <fp@igh-essen.com>
parents:
872
diff
changeset
|
37 |
#define __EC_MASTER_GLOBALS_H__ |
0 | 38 |
|
444
31223539fc00
Compiler flag -DSVNREV only for module.c to avoid unnecessary recompiling.
Florian Pose <fp@igh-essen.com>
parents:
427
diff
changeset
|
39 |
#include "../globals.h" |
1209 | 40 |
#include "../include/ecrt.h" |
392
eaee3c8d6ae0
Debug interfaces not compiled by default.
Florian Pose <fp@igh-essen.com>
parents:
382
diff
changeset
|
41 |
|
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
42 |
#ifdef __KERNEL__ |
2035
72a4e043e67d
always use rt_mutex instead of semaphore for mutual exclusion on kernels >= 2.6.24 (removed --enable-mutex build option)
Martin Troxler <ch1010277@ch10pc446>
parents:
2028
diff
changeset
|
43 |
#include <linux/version.h> |
72a4e043e67d
always use rt_mutex instead of semaphore for mutual exclusion on kernels >= 2.6.24 (removed --enable-mutex build option)
Martin Troxler <ch1010277@ch10pc446>
parents:
2028
diff
changeset
|
44 |
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,24) |
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
45 |
#include <linux/rtmutex.h> |
2035
72a4e043e67d
always use rt_mutex instead of semaphore for mutual exclusion on kernels >= 2.6.24 (removed --enable-mutex build option)
Martin Troxler <ch1010277@ch10pc446>
parents:
2028
diff
changeset
|
46 |
#endif // KERNEL_VERSION(2,6,24) |
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
47 |
#endif // __KERNEL__ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
48 |
|
2037
ea0319750e13
Optionally compile with trace_printk support
Martin Troxler <ch1010277@ch10pc446>
parents:
2035
diff
changeset
|
49 |
#ifdef CONFIG_TRACING |
ea0319750e13
Optionally compile with trace_printk support
Martin Troxler <ch1010277@ch10pc446>
parents:
2035
diff
changeset
|
50 |
//#define USE_TRACE_PRINTK |
ea0319750e13
Optionally compile with trace_printk support
Martin Troxler <ch1010277@ch10pc446>
parents:
2035
diff
changeset
|
51 |
#endif |
ea0319750e13
Optionally compile with trace_printk support
Martin Troxler <ch1010277@ch10pc446>
parents:
2035
diff
changeset
|
52 |
|
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
53 |
/****************************************************************************** |
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
54 |
* EtherCAT master |
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
55 |
*****************************************************************************/ |
41 | 56 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
57 |
/** Datagram timeout in microseconds. */ |
325
7833cf70c4f2
VERSION 1.1: New realtime interface, only state machines.
Florian Pose <fp@igh-essen.com>
parents:
293
diff
changeset
|
58 |
#define EC_IO_TIMEOUT 500 |
7833cf70c4f2
VERSION 1.1: New realtime interface, only state machines.
Florian Pose <fp@igh-essen.com>
parents:
293
diff
changeset
|
59 |
|
2022
393e7aef6706
renamed ext_injection_timeout -> fsm_injection_timeout
Martin Troxler <ch1010277@ch10pc446>
parents:
1982
diff
changeset
|
60 |
/** FSM injection timeout in microseconds. */ |
393e7aef6706
renamed ext_injection_timeout -> fsm_injection_timeout
Martin Troxler <ch1010277@ch10pc446>
parents:
1982
diff
changeset
|
61 |
#define EC_FSM_INJECTION_TIMEOUT 10000 |
1585
1f640e321ee4
ecrt_master_set_max_cycle_size: limit SDO traffic
Martin Troxler <martin.troxler@komaxgroup.com>
parents:
1489
diff
changeset
|
62 |
|
1774
a9143f82c7c5
Fixed name of byte transmission time define; changed coding style.
Florian Pose <fp@igh-essen.com>
parents:
1606
diff
changeset
|
63 |
/** Time to send a byte in nanoseconds. |
a9143f82c7c5
Fixed name of byte transmission time define; changed coding style.
Florian Pose <fp@igh-essen.com>
parents:
1606
diff
changeset
|
64 |
* |
a9143f82c7c5
Fixed name of byte transmission time define; changed coding style.
Florian Pose <fp@igh-essen.com>
parents:
1606
diff
changeset
|
65 |
* t_ns = 1 / (100 MBit/s / 8 bit/byte) = 80 ns/byte |
a9143f82c7c5
Fixed name of byte transmission time define; changed coding style.
Florian Pose <fp@igh-essen.com>
parents:
1606
diff
changeset
|
66 |
*/ |
a9143f82c7c5
Fixed name of byte transmission time define; changed coding style.
Florian Pose <fp@igh-essen.com>
parents:
1606
diff
changeset
|
67 |
#define EC_BYTE_TRANSMISSION_TIME_NS 80 |
1585
1f640e321ee4
ecrt_master_set_max_cycle_size: limit SDO traffic
Martin Troxler <martin.troxler@komaxgroup.com>
parents:
1489
diff
changeset
|
68 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
69 |
/** Number of state machine retries on datagram timeout. */ |
505
bc443ca0077f
State machines re-send datagrams on timeout.
Florian Pose <fp@igh-essen.com>
parents:
453
diff
changeset
|
70 |
#define EC_FSM_RETRIES 3 |
bc443ca0077f
State machines re-send datagrams on timeout.
Florian Pose <fp@igh-essen.com>
parents:
453
diff
changeset
|
71 |
|
1327
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
72 |
/** Seconds to wait before fetching SDO dictionary |
427
f70c7c6db7f4
Added EC_WAIT_SDO_DICT define.
Florian Pose <fp@igh-essen.com>
parents:
403
diff
changeset
|
73 |
after slave entered PREOP state. */ |
f70c7c6db7f4
Added EC_WAIT_SDO_DICT define.
Florian Pose <fp@igh-essen.com>
parents:
403
diff
changeset
|
74 |
#define EC_WAIT_SDO_DICT 3 |
f70c7c6db7f4
Added EC_WAIT_SDO_DICT define.
Florian Pose <fp@igh-essen.com>
parents:
403
diff
changeset
|
75 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
76 |
/** Minimum size of a buffer used with ec_state_string(). */ |
453
2ecaa53c6291
Changed output of ec_state_string() for error flag to "+ ERROR".
Florian Pose <fp@igh-essen.com>
parents:
444
diff
changeset
|
77 |
#define EC_STATE_STRING_SIZE 32 |
403
7bb931deccd9
Added EC_SLAVE_STATE_ACK_ERR to ec_state_string(); added EC_STATE_STRING_SIZE
Florian Pose <fp@igh-essen.com>
parents:
392
diff
changeset
|
78 |
|
872 | 79 |
/** Maximum SII size in words, to avoid infinite reading. */ |
1443
731422684dfd
Changed EC_MAX_SII_SIZE to 4096.
Florian Pose <fp@igh-essen.com>
parents:
1438
diff
changeset
|
80 |
#define EC_MAX_SII_SIZE 4096 |
696
24fac09b5b26
Limited EEPROM reading; added EC_FIRST_EEPROM_CATEGORY_HEADER define.
Florian Pose <fp@igh-essen.com>
parents:
649
diff
changeset
|
81 |
|
1851
a56bd34e20a1
Frame statistics in 'ethercat master' output.
Florian Pose <fp@igh-essen.com>
parents:
1826
diff
changeset
|
82 |
/** Number of statistic rate intervals to maintain. */ |
a56bd34e20a1
Frame statistics in 'ethercat master' output.
Florian Pose <fp@igh-essen.com>
parents:
1826
diff
changeset
|
83 |
#define EC_RATE_COUNT 3 |
a56bd34e20a1
Frame statistics in 'ethercat master' output.
Florian Pose <fp@igh-essen.com>
parents:
1826
diff
changeset
|
84 |
|
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
85 |
/****************************************************************************** |
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
86 |
* EtherCAT protocol |
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
87 |
*****************************************************************************/ |
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
88 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
89 |
/** Size of an EtherCAT frame header. */ |
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
90 |
#define EC_FRAME_HEADER_SIZE 2 |
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
91 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
92 |
/** Size of an EtherCAT datagram header. */ |
293
14aeb79aa992
Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents:
259
diff
changeset
|
93 |
#define EC_DATAGRAM_HEADER_SIZE 10 |
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
94 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
95 |
/** Size of an EtherCAT datagram footer. */ |
293
14aeb79aa992
Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents:
259
diff
changeset
|
96 |
#define EC_DATAGRAM_FOOTER_SIZE 2 |
196
f8a1e9f364a3
Introduced version number define.
Florian Pose <fp@igh-essen.com>
parents:
195
diff
changeset
|
97 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
98 |
/** Size of the EtherCAT address field. */ |
708
90bdb315f560
Fixed EtherCAT addressing problem on big-endian systems. The slaves
Florian Pose <fp@igh-essen.com>
parents:
696
diff
changeset
|
99 |
#define EC_ADDR_LEN 4 |
90bdb315f560
Fixed EtherCAT addressing problem on big-endian systems. The slaves
Florian Pose <fp@igh-essen.com>
parents:
696
diff
changeset
|
100 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
101 |
/** Resulting maximum data size of a single datagram in a frame. */ |
211
c684b6b7adaf
Using kernel Ethernet constants.
Florian Pose <fp@igh-essen.com>
parents:
199
diff
changeset
|
102 |
#define EC_MAX_DATA_SIZE (ETH_DATA_LEN - EC_FRAME_HEADER_SIZE \ |
293
14aeb79aa992
Renamed command structure to datagram.
Florian Pose <fp@igh-essen.com>
parents:
259
diff
changeset
|
103 |
- EC_DATAGRAM_HEADER_SIZE - EC_DATAGRAM_FOOTER_SIZE) |
0 | 104 |
|
1217
e8a9785e63c3
Introduced EC_MBOX_HEADER_SIZE.
Florian Pose <fp@igh-essen.com>
parents:
1209
diff
changeset
|
105 |
/** Mailbox header size. */ |
e8a9785e63c3
Introduced EC_MBOX_HEADER_SIZE.
Florian Pose <fp@igh-essen.com>
parents:
1209
diff
changeset
|
106 |
#define EC_MBOX_HEADER_SIZE 6 |
e8a9785e63c3
Introduced EC_MBOX_HEADER_SIZE.
Florian Pose <fp@igh-essen.com>
parents:
1209
diff
changeset
|
107 |
|
872 | 108 |
/** Word offset of first SII category. */ |
109 |
#define EC_FIRST_SII_CATEGORY_OFFSET 0x40 |
|
696
24fac09b5b26
Limited EEPROM reading; added EC_FIRST_EEPROM_CATEGORY_HEADER define.
Florian Pose <fp@igh-essen.com>
parents:
649
diff
changeset
|
110 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
111 |
/** Size of a sync manager configuration page. */ |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
112 |
#define EC_SYNC_PAGE_SIZE 8 |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
113 |
|
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
114 |
/** Maximum number of FMMUs per slave. */ |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
115 |
#define EC_MAX_FMMUS 16 |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
116 |
|
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
117 |
/** Size of an FMMU configuration page. */ |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
118 |
#define EC_FMMU_PAGE_SIZE 16 |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
119 |
|
1438
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
120 |
/** Number of DC sync signals. */ |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
121 |
#define EC_SYNC_SIGNAL_COUNT 2 |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
122 |
|
1485 | 123 |
/** Size of the datagram description string. |
124 |
* |
|
125 |
* This is also used as the maximum lenth of EoE device names. |
|
126 |
**/ |
|
127 |
#define EC_DATAGRAM_NAME_SIZE 20 |
|
128 |
||
989
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
129 |
/** Slave state mask. |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
130 |
* |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
131 |
* Apply this mask to a slave state byte to get the slave state without |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
132 |
* the error flag. |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
133 |
*/ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
134 |
#define EC_SLAVE_STATE_MASK 0x0F |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
135 |
|
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
136 |
/** State of an EtherCAT slave. |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
137 |
*/ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
138 |
typedef enum { |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
139 |
EC_SLAVE_STATE_UNKNOWN = 0x00, |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
140 |
/**< unknown state */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
141 |
EC_SLAVE_STATE_INIT = 0x01, |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
142 |
/**< INIT state (no mailbox communication, no IO) */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
143 |
EC_SLAVE_STATE_PREOP = 0x02, |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
144 |
/**< PREOP state (mailbox communication, no IO) */ |
1337
0253c74d0940
merge -c1619 branches/1.4-foe: Implemented going to bootstrap state BOOT.
Florian Pose <fp@igh-essen.com>
parents:
1327
diff
changeset
|
145 |
EC_SLAVE_STATE_BOOT = 0x03, |
0253c74d0940
merge -c1619 branches/1.4-foe: Implemented going to bootstrap state BOOT.
Florian Pose <fp@igh-essen.com>
parents:
1327
diff
changeset
|
146 |
/**< Bootstrap state (mailbox communication, firmware update) */ |
989
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
147 |
EC_SLAVE_STATE_SAFEOP = 0x04, |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
148 |
/**< SAFEOP (mailbox communication and input update) */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
149 |
EC_SLAVE_STATE_OP = 0x08, |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
150 |
/**< OP (mailbox communication and input/output update) */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
151 |
EC_SLAVE_STATE_ACK_ERR = 0x10 |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
152 |
/**< Acknowledge/Error bit (no actual state) */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
153 |
} ec_slave_state_t; |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
154 |
|
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
155 |
/** Supported mailbox protocols. |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
156 |
*/ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
157 |
enum { |
1327
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
158 |
EC_MBOX_AOE = 0x01, /**< ADS over EtherCAT */ |
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
159 |
EC_MBOX_EOE = 0x02, /**< Ethernet over EtherCAT */ |
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
160 |
EC_MBOX_COE = 0x04, /**< CANopen over EtherCAT */ |
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
161 |
EC_MBOX_FOE = 0x08, /**< File-Access over EtherCAT */ |
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
162 |
EC_MBOX_SOE = 0x10, /**< Servo-Profile over EtherCAT */ |
989
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
163 |
EC_MBOX_VOE = 0x20 /**< Vendor specific */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
164 |
}; |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
165 |
|
1327
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
166 |
/** Slave information interface CANopen over EtherCAT details flags. |
989
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
167 |
*/ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
168 |
typedef struct { |
1327
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
169 |
uint8_t enable_sdo : 1; /**< Enable SDO access. */ |
989
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
170 |
uint8_t enable_sdo_info : 1; /**< SDO information service available. */ |
1327
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
171 |
uint8_t enable_pdo_assign : 1; /**< PDO mapping configurable. */ |
4d179b06dd3c
merge -c1604 branches/stable-1.4: Fixed spelling of EtherCAT terms.
Florian Pose <fp@igh-essen.com>
parents:
1326
diff
changeset
|
172 |
uint8_t enable_pdo_configuration : 1; /**< PDO configuration possible. */ |
989
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
173 |
uint8_t enable_upload_at_startup : 1; /**< ?. */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
174 |
uint8_t enable_sdo_complete_access : 1; /**< Complete access possible. */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
175 |
} ec_sii_coe_details_t; |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
176 |
|
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
177 |
/** Slave information interface general flags. |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
178 |
*/ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
179 |
typedef struct { |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
180 |
uint8_t enable_safeop : 1; /**< ?. */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
181 |
uint8_t enable_not_lrw : 1; /**< Slave does not support LRW. */ |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
182 |
} ec_sii_general_flags_t; |
816663ca9370
Slave information via 'ethercat slave'.
Florian Pose <fp@igh-essen.com>
parents:
883
diff
changeset
|
183 |
|
1379
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
184 |
/** EtherCAT slave distributed clocks range. |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
185 |
*/ |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
186 |
typedef enum { |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
187 |
EC_DC_32, /**< 32 bit. */ |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
188 |
EC_DC_64 /*< 64 bit for system time, system time offset and |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
189 |
port 0 receive time. */ |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
190 |
} ec_slave_dc_range_t; |
cbceb0e2f2a0
Reading more base information (incl. whether DC supported).
Florian Pose <fp@igh-essen.com>
parents:
1363
diff
changeset
|
191 |
|
1438
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
192 |
/** EtherCAT slave sync signal configuration. |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
193 |
*/ |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
194 |
typedef struct { |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
195 |
uint32_t cycle_time; /**< Cycle time [ns]. */ |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
196 |
uint32_t shift_time; /**< Shift time [ns]. */ |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
197 |
} ec_sync_signal_t; |
1d30b96bb04f
Replaced ecrt_slave_config_dc_cycle_times() and ecrt_slave_config_dc_shift_times() by ecrt_slave_config_dc_sync_signals().
Florian Pose <fp@igh-essen.com>
parents:
1425
diff
changeset
|
198 |
|
1382
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
199 |
/** Access states for SDO entries. |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
200 |
* |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
201 |
* The access rights are managed per AL state. |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
202 |
*/ |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
203 |
enum { |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
204 |
EC_SDO_ENTRY_ACCESS_PREOP, /**< Access rights in PREOP. */ |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
205 |
EC_SDO_ENTRY_ACCESS_SAFEOP, /**< Access rights in SAFEOP. */ |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
206 |
EC_SDO_ENTRY_ACCESS_OP, /**< Access rights in OP. */ |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
207 |
EC_SDO_ENTRY_ACCESS_COUNT /**< Number of states. */ |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
208 |
}; |
cb2188d111f3
Read SDO entry access rights.
Florian Pose <fp@igh-essen.com>
parents:
1379
diff
changeset
|
209 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
210 |
/*****************************************************************************/ |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
211 |
|
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
212 |
/** Convenience macro for printing EtherCAT-specific information to syslog. |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
213 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
214 |
* This will print the message in \a fmt with a prefixed "EtherCAT: ". |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
215 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
216 |
* \param fmt format string (like in printf()) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
217 |
* \param args arguments (optional) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
218 |
*/ |
84
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
219 |
#define EC_INFO(fmt, args...) \ |
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
220 |
printk(KERN_INFO "EtherCAT: " fmt, ##args) |
259 | 221 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
222 |
/** Convenience macro for printing EtherCAT-specific errors to syslog. |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
223 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
224 |
* This will print the message in \a fmt with a prefixed "EtherCAT ERROR: ". |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
225 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
226 |
* \param fmt format string (like in printf()) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
227 |
* \param args arguments (optional) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
228 |
*/ |
84
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
229 |
#define EC_ERR(fmt, args...) \ |
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
230 |
printk(KERN_ERR "EtherCAT ERROR: " fmt, ##args) |
259 | 231 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
232 |
/** Convenience macro for printing EtherCAT-specific warnings to syslog. |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
233 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
234 |
* This will print the message in \a fmt with a prefixed "EtherCAT WARNING: ". |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
235 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
236 |
* \param fmt format string (like in printf()) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
237 |
* \param args arguments (optional) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
238 |
*/ |
84
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
239 |
#define EC_WARN(fmt, args...) \ |
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
240 |
printk(KERN_WARNING "EtherCAT WARNING: " fmt, ##args) |
259 | 241 |
|
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
242 |
/** Convenience macro for printing EtherCAT debug messages to syslog. |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
243 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
244 |
* This will print the message in \a fmt with a prefixed "EtherCAT DEBUG: ". |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
245 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
246 |
* \param fmt format string (like in printf()) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
247 |
* \param args arguments (optional) |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
248 |
*/ |
84
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
249 |
#define EC_DBG(fmt, args...) \ |
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
250 |
printk(KERN_DEBUG "EtherCAT DEBUG: " fmt, ##args) |
b4ae98855cea
printk durch Makros ersetzt.
Florian Pose <fp@igh-essen.com>
parents:
73
diff
changeset
|
251 |
|
41 | 252 |
/*****************************************************************************/ |
253 |
||
1904
2fadf016d9be
Moved ABS() macro to globals.
Florian Pose <fp@igh-essen.com>
parents:
1884
diff
changeset
|
254 |
/** Absolute value. |
2fadf016d9be
Moved ABS() macro to globals.
Florian Pose <fp@igh-essen.com>
parents:
1884
diff
changeset
|
255 |
*/ |
2fadf016d9be
Moved ABS() macro to globals.
Florian Pose <fp@igh-essen.com>
parents:
1884
diff
changeset
|
256 |
#define EC_ABS(X) ((X) >= 0 ? (X) : -(X)) |
2fadf016d9be
Moved ABS() macro to globals.
Florian Pose <fp@igh-essen.com>
parents:
1884
diff
changeset
|
257 |
|
2fadf016d9be
Moved ABS() macro to globals.
Florian Pose <fp@igh-essen.com>
parents:
1884
diff
changeset
|
258 |
/*****************************************************************************/ |
2fadf016d9be
Moved ABS() macro to globals.
Florian Pose <fp@igh-essen.com>
parents:
1884
diff
changeset
|
259 |
|
444
31223539fc00
Compiler flag -DSVNREV only for module.c to avoid unnecessary recompiling.
Florian Pose <fp@igh-essen.com>
parents:
427
diff
changeset
|
260 |
extern char *ec_master_version_str; |
31223539fc00
Compiler flag -DSVNREV only for module.c to avoid unnecessary recompiling.
Florian Pose <fp@igh-essen.com>
parents:
427
diff
changeset
|
261 |
|
31223539fc00
Compiler flag -DSVNREV only for module.c to avoid unnecessary recompiling.
Florian Pose <fp@igh-essen.com>
parents:
427
diff
changeset
|
262 |
/*****************************************************************************/ |
31223539fc00
Compiler flag -DSVNREV only for module.c to avoid unnecessary recompiling.
Florian Pose <fp@igh-essen.com>
parents:
427
diff
changeset
|
263 |
|
1826
ec6223c3b7ec
Multi-master support for command-line tool. The --master option supports
Florian Pose <fp@igh-essen.com>
parents:
1774
diff
changeset
|
264 |
unsigned int ec_master_count(void); |
325
7833cf70c4f2
VERSION 1.1: New realtime interface, only state machines.
Florian Pose <fp@igh-essen.com>
parents:
293
diff
changeset
|
265 |
void ec_print_data(const uint8_t *, size_t); |
7833cf70c4f2
VERSION 1.1: New realtime interface, only state machines.
Florian Pose <fp@igh-essen.com>
parents:
293
diff
changeset
|
266 |
void ec_print_data_diff(const uint8_t *, const uint8_t *, size_t); |
1337
0253c74d0940
merge -c1619 branches/1.4-foe: Implemented going to bootstrap state BOOT.
Florian Pose <fp@igh-essen.com>
parents:
1327
diff
changeset
|
267 |
size_t ec_state_string(uint8_t, char *, uint8_t); |
639
aa23c48dca2d
Allow only MAC addresses as device identifiers; replaced master list by
Florian Pose <fp@igh-essen.com>
parents:
630
diff
changeset
|
268 |
ssize_t ec_mac_print(const uint8_t *, char *); |
aa23c48dca2d
Allow only MAC addresses as device identifiers; replaced master list by
Florian Pose <fp@igh-essen.com>
parents:
630
diff
changeset
|
269 |
int ec_mac_is_zero(const uint8_t *); |
152
9654f3cf588d
Plugfest: Globale Debug-Funktionen f?r Frame-Daten.
Florian Pose <fp@igh-essen.com>
parents:
141
diff
changeset
|
270 |
|
1312
74853e018898
Created backend versions of all API functions returing a pointer; using
Florian Pose <fp@igh-essen.com>
parents:
1217
diff
changeset
|
271 |
ec_master_t *ecrt_request_master_err(unsigned int); |
74853e018898
Created backend versions of all API functions returing a pointer; using
Florian Pose <fp@igh-essen.com>
parents:
1217
diff
changeset
|
272 |
|
152
9654f3cf588d
Plugfest: Globale Debug-Funktionen f?r Frame-Daten.
Florian Pose <fp@igh-essen.com>
parents:
141
diff
changeset
|
273 |
/*****************************************************************************/ |
9654f3cf588d
Plugfest: Globale Debug-Funktionen f?r Frame-Daten.
Florian Pose <fp@igh-essen.com>
parents:
141
diff
changeset
|
274 |
|
809 | 275 |
/** Code/Message pair. |
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
276 |
* |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
277 |
* Some EtherCAT datagrams support reading a status code to display a certain |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
278 |
* message. This type allows to map a code to a message string. |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
279 |
*/ |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
280 |
typedef struct { |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
281 |
uint32_t code; /**< Code. */ |
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
282 |
const char *message; /**< Message belonging to \a code. */ |
809 | 283 |
} ec_code_msg_t; |
164
ed85368b2b2e
AL status code reading after failed state transition.
Florian Pose <fp@igh-essen.com>
parents:
152
diff
changeset
|
284 |
|
ed85368b2b2e
AL status code reading after failed state transition.
Florian Pose <fp@igh-essen.com>
parents:
152
diff
changeset
|
285 |
/*****************************************************************************/ |
ed85368b2b2e
AL status code reading after failed state transition.
Florian Pose <fp@igh-essen.com>
parents:
152
diff
changeset
|
286 |
|
861
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
287 |
/** Generic request state. |
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
288 |
* |
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
289 |
* \attention If ever changing this, please be sure to adjust the \a |
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
290 |
* state_table in master/sdo_request.c. |
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
291 |
*/ |
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
292 |
typedef enum { |
1209 | 293 |
EC_INT_REQUEST_INIT, |
294 |
EC_INT_REQUEST_QUEUED, |
|
295 |
EC_INT_REQUEST_BUSY, |
|
296 |
EC_INT_REQUEST_SUCCESS, |
|
297 |
EC_INT_REQUEST_FAILURE |
|
298 |
} ec_internal_request_state_t; |
|
299 |
||
300 |
/*****************************************************************************/ |
|
301 |
||
302 |
extern const ec_request_state_t ec_request_state_translation_table[]; |
|
861
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
303 |
|
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
304 |
/*****************************************************************************/ |
6e3de145421a
Introduced ec_sdo_request_state_t, making ec_request_t private again;
Florian Pose <fp@igh-essen.com>
parents:
858
diff
changeset
|
305 |
|
809 | 306 |
/** Origin type. |
307 |
*/ |
|
308 |
typedef enum { |
|
309 |
EC_ORIG_INTERNAL, /**< Internal. */ |
|
310 |
EC_ORIG_EXTERNAL /**< External. */ |
|
311 |
} ec_origin_t; |
|
312 |
||
313 |
/*****************************************************************************/ |
|
314 |
||
792
3778920f61e4
Implemented most realtime interface changes for version 1.4, improved
Florian Pose <fp@igh-essen.com>
parents:
773
diff
changeset
|
315 |
typedef struct ec_slave ec_slave_t; /**< \see ec_slave. */ |
740
68d83b45dfa2
Added ec_slave_get_sdo() and ec_sdo_get_entry().
Florian Pose <fp@igh-essen.com>
parents:
708
diff
changeset
|
316 |
|
68d83b45dfa2
Added ec_slave_get_sdo() and ec_sdo_get_entry().
Florian Pose <fp@igh-essen.com>
parents:
708
diff
changeset
|
317 |
/*****************************************************************************/ |
68d83b45dfa2
Added ec_slave_get_sdo() and ec_sdo_get_entry().
Florian Pose <fp@igh-essen.com>
parents:
708
diff
changeset
|
318 |
|
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
319 |
/*****************************************************************************/ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
320 |
|
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
321 |
#ifdef __KERNEL__ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
322 |
|
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
323 |
/** Mutual exclusion helpers. |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
324 |
* |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
325 |
*/ |
2035
72a4e043e67d
always use rt_mutex instead of semaphore for mutual exclusion on kernels >= 2.6.24 (removed --enable-mutex build option)
Martin Troxler <ch1010277@ch10pc446>
parents:
2028
diff
changeset
|
326 |
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,24) |
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
327 |
#define ec_mutex_t rt_mutex |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
328 |
static inline void ec_mutex_init(struct ec_mutex_t *mutex) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
329 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
330 |
rt_mutex_init(mutex); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
331 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
332 |
static inline void ec_mutex_lock(struct ec_mutex_t *mutex) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
333 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
334 |
rt_mutex_lock(mutex); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
335 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
336 |
static inline int ec_mutex_trylock(struct ec_mutex_t *mutex) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
337 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
338 |
return rt_mutex_trylock(mutex); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
339 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
340 |
static inline int ec_mutex_lock_interruptible(struct ec_mutex_t *mutex) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
341 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
342 |
return rt_mutex_lock_interruptible(mutex,0); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
343 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
344 |
static inline void ec_mutex_unlock(struct ec_mutex_t *mutex) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
345 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
346 |
rt_mutex_unlock(mutex); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
347 |
} |
2035
72a4e043e67d
always use rt_mutex instead of semaphore for mutual exclusion on kernels >= 2.6.24 (removed --enable-mutex build option)
Martin Troxler <ch1010277@ch10pc446>
parents:
2028
diff
changeset
|
348 |
#else // < KERNEL_VERSION(2,6,24) |
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
349 |
#define ec_mutex_t semaphore |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
350 |
static inline void ec_mutex_init(struct ec_mutex_t *sem) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
351 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
352 |
sema_init(sem, 1); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
353 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
354 |
static inline void ec_mutex_lock(struct ec_mutex_t *sem) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
355 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
356 |
down(sem); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
357 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
358 |
static inline int ec_mutex_trylock(struct ec_mutex_t *sem) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
359 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
360 |
down(sem); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
361 |
return 1; |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
362 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
363 |
static inline int ec_mutex_lock_interruptible(struct ec_mutex_t *sem) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
364 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
365 |
return down_interruptible(sem); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
366 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
367 |
static inline void ec_mutex_unlock(struct ec_mutex_t *sem) |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
368 |
{ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
369 |
up(sem); |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
370 |
} |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
371 |
|
2035
72a4e043e67d
always use rt_mutex instead of semaphore for mutual exclusion on kernels >= 2.6.24 (removed --enable-mutex build option)
Martin Troxler <ch1010277@ch10pc446>
parents:
2028
diff
changeset
|
372 |
#endif // KERNEL_VERSION(2,6,24) |
2028
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
373 |
#endif // __KERNEL__ |
55854f070c4a
use rt_mutex instead of semaphore for mutual exclusion (use --enable-mutex)
Martin Troxler <ch1010277@ch10pc446>
parents:
2022
diff
changeset
|
374 |
|
0 | 375 |
#endif |