时间:2021-07-01 10:21:17 帮助过:10人阅读
1.开启一个 Serial Port: 利用一般开启档案的 CreatFile() 即可开启 serial port device用 CreateFile() API. HANDLECreateFile( LPCTSTRlpFileName, // pointertonameofthefile DWORDdwDesiredAccess, // access(read-write)mode DWORDdwShareMode,
1.开启一个 Serial Port:
  利用一般开启档案的 CreatFile() 即可开启 serial port device用 CreateFile() API.
 HANDLE CreateFile(
HANDLE CreateFile( LPCTSTR lpFileName, // pointer to name of the file
                  LPCTSTR lpFileName, // pointer to name of the file DWORD dwDesiredAccess, // access (read-write) mode
                  DWORD dwDesiredAccess, // access (read-write) mode DWORD dwShareMode, // share mode
                  DWORD dwShareMode, // share mode LPSECURITY_ATTRIBUTES lpSecurityAttributes, // pointer to security attributes
                  LPSECURITY_ATTRIBUTES lpSecurityAttributes, // pointer to security attributes DWORD dwCreationDistribution, // how to create
                  DWORD dwCreationDistribution, // how to create DWORD dwFlagsAndAttributes, // file attributes
                  DWORD dwFlagsAndAttributes, // file attributes HANDLE hTemplateFile // handle to file with attributes to copy
                  HANDLE hTemplateFile // handle to file with attributes to copy );
                  );
在开启完 serial port 之后, 可以藉由呼叫 SetupComm() 来进行配置传送时的缓冲区及接收时的缓冲区. 如果没有呼叫 SetupComm() 的话, Win95 会配置内定的缓冲区
 BOOL SetupComm(
BOOL SetupComm( HANDLE hFile, // handle of communications device
               HANDLE hFile, // handle of communications device DWORD dwInQueue, // size of input buffer
               DWORD dwInQueue, // size of input buffer DWORD dwOutQueue // size of output buffer
               DWORD dwOutQueue // size of output buffer );
               );2.关闭 Serial Port file
利用一般的 CloseHandle() 即可.
 BOOL CloseHandle(
BOOL CloseHandle( HANDLE hObject // handle to object to close
                 HANDLE hObject // handle to object to close )
                 )  在 Win32 里头, 将一些通讯时会用到的信息用 COMMPROP 这个结构来表示. (当然不仅仅是 Serial Port) 可以用 GetCommProperties() 来取得:
 BOOL GetCommProperties(
BOOL GetCommProperties( HANDLE hFile, // handle of communications device
                       HANDLE hFile, // handle of communications device LPCOMMPROP lpCommProp // address of communications properties structure
                       LPCOMMPROP lpCommProp // address of communications properties structure );
                       );

 typedef struct _COMMPROP
typedef struct _COMMPROP  { // cmmp
{ // cmmp WORD wPacketLength; // packet size, in bytes
    WORD wPacketLength; // packet size, in bytes WORD wPacketVersion; // packet version
    WORD wPacketVersion; // packet version DWORD dwServiceMask; // services implemented
    DWORD dwServiceMask; // services implemented DWORD dwReserved1; // reserved
    DWORD dwReserved1; // reserved DWORD dwMaxTxQueue; // max Tx bufsize, in bytes
    DWORD dwMaxTxQueue; // max Tx bufsize, in bytes DWORD dwMaxRxQueue; // max Rx bufsize, in bytes
    DWORD dwMaxRxQueue; // max Rx bufsize, in bytes DWORD dwMaxBaud; // max baud rate, in bps
    DWORD dwMaxBaud; // max baud rate, in bps DWORD dwProvSubType; // specific provider type
    DWORD dwProvSubType; // specific provider type DWORD dwProvCapabilities; // capabilities supported
    DWORD dwProvCapabilities; // capabilities supported DWORD dwSettableParams; // changable parameters
    DWORD dwSettableParams; // changable parameters DWORD dwSettableBaud; // allowable baud rates
    DWORD dwSettableBaud; // allowable baud rates WORD wSettableData; // allowable byte sizes
    WORD wSettableData; // allowable byte sizes WORD wSettableStopParity; // stop bits/parity allowed
    WORD wSettableStopParity; // stop bits/parity allowed DWORD dwCurrentTxQueue; // Tx buffer size, in bytes
    DWORD dwCurrentTxQueue; // Tx buffer size, in bytes DWORD dwCurrentRxQueue; // Rx buffer size, in bytes
    DWORD dwCurrentRxQueue; // Rx buffer size, in bytes DWORD dwProvSpec1; // provider-specific data
    DWORD dwProvSpec1; // provider-specific data DWORD dwProvSpec2; // provider-specific data
    DWORD dwProvSpec2; // provider-specific data WCHAR wcProvChar[1]; // provider-specific data
    WCHAR wcProvChar[1]; // provider-specific data } COMMPROP;
} COMMPROP;  至于上述 COMMPROP 结构的成员所代表的意思, on-line help 中应该写的都满清楚的 .
  你可以利用 COMMPROP 来取得一些状态, 但是当你想改变目前的设定时你需要两个 API 来完成:
 BOOL GetCommState(
BOOL GetCommState( HANDLE hFile, // handle of communications device
                  HANDLE hFile, // handle of communications device LPDCB lpDCB // address of device-control block structure
                  LPDCB lpDCB // address of device-control block structure );
                  );
 BOOL SetCommState(
BOOL SetCommState( HANDLE hFile, // handle of communications device
                  HANDLE hFile, // handle of communications device LPDCB lpDCB // address of device-control block structure
                  LPDCB lpDCB // address of device-control block structure );
                  );你可以用 GetCommState() 来取得目前 Serial Port 的状态, 也可以用 SetCommState() 来设定 Serial Port 的状态.
DCB 的结构就请自行翻阅 help 啰.
另外, programmer 最常控制的几个设定就是 baud rate, parity method, data bits, 还有 stop bit. BuildCommDCB() 提供了对于这几个常见设定的控制.
 BOOL BuildCommDCB(
BOOL BuildCommDCB( LPCTSTR lpDef, // pointer to device-control string
                  LPCTSTR lpDef, // pointer to device-control string