|
|
#include <stdio.h>
#include <windows.h>
BOOL DoComIo(LPSTR lpCom,DWORD Baud,BYTE Size,BYTE Parity,BYTE Stop);
//#define COM_DEB 1
#define NUM 128
#define print printf
#define SETTINGS1 "COM1",9600,8,NOPARITY,ONESTOPBIT
#define SETTINGS2 "COM1",4800,8,NOPARITY,ONESTOPBIT
#define SETTINGS3 "COM1",2400,8,NOPARITY,ONESTOPBIT
#define SETTINGS4 "COM1",1200,8,NOPARITY,ONESTOPBIT
DWORD dwSize; DWORD dwRIT,dwRTTM,dwRTTC;
DWORD main(int argc, char *argv[], char *envp[]) { BOOL bRc; CHAR chDummy; BOOL bSize,bRIT,bRTTM,bRTTC;
UNREFERENCED_PARAMETER(envp);
bRIT = bRTTM = bSize = bRTTC = FALSE;
while(argc--) {
switch(argv[argc][1]) { // case 'f' :
// case 'F' : {
// if (argv[argc][0] != '-') break;
// printf("filename option=%s\n\n",argv[argc]);
// sscanf(argv[argc],"%c %c %s",&chDummy,&chDummy,lpFilename);
// printf("filename to be displayed=%s\n\n",lpFilename);
// bFile = TRUE;
// break;
// }
case 'I' : case 'i' : { if (argv[argc][0] != '-') break; printf("RIT option=%s\n\n",argv[argc]); sscanf(argv[argc],"%c %c %lx",&chDummy,&chDummy,&dwRIT); printf("RIT =%lx\n\n",dwRIT); bRIT = TRUE; break; } case 'M' : case 'm' : { if (argv[argc][0] != '-') break; printf("RTTM option=%s\n\n",argv[argc]); sscanf(argv[argc],"%c %c %lx",&chDummy,&chDummy,&dwRTTM); printf("RTTM =%lx\n\n",dwRTTM); bRTTM = TRUE; break; }
case 'C' : case 'c' : { if (argv[argc][0] != '-') break; printf("RTTC option=%s\n\n",argv[argc]); sscanf(argv[argc],"%c %c %lx",&chDummy,&chDummy,&dwRTTC); printf("RTTC =%lx\n\n",dwRTTC); bRTTC = TRUE; break; }
case 'S' : case 's' : { if (argv[argc][0] != '-') break; printf("size option=%s\n\n",argv[argc]); sscanf(argv[argc],"%c %c %lx",&chDummy,&chDummy,&dwSize); printf("Size to be xfered =%lx bytes\n\n",dwSize); if (dwSize > NUM) { printf("dwSize[%lx] should be < %lx\n",dwSize,NUM); return -1; } bSize = TRUE; break; } default: { break; }
}
}
if (!bRIT || !bRTTM || !bRTTC ||!bSize) { printf("\n\nOptions are required!!\n\n"); printf("timeout <required options>\n\n"); printf("options:\n"); printf(" -i<read interval timeout > eg: -i0x0000>\n\n"); printf(" -m<read total timeout multiplier> eg: -m0x0000>\n\n"); printf(" -c<read total timeout constant> eg: -c0x0000>\n\n"); printf(" -s<size in bytes to be xfred eg: -s0x10>\n\n"); return (-1); }
print("\n\n *** Doing COM TEST with [port=%s Baud=%d,Size=%d,Parity=%d,Stop=%d]***\n\n", SETTINGS1); bRc = DoComIo(SETTINGS1); if (!bRc) { print("\n\nCOM TEST FAILED********************************\n\n"); }
return 0; }
BOOL DoComIo(LPSTR lpCom,DWORD Baud,BYTE Size,BYTE Parity,BYTE Stop) {
CHAR WrBuffer[NUM]; CHAR RdBuffer[NUM]; DWORD i; HANDLE hCommPort; DCB dcb; BOOL bRc; DWORD dwNumWritten,dwNumRead,dwErrors; COMMTIMEOUTS CommTimeOuts;
print("\n\n *** COMM TEST START [port=%s,Baud=%d,Size=%d,Parity=%d,Stop=%d]***\n\n", lpCom,Baud,Size,Parity,Stop);
print("Opening the comm port for read write\n");
hCommPort = CreateFile( lpCom, GENERIC_READ|GENERIC_WRITE, 0, // exclusive
NULL, // sec attr
OPEN_EXISTING, 0, // no attributes
NULL); // no template
if (hCommPort == (HANDLE)-1) { print("FAIL: OpenComm failed rc: %lx\n",hCommPort); return FALSE; }
print("Opening the comm port for read write: SUCCESS hCommPort=%lx\n",hCommPort);
print("Setting the line characteristics on comm \n");
if (!GetCommState(hCommPort,&dcb)) { printf("FAIL: Couldn't get the dcb: %d\n",GetLastError()); return FALSE; } dcb.DCBlength = sizeof(DCB); // dcb.DCBversion = 0x0002; BUG BUG in spec not in header
dcb.BaudRate = Baud; dcb.ByteSize = Size; dcb.Parity = Parity; dcb.StopBits = Stop;
bRc = SetupComm(hCommPort,1024,1024);
printf("bRc from CommSetup = %lx\n",bRc);
if (!bRc) { printf("FAIL: comsetup\n"); }
bRc = SetCommState(hCommPort,&dcb);
if (!bRc) { print("FAIL: cannot set the comm state rc:%lx\n",bRc); bRc = CloseHandle(hCommPort); if (!bRc) { print("FAIL: cannot close the comm port:%lx\n",bRc); } return FALSE; }
print("Setting the line characteristics on comm: SUCCESS\n");
CommTimeOuts.ReadIntervalTimeout = dwRIT; CommTimeOuts.ReadTotalTimeoutMultiplier = dwRTTM; CommTimeOuts.ReadTotalTimeoutConstant = dwRTTC; CommTimeOuts.WriteTotalTimeoutMultiplier = 0; CommTimeOuts.WriteTotalTimeoutConstant = 0;
printf("setting timeouts: RIT=%lx RTTM = %lx RTTC = %lx\n", dwRIT, dwRTTM, dwRTTC);
bRc = SetCommTimeouts(hCommPort, &CommTimeOuts);
printf("bRc from setcommtimeouts = %lx\n",bRc);
if (!bRc) { printf("FAIL: setcommtimeouts\n"); }
printf("Filling the buffer with the known chars \n");
for (i=0; i<dwSize; i++) { //WrBuffer[i] = 'a';
WrBuffer[i] = (CHAR)i;
}
print("Filling the buffer with the known chars : SUCCESS\n");
#ifdef COM_DEB
print("Dumping the buffer before sending it to comm\n");
for (i=0; i< dwSize; i++) { //print("%c",RdBuffer[i]);
print(" %d ",WrBuffer[i]);
}
print("\nDumping the buffer before sending it to comm SUCCESS\n"); #endif
print("Filling the Rdbuffer with the known chars (0xFF) to makeit dirty\n");
for (i=0; i< dwSize; i++) { RdBuffer[i] = (CHAR)'0xFF'; }
print("Filling the Rdbuffer with the known chars (0xFF): SUCCESS\n");
print("Writting this buffer to the comm port\n");
bRc = WriteFile( hCommPort, WrBuffer, dwSize, &dwNumWritten, NULL);
if (!bRc) { print("FAIL: cannot Write To the comm port:%lx\n",bRc); bRc = CloseHandle(hCommPort); if (!bRc) { print("FAIL: cannot close the comm port:%lx\n",bRc); } return FALSE; }
print("Writting this buffer to the comm port: SUCCESS rc:%lx, byteswritten:%lx\n", bRc,dwNumWritten);
print("Reading this buffer from the comm port\n");
bRc = ReadFile( hCommPort, RdBuffer, dwSize, &dwNumRead, NULL);
if (!bRc) { print("FAIL: cannot Read From the comm port:%lx\n",bRc); bRc = CloseHandle(hCommPort); if (!bRc) { print("FAIL: cannot close the comm port:%lx\n",bRc); } return FALSE; }
print("Reading this buffer from the comm port: SUCCESS rc:%lx, bytesread:%lx\n", bRc,dwNumRead);
//#ifdef COM_DEB
print("Dumping the Rdbuffer with the comm data\n");
for (i=0; i< dwSize; i++) { //print("%c",RdBuffer[i]);
print(" %d ",RdBuffer[i]);
}
print("\nDumping the Rdbuffer with the comm data: SUCCESS\n"); //#endif
print("Comparing the rd and wr buffers\n");
for (i=0; i< dwSize; i++) { if (RdBuffer[i] != WrBuffer[i]) { print("FAIL: BufferMisMatch: RdBuffer[%d]=%lx,WrBuffer[%d]=%lx\n", i,RdBuffer[i],i,WrBuffer[i]); bRc = CloseHandle(hCommPort); if (!bRc) { print("FAIL: cannot close the comm port:%lx\n",bRc); } return FALSE; } }
print("Comparing the rd and wr buffers: SUCCESS\n");
bRc = ClearCommError(hCommPort,&dwErrors,NULL); print("ClearCommError: rc= %lx and dwErrors=%lx\n",bRc,dwErrors);
bRc = PurgeComm(hCommPort,0); print("PurgeComm (%lx,0) rc = %lx\n",hCommPort,bRc);
//bRc = FlushFileBuffers(hCommPort);
//print("flushfilebuffers(%lx) rc = %lx\n",hCommPort,bRc);
print("Closing the comm port\n"); bRc = CloseHandle(hCommPort);
if (!bRc) { print("FAIL: cannot close the comm port:%lx\n",bRc); return FALSE; }
print("\n\n*** COMM TEST OVER*** \n\n"); }
|