xref: /nrf52832-nimble/rt-thread/components/net/freemodbus/modbus/include/mbport.h (revision 104654410c56c573564690304ae786df310c91fc)
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