I currently have two programs("reading" and "writing") and each program run on one PC to do textfile transferring/logging. The PCs is connected via a null modem cable. The program is run in widows and is a DOS application written in c++. The programs work but it is working in a way that i have to run the "reading" program first to let it poll before i can run the "writing" program to send the content of the text file.
How do i make it in a way that the "reading" program will only start polling upon request from the "writing" program? Meaning, when i clicked the "writing" program to send the data, it will communicate with the "reading" program to start and get ready to receive.
This is my codes for the "reading" side (Upon receiving the content from the "writing" side, it will log it into a text file called "new.txt")
Code:#include "windows.h" #include <stdio.h> #include <ctype.h> #include <io.h> #include <conio.h> #include <stdlib.h> #define maxBytes 111 int main() { HANDLE hSerial; DCB dcbSerialParams = {0}; COMMTIMEOUTS timeouts = {0}; DWORD dwBytesRead = 0; char szBuff[maxBytes] = {0}; int firstdigit = 0; FILE *fp; int i; //opening the serial port hSerial = CreateFile("COM1", GENERIC_READ | GENERIC_WRITE, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0); if(hSerial==INVALID_HANDLE_VALUE) { if(GetLastError()==ERROR_FILE_NOT_FOUND) { printf("Serial port does not exist\n"); } printf("Other errors\n"); } //setting parameters dcbSerialParams.DCBlength = sizeof (dcbSerialParams); //GetCommState is to retrieves the current control settings for a specific communications device. if (!GetCommState(hSerial, &dcbSerialParams)) { printf("Not GetCommState, not able to retrieves the current control\n"); } dcbSerialParams.BaudRate = CBR_115200; dcbSerialParams.ByteSize = 8; dcbSerialParams.StopBits = ONESTOPBIT; dcbSerialParams.Parity = NOPARITY; //SetCommState configures a communications device according to the specifications //in DCB. The function reinitializes all hardware control settings but it does not //empty output or input queues if (!SetCommState(hSerial, &dcbSerialParams)) { printf("Not SetCommState, cannot configures serial port according to DCB specifications set\n"); } //setting timeouts timeouts.ReadIntervalTimeout = 40; timeouts.ReadTotalTimeoutConstant = 40; timeouts.ReadTotalTimeoutMultiplier = 40; timeouts.WriteTotalTimeoutConstant = 40; timeouts.WriteTotalTimeoutMultiplier = 40; //SetCommTimeouts set the time out parameters for all read and write operation if (!SetCommTimeouts(hSerial, &timeouts)) { printf("Not SetCommTimeouts, cannot set the timeout parameters to serial port\n"); } //reading data //ReadFile reads data from the specified file or i/o devices. printf("The content inside the file: \n\n"); if(!ReadFile(hSerial, szBuff, maxBytes, &dwBytesRead, NULL)) { printf("error\n"); } else { fp = fopen("c:\\new.txt", "w"); while (ReadFile(hSerial, szBuff, maxBytes, &dwBytesRead, NULL)) { for (i = 0; i < dwBytesRead; i++) { if (szBuff[i] == 10 || szBuff[i] == 13) { fprintf(fp, "\n"); printf("\n"); break; } else { fprintf(fp, "%c", szBuff[i]); printf("%c", szBuff[i]); } } } fclose(fp); CloseHandle(hSerial); } }
This is my codes for thw "writing" side (The program will read the content inside a textfile called "helloworld.txt" and write it line by line to the serial port)
I know that this is just a small program but how do i make the "reading" program poll only when the "writing" program is trying to send data?Code:#include "windows.h" #include <stdio.h> #include <io.h> #include <conio.h> #include <stdlib.h> #define maxBytes 111 #define MAX 256 int main() { HANDLE hSerial; DCB dcbSerialParams = {0}; COMMTIMEOUTS timeouts = {0}; DWORD dwBytesWrite = 0; int i; char szBuff[maxBytes]; char stemp[MAX]; FILE *fp; //opening the serial port hSerial = CreateFile("COM1", GENERIC_READ | GENERIC_WRITE, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0); if(hSerial==INVALID_HANDLE_VALUE) { if(GetLastError()==ERROR_FILE_NOT_FOUND) { printf("Serial port does not exist\n"); } printf("Other errors\n"); } //setting parameters dcbSerialParams.DCBlength = sizeof (dcbSerialParams); //GetCommState is to retrieves the current control settings for a specific communications device. if (!GetCommState(hSerial, &dcbSerialParams)) { printf("Not GetCommState, not able to retrieves the current control.\n"); } dcbSerialParams.BaudRate = CBR_115200; dcbSerialParams.ByteSize = 8; dcbSerialParams.StopBits = ONESTOPBIT; dcbSerialParams.Parity = NOPARITY; //SetCommState configures a communications device according to the specifications //in DCB. The function reinitializes all hardware control settings but it does not //empty output or input queues if (!SetCommState(hSerial, &dcbSerialParams)) { printf("Not SetCommState, cannot configures serial port according to DCB specifications set.\n"); } //setting timeouts timeouts.ReadIntervalTimeout = 40; timeouts.ReadTotalTimeoutConstant = 40; timeouts.ReadTotalTimeoutMultiplier = 40; timeouts.WriteTotalTimeoutConstant = 40; timeouts.WriteTotalTimeoutMultiplier = 40; //SetCommTimeouts set the time out parameters for all reand and write operation if (!SetCommTimeouts(hSerial, &timeouts)) { printf("Not SetCommTimeouts, cannot set the timeout parameters to serial port.\n"); } //Writting data //WriteFile write data from the specified file or i/o devices. printf("The content inside the file: \n\n"); fp = fopen("c:\\helloworld.txt", "r"); while ((fgets(stemp, MAX, fp)) != NULL) { i = sprintf(szBuff, "%s", stemp); if (!WriteFile(hSerial, szBuff, maxBytes, &dwBytesWrite, NULL)) { printf("Serial port cannot write file.\n"); } else { printf("%s", szBuff); } } fclose(fp); CloseHandle(hSerial); }
Someone please help, new in serial port.
Last edited by infineonintern; 06-10-2009 at 10:42 PM.
You can't, unless you have a small stub running or something like that, which defeats the purpose of what you're asking. The reading program has to be running first because the system doesn't know what to do with the incoming data. What you could do is have the programs exchange control codes to avoid extraneous polling. For example:
Code:<start reader> <start writer> WRITER: Wake up! I have data to send. READER: I'm ready. WRITER: Okay. I'm sending you 58127 bytes. WRITER: <sends data> READER: I got 58127 bytes. WRITER: Good. I'm done. Bye. <exits> READER: Bye. <goes to sleep>
sudo rm -rf /
There are currently 1 users browsing this thread. (0 members and 1 guests)
Bookmarks