/kern_oII/drivers/staging/epl/EplEvent.h

http://omnia2droid.googlecode.com/ · C++ Header · 279 lines · 133 code · 30 blank · 116 comment · 0 complexity · d47e2ef3cab73c10d48efc9c2617065c MD5 · raw file

  1. /****************************************************************************
  2. (c) SYSTEC electronic GmbH, D-07973 Greiz, August-Bebel-Str. 29
  3. www.systec-electronic.com
  4. Project: openPOWERLINK
  5. Description: include file for event module
  6. License:
  7. Redistribution and use in source and binary forms, with or without
  8. modification, are permitted provided that the following conditions
  9. are met:
  10. 1. Redistributions of source code must retain the above copyright
  11. notice, this list of conditions and the following disclaimer.
  12. 2. Redistributions in binary form must reproduce the above copyright
  13. notice, this list of conditions and the following disclaimer in the
  14. documentation and/or other materials provided with the distribution.
  15. 3. Neither the name of SYSTEC electronic GmbH nor the names of its
  16. contributors may be used to endorse or promote products derived
  17. from this software without prior written permission. For written
  18. permission, please contact info@systec-electronic.com.
  19. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  20. "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  21. LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  22. FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  23. COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  24. INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  25. BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  26. LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  27. CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  28. LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  29. ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  30. POSSIBILITY OF SUCH DAMAGE.
  31. Severability Clause:
  32. If a provision of this License is or becomes illegal, invalid or
  33. unenforceable in any jurisdiction, that shall not affect:
  34. 1. the validity or enforceability in that jurisdiction of any other
  35. provision of this License; or
  36. 2. the validity or enforceability in other jurisdictions of that or
  37. any other provision of this License.
  38. -------------------------------------------------------------------------
  39. $RCSfile: EplEvent.h,v $
  40. $Author: D.Krueger $
  41. $Revision: 1.8 $ $Date: 2008/11/17 16:40:39 $
  42. $State: Exp $
  43. Build Environment:
  44. GCC V3.4
  45. -------------------------------------------------------------------------
  46. Revision History:
  47. 2006/06/12 d.k.: start of the implementation, version 1.00
  48. ****************************************************************************/
  49. #ifndef _EPL_EVENT_H_
  50. #define _EPL_EVENT_H_
  51. #include "EplInc.h"
  52. #include "EplNmt.h"
  53. //---------------------------------------------------------------------------
  54. // const defines
  55. //---------------------------------------------------------------------------
  56. // name and size of event queues
  57. #define EPL_EVENT_NAME_SHB_KERNEL_TO_USER "ShbKernelToUser"
  58. #ifndef EPL_EVENT_SIZE_SHB_KERNEL_TO_USER
  59. #define EPL_EVENT_SIZE_SHB_KERNEL_TO_USER 32768 // 32 kByte
  60. #endif
  61. #define EPL_EVENT_NAME_SHB_USER_TO_KERNEL "ShbUserToKernel"
  62. #ifndef EPL_EVENT_SIZE_SHB_USER_TO_KERNEL
  63. #define EPL_EVENT_SIZE_SHB_USER_TO_KERNEL 32768 // 32 kByte
  64. #endif
  65. // max size of event argument
  66. #ifndef EPL_MAX_EVENT_ARG_SIZE
  67. #define EPL_MAX_EVENT_ARG_SIZE 256 // because of PDO
  68. #endif
  69. #define EPL_DLL_ERR_MN_CRC 0x00000001L // object 0x1C00
  70. #define EPL_DLL_ERR_MN_COLLISION 0x00000002L // object 0x1C01
  71. #define EPL_DLL_ERR_MN_CYCTIMEEXCEED 0x00000004L // object 0x1C02
  72. #define EPL_DLL_ERR_MN_LOSS_LINK 0x00000008L // object 0x1C03
  73. #define EPL_DLL_ERR_MN_CN_LATE_PRES 0x00000010L // objects 0x1C04-0x1C06
  74. #define EPL_DLL_ERR_MN_CN_LOSS_PRES 0x00000080L // objects 0x1C07-0x1C09
  75. #define EPL_DLL_ERR_CN_COLLISION 0x00000400L // object 0x1C0A
  76. #define EPL_DLL_ERR_CN_LOSS_SOC 0x00000800L // object 0x1C0B
  77. #define EPL_DLL_ERR_CN_LOSS_SOA 0x00001000L // object 0x1C0C
  78. #define EPL_DLL_ERR_CN_LOSS_PREQ 0x00002000L // object 0x1C0D
  79. #define EPL_DLL_ERR_CN_RECVD_PREQ 0x00004000L // decrement object 0x1C0D/2
  80. #define EPL_DLL_ERR_CN_SOC_JITTER 0x00008000L // object 0x1C0E
  81. #define EPL_DLL_ERR_CN_CRC 0x00010000L // object 0x1C0F
  82. #define EPL_DLL_ERR_CN_LOSS_LINK 0x00020000L // object 0x1C10
  83. #define EPL_DLL_ERR_MN_LOSS_STATRES 0x00040000L // objects 0x1C15-0x1C17 (should be operated by NmtMnu module)
  84. #define EPL_DLL_ERR_BAD_PHYS_MODE 0x00080000L // no object
  85. #define EPL_DLL_ERR_MAC_BUFFER 0x00100000L // no object (NMT_GT6)
  86. #define EPL_DLL_ERR_INVALID_FORMAT 0x00200000L // no object (NMT_GT6)
  87. #define EPL_DLL_ERR_ADDRESS_CONFLICT 0x00400000L // no object (remove CN from configuration)
  88. //---------------------------------------------------------------------------
  89. // typedef
  90. //---------------------------------------------------------------------------
  91. // EventType determines the argument of the event
  92. typedef enum {
  93. kEplEventTypeNmtEvent = 0x01, // NMT event
  94. // arg is pointer to tEplNmtEvent
  95. kEplEventTypePdoRx = 0x02, // PDO frame received event (PRes/PReq)
  96. // arg is pointer to tEplFrame
  97. kEplEventTypePdoTx = 0x03, // PDO frame transmitted event (PRes/PReq)
  98. // arg is pointer to tEplFrameInfo
  99. kEplEventTypePdoSoa = 0x04, // SoA frame received event (isochronous phase completed)
  100. // arg is pointer to nothing
  101. kEplEventTypeSync = 0x05, // Sync event (e.g. SoC or anticipated SoC)
  102. // arg is pointer to nothing
  103. kEplEventTypeTimer = 0x06, // Timer event
  104. // arg is pointer to tEplTimerEventArg
  105. kEplEventTypeHeartbeat = 0x07, // Heartbeat event
  106. // arg is pointer to tEplHeartbeatEvent
  107. kEplEventTypeDllkCreate = 0x08, // DLL kernel create event
  108. // arg is pointer to the new tEplNmtState
  109. kEplEventTypeDllkDestroy = 0x09, // DLL kernel destroy event
  110. // arg is pointer to the old tEplNmtState
  111. kEplEventTypeDllkFillTx = 0x0A, // DLL kernel fill TxBuffer event
  112. // arg is pointer to tEplDllAsyncReqPriority
  113. kEplEventTypeDllkPresReady = 0x0B, // DLL kernel PRes ready event
  114. // arg is pointer to nothing
  115. kEplEventTypeError = 0x0C, // Error event for API layer
  116. // arg is pointer to tEplEventError
  117. kEplEventTypeNmtStateChange = 0x0D, // indicate change of NMT-State
  118. // arg is pointer to tEplEventNmtStateChange
  119. kEplEventTypeDllError = 0x0E, // DLL error event for Error handler
  120. // arg is pointer to tEplErrorHandlerkEvent
  121. kEplEventTypeAsndRx = 0x0F, // received ASnd frame for DLL user module
  122. // arg is pointer to tEplFrame
  123. kEplEventTypeDllkServFilter = 0x10, // configure ServiceIdFilter
  124. // arg is pointer to tEplDllCalServiceIdFilter
  125. kEplEventTypeDllkIdentity = 0x11, // configure Identity
  126. // arg is pointer to tEplDllIdentParam
  127. kEplEventTypeDllkConfig = 0x12, // configure ConfigParam
  128. // arg is pointer to tEplDllConfigParam
  129. kEplEventTypeDllkIssueReq = 0x13, // issue Ident/Status request
  130. // arg is pointer to tEplDllCalIssueRequest
  131. kEplEventTypeDllkAddNode = 0x14, // add node to isochronous phase
  132. // arg is pointer to tEplDllNodeInfo
  133. kEplEventTypeDllkDelNode = 0x15, // remove node from isochronous phase
  134. // arg is pointer to unsigned int
  135. kEplEventTypeDllkSoftDelNode = 0x16, // remove node softly from isochronous phase
  136. // arg is pointer to unsigned int
  137. kEplEventTypeDllkStartReducedCycle = 0x17, // start reduced EPL cycle on MN
  138. // arg is pointer to nothing
  139. kEplEventTypeNmtMnuNmtCmdSent = 0x18, // NMT command was actually sent
  140. // arg is pointer to tEplFrame
  141. } tEplEventType;
  142. // EventSink determines the consumer of the event
  143. typedef enum {
  144. kEplEventSinkSync = 0x00, // Sync event for application or kernel EPL module
  145. kEplEventSinkNmtk = 0x01, // events for Nmtk module
  146. kEplEventSinkDllk = 0x02, // events for Dllk module
  147. kEplEventSinkDlluCal = 0x03, // events for DlluCal module
  148. kEplEventSinkDllkCal = 0x04, // events for DllkCal module
  149. kEplEventSinkPdok = 0x05, // events for Pdok module
  150. kEplEventSinkNmtu = 0x06, // events for Nmtu module
  151. kEplEventSinkErrk = 0x07, // events for Error handler module
  152. kEplEventSinkErru = 0x08, // events for Error signaling module
  153. kEplEventSinkSdoAsySeq = 0x09, // events for asyncronous SDO Sequence Layer module
  154. kEplEventSinkNmtMnu = 0x0A, // events for NmtMnu module
  155. kEplEventSinkLedu = 0x0B, // events for Ledu module
  156. kEplEventSinkApi = 0x0F, // events for API module
  157. } tEplEventSink;
  158. // EventSource determines the source of an errorevent
  159. typedef enum {
  160. // kernelspace modules
  161. kEplEventSourceDllk = 0x01, // Dllk module
  162. kEplEventSourceNmtk = 0x02, // Nmtk module
  163. kEplEventSourceObdk = 0x03, // Obdk module
  164. kEplEventSourcePdok = 0x04, // Pdok module
  165. kEplEventSourceTimerk = 0x05, // Timerk module
  166. kEplEventSourceEventk = 0x06, // Eventk module
  167. kEplEventSourceSyncCb = 0x07, // sync-Cb
  168. kEplEventSourceErrk = 0x08, // Error handler module
  169. // userspace modules
  170. kEplEventSourceDllu = 0x10, // Dllu module
  171. kEplEventSourceNmtu = 0x11, // Nmtu module
  172. kEplEventSourceNmtCnu = 0x12, // NmtCnu module
  173. kEplEventSourceNmtMnu = 0x13, // NmtMnu module
  174. kEplEventSourceObdu = 0x14, // Obdu module
  175. kEplEventSourceSdoUdp = 0x15, // Sdo/Udp module
  176. kEplEventSourceSdoAsnd = 0x16, // Sdo/Asnd module
  177. kEplEventSourceSdoAsySeq = 0x17, // Sdo asynchronus Sequence Layer module
  178. kEplEventSourceSdoCom = 0x18, // Sdo command layer module
  179. kEplEventSourceTimeru = 0x19, // Timeru module
  180. kEplEventSourceCfgMau = 0x1A, // CfgMau module
  181. kEplEventSourceEventu = 0x1B, // Eventu module
  182. kEplEventSourceEplApi = 0x1C, // Api module
  183. kEplEventSourceLedu = 0x1D, // Ledu module
  184. } tEplEventSource;
  185. // structure of EPL event (element order must not be changed!)
  186. typedef struct {
  187. tEplEventType m_EventType /*:28 */ ; // event type
  188. tEplEventSink m_EventSink /*:4 */ ; // event sink
  189. tEplNetTime m_NetTime; // timestamp
  190. unsigned int m_uiSize; // size of argument
  191. void *m_pArg; // argument of event
  192. } tEplEvent;
  193. // short structure of EPL event without argument and its size (element order must not be changed!)
  194. typedef struct {
  195. tEplEventType m_EventType /*:28 */ ; // event type
  196. tEplEventSink m_EventSink /*:4 */ ; // event sink
  197. tEplNetTime m_NetTime; // timestamp
  198. } tEplEventShort;
  199. typedef struct {
  200. unsigned int m_uiIndex;
  201. unsigned int m_uiSubIndex;
  202. } tEplEventObdError;
  203. // structure for kEplEventTypeError
  204. typedef struct {
  205. tEplEventSource m_EventSource; // module which posted this error event
  206. tEplKernel m_EplError; // EPL error which occured
  207. union {
  208. u8 m_bArg;
  209. u32 m_dwArg;
  210. tEplEventSource m_EventSource; // from Eventk/u module (originating error source)
  211. tEplEventObdError m_ObdError; // from Obd module
  212. // tEplErrHistoryEntry m_HistoryEntry; // from Nmtk/u module
  213. } m_Arg;
  214. } tEplEventError;
  215. // structure for kEplEventTypeDllError
  216. typedef struct {
  217. unsigned long m_ulDllErrorEvents; // EPL_DLL_ERR_*
  218. unsigned int m_uiNodeId;
  219. tEplNmtState m_NmtState;
  220. } tEplErrorHandlerkEvent;
  221. // callback function to get informed about sync event
  222. typedef tEplKernel(*tEplSyncCb) (void);
  223. // callback function for generic events
  224. typedef tEplKernel(*tEplProcessEventCb) (tEplEvent *pEplEvent_p);
  225. //---------------------------------------------------------------------------
  226. // function prototypes
  227. //---------------------------------------------------------------------------
  228. #endif // #ifndef _EPL_EVENT_H_