| 1 | /* -*-C-*- | 
|---|
| 2 | * gendef.h -   CANopen; home of generic definitions | 
|---|
| 3 | * | 
|---|
| 4 | *----------------------------------------------------------------------- | 
|---|
| 5 | * | 
|---|
| 6 | *                Copyright (c) 1998 JANZ Computer AG | 
|---|
| 7 | *                        All Rights Reserved | 
|---|
| 8 | * | 
|---|
| 9 | * Permission is hereby granted to licensees of JANZ Computer AG | 
|---|
| 10 | * products to use or abstract this computer program for the sole | 
|---|
| 11 | * purpose of implementing a product based on JANZ Computer AG | 
|---|
| 12 | * products.   No other rights to reproduce, use, or disseminate | 
|---|
| 13 | * this computer program, whether in part or in whole, are granted. | 
|---|
| 14 | * | 
|---|
| 15 | * JANZ Computer AG makes no representation or warranties with respect | 
|---|
| 16 | * to the performance of this computer program, and specifically | 
|---|
| 17 | * disclaims any responsibility for any damages, special or consequential, | 
|---|
| 18 | * connected with the use of this program. | 
|---|
| 19 | * | 
|---|
| 20 | * JANZ Computer AG products are not authorized for use as critical | 
|---|
| 21 | * components in life support devices or systems without the express | 
|---|
| 22 | * written approval of JANZ Computer AG. | 
|---|
| 23 | * | 
|---|
| 24 | *----------------------------------------------------------------------- | 
|---|
| 25 | * | 
|---|
| 26 | * $Id: gendef.h,v 1.1 2001-04-09 13:32:55 tbretz Exp $ | 
|---|
| 27 | * | 
|---|
| 28 | *----------------------------------------------------------------------- | 
|---|
| 29 | * | 
|---|
| 30 | * $Log: not supported by cvs2svn $ | 
|---|
| 31 | * Revision 1.7  2000/02/18 11:22:11  jens | 
|---|
| 32 | * adding variable in global variable structure: incomingSdoBehaviour | 
|---|
| 33 | * | 
|---|
| 34 | * Revision 1.6  1999/10/29 11:07:51  gerd | 
|---|
| 35 | * Add support for Linux. | 
|---|
| 36 | * | 
|---|
| 37 | * Revision 1.5  1999/09/16 14:50:02  gerd | 
|---|
| 38 | * Add support for PSOS | 
|---|
| 39 | * | 
|---|
| 40 | * Revision 1.4  1999/09/06 14:20:54  wolfgang | 
|---|
| 41 | * Add macros and variable for MS-DOS. | 
|---|
| 42 | * | 
|---|
| 43 | * Revision 1.3  1999/06/18 12:08:15  jens | 
|---|
| 44 | * made VMOD-ICAN/CAN104 dependend headers conditional (CAL_CANOPEN_CLAMPED) | 
|---|
| 45 | * made pdoTagTables available at CAL_CANOPEN_CLAMPED-section only | 
|---|
| 46 | * | 
|---|
| 47 | * Revision 1.2  1999/06/10 14:10:36  wolfgang | 
|---|
| 48 | * Add NT40 part for CANopen stuff. | 
|---|
| 49 | * | 
|---|
| 50 | * Revision 1.1  1999/03/08 16:55:13  jens | 
|---|
| 51 | * Initial revision | 
|---|
| 52 | * | 
|---|
| 53 | * | 
|---|
| 54 | *----------------------------------------------------------------------- | 
|---|
| 55 | */ | 
|---|
| 56 |  | 
|---|
| 57 | #ifndef gendef_DEFINED | 
|---|
| 58 | #define gendef_DEFINED | 
|---|
| 59 |  | 
|---|
| 60 | #ifdef __cplusplus | 
|---|
| 61 | extern "C" { | 
|---|
| 62 | #endif | 
|---|
| 63 |  | 
|---|
| 64 | #ifdef WIN95 | 
|---|
| 65 | #include <windows.h> | 
|---|
| 66 | #endif | 
|---|
| 67 |  | 
|---|
| 68 | #ifdef WIN_NT40 | 
|---|
| 69 | #include <windows.h> | 
|---|
| 70 | #endif | 
|---|
| 71 |  | 
|---|
| 72 | #include "icanconf.h" | 
|---|
| 73 | #include "calconf.h" | 
|---|
| 74 | #include "cms.h" | 
|---|
| 75 |  | 
|---|
| 76 | #include "bcan.h" | 
|---|
| 77 |  | 
|---|
| 78 | #ifndef CAL_CANOPEN_CLAMPED | 
|---|
| 79 | #include "mican.h" | 
|---|
| 80 | #include "dpm.h" | 
|---|
| 81 | #include "can_lib.h" | 
|---|
| 82 | #endif | 
|---|
| 83 |  | 
|---|
| 84 | #include <stdio.h> | 
|---|
| 85 | #include <string.h> | 
|---|
| 86 |  | 
|---|
| 87 | #ifdef WIN95 | 
|---|
| 88 |  | 
|---|
| 89 | #define LCL_SLEEP(sleepTimeInMs) \ | 
|---|
| 90 | Sleep(sleepTimeInMs) | 
|---|
| 91 |  | 
|---|
| 92 | #define CREATE_SEMAPHORE(pSecure, initCount, maxCount, pName) \ | 
|---|
| 93 | CreateSemaphore(pSecure, initCount, maxCount, pName); | 
|---|
| 94 |  | 
|---|
| 95 | #define WAIT_FOR_SEMAPHORE(semId, howLong) \ | 
|---|
| 96 | WaitForSingleObject(semId, howLong) | 
|---|
| 97 |  | 
|---|
| 98 | #define RELEASE_SEMAPHORE(semId, count, addrPrevCount) \ | 
|---|
| 99 | ReleaseSemaphore(semId, count, addrPrevCount) | 
|---|
| 100 | #endif | 
|---|
| 101 |  | 
|---|
| 102 |  | 
|---|
| 103 | #ifdef WIN_NT40 | 
|---|
| 104 |  | 
|---|
| 105 | #define LCL_SLEEP(sleepTimeInMs) \ | 
|---|
| 106 | Sleep(sleepTimeInMs) | 
|---|
| 107 |  | 
|---|
| 108 | #define CREATE_SEMAPHORE(pSecure, initCount, maxCount, pName) \ | 
|---|
| 109 | CreateSemaphore(pSecure, initCount, maxCount, pName); | 
|---|
| 110 |  | 
|---|
| 111 | #define WAIT_FOR_SEMAPHORE(semId, howLong) \ | 
|---|
| 112 | WaitForSingleObject(semId, howLong) | 
|---|
| 113 |  | 
|---|
| 114 | #define RELEASE_SEMAPHORE(semId, count, addrPrevCount) \ | 
|---|
| 115 | ReleaseSemaphore(semId, count, addrPrevCount) | 
|---|
| 116 |  | 
|---|
| 117 | #endif | 
|---|
| 118 |  | 
|---|
| 119 | #ifdef VXWORKS | 
|---|
| 120 | #include <taskLib.h> | 
|---|
| 121 | #include <sysLib.h> | 
|---|
| 122 |  | 
|---|
| 123 | #define INFINITE        0 | 
|---|
| 124 |  | 
|---|
| 125 | #define LCL_SLEEP(sleepTimeInMs) \ | 
|---|
| 126 | taskDelay(((sleepTimeInMs * 100) / (100000 / sysClkRateGet())) + 1) | 
|---|
| 127 |  | 
|---|
| 128 | #define CREATE_SEMAPHORE(pSecure, initCount, maxCount, pName) \ | 
|---|
| 129 | semBCreate(SEM_Q_FIFO, (SEM_B_STATE)initCount); | 
|---|
| 130 |  | 
|---|
| 131 | #define WAIT_FOR_SEMAPHORE(semId, howLong) \ | 
|---|
| 132 | semTake(semId, WAIT_FOREVER) | 
|---|
| 133 |  | 
|---|
| 134 | #define RELEASE_SEMAPHORE(semId, count, addrPrevCount) \ | 
|---|
| 135 | semGive(semId) | 
|---|
| 136 | #endif | 
|---|
| 137 |  | 
|---|
| 138 | #ifdef  MSDOS | 
|---|
| 139 |  | 
|---|
| 140 | #define LCL_SLEEP(sleepTimeInMs) \ | 
|---|
| 141 | delay(sleepTimeInMs) | 
|---|
| 142 |  | 
|---|
| 143 | #define WAIT_FOR_SEMAPHORE(semId, howLong) \ | 
|---|
| 144 | {do{delay(100);}while(((myVars->pMsgHandler)((void*)myVars))==1);} | 
|---|
| 145 |  | 
|---|
| 146 | #define RELEASE_SEMAPHORE(semId, count, addrPrevCount) | 
|---|
| 147 |  | 
|---|
| 148 | #endif | 
|---|
| 149 |  | 
|---|
| 150 | #ifdef PSOS | 
|---|
| 151 | #include        "sysdep.h" | 
|---|
| 152 | #include        <types.h> | 
|---|
| 153 | #include        <psos.h> | 
|---|
| 154 | #include        <configs.h> | 
|---|
| 155 | #include        <bspfuncs.h> | 
|---|
| 156 | #include        <drv_intf.h> | 
|---|
| 157 | #include        <stdlib.h> | 
|---|
| 158 |  | 
|---|
| 159 | #include        "defs.h" | 
|---|
| 160 |  | 
|---|
| 161 |  | 
|---|
| 162 | extern NODE_CT  *anchor; | 
|---|
| 163 |  | 
|---|
| 164 | /* The following functions are used to translate vxWorks functions      */ | 
|---|
| 165 | /* to pSOS+ system calls                                                */ | 
|---|
| 166 | /* This functions will be removed within later versions.                */ | 
|---|
| 167 |  | 
|---|
| 168 | static int | 
|---|
| 169 | semBCreate(int options, int state) | 
|---|
| 170 | { | 
|---|
| 171 | unsigned long   semid; | 
|---|
| 172 | char    semname[4]; | 
|---|
| 173 |  | 
|---|
| 174 | semname[0] = 'S'; | 
|---|
| 175 | semname[1] = 'M'; | 
|---|
| 176 | semname[2] = '0'; | 
|---|
| 177 | semname[3] = '0'; | 
|---|
| 178 |  | 
|---|
| 179 | if(sm_create(semname, (unsigned long)state, | 
|---|
| 180 | SM_GLOBAL | SM_FIFO, &semid) != 0) | 
|---|
| 181 | return(0); | 
|---|
| 182 |  | 
|---|
| 183 | return((int)semid); | 
|---|
| 184 | } | 
|---|
| 185 |  | 
|---|
| 186 | /* end of vxWorks to pSOS+ translation */ | 
|---|
| 187 |  | 
|---|
| 188 | #define CLOCKS_PER_SEC  (anchor->psosct->kc_ticks2sec) | 
|---|
| 189 |  | 
|---|
| 190 | #define LCL_SLEEP(sleepTimeInMs) \ | 
|---|
| 191 | tm_wkafter(((sleepTimeInMs * 100) / (100000 / CLOCKS_PER_SEC)) + 1) | 
|---|
| 192 |  | 
|---|
| 193 | #define CREATE_SEMAPHORE(pSecure, initCount, maxCount, pName) \ | 
|---|
| 194 | semBCreate(0, (int)initCount); | 
|---|
| 195 |  | 
|---|
| 196 | #define WAIT_FOR_SEMAPHORE(semId, howLong) \ | 
|---|
| 197 | sm_p((unsigned long)semId, SM_WAIT, 0) | 
|---|
| 198 |  | 
|---|
| 199 | #define RELEASE_SEMAPHORE(semId, count, addrPrevCount) \ | 
|---|
| 200 | sm_v(semId); | 
|---|
| 201 |  | 
|---|
| 202 | #endif | 
|---|
| 203 |  | 
|---|
| 204 | #ifdef LINUX | 
|---|
| 205 | #include        <unistd.h> | 
|---|
| 206 | #include        <sys/ipc.h> | 
|---|
| 207 | #include        <sys/sem.h> | 
|---|
| 208 |  | 
|---|
| 209 | #define WAIT_FOREVER    0 | 
|---|
| 210 |  | 
|---|
| 211 | extern int semBCreate(int options, int initCount); | 
|---|
| 212 | extern int semTake(int semId, int timeout); | 
|---|
| 213 | extern int semGive(int semId); | 
|---|
| 214 |  | 
|---|
| 215 | #if 0 | 
|---|
| 216 | static int | 
|---|
| 217 | semBCreate(int options, int initCount) | 
|---|
| 218 | { | 
|---|
| 219 | int                     semId; | 
|---|
| 220 |  | 
|---|
| 221 | if((semId = semget(IPC_PRIVATE, 1, 0766|IPC_CREAT)) < 0) { | 
|---|
| 222 | return(0); | 
|---|
| 223 | } | 
|---|
| 224 |  | 
|---|
| 225 | if(semctl(semId, 0, SETVAL, (union semun) initCount) < 0) { | 
|---|
| 226 | return(0); | 
|---|
| 227 | } | 
|---|
| 228 |  | 
|---|
| 229 | return((int)semId); | 
|---|
| 230 | } | 
|---|
| 231 |  | 
|---|
| 232 | static int | 
|---|
| 233 | semTake(int semId, int timeout) | 
|---|
| 234 | { | 
|---|
| 235 | static struct sembuf    semaphor; | 
|---|
| 236 |  | 
|---|
| 237 | semaphor.sem_op = -1; | 
|---|
| 238 | semaphor.sem_flg = SEM_UNDO; | 
|---|
| 239 |  | 
|---|
| 240 | return( (int)semop(semId, &semaphor, 1) ); | 
|---|
| 241 | } | 
|---|
| 242 |  | 
|---|
| 243 | static int | 
|---|
| 244 | semGive(int semId) | 
|---|
| 245 | { | 
|---|
| 246 | static struct sembuf    semaphor; | 
|---|
| 247 |  | 
|---|
| 248 | semaphor.sem_op = 1; | 
|---|
| 249 | semaphor.sem_flg = SEM_UNDO; | 
|---|
| 250 |  | 
|---|
| 251 | return( (int)semop(semId, &semaphor, 1) ); | 
|---|
| 252 | } | 
|---|
| 253 | #endif | 
|---|
| 254 |  | 
|---|
| 255 | #define LCL_SLEEP(sleepTimeInMs)        (void)usleep(sleepTimeInMs * 1000) | 
|---|
| 256 |  | 
|---|
| 257 |  | 
|---|
| 258 | #define CREATE_SEMAPHORE(pSecure, initCount, maxCount, pName) \ | 
|---|
| 259 | semBCreate(0, (int)initCount); | 
|---|
| 260 |  | 
|---|
| 261 | #define WAIT_FOR_SEMAPHORE(semId, howLong)      \ | 
|---|
| 262 | semTake(semId, WAIT_FOREVER) | 
|---|
| 263 |  | 
|---|
| 264 | #define RELEASE_SEMAPHORE(semId, count, addrPrevCount)  \ | 
|---|
| 265 | semGive(semId) | 
|---|
| 266 |  | 
|---|
| 267 | #endif  /* LINUX */ | 
|---|
| 268 |  | 
|---|
| 269 | /* | 
|---|
| 270 | *      generic variable types | 
|---|
| 271 | */ | 
|---|
| 272 | #define LWORD_t         unsigned long | 
|---|
| 273 | #define WORD_t          unsigned short | 
|---|
| 274 | #define BYTE_t          unsigned char | 
|---|
| 275 |  | 
|---|
| 276 | #define LWORDS_t        long | 
|---|
| 277 | #define WORDS_t         short | 
|---|
| 278 | #define BYTES_t         char | 
|---|
| 279 |  | 
|---|
| 280 | #define VOID_t          void | 
|---|
| 281 |  | 
|---|
| 282 | #define INT_t           int | 
|---|
| 283 |  | 
|---|
| 284 | /* | 
|---|
| 285 | *      CANopen specific structures/defines | 
|---|
| 286 | */ | 
|---|
| 287 |  | 
|---|
| 288 | /* | 
|---|
| 289 | * Translation: CANopen data-type -> machine data-type | 
|---|
| 290 | */ | 
|---|
| 291 | #define Boolean                 char | 
|---|
| 292 |  | 
|---|
| 293 | #define Integer8                char | 
|---|
| 294 | #define Integer16               short | 
|---|
| 295 | #define Integer32               long | 
|---|
| 296 |  | 
|---|
| 297 | #define Signed8                 char | 
|---|
| 298 | #define Signed16                short | 
|---|
| 299 | #define Signed32                long | 
|---|
| 300 |  | 
|---|
| 301 | #define Unsigned8               unsigned char | 
|---|
| 302 | #define Unsigned16              unsigned short | 
|---|
| 303 | #define Unsigned32              unsigned long | 
|---|
| 304 |  | 
|---|
| 305 | #define FloatingPoint   float | 
|---|
| 306 |  | 
|---|
| 307 | #define VisString               char | 
|---|
| 308 |  | 
|---|
| 309 |  | 
|---|
| 310 | /* | 
|---|
| 311 | * machine dependant size of data-type | 
|---|
| 312 | */ | 
|---|
| 313 | #define Boolean_size            sizeof(char) | 
|---|
| 314 |  | 
|---|
| 315 | #define Integer8_size           sizeof(char) | 
|---|
| 316 | #define Integer16_size          (2 * sizeof(char)) | 
|---|
| 317 | #define Integer32_size          (4 * sizeof(char)) | 
|---|
| 318 | #define Integer64_size          (8 * sizeof(char)) | 
|---|
| 319 |  | 
|---|
| 320 | #define Signed8_size            sizeof(char) | 
|---|
| 321 | #define Signed16_size           (2 * sizeof(char)) | 
|---|
| 322 | #define Signed32_size           (4 * sizeof(char)) | 
|---|
| 323 | #define Signed64_size           (8 * sizeof(char)) | 
|---|
| 324 |  | 
|---|
| 325 | #define Unsigned8_size          sizeof(char) | 
|---|
| 326 | #define Unsigned16_size         (2 * sizeof(char)) | 
|---|
| 327 | #define Unsigned32_size         (4 * sizeof(char)) | 
|---|
| 328 | #define Unsigned64_size         (8 * sizeof(char)) | 
|---|
| 329 |  | 
|---|
| 330 |  | 
|---|
| 331 |  | 
|---|
| 332 | #define FloatingPoint_size      sizeof(float) | 
|---|
| 333 |  | 
|---|
| 334 | #define VisString_size          (255 * sizeof(char)) | 
|---|
| 335 |  | 
|---|
| 336 |  | 
|---|
| 337 | struct dataType64bit { | 
|---|
| 338 | LWORD_t highBytes; | 
|---|
| 339 | LWORD_t lowBytes; | 
|---|
| 340 | }; | 
|---|
| 341 |  | 
|---|
| 342 |  | 
|---|
| 343 | #define NIL     (void *)0 | 
|---|
| 344 |  | 
|---|
| 345 | /* define values for FALSE and TRUE */ | 
|---|
| 346 |  | 
|---|
| 347 | #ifndef MSDOS | 
|---|
| 348 |  | 
|---|
| 349 | #ifdef LINUX | 
|---|
| 350 | #define TRUE            1 | 
|---|
| 351 | #define FALSE           0 | 
|---|
| 352 | #else | 
|---|
| 353 | #ifndef TRUE | 
|---|
| 354 | #define TRUE            0 | 
|---|
| 355 | #endif | 
|---|
| 356 |  | 
|---|
| 357 | #ifndef FALSE | 
|---|
| 358 | #define FALSE           (-1) | 
|---|
| 359 | #endif | 
|---|
| 360 | #endif | 
|---|
| 361 |  | 
|---|
| 362 | #else | 
|---|
| 363 | #define TRUE            1 | 
|---|
| 364 | #define FALSE           0 | 
|---|
| 365 | #endif | 
|---|
| 366 |  | 
|---|
| 367 | #ifdef CAL_CANOPEN_CLAMPED | 
|---|
| 368 | #define LCL_NIL_CMSO    NIL_CMSO | 
|---|
| 369 | #else | 
|---|
| 370 | #define LCL_NIL_CMSO    0 | 
|---|
| 371 | #endif | 
|---|
| 372 |  | 
|---|
| 373 |  | 
|---|
| 374 | struct Node { | 
|---|
| 375 | struct Node     *Next;                  /* next node */ | 
|---|
| 376 | WORD_t          objDicIndex;    /* data stored in node */ | 
|---|
| 377 | VOID_t          *pEntry;                /* pointer to entry of object dictionary */ | 
|---|
| 378 | }; | 
|---|
| 379 |  | 
|---|
| 380 | struct  hashTabs { | 
|---|
| 381 | struct  Node **pComProfHashTab; | 
|---|
| 382 | struct  Node **pManProfHashTab; | 
|---|
| 383 | struct  Node **pDevProfHashTab; | 
|---|
| 384 | struct  Node **pDataTypHashTab; | 
|---|
| 385 | struct  Node **pIec1131ProfHashTab; | 
|---|
| 386 | }; | 
|---|
| 387 |  | 
|---|
| 388 | struct pdoDataArray { | 
|---|
| 389 | BYTE_t  data[8]; | 
|---|
| 390 | BYTE_t  arrivedLength; | 
|---|
| 391 | }; | 
|---|
| 392 |  | 
|---|
| 393 | struct mSpErrField { | 
|---|
| 394 | BYTE_t  mSpErrData[5]; | 
|---|
| 395 | }; | 
|---|
| 396 |  | 
|---|
| 397 | #define NIL_SDO_DATA_AREA       (struct sdoDataArea *)0 | 
|---|
| 398 |  | 
|---|
| 399 | #define NUM_OF_TAG_BYTES        64      /* will be enough for 512 (* 2) PDOs */ | 
|---|
| 400 | #define RX_PDO_TAG                      0 | 
|---|
| 401 | #define TX_PDO_TAG                      1 | 
|---|
| 402 |  | 
|---|
| 403 | #define SDO_ARRIVED                     1 | 
|---|
| 404 | #define PDO_ARRIVED                     2 | 
|---|
| 405 |  | 
|---|
| 406 |  | 
|---|
| 407 | #define NUM_BIT_RATE_TABLE_ENTRY        9 | 
|---|
| 408 | #define CANOPEN_DEFAULT_BIT_RATE        4 | 
|---|
| 409 |  | 
|---|
| 410 | struct baudTable { | 
|---|
| 411 | WORD_t  bitMacro; | 
|---|
| 412 | WORD_t  bitRate; | 
|---|
| 413 | }; | 
|---|
| 414 |  | 
|---|
| 415 | /* Code switch settings for LMT configuration */ | 
|---|
| 416 | #define CS_SET_BIT_RATE                 0xf0 | 
|---|
| 417 | #define CS_SET_DEFAULT_BIT_RATE 0x00 | 
|---|
| 418 |  | 
|---|
| 419 | /* | 
|---|
| 420 | * Place of global variables | 
|---|
| 421 | */ | 
|---|
| 422 |  | 
|---|
| 423 |  | 
|---|
| 424 | struct globVars { | 
|---|
| 425 | struct  hashTabs        haTab;          /* place where pointer to */ | 
|---|
| 426 | /* hash tables are stored */ | 
|---|
| 427 |  | 
|---|
| 428 | BYTE_t                  nodeState;              /* current CANopen slave node state */ | 
|---|
| 429 | BYTE_t                  nodeClass;              /* NMT node-class of slave node to create */ | 
|---|
| 430 |  | 
|---|
| 431 | /* global entries from DCF: [DeviceCommisioning] */ | 
|---|
| 432 | BYTE_t                  nodeId;                 /* CANopen node ID */ | 
|---|
| 433 | BYTE_t                  nodeName[7];    /* CANopen LMT node name */ | 
|---|
| 434 | WORD_t                  bitRateMacro;   /* current CANopen CAN-Bus-bit-rate */ | 
|---|
| 435 |  | 
|---|
| 436 | struct baudTable        bitRateTable[NUM_BIT_RATE_TABLE_ENTRY]; /* CANopen bit-rate-table */ | 
|---|
| 437 |  | 
|---|
| 438 |  | 
|---|
| 439 | /* field which holds manufacturer specific error for EMCY */ | 
|---|
| 440 | struct  mSpErrField     myManSpErrorField; | 
|---|
| 441 |  | 
|---|
| 442 | /* | 
|---|
| 443 | * Holding number of TPDOs and RPDOs | 
|---|
| 444 | */ | 
|---|
| 445 | BYTE_t                  numRxPdo; | 
|---|
| 446 | BYTE_t                  numTxPdo; | 
|---|
| 447 |  | 
|---|
| 448 | /* | 
|---|
| 449 | * behaviour on incoming SDOs in relationship to Slave nodeState | 
|---|
| 450 | */ | 
|---|
| 451 | BYTE_t                  incomingSdoBehaviour; | 
|---|
| 452 |  | 
|---|
| 453 | #ifdef CAL_CANOPEN_CLAMPED | 
|---|
| 454 | /* | 
|---|
| 455 | * This table holds a tag if data which are | 
|---|
| 456 | * mapped to a PDO (txDataTable) or if data | 
|---|
| 457 | * of a PDO (rxDataTable) had changed. The | 
|---|
| 458 | * Table is bit oriented and holds 512 RxPDOs | 
|---|
| 459 | * and 512 TxPDOs | 
|---|
| 460 | */ | 
|---|
| 461 | BYTE_t                  rxPdoTagTable[NUM_OF_TAG_BYTES]; | 
|---|
| 462 | BYTE_t                  txPdoTagTable[NUM_OF_TAG_BYTES]; | 
|---|
| 463 |  | 
|---|
| 464 | /* | 
|---|
| 465 | * Holding a table, where data[8] of each RPDO | 
|---|
| 466 | * is hold to grant access without scrolling | 
|---|
| 467 | * through Object Dictionary | 
|---|
| 468 | */ | 
|---|
| 469 | struct pdoDataArray     *dataTablePdo; | 
|---|
| 470 |  | 
|---|
| 471 | /* | 
|---|
| 472 | * This variable gives a chance to decide, | 
|---|
| 473 | * if the tag entry in the PDO-change-array | 
|---|
| 474 | * was caused by a PDO arrival or by SDO- | 
|---|
| 475 | * communication. | 
|---|
| 476 | */ | 
|---|
| 477 | BYTE_t  lastDataFromPdoSdo; | 
|---|
| 478 |  | 
|---|
| 479 | /* This linked list holds the created (and enabled, coded!) TPDOs */ | 
|---|
| 480 | struct pdoSendList      *pPdoSendList; | 
|---|
| 481 |  | 
|---|
| 482 | #endif | 
|---|
| 483 | /* | 
|---|
| 484 | * array to hold temp VisString-OD-data | 
|---|
| 485 | */ | 
|---|
| 486 | char    charBuf[256]; | 
|---|
| 487 |  | 
|---|
| 488 | #ifndef CAL_CANOPEN_CLAMPED | 
|---|
| 489 | /* stuff for communication to VMOD-ICAN3 */ | 
|---|
| 490 | Message msgBufferTx;                            /* message buffer */ | 
|---|
| 491 | int             fd;                                                     /* file descriptor of module */ | 
|---|
| 492 | WORD_t  cmsDefinitionTimeout;           /* timeout in milliseconds to */ | 
|---|
| 493 | /* wait for module response at */ | 
|---|
| 494 | /* cms definition services */ | 
|---|
| 495 | char    lastCmsDefinitionName[13];      /* ID from VMOD-ICAN3 at definition response */ | 
|---|
| 496 | WORD_t  lastCmsDefinitionId;            /* ID from VMOD-ICAN3 at definition response */ | 
|---|
| 497 |  | 
|---|
| 498 |  | 
|---|
| 499 | /* for CANopen manager functionality: */ | 
|---|
| 500 | WORD_t  variableSDOIdToIcan3; | 
|---|
| 501 | WORD_t  variableSDOIdFromIcan3; | 
|---|
| 502 | WORD_t  sdoResponseTimeout;                     /* timeout in milliseconds to */ | 
|---|
| 503 | /* wait for peer nodes' SDO response */ | 
|---|
| 504 | BYTE_t  sdoRxBuffer[256];       /* place for SDO data exchange (Rx) */ | 
|---|
| 505 | BYTE_t  sdoTxBuffer[256];       /* place for SDO data exchange (Tx) */ | 
|---|
| 506 | BYTE_t  sdoValidData;           /* number of received SDO data */ | 
|---|
| 507 | BYTE_t  sdoResponse;                            /* flag for answer of peer SDO */ | 
|---|
| 508 |  | 
|---|
| 509 | #ifdef WIN95 | 
|---|
| 510 | HANDLE  hThreadCopSlv;                          /* thread handle */ | 
|---|
| 511 | #endif | 
|---|
| 512 | #ifdef VXWORKS | 
|---|
| 513 | int             hThreadCopSlv;                          /* task ID */ | 
|---|
| 514 | #endif | 
|---|
| 515 | #ifdef PSOS | 
|---|
| 516 | unsigned long   hThreadCopSlv;                          /* task ID */ | 
|---|
| 517 | #endif | 
|---|
| 518 | #ifdef LINUX | 
|---|
| 519 | unsigned long   hThreadCopSlv;                          /* task ID */ | 
|---|
| 520 | #endif | 
|---|
| 521 | #ifdef WIN_NT40 | 
|---|
| 522 | HANDLE  hThreadCopSlv;                          /* thread handle */ | 
|---|
| 523 | #endif | 
|---|
| 524 |  | 
|---|
| 525 | #ifdef WIN95 | 
|---|
| 526 | HANDLE  hSemCopSlv; | 
|---|
| 527 | HANDLE  hSemIcanCom;                            /* semaphore for thread-save comunication */ | 
|---|
| 528 | /* between receive thread and lib */ | 
|---|
| 529 | #endif | 
|---|
| 530 |  | 
|---|
| 531 | #ifdef WIN_NT40 | 
|---|
| 532 | HANDLE  hSemCopSlv; | 
|---|
| 533 | HANDLE  hSemIcanCom;                            /* semaphore for thread-save comunication */ | 
|---|
| 534 | /* between receive thread and lib */ | 
|---|
| 535 | HANDLE  hSemPlainQueue;                         /* semaphore to signal application that a message is */ | 
|---|
| 536 | /* inside the to-host plain queue */ | 
|---|
| 537 | HANDLE  hSemFastQueue;                          /* semaphore to signal application that a message is */ | 
|---|
| 538 | /* inside the to-host fast queue */ | 
|---|
| 539 | #endif | 
|---|
| 540 |  | 
|---|
| 541 | #ifdef VXWORKS | 
|---|
| 542 | SEM_ID  hSemCopSlv; | 
|---|
| 543 | SEM_ID  hSemIcanCom;                            /* semaphore for thread-save comunication */ | 
|---|
| 544 | /* between receive thread and lib */ | 
|---|
| 545 | #endif | 
|---|
| 546 | #ifdef PSOS | 
|---|
| 547 | SEM_ID  hSemCopSlv; | 
|---|
| 548 | SEM_ID  hSemIcanCom;                            /* semaphore for thread-save comunication */ | 
|---|
| 549 | /* between receive thread and lib */ | 
|---|
| 550 | #endif | 
|---|
| 551 | #ifdef LINUX | 
|---|
| 552 | int     hSemCopSlv; | 
|---|
| 553 | int     hSemIcanCom;                            /* semaphore for thread-save comunication */ | 
|---|
| 554 | /* between receive thread and lib */ | 
|---|
| 555 | #endif | 
|---|
| 556 |  | 
|---|
| 557 | #ifdef MSDOS | 
|---|
| 558 | int     (*pMsgHandler) (void*); | 
|---|
| 559 | #endif | 
|---|
| 560 | int             tIdCopSlv; | 
|---|
| 561 | Message msgBufferRx; | 
|---|
| 562 |  | 
|---|
| 563 | LWORD_t usedDpmCount;                           /* variable for objects interfacing to DPM, */ | 
|---|
| 564 | /* counts the actual offset to start of PP-area */ | 
|---|
| 565 |  | 
|---|
| 566 | int (*drvRead)();                                       /* driver function to call on internal DPM-read */ | 
|---|
| 567 | void (*drvWrite)();                                     /* driver function to call on internal DPM-write */ | 
|---|
| 568 | #endif | 
|---|
| 569 |  | 
|---|
| 570 | }; | 
|---|
| 571 |  | 
|---|
| 572 |  | 
|---|
| 573 | #if KDEBUG==1 | 
|---|
| 574 | /* DEBUG tool KPRINTF */ | 
|---|
| 575 | extern long freeMemDebug; | 
|---|
| 576 | #endif | 
|---|
| 577 |  | 
|---|
| 578 | #ifdef __cplusplus | 
|---|
| 579 | } | 
|---|
| 580 | #endif | 
|---|
| 581 |  | 
|---|
| 582 | #endif /* !gendef_DEFINED */ | 
|---|