1*10465441SEvalZero /* 2*10465441SEvalZero * FreeModbus Libary: A portable Modbus implementation for Modbus ASCII/RTU. 3*10465441SEvalZero * Copyright (c) 2006 Christian Walter <[email protected]> 4*10465441SEvalZero * All rights reserved. 5*10465441SEvalZero * 6*10465441SEvalZero * Redistribution and use in source and binary forms, with or without 7*10465441SEvalZero * modification, are permitted provided that the following conditions 8*10465441SEvalZero * are met: 9*10465441SEvalZero * 1. Redistributions of source code must retain the above copyright 10*10465441SEvalZero * notice, this list of conditions and the following disclaimer. 11*10465441SEvalZero * 2. Redistributions in binary form must reproduce the above copyright 12*10465441SEvalZero * notice, this list of conditions and the following disclaimer in the 13*10465441SEvalZero * documentation and/or other materials provided with the distribution. 14*10465441SEvalZero * 3. The name of the author may not be used to endorse or promote products 15*10465441SEvalZero * derived from this software without specific prior written permission. 16*10465441SEvalZero * 17*10465441SEvalZero * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 18*10465441SEvalZero * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 19*10465441SEvalZero * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 20*10465441SEvalZero * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 21*10465441SEvalZero * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 22*10465441SEvalZero * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23*10465441SEvalZero * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24*10465441SEvalZero * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25*10465441SEvalZero * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 26*10465441SEvalZero * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27*10465441SEvalZero * 28*10465441SEvalZero * File: $Id: mbport.h,v 1.17 2006/12/07 22:10:34 wolti Exp $ 29*10465441SEvalZero * mbport.h,v 1.60 2013/08/17 11:42:56 Armink Add Master Functions $ 30*10465441SEvalZero */ 31*10465441SEvalZero 32*10465441SEvalZero #ifndef _MB_PORT_H 33*10465441SEvalZero #define _MB_PORT_H 34*10465441SEvalZero 35*10465441SEvalZero #ifdef __cplusplus 36*10465441SEvalZero PR_BEGIN_EXTERN_C 37*10465441SEvalZero #endif 38*10465441SEvalZero 39*10465441SEvalZero /* ----------------------- Defines ------------------------------------------*/ 40*10465441SEvalZero 41*10465441SEvalZero /* ----------------------- Type definitions ---------------------------------*/ 42*10465441SEvalZero 43*10465441SEvalZero typedef enum 44*10465441SEvalZero { 45*10465441SEvalZero EV_READY = 1<<0, /*!< Startup finished. */ 46*10465441SEvalZero EV_FRAME_RECEIVED = 1<<1, /*!< Frame received. */ 47*10465441SEvalZero EV_EXECUTE = 1<<2, /*!< Execute function. */ 48*10465441SEvalZero EV_FRAME_SENT = 1<<3 /*!< Frame sent. */ 49*10465441SEvalZero } eMBEventType; 50*10465441SEvalZero 51*10465441SEvalZero typedef enum 52*10465441SEvalZero { 53*10465441SEvalZero EV_MASTER_READY = 1<<0, /*!< Startup finished. */ 54*10465441SEvalZero EV_MASTER_FRAME_RECEIVED = 1<<1, /*!< Frame received. */ 55*10465441SEvalZero EV_MASTER_EXECUTE = 1<<2, /*!< Execute function. */ 56*10465441SEvalZero EV_MASTER_FRAME_SENT = 1<<3, /*!< Frame sent. */ 57*10465441SEvalZero EV_MASTER_ERROR_PROCESS = 1<<4, /*!< Frame error process. */ 58*10465441SEvalZero EV_MASTER_PROCESS_SUCESS = 1<<5, /*!< Request process success. */ 59*10465441SEvalZero EV_MASTER_ERROR_RESPOND_TIMEOUT = 1<<6, /*!< Request respond timeout. */ 60*10465441SEvalZero EV_MASTER_ERROR_RECEIVE_DATA = 1<<7, /*!< Request receive data error. */ 61*10465441SEvalZero EV_MASTER_ERROR_EXECUTE_FUNCTION = 1<<8, /*!< Request execute function error. */ 62*10465441SEvalZero } eMBMasterEventType; 63*10465441SEvalZero 64*10465441SEvalZero typedef enum 65*10465441SEvalZero { 66*10465441SEvalZero EV_ERROR_RESPOND_TIMEOUT, /*!< Slave respond timeout. */ 67*10465441SEvalZero EV_ERROR_RECEIVE_DATA, /*!< Receive frame data erroe. */ 68*10465441SEvalZero EV_ERROR_EXECUTE_FUNCTION, /*!< Execute function error. */ 69*10465441SEvalZero } eMBMasterErrorEventType; 70*10465441SEvalZero 71*10465441SEvalZero /*! \ingroup modbus 72*10465441SEvalZero * \brief Parity used for characters in serial mode. 73*10465441SEvalZero * 74*10465441SEvalZero * The parity which should be applied to the characters sent over the serial 75*10465441SEvalZero * link. Please note that this values are actually passed to the porting 76*10465441SEvalZero * layer and therefore not all parity modes might be available. 77*10465441SEvalZero */ 78*10465441SEvalZero typedef enum 79*10465441SEvalZero { 80*10465441SEvalZero MB_PAR_NONE, /*!< No parity. */ 81*10465441SEvalZero MB_PAR_ODD, /*!< Odd parity. */ 82*10465441SEvalZero MB_PAR_EVEN /*!< Even parity. */ 83*10465441SEvalZero } eMBParity; 84*10465441SEvalZero 85*10465441SEvalZero /* ----------------------- Supporting functions -----------------------------*/ 86*10465441SEvalZero BOOL xMBPortEventInit( void ); 87*10465441SEvalZero 88*10465441SEvalZero BOOL xMBPortEventPost( eMBEventType eEvent ); 89*10465441SEvalZero 90*10465441SEvalZero BOOL xMBPortEventGet( /*@out@ */ eMBEventType * eEvent ); 91*10465441SEvalZero 92*10465441SEvalZero BOOL xMBMasterPortEventInit( void ); 93*10465441SEvalZero 94*10465441SEvalZero BOOL xMBMasterPortEventPost( eMBMasterEventType eEvent ); 95*10465441SEvalZero 96*10465441SEvalZero BOOL xMBMasterPortEventGet( /*@out@ */ eMBMasterEventType * eEvent ); 97*10465441SEvalZero 98*10465441SEvalZero void vMBMasterOsResInit( void ); 99*10465441SEvalZero 100*10465441SEvalZero BOOL xMBMasterRunResTake( int32_t time ); 101*10465441SEvalZero 102*10465441SEvalZero void vMBMasterRunResRelease( void ); 103*10465441SEvalZero 104*10465441SEvalZero /* ----------------------- Serial port functions ----------------------------*/ 105*10465441SEvalZero 106*10465441SEvalZero BOOL xMBPortSerialInit( UCHAR ucPort, ULONG ulBaudRate, 107*10465441SEvalZero UCHAR ucDataBits, eMBParity eParity ); 108*10465441SEvalZero 109*10465441SEvalZero void vMBPortClose( void ); 110*10465441SEvalZero 111*10465441SEvalZero void xMBPortSerialClose( void ); 112*10465441SEvalZero 113*10465441SEvalZero void vMBPortSerialEnable( BOOL xRxEnable, BOOL xTxEnable ); 114*10465441SEvalZero 115*10465441SEvalZero INLINE BOOL xMBPortSerialGetByte( CHAR * pucByte ); 116*10465441SEvalZero 117*10465441SEvalZero INLINE BOOL xMBPortSerialPutByte( CHAR ucByte ); 118*10465441SEvalZero 119*10465441SEvalZero BOOL xMBMasterPortSerialInit( UCHAR ucPort, ULONG ulBaudRate, 120*10465441SEvalZero UCHAR ucDataBits, eMBParity eParity ); 121*10465441SEvalZero 122*10465441SEvalZero void vMBMasterPortClose( void ); 123*10465441SEvalZero 124*10465441SEvalZero void xMBMasterPortSerialClose( void ); 125*10465441SEvalZero 126*10465441SEvalZero void vMBMasterPortSerialEnable( BOOL xRxEnable, BOOL xTxEnable ); 127*10465441SEvalZero 128*10465441SEvalZero INLINE BOOL xMBMasterPortSerialGetByte( CHAR * pucByte ); 129*10465441SEvalZero 130*10465441SEvalZero INLINE BOOL xMBMasterPortSerialPutByte( CHAR ucByte ); 131*10465441SEvalZero 132*10465441SEvalZero /* ----------------------- Timers functions ---------------------------------*/ 133*10465441SEvalZero BOOL xMBPortTimersInit( USHORT usTimeOut50us ); 134*10465441SEvalZero 135*10465441SEvalZero void xMBPortTimersClose( void ); 136*10465441SEvalZero 137*10465441SEvalZero INLINE void vMBPortTimersEnable( void ); 138*10465441SEvalZero 139*10465441SEvalZero INLINE void vMBPortTimersDisable( void ); 140*10465441SEvalZero 141*10465441SEvalZero BOOL xMBMasterPortTimersInit( USHORT usTimeOut50us ); 142*10465441SEvalZero 143*10465441SEvalZero void xMBMasterPortTimersClose( void ); 144*10465441SEvalZero 145*10465441SEvalZero INLINE void vMBMasterPortTimersT35Enable( void ); 146*10465441SEvalZero 147*10465441SEvalZero INLINE void vMBMasterPortTimersConvertDelayEnable( void ); 148*10465441SEvalZero 149*10465441SEvalZero INLINE void vMBMasterPortTimersRespondTimeoutEnable( void ); 150*10465441SEvalZero 151*10465441SEvalZero INLINE void vMBMasterPortTimersDisable( void ); 152*10465441SEvalZero 153*10465441SEvalZero /* ----------------- Callback for the master error process ------------------*/ 154*10465441SEvalZero void vMBMasterErrorCBRespondTimeout( UCHAR ucDestAddress, const UCHAR* pucPDUData, 155*10465441SEvalZero USHORT ucPDULength ); 156*10465441SEvalZero 157*10465441SEvalZero void vMBMasterErrorCBReceiveData( UCHAR ucDestAddress, const UCHAR* pucPDUData, 158*10465441SEvalZero USHORT ucPDULength ); 159*10465441SEvalZero 160*10465441SEvalZero void vMBMasterErrorCBExecuteFunction( UCHAR ucDestAddress, const UCHAR* pucPDUData, 161*10465441SEvalZero USHORT ucPDULength ); 162*10465441SEvalZero 163*10465441SEvalZero void vMBMasterCBRequestScuuess( void ); 164*10465441SEvalZero 165*10465441SEvalZero /* ----------------------- Callback for the protocol stack ------------------*/ 166*10465441SEvalZero 167*10465441SEvalZero /*! 168*10465441SEvalZero * \brief Callback function for the porting layer when a new byte is 169*10465441SEvalZero * available. 170*10465441SEvalZero * 171*10465441SEvalZero * Depending upon the mode this callback function is used by the RTU or 172*10465441SEvalZero * ASCII transmission layers. In any case a call to xMBPortSerialGetByte() 173*10465441SEvalZero * must immediately return a new character. 174*10465441SEvalZero * 175*10465441SEvalZero * \return <code>TRUE</code> if a event was posted to the queue because 176*10465441SEvalZero * a new byte was received. The port implementation should wake up the 177*10465441SEvalZero * tasks which are currently blocked on the eventqueue. 178*10465441SEvalZero */ 179*10465441SEvalZero extern BOOL( *pxMBFrameCBByteReceived ) ( void ); 180*10465441SEvalZero 181*10465441SEvalZero extern BOOL( *pxMBFrameCBTransmitterEmpty ) ( void ); 182*10465441SEvalZero 183*10465441SEvalZero extern BOOL( *pxMBPortCBTimerExpired ) ( void ); 184*10465441SEvalZero 185*10465441SEvalZero extern BOOL( *pxMBMasterFrameCBByteReceived ) ( void ); 186*10465441SEvalZero 187*10465441SEvalZero extern BOOL( *pxMBMasterFrameCBTransmitterEmpty ) ( void ); 188*10465441SEvalZero 189*10465441SEvalZero extern BOOL( *pxMBMasterPortCBTimerExpired ) ( void ); 190*10465441SEvalZero 191*10465441SEvalZero /* ----------------------- TCP port functions -------------------------------*/ 192*10465441SEvalZero BOOL xMBTCPPortInit( USHORT usTCPPort ); 193*10465441SEvalZero 194*10465441SEvalZero void vMBTCPPortClose( void ); 195*10465441SEvalZero 196*10465441SEvalZero void vMBTCPPortDisable( void ); 197*10465441SEvalZero 198*10465441SEvalZero BOOL xMBTCPPortGetRequest( UCHAR **ppucMBTCPFrame, USHORT * usTCPLength ); 199*10465441SEvalZero 200*10465441SEvalZero BOOL xMBTCPPortSendResponse( const UCHAR *pucMBTCPFrame, USHORT usTCPLength ); 201*10465441SEvalZero 202*10465441SEvalZero #ifdef __cplusplus 203*10465441SEvalZero PR_END_EXTERN_C 204*10465441SEvalZero #endif 205*10465441SEvalZero #endif 206