⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 modbus_arm.h

📁 wince环境下的一个EVC的modbus协议通讯的例子程序
💻 H
字号:
// Modbus_ARM.h : main header file for the Modbus_ARM DLL
//

#if !defined(AFX_Modbus_ARM_H__94D9CFBC_56CE_4C36_B846_FA74648487CF__INCLUDED_)
#define AFX_Modbus_ARM_H__94D9CFBC_56CE_4C36_B846_FA74648487CF__INCLUDED_

#if _MSC_VER >= 1000
#pragma once
#endif // _MSC_VER >= 1000

#ifndef __AFXWIN_H__
	#error include 'stdafx.h' before including this file for PCH
#endif

#include "resource.h"		// main symbols

/////////////////////////////////////////////////////////////////////////////
// CModbus_ARMApp
// See Modbus_ARM.cpp for the implementation of this class
//

//#include  "MBDLLTool.h"   // fun. define
// The following ifdef block is the standard way of creating macros which make exporting 
// from a DLL simpler. All files within this DLL are compiled with the WINCONSDK_EXPORTS
// symbol defined on the command line. this symbol should not be defined on any project
// that uses this DLL. This way any other project whose source files include this file see 
// WINCONSDK_API functions as being imported from a DLL, wheras this DLL sees symbols
// defined with this macro as being exported.
#ifdef Modbus_ARM_API_EXPORTS
#define Modbus_ARM_API extern "C" __declspec(dllexport)
#else
#define Modbus_ARM_API extern "C" __declspec(dllimport)
#endif

//#define EXPORTED_DLL_FUNCTION \
// __declspec(dllexport) __stdcall

//Modbus Master RTU functions
Modbus_ARM_API int CALLBACK MBRTUInit(int iPortNumber, int iBaudrate,int iParity, int iDataBit, int iStopBit, int iTimeOut); 
Modbus_ARM_API int CALLBACK MBRTU_R_Coils(int iPortNumber, int iSlaveNumber, int iStartAddress, int iCount, unsigned char *iRecv, int iFuncNumber /*1/2 up to the modbus device*/);
Modbus_ARM_API int CALLBACK MBRTU_W_Coil(int iPortNumber, int iSlaveNumber, int iCoilAddress, int iCoilStatus); // Fun 5
Modbus_ARM_API int CALLBACK MBRTU_R_Registers(int iPortNumber, int iSlaveNumber, int iStartAddress, int iCount, short *iRecv, int iFuncNumber /*3/4 up to the modbus device*/);	
Modbus_ARM_API int CALLBACK MBRTU_W_Register(int iPortNumber, int iSlaveNumber, int iRegAddress, short iRegStatus); // Fun 6
Modbus_ARM_API void CALLBACK MBRTUClose(int iPortNumber);
Modbus_ARM_API int CALLBACK MBRTU_W_Multi_Coils(int iPortNumber, int iSlaveNumber, int iCoilAddress, int iCount, unsigned char *iCoilStatus); // Fun 15
Modbus_ARM_API int CALLBACK MBRTU_W_Multi_Registers(int iPortNumber, int iSlaveNumber, int iRegAddress, int iCount, short *iRegStatus); // Fun 16
//Modbus Master ASCII functions
Modbus_ARM_API int CALLBACK MBASCInit(int iPortNumber, int iBaudrate,int iParity, int iDataBit, int iStopBit, int iTimeOut); 
Modbus_ARM_API int CALLBACK MBASC_R_Coils(int iPortNumber, int iSlaveNumber, int iStartAddress, int iCount, unsigned char *iRecv, int iFuncNumber /*1/2 up to the modbus device*/);
Modbus_ARM_API int CALLBACK MBASC_W_Coil(int iPortNumber, int iSlaveNumber, int iCoilAddress, int iCoilStatus); // Fun 5
Modbus_ARM_API int CALLBACK MBASC_R_Registers(int iPortNumber, int iSlaveNumber, int iStartAddress, int iCount, short *iRecv, int iFuncNumber /*3/4 up to the modbus device*/);	
Modbus_ARM_API int CALLBACK MBASC_W_Register(int iPortNumber, int iSlaveNumber, int iRegAddress, short iRegStatus); // Fun 6
Modbus_ARM_API void CALLBACK MBASCClose(int iPortNumber);
Modbus_ARM_API int CALLBACK MBASC_W_Multi_Coils(int iPortNumber, int iSlaveNumber, int iCoilAddress, int iCount, unsigned char *iCoilStatus); // Fun 15
Modbus_ARM_API int CALLBACK MBASC_W_Multi_Registers(int iPortNumber, int iSlaveNumber, int iRegAddress, int iCount, short *iRegStatus); // Fun 16
//Modbus Master TCP functions
Modbus_ARM_API int CALLBACK MBTCPInit(int iSocketNumber, char *tcpipaddr, int tcpipport, int iTimeOut); // Return 1==>True 0==>False
Modbus_ARM_API int CALLBACK MBTCP_R_Coils(int iSocketNumber,int iSlaveNumber, int iStartAddress, int iCount, unsigned char *iRecv, int iFuncNumber /*1/2 up to the modbus device*/);	//Function 1/2 Return 1==>True 0==>False
Modbus_ARM_API int CALLBACK MBTCP_W_Coil(int iSocketNumber, int iSlaveNumber, int iCoilAddress, int iCoilStatus);	//Function 15 Return 1==>True 0==>False
Modbus_ARM_API int CALLBACK MBTCP_R_Registers(int iSocketNumber, int iSlaveNumber, int iStartAddress, int iCount, short *iRecv, int iFuncNumber /*3/4 up to the modbus device*/);	//Function 3/4 Return 1==>True 0==>False
Modbus_ARM_API int CALLBACK MBTCP_W_Register(int iSocketNumber, int iSlaveNumber, int iRegAddress, short iRegStatus);	//Function 16 iRegStatus==>-32768~32767 Return 1==>True 0==>False 
Modbus_ARM_API void CALLBACK MBTCPClose(int iSocketNumber);	//Return 1==>True 0==>False
Modbus_ARM_API int CALLBACK MBTCP_W_Multi_Coils(int iPortNumber, int iSlaveNumber, int iCoilAddress, int iCount, unsigned char *iCoilStatus); // Fun 15
Modbus_ARM_API int CALLBACK MBTCP_W_Multi_Registers(int iPortNumber, int iSlaveNumber, int iRegAddress, int iCount, short *iRegStatus); // Fun 16
//Bit Pattern sub.
Modbus_ARM_API int CALLBACK Coil_Bit_Read(unsigned char *coil, int bitno); 
Modbus_ARM_API int CALLBACK Coil_Bit_Write(unsigned char *coil, int bitno, int onoff); 

