include/sdo.h
author greg
Wed, 15 Jul 2009 09:32:35 +0200
changeset 555 ee24dcbd3e64
parent 539 187058b4a4b8
child 561 f9be4262c68d
permissions -rw-r--r--
Add new example : CANOpen shell
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     1
/*
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
     2
This file is part of CanFestival, a library implementing CanOpen Stack.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     3
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     4
Copyright (C): Edouard TISSERANT and Francis DUPIN
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     5
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     6
See COPYING file for copyrights details.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     7
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     8
This library is free software; you can redistribute it and/or
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     9
modify it under the terms of the GNU Lesser General Public
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    10
License as published by the Free Software Foundation; either
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    11
version 2.1 of the License, or (at your option) any later version.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    12
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    13
This library is distributed in the hope that it will be useful,
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    14
but WITHOUT ANY WARRANTY; without even the implied warranty of
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    15
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    16
Lesser General Public License for more details.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    17
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    18
You should have received a copy of the GNU Lesser General Public
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    19
License along with this library; if not, write to the Free Software
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    20
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    21
*/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    22
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    23
/** @defgroup comobj Communication Objects
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    24
 *  @ingroup userapi
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    25
 */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    26
 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    27
/** @defgroup sdo Service Data Object (SDO)
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    28
 *  SDOs provide the access to entries in the CANopen Object Dictionary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    29
 * 	An SDO is made up of at least two CAN messages with different identifiers.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    30
 * 	SDO s are always confirmed point-to-point communications services. 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    31
 *  @ingroup comobj
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    32
 */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    33
 
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    34
#ifndef __sdo_h__
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    35
#define __sdo_h__
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    36
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    37
struct struct_s_transfer;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    38
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    39
#include "timer.h"
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    40
32
8afa33692372 SDO callbacks.
etisserant
parents: 0
diff changeset
    41
typedef void (*SDOCallback_t)(CO_Data* d, UNS8 nodeId);
8afa33692372 SDO callbacks.
etisserant
parents: 0
diff changeset
    42
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    43
/* The Transfer structure
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    44
Used to store the different segments of
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    45
 - a SDO received before writing in the dictionary
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    46
 - the reading of the dictionary to put on a SDO to transmit
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    47
*/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    48
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    49
struct struct_s_transfer {
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    50
  UNS8           nodeId;     /**<own ID if server, or node ID of the server if client */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    51
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    52
  UNS8           whoami;     /**< Takes the values SDO_CLIENT or SDO_SERVER */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    53
  UNS8           state;      /**< state of the transmission : Takes the values SDO_... */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    54
  UNS8           toggle;	
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    55
  UNS32          abortCode;  /**< Sent or received */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    56
  /**< index and subindex of the dictionary where to store */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    57
  /**< (for a received SDO) or to read (for a transmit SDO) */
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    58
  UNS16          index;
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    59
  UNS8           subIndex;
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    60
  UNS32          count;      /**< Number of data received or to be sent. */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    61
  UNS32          offset;     /**< stack pointer of data[]
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    62
                              * Used only to tranfer part of a line to or from a SDO.
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    63
                              * offset is always pointing on the next free cell of data[].
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    64
                              * WARNING s_transfer.data is subject to ENDIANISATION
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    65
                              * (with respect to CANOPEN_BIG_ENDIAN)
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    66
                              */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    67
  UNS8           data [SDO_MAX_LENGTH_TRANSFERT];
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    68
  UNS8           dataType;   /**< Defined in objdictdef.h Value is visible_string
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    69
                              * if it is a string, any other value if it is not a string,
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    70
                              * like 0. In fact, it is used only if client.
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    71
                              */
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    72
  TIMER_HANDLE   timer;      /**< Time counter to implement a timeout in milliseconds.
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    73
                              * It is automatically incremented whenever
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    74
                              * the line state is in SDO_DOWNLOAD_IN_PROGRESS or
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    75
                              * SDO_UPLOAD_IN_PROGRESS, and reseted to 0
74
c0b4b2ef7579 compiler compatibility : comments
frdupin
parents: 71
diff changeset
    76
                              * when the response SDO have been received.
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    77
                              */
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    78
  SDOCallback_t Callback;   /**< The user callback func to be called at SDO transaction end */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    79
};
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    80
typedef struct struct_s_transfer s_transfer;
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
    81
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    82
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    83
#include "data.h"
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    84
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    85
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    86
struct BODY{
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    87
    UNS8 data[8]; /**< The 8 bytes data of the SDO */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    88
};
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    89
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 53
diff changeset
    90
