| 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 */
|
|---|