2 This file is part of CanFestival, a library implementing CanOpen Stack.
4 Copyright (C): Edouard TISSERANT and Francis DUPIN
6 See COPYING file for copyrights details.
8 This library is free software; you can redistribute it and/or
9 modify it under the terms of the GNU Lesser General Public
10 License as published by the Free Software Foundation; either
11 version 2.1 of the License, or (at your option) any later version.
13 This library is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 Lesser General Public License for more details.
18 You should have received a copy of the GNU Lesser General Public
19 License along with this library; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30 /* declaration of CO_Data type let us include all necessary headers
31 struct struct_CO_Data can then be defined later
33 typedef struct struct_CO_Data CO_Data;
38 #include "objdictdef.h"
46 #include "nmtMaster.h"
52 /* This structurs contains all necessary information for a CanOpen node */
53 struct struct_CO_Data {
54 /* Object dictionary */
56 const indextable *objdict;
57 s_PDO_status *PDO_status;
58 quick_index *firstIndex;
59 quick_index *lastIndex;
61 const UNS8 *iam_a_slave;
62 valueRangeTest_t valueRangeTest;
65 s_transfer transfers[SDO_MAX_SIMULTANEOUS_TRANSFERTS];
66 /* s_sdo_parameter *sdo_parameters; */
69 e_nodeState nodeState;
70 s_state_communication CurrentCommunicationState;
71 initialisation_t initialisation;
72 preOperational_t preOperational;
73 operational_t operational;
77 UNS8 *ConsumerHeartbeatCount;
78 UNS32 *ConsumerHeartbeatEntries;
79 TIMER_HANDLE *ConsumerHeartBeatTimers;
80 UNS16 *ProducerHeartBeatTime;
81 TIMER_HANDLE ProducerHeartBeatTimer;
82 heartbeatError_t heartbeatError;
83 e_nodeState NMTable[NMT_MAX_NODE_ID];
86 TIMER_HANDLE syncTimer;
88 UNS32 *Sync_Cycle_Period;
89 /*UNS32 *Sync_window_length;;*/
90 post_sync_t post_sync;
91 post_TPDO_t post_TPDO;
92 post_SlaveBootup_t post_SlaveBootup;
97 scanIndexOD_t scanIndexOD;
98 storeODSubIndex_t storeODSubIndex;
101 const indextable* dcf_odentry;
103 UNS32 dcf_entries_count;
107 e_errorState error_state;
108 UNS8 error_history_size;
110 UNS32* error_first_element;
111 UNS8* error_register;
113 s_errors error_data[EMCY_MAX_ERRORS];
114 post_emcy_t post_emcy;
118 lss_transfer_t lss_transfer;
119 lss_StoreConfiguration_t lss_StoreConfiguration;
123 #define NMTable_Initializer Unknown_state,
125 #define s_transfer_Initializer {\
128 SDO_RESET, /* state */\
135 {0}, /* data (static use, so that all the table is initialize at 0)*/\
141 #define ERROR_DATA_INITIALIZER \
150 #ifdef CO_ENABLE_LSS_FS
151 #define lss_fs_Initializer \
153 128, /* BitChecked */\
157 LSS_FS_RESET, /* FastScan_SM */\
160 #define lss_fs_Initializer
163 #define lss_Initializer {\
164 LSS_RESET, /* state */\
166 LSS_WAITING_MODE, /* mode */\
170 0, /* addr_sel_match */\
171 0, /* addr_ident_match */\
172 "none", /* BaudRate */\
173 0, /* SwitchDelay */\
174 SDELAY_OFF, /* SwitchDelayState */\
175 NULL, /* canHandle_t */\
177 -1, /* TimerSDELAY */\
178 NULL, /* Callback */\
180 lss_fs_Initializer /*FastScan service initialization */\
182 NULL /* _lss_StoreConfiguration*/
184 #define lss_Initializer
188 /* A macro to initialize the data in client app.*/
189 /* CO_Data structure */
190 #define CANOPEN_NODE_DATA_INITIALIZER(NODE_PREFIX) {\
191 /* Object dictionary*/\
192 & NODE_PREFIX ## _bDeviceNodeId, /* bDeviceNodeId */\
193 NODE_PREFIX ## _objdict, /* objdict */\
194 NODE_PREFIX ## _PDO_status, /* PDO_status */\
195 & NODE_PREFIX ## _firstIndex, /* firstIndex */\
196 & NODE_PREFIX ## _lastIndex, /* lastIndex */\
197 & NODE_PREFIX ## _ObjdictSize, /* ObjdictSize */\
198 & NODE_PREFIX ## _iam_a_slave, /* iam_a_slave */\
199 NODE_PREFIX ## _valueRangeTest, /* valueRangeTest */\
201 /* SDO, structure s_transfer */\
203 REPEAT_SDO_MAX_SIMULTANEOUS_TRANSFERTS_TIMES(s_transfer_Initializer)\
207 Unknown_state, /* nodeState */\
208 /* structure s_state_communication */\
212 0, /* csEmergency */\
214 0, /* csHeartbeat */\
218 _initialisation, /* initialisation */\
219 _preOperational, /* preOperational */\
220 _operational, /* operational */\
221 _stopped, /* stopped */\
224 & NODE_PREFIX ## _highestSubIndex_obj1016, /* ConsumerHeartbeatCount */\
225 NODE_PREFIX ## _obj1016, /* ConsumerHeartbeatEntries */\
226 NODE_PREFIX ## _heartBeatTimers, /* ConsumerHeartBeatTimers */\
227 & NODE_PREFIX ## _obj1017, /* ProducerHeartBeatTime */\
228 TIMER_NONE, /* ProducerHeartBeatTimer */\
229 _heartbeatError, /* heartbeatError */\
231 {REPEAT_NMT_MAX_NODE_ID_TIMES(NMTable_Initializer)},\
232 /* is well initialized at "Unknown_state". Is it ok ? (FD)*/\
235 TIMER_NONE, /* syncTimer */\
236 & NODE_PREFIX ## _obj1005, /* COB_ID_Sync */\
237 & NODE_PREFIX ## _obj1006, /* Sync_Cycle_Period */\
238 /*& NODE_PREFIX ## _obj1007, */ /* Sync_window_length */\
239 _post_sync, /* post_sync */\
240 _post_TPDO, /* post_TPDO */\
241 _post_SlaveBootup, /* post_SlaveBootup */\
246 NODE_PREFIX ## _scanIndexOD, /* scanIndexOD */\
247 _storeODSubIndex, /* storeODSubIndex */\
249 NULL, /*dcf_odentry*/\
250 NULL, /*dcf_cursor*/\
251 1, /*dcf_entries_count*/\
255 Error_free, /* error_state */\
256 sizeof(NODE_PREFIX ## _obj1003) / sizeof(NODE_PREFIX ## _obj1003[0]), /* error_history_size */\
257 & NODE_PREFIX ## _highestSubIndex_obj1003, /* error_number */\
258 & NODE_PREFIX ## _obj1003[0], /* error_first_element */\
259 & NODE_PREFIX ## _obj1001, /* error_register */\
260 & NODE_PREFIX ## _obj1014, /* error_cobid */\
261 /* error_data: structure s_errors */\
263 REPEAT_EMCY_MAX_ERRORS_TIMES(ERROR_DATA_INITIALIZER)\
265 _post_emcy, /* post_emcy */\
274 #endif /* __data_h__ */