/* The SDO structure ...*/
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    91
struct struct_s_SDO {
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    92
  UNS8 nodeId;		/**< In any case, Node ID of the server (case sender or receiver).*/
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    93
  struct BODY body;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    94
};
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    95
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    96
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    97
typedef struct struct_s_SDO s_SDO;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    98
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
    99
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   100
 * @brief Reset of a SDO exchange on timeout.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   101
 * Send a SDO abort.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   102
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   103
 * @param id
53
73bc47a0db55 Add prototypes
frdupin
parents: 32
diff changeset
   104
 */
73bc47a0db55 Add prototypes
frdupin
parents: 32
diff changeset
   105
void SDOTimeoutAlarm(CO_Data* d, UNS32 id);
73bc47a0db55 Add prototypes
frdupin
parents: 32
diff changeset
   106
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   107
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   108
 * @brief Reset all SDO buffers.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   109
 * @param *d Pointer on a CAN object data structure
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   110
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   111
void resetSDO (CO_Data* d);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   112
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   113
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   114
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   115
 * @brief Copy the data received from the SDO line transfert to the object dictionary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   116
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   117
 * @param line SDO line
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   118
 * @return SDO error code if error. Else, returns 0.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   119
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   120
UNS32 SDOlineToObjdict (CO_Data* d, UNS8 line);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   121
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   122
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   123
 * @brief Copy the data from the object dictionary to the SDO line for a network transfert.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   124
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   125
 * @param line SDO line
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   126
 * @return SDO error code if error. Else, returns 0.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   127
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   128
UNS32 objdictToSDOline (CO_Data* d, UNS8 line);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   129
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   130
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   131
 * @brief Copy data from an existant line in the argument "* data"
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   132
 * @param d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   133
 * @param line SDO line
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   134
 * @param nbBytes
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   135
 * @param *data Pointer on the data
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   136
 * @return 0xFF if error. Else, returns 0.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   137
 */
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   138
UNS8 lineToSDO (CO_Data* d, UNS8 line, UNS32 nbBytes, UNS8 * data);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   139
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   140
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   141
 * @brief Add data to an existant line
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   142
 * @param d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   143
 * @param line SDO line
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   144
 * @param nbBytes
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   145
 * @param *data Pointer on the data
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   146
 * @return 0xFF if error. Else, returns 0.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   147
 */
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   148
UNS8 SDOtoLine (CO_Data* d, UNS8 line, UNS32 nbBytes, UNS8 * data);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   149
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   150
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   151
 * @brief Called when an internal SDO abort occurs.
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   152
 * Release the line * Only if server *
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   153
 * If client, the line must be released manually in the core application.
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   154
 * The reason of that is to permit the program to read the transfers structure before its reset,
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   155
 * because many informations are stored on it : index, subindex, data received or trasmited, ...
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   156
 * In all cases, sends a SDO abort.
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   157
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   158
 * @param nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   159
 * @param whoami
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   160
 * @param index
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   161
 * @param subIndex
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   162
 * @param abortCode
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   163
 * @return 0
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   164
 */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   165