#define    iPARITY_NONE   0
#define    iPARITY_ODD    1
#define    iPARITY_EVEN   2

// Modbus exception code 
#define    MB_RTC_OK                      0
#define    MB_ILLEGAL_FUNCTION            1
#define    MB_ILLEGAL_DATA_ADDRESS        2
#define    MB_ILLEGAL_DATA_VALUE          3
#define    MB_SLAVE_DEVICE_FAILURE        4
#define    MB_ACKNOWLEDGE                 5
#define    MB_SLAVE_DEVICE_BUSY           6
#define    MB_NEGATIVE_ACKNOWLEDGE        7
#define    MB_MEMORY_PARITY_ERROR         8
//#define    MB_ILLEGAL_FUNCTION          9    // undefine code
#define    MB_GATEWAY_PATH_UNAVAILABLE    10
#define    MB_GATEWAY_FAILED_TO_RESPOND   11
// DLL sub. parameter error
#define    MB_OPEN_PORT_ERROR   101  // Open COM/TCP Port error
#define    MB_PORTNO_OVER       102  // COM Port is 1 - 8
#define    MB_PORT_NOT_OPEN     103  // COM/TCP Port does not open yet
#define    MB_FUN_ERROR         104  // Modbus Fun. No. error
#define    MB_READ_COUNT_OVER   105  // reading Count of Register or Bits is over range
                                     // RTU: 120 register, 1920 coils
                                     // ASCII: 60 register, 960 coils
                                     // TCP: 120 register, 1920 coils
#define    MB_SLAVENO_OVER      106  // Modbus Slave No. must be 1 - 247
#define    MB_ADDRESS_OVER      107  // Register or Coil Address must count from 1
#define    MB_COMM_TIMEOUT      108  // Comm. timeout
#define    MB_CRC_ERROR         109  // RTU CRC Check error
#define    MB_LRC_ERROR         110  // ASCII LRC Check error
#define    MB_INVALID_SOCKET    111  // Initial Socket error
#define    MB_TCP_CONNECT_ERROR 112  // Connect Remote Modbus Server error
#define    MB_TCP_SEND_ERROR    113  // Send TCP Data error
#define    MB_TCP_TIMEOUT       114  // Waiting Modbus Response Timeout
#define    MB_WSA_INIT_ERROR    115  // WSA Startup error
#define    MB_TCP_SOCKET_ERROR  116  // Create Socket error
#define    MB_TCP_BIND_ERROR    117  // TCP Server Bind error
#define    MB_TCP_LISTEN_ERROR  118  // TCP Server Listen error
#define    MB_TCP_HAS_DATA      119  // it has data from remote Modbus Master
#define    MB_WRITE_COUNT_OVER  120  // reading Count of Register or Bits is over range
                                     // RTU: 120 register, 1920 coils
                                     // ASCII: 60 register, 960 coils
                                     // TCP: 120 register, 1920 coils
class CModbus_ARMApp : public CWinApp
{
public:
	CModbus_ARMApp();

// Overrides
	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CModbus_ARMApp)
	//}}AFX_VIRTUAL

	//{{AFX_MSG(CModbus_ARMApp)
		// NOTE - the ClassWizard will add and remove member functions here.
		//    DO NOT EDIT what you see in these blocks of generated code !
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

/////////////////////////////////////////////////////////////////////////////

//{{AFX_INSERT_LOCATION}}
// Microsoft eMbedded Visual C++ will insert additional declarations immediately before the previous line.

#endif // !defined(AFX_Modbus_ARM_H__94D9CFBC_56CE_4C36_B846_FA74648487CF__INCLUDED_)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -