123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
-
-
- #include <stdio.h>
- #include <windows.h>
-
- #define BAUD CBR_19200;
-
- HANDLE hSerial = INVALID_HANDLE_VALUE;
-
-
- int serialOpen(char *port) {
- DCB dcbSerialParams = {0};
- COMMTIMEOUTS timeouts = {0};
-
- hSerial = CreateFile(port, GENERIC_READ | GENERIC_WRITE, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
-
- if (hSerial == INVALID_HANDLE_VALUE) {
- return -1;
- }
-
-
- dcbSerialParams.DCBlength = sizeof(dcbSerialParams);
- if (!GetCommState(hSerial, &dcbSerialParams)) {
- CloseHandle(hSerial);
- hSerial = INVALID_HANDLE_VALUE;
- return -1;
- }
- dcbSerialParams.BaudRate = BAUD;
- dcbSerialParams.ByteSize = 8;
- dcbSerialParams.StopBits = ONESTOPBIT;
- dcbSerialParams.Parity = NOPARITY;
- if (!SetCommState(hSerial, &dcbSerialParams)) {
- CloseHandle(hSerial);
- hSerial = INVALID_HANDLE_VALUE;
- return -1;
- }
-
- timeouts.ReadIntervalTimeout = 1000 * dwReadTimeOutIntervalInSec;
- timeouts.ReadTotalTimeoutConstant = 1000 * dwReadTimeOutIntervalInSec;
- timeouts.ReadTotalTimeoutMultiplier = 1000 * dwReadTimeOutIntervalInSec;
- timeouts.WriteTotalTimeoutConstant = 1000 * dwReadTimeOutIntervalInSec;
- timeouts.WriteTotalTimeoutMultiplier = 1000 * dwReadTimeOutIntervalInSec;
-
- if (!SetCommTimeouts(hSerial, &timeouts)) {
- CloseHandle(hSerial);
- hSerial = INVALID_HANDLE_VALUE;
- return -1;
- }
-
- return 0;
- }
-
-
- ssize_t serialWrite(char *data, size_t length) {
- DWORD dwBytesWritten = 0;
- if (!WriteFile(hSerial, data, length, &dwBytesWritten, NULL)) {
- return -1;
- }
- return dwBytesWritten;
-
- }
-
-
- ssize_t serialRead(char *data, size_t length) {
- DWORD dwBytesRead = 0;
- if (!ReadFile(hSerial, data, length, &dwBytesRead, NULL)) {
- return -1;
- }
- return dwBytesRead;
- }
-
-
- void serialClose(void) {
- CloseHandle(hSerial);
- hSerial = INVALID_HANDLE_VALUE;
- }
|