UNS8 failedSDO (CO_Data* d, UNS8 nodeId, UNS8 whoami, UNS16 index, UNS8 subIndex, UNS32 abortCode);
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   166
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   167
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   168
 * @brief Reset an unused line.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   169
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   170
 * @param line SDO line
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   171
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   172
void resetSDOline (CO_Data* d, UNS8 line);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   173
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   174
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   175
 * @brief Initialize some fields of the structure.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   176
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   177
 * @param line
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   178
 * @param nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   179
 * @param index
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   180
 * @param subIndex
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   181
 * @param state
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   182
 * @return 0
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   183
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   184
UNS8 initSDOline (CO_Data* d, UNS8 line, UNS8 nodeId, UNS16 index, UNS8 subIndex, UNS8 state);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   185
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   186
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   187
 * @brief Search for an unused line in the transfers array
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   188
 * to store a new SDO.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   189
 * ie a line which value of the field "state" is "SDO_RESET"
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   190
 * An unused line have the field "state" at the value SDO_RESET
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   191
 * bus_id is hardware dependant
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   192
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   193
 * @param whoami Create the line for a SDO_SERVER or SDO_CLIENT.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   194
 * @param *line Pointer on a SDO line 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   195
 * @return 0xFF if all the lines are on use. Else, return 0.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   196
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   197
UNS8 getSDOfreeLine (CO_Data* d, UNS8 whoami, UNS8 *line);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   198
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   199
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   200
 * @brief Search for the line, in the transfers array, which contains the
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   201
 * beginning of the reception of a fragmented SDO
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   202
 * bus_id is hardware dependant
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   203
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   204
 * @param nodeId correspond to the message node-id
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   205
 * @param whoami takes 2 values : look for a line opened as SDO_CLIENT or SDO_SERVER
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   206
 * @param *line Pointer on a SDO line 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   207
 * @return 0xFF if error.  Else, return 0
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   208
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   209
UNS8 getSDOlineOnUse (CO_Data* d, UNS8 nodeId, UNS8 whoami, UNS8 *line);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   210
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   211
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   212
 * @brief Close a transmission.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   213
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   214
 * @param nodeId Node id of the server if both server or client
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   215
 * @param whoami Line opened as SDO_CLIENT or SDO_SERVER
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   216
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   217
UNS8 closeSDOtransfer (CO_Data* d, UNS8 nodeId, UNS8 whoami);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   218
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   219
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   220
 * @brief Bytes in the line structure which must be transmited (or received)
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   221
 * bus_id is hardware dependant.
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   222
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   223
 * @param line SDO line 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   224
 * @param *nbBytes Pointer on nbBytes
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   225
 * @return 0.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   226
 */
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   227
UNS8 getSDOlineRestBytes (CO_Data* d, UNS8 line, UNS32 * nbBytes);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   228
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   229
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   230
 * @brief Store in the line structure the nb of bytes which must be transmited (or received)
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   231
 * bus_id is hardware dependant.
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   232
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   233
 * @param line SDO line 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   234
 * @param nbBytes
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   235
 * @return 0 if success, 0xFF if error.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   236
 */
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   237
UNS8 setSDOlineRestBytes (CO_Data* d, UNS8 line, UNS32 nbBytes);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   238
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   239
/**
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   240
 * @brief Transmit a SDO frame on the bus bus_id
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   241
 * bus_id is hardware dependant
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   242
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   243
 * @param whoami Takes 2 values : SDO_CLIENT or SDO_SERVER
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   244
 * @param sdo SDO Structure which contains the sdo to transmit
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   245
 * @return canSend(bus_id,&m) or 0xFF if error.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   246
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   247
UNS8 sendSDO (CO_Data* d, UNS8 whoami, s_SDO sdo);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   248
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   249
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   250
 * @brief Transmit a SDO error to the client. The reasons may be :
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   251
 * Read/Write to a undefined object
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   252
 * Read/Write to a undefined subindex
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   253
 * Read/write a not valid length object
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   254
 * Write a read only object
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   255
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   256
 * @param whoami takes 2 values : SDO_CLIENT or SDO_SERVER
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   257
 * @param nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   258
 * @param index
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   259
 * @param subIndex
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   260
 * @param abortCode
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   261
 * @return 0
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   262
 */
499
061f12bd838b getReadResultNetworkDict now returns abortcode. Now, abort message should be sent correctly from client.
etisserant
parents: 172
diff changeset
   263
UNS8 sendSDOabort (CO_Data* d, UNS8 whoami, UNS8 nodeId, UNS16 index, UNS8 subIndex, UNS32 abortCode);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   264
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   265
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   266
 * @brief Treat a SDO frame reception
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   267
 * bus_id is hardware dependant
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   268
 * call the function sendSDO
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   269
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   270
 * @param *m Pointer on a CAN message structure 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   271
 * @return code : 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   272
 * 		   - 0xFF if error
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   273
 *         - 0x80 if transfert aborted by the server
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   274
 *         - 0x0  ok
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   275
 */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   276
