/* * * winSerial.c * * Windows 16 (& 32 & 64?) compatible serial port library * Uses 8 databits, no parity, 1 stop bit, no handshaking * * Copyright 2011 Thomas Buck * Copyright 2011 Max Nuding * Copyright 2011 Felix Bäder * * This file is part of LED-Cube. * * LED-Cube is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * LED-Cube is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with LED-Cube. If not, see . */ #include #include #define BAUD CBR_19200; HANDLE hSerial = INVALID_HANDLE_VALUE; // Open the serial port 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; timeouts.ReadTotalTimeoutConstant = 1000; timeouts.ReadTotalTimeoutMultiplier = 1000; timeouts.WriteTotalTimeoutConstant = 1000; timeouts.WriteTotalTimeoutMultiplier = 1000; if (!SetCommTimeouts(hSerial, &timeouts)) { CloseHandle(hSerial); hSerial = INVALID_HANDLE_VALUE; return -1; } return 0; } // Write to port. Returns number of characters sent, -1 on error ssize_t serialWrite(char *data, size_t length) { DWORD dwBytesWritten = 0; if (!WriteFile(hSerial, data, length, &dwBytesWritten, NULL)) { return -1; } return dwBytesWritten; } // Read from port. Return number of characters read, 0 if none available, -1 on error ssize_t serialRead(char *data, size_t length) { DWORD dwBytesRead = 0; if (!ReadFile(hSerial, data, length, &dwBytesRead, NULL)) { return -1; } return dwBytesRead; } // Close the serial Port void serialClose(void) { CloseHandle(hSerial); hSerial = INVALID_HANDLE_VALUE; } // Last element has to be NULL char** getSerialPorts(const char *search) { LPTSTR ports; DWORD num; char **files; int i, j = 0, start, k; #ifdef UNICODE ports = (LPTSTR)malloc(100 * sizeof(WCHAR)); #else ports = (LPTSTR)malloc(100 * sizeof(CHAR)); #endif num = QueryDosDevice(NULL, ports, 100); files = (char **)malloc(num * sizeof(char *)); for (i = 0; i < num; i++) { start = j; j = 0; while (ports[start + j] != '\0') { j++; } j++; // \0 files[i] = (char *)malloc(j * sizeof(char)); for (k = 0; k < j; k++) { files[i][k] = ports[start + k]; } } return files; }