UNS8 proceedSDO (CO_Data* d, Message *m);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   277
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   278
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   279
 * @ingroup sdo
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   280
 * @brief Used by the application to send a SDO request frame to write the data *data
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   281
 * at the index and subIndex indicated
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   282
 * bus_id is hardware dependant
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   283
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   284
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   285
 * @param index At index indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   286
 * @param subIndex At subIndex indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   287
 * @param count number of bytes to write in the dictionnary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   288
 * @param dataType (defined in objdictdef.h) : put "visible_string" for strings, 0 for integers or reals or other value.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   289
 * @param *data Pointer on data
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   290
 * @return 0xFF if error, else return 0
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   291
 */
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   292
UNS8 writeNetworkDict (CO_Data* d, UNS8 nodeId, UNS16 index,
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   293
		       UNS8 subIndex, UNS32 count, UNS8 dataType, void *data);
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   294
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   295
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   296
 * @ingroup sdo
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   297
 * @brief Used to send a SDO request frame to write in a distant node dictionnary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   298
 * The function Callback which must be defined in the user code is called at the
53
73bc47a0db55 Add prototypes
frdupin
parents: 32
diff changeset
   299
 * end of the exchange. (on succes or abort).
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   300
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   301
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   302
 * @param index At index indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   303
 * @param subIndex At subIndex indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   304
 * @param count number of bytes to write in the dictionnary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   305
 * @param dataType (defined in objdictdef.h) : put "visible_string" for strings, 0 for integers or reals or other value.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   306
 * @param *data Pointer on data
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   307
 * @param Callback Callback function
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   308
 * @return 0xFF if error, else return 0
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   309
 */
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   310
UNS8 writeNetworkDictCallBack (CO_Data* d, UNS8 nodeId, UNS16 index,
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   311
		       UNS8 subIndex, UNS32 count, UNS8 dataType, void *data, SDOCallback_t Callback);
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   312
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   313
/**
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   314
 * @ingroup sdo 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   315
 * @brief Used to send a SDO request frame to write in a distant node dictionnary.
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   316
 * The function Callback	which must be defined in the user code is called at the
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   317
 * end of the exchange. (on succes or abort). First free SDO client parameter is
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   318
 * automatically initialized for specific node if not already defined.
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   319
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   320
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   321
 * @param index At index indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   322
 * @param subIndex At subIndex indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   323
 * @param count number of bytes to write in the dictionnary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   324
 * @param dataType (defined in objdictdef.h) : put "visible_string" for strings, 0 for integers or reals or other value.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   325
 * @param *data Pointer on data
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   326
 * @param Callback Callback function
529
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   327
 * @param endianize When not 0, data is endianized into network byte order
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   328
 *                  when 0, data is not endianized and copied in machine native
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   329
 *                  endianness
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   330
 * @return 0xFF if error, else return 0
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   331
 */
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   332
UNS8 writeNetworkDictCallBackAI (CO_Data* d, UNS8 nodeId, UNS16 index,
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   333
		       UNS8 subIndex, UNS32 count, UNS8 dataType, void *data, SDOCallback_t Callback, UNS8 endianize);
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   334
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   335
/**
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   336
 * @ingroup sdo 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   337
 * @brief Used by the application to send a SDO request frame to read
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   338
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   339
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   340
 * @param index At index indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   341
 * @param subIndex At subIndex indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   342
 * @param dataType (defined in objdictdef.h) : put "visible_string" for strings, 0 for integers or reals or other value. * bus_id is hardware dependant
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   343
 * @return 0xFF if error, else return 0
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   344
 */
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   345
UNS8 readNetworkDict (CO_Data* d, UNS8 nodeId, UNS16 index, UNS8 subIndex, UNS8 dataType);
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   346
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   347
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   348
 * @ingroup sdo
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   349
 * @brief Used to send a SDO request frame to read in a distant node dictionnary.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   350
 * The function Callback which must be defined in the user code is called at the
53
73bc47a0db55 Add prototypes
frdupin
parents: 32
diff changeset
   351
 * end of the exchange. (on succes or abort).
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   352
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   353
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   354
 * @param index At index indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   355
 * @param subIndex At subIndex indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   356
 * @param dataType (defined in objdictdef.h) : put "visible_string" for strings, 0 for integers or reals or other value.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   357
 * @param Callback Callback function
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   358
 * @return 0xFF if error, else return 0
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   359
 */
53
73bc47a0db55 Add prototypes
frdupin
parents: 32
diff changeset
   360
UNS8 readNetworkDictCallback (CO_Data* d, UNS8 nodeId, UNS16 index, UNS8 subIndex, UNS8 dataType, SDOCallback_t Callback);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   361
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   362
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   363
 * @ingroup sdo
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   364
 * @brief Used to send a SDO request frame to read in a distant node dictionnary.
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   365
 * The function Callback which must be defined in the user code is called at the
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   366
 * end of the exchange. (on succes or abort). First free SDO client parameter is
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   367
 * automatically initialized for specific node if not already defined.
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   368
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   369
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   370
 * @param index At index indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   371
 * @param subIndex At subIndex indicated
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   372
 * @param dataType (defined in objdictdef.h) : put "visible_string" for strings, 0 for integers or reals or other value.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   373
 * @param Callback Callback function
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   374
 * @return 0xFF if error, else return 0
506
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   375
 */
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   376
UNS8 readNetworkDictCallbackAI (CO_Data* d, UNS8 nodeId, UNS16 index, UNS8 subIndex, UNS8 dataType, SDOCallback_t Callback);
c17e2e17aca8 Patch from Jari K. implementing automatic SDO clien allocation, and add a new interface for (read/write)networkdict.
etisserant
parents: 499
diff changeset
   377
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   378
/** 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   379
 * @ingroup sdo
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   380
 * @brief Use this function after a readNetworkDict to get the result.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   381
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   382
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   383
 * @param *data Pointer on data
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   384
 * @param *size Pointer on size
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   385
 * @param *abortCode Pointer on the abortcode. 0 = not available. Else : SDO abort code. (received if return SDO_ABORTED_RCV)
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   386
 * 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   387
 * 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   388
 * @return
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   389
 *           - SDO_FINISHED             // data is available
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   390
 *           - SDO_ABORTED_RCV          // Transfert failed. (abort SDO received)
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   391
 *           - SDO_ABORTED_INTERNAL     // Transfert failed. Internal abort.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   392
 *           - SDO_UPLOAD_IN_PROGRESS   // Data not yet available
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   393
 *           - SDO_DOWNLOAD_IN_PROGRESS // Should not arrive !
529
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   394
 * @code
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   395
 * example :
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   396
 * UNS32 data;
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   397
 * UNS8 size;
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   398
 * readNetworkDict(0, 0x05, 0x1016, 1, 0) // get the data index 1016 subindex 1 of node 5
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   399
 * while (getReadResultNetworkDict (0, 0x05, &data, &size) != SDO_UPLOAD_IN_PROGRESS);
529
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   400
 * @endcode
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   401
*/
539
187058b4a4b8 Changed OD size from UNS8 to UNS32, and repercuted change to PDO and SDO. Thanks to Jari Kuusisto for patch.
etisserant
parents: 529
diff changeset
   402
UNS8 getReadResultNetworkDict (CO_Data* d, UNS8 nodeId, void* data, UNS32 *size, UNS32 * abortCode);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   403
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   404
/**
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   405
 * @brief Use this function after a writeNetworkDict to get the result of the write
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   406
 * It is mandatory to call this function because it is releasing the line used for the transfer.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   407
 * @param *d Pointer on a CAN object data structure
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   408
 * @param nodeId In the dictionary of the slave whose node_id is nodeId
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   409
 * @param *abortCode Pointer on the abortcode. 0 = not available. Else : SDO abort code. (received if return SDO_ABORTED_RCV)
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   410
 * 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   411
 * @return : 
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   412
 *           - SDO_FINISHED             // data is available
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   413
 *           - SDO_ABORTED_RCV          // Transfert failed. (abort SDO received)
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   414
 *           - SDO_ABORTED_INTERNAL     // Transfert failed. Internal abort.
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   415
 *           - SDO_DOWNLOAD_IN_PROGRESS // Data not yet available
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   416
 *           - SDO_UPLOAD_IN_PROGRESS   // Should not arrive !
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   417
 * 
529
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   418
 * @code
528
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   419
 * example :
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   420
 * UNS32 data = 0x50;
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   421
 * UNS8 size;
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   422
 * UNS32 abortCode;
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   423
 * writeNetworkDict(0, 0x05, 0x1016, 1, size, &data) // write the data index 1016 subindex 1 of node 5
0a30e161d63c Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 506
diff changeset
   424
 * while (getWriteResultNetworkDict (0, 0x05, &abortCode) != SDO_DOWNLOAD_IN_PROGRESS);
529
c171e11707c5 Second time, Re-write doxygen tags in headers files to generate User API documentation
greg
parents: 528
diff changeset
   425
 * @endcode
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   426
*/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   427
UNS8 getWriteResultNetworkDict (CO_Data* d, UNS8 nodeId, UNS32 * abortCode);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   428
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   429
#endif