i'm trying to set the serial port.(XP SP2, Visual Studio 2005). I use
the example code from MSDN "configuring a communications resource".
CreateFile pass through, however GetCommState return 0.With
GetLastError(), i get the error number 87, which means
"ERROR_INVALID_PARAMETER The parameter is incorrect. "
I'm sure the serial port works, because i can use another program to
read/write through it.
thx
Cheng
Error 87 usually means you have made a simple programming mistake with the
parameters. Can you show the relevant lines of the code? It is very hard
to guess what is wrong if you do not show some code.
--
Scott McPhillips [VC++ MVP]
Sorry, i forgot to paste them.
#include <windows.h>
#include <stdio.h>
int main(int argc, char *argv[])
{
DCB dcb;
HANDLE hCom;
BOOL fSuccess;
char *pcCommPort = "COM1";
hCom = CreateFile( pcCommPort,
GENERIC_READ | GENERIC_WRITE,
0, // must be opened with exclusive-access
NULL, // no security attributes
OPEN_EXISTING, // must use OPEN_EXISTING
0, // not overlapped I/O
NULL // hTemplate must be NULL for comm devices
);
if (hCom == INVALID_HANDLE_VALUE)
{
// Handle the error.
printf ("CreateFile failed with error %d.\n", GetLastError());
return (1);
}
// Build on the current configuration, and skip setting the size
// of the input and output buffers with SetupComm.
fSuccess = GetCommState(hCom, &dcb);
if (!fSuccess)
{
// Handle the error.
printf ("GetCommState failed with error %d.\n", GetLastError());
return (2);
}
// Fill in DCB: 57,600 bps, 8 data bits, no parity, and 1 stop bit.
dcb.BaudRate = CBR_57600; // set the baud rate
dcb.ByteSize = 8; // data size, xmit, and rcv
dcb.Parity = NOPARITY; // no parity bit
dcb.StopBits = ONESTOPBIT; // one stop bit
fSuccess = SetCommState(hCom, &dcb);
if (!fSuccess)
{
// Handle the error.
printf ("SetCommState failed with error %d.\n", GetLastError());
return (3);
}
printf ("Serial port %s successfully reconfigured.\n", pcCommPort);
return (0);
}
Cheers
Check Abdoul
---------------------
"uvbaz" <uv...@stud.uni-karlsruhe.de> wrote in message
news:7fb0be98-eb01-4b8f...@e39g2000hsf.googlegroups.com...
You haven't set dcb.DCBlength = sizeof(dcb), so it will fail, as it doesn't
know what size the strucure is.
Anthony Wieser
Wieser Software Ltd
m_securityAttributes.nLength = sizeof ( SECURITY_ATTRIBUTES );
m_securityAttributes.lpSecurityDescriptor = 0;
m_securityAttributes.bInheritHandle = true;
Don't know if it will change anything, but that is what I do. Your code
appears OK.
"uvbaz" <uv...@stud.uni-karlsruhe.de> wrote in message
news:7fb0be98-eb01-4b8f...@e39g2000hsf.googlegroups.com:
Joseph M. Newcomer [MVP]
email: newc...@flounder.com
Web: http://www.flounder.com
MVP Tips: http://www.flounder.com/mvp_tips.htm
>On 14 Apr., 17:01, "Scott McPhillips [MVP]" <org-dot-mvps-at-scottmcp>
>wrote:
>> "uvbaz" <uv...@stud.uni-karlsruhe.de> wrote in message
>>
>> news:ec8b47a1-6f67-48ec...@a9g2000prl.googlegroups.com...
>>
>> > Hi,
>>
>> > i'm trying to set the serial port.(XP SP2, Visual Studio 2005). I use
>> > the example code from MSDN "configuring a communications resource".
>>
>> > CreateFile pass through, however GetCommState return 0.With
>> > GetLastError(), i get the error number 87, which means
>> > "ERROR_INVALID_PARAMETER The parameter is incorrect. "
>> > I'm sure the serial port works, because i can use another program to
>> > read/write through it.
>>
>> Error 87 usually means you have made a simple programming mistake with the
>> parameters. Can you show the relevant lines of the code? It is very hard
>> to guess what is wrong if you do not show some code.
>>
>> --
>> Scott McPhillips [VC++ MVP]
>
>Sorry, i forgot to paste them.
>
>#include <windows.h>
>#include <stdio.h>
>
>int main(int argc, char *argv[])
****
int _tmain(int argc _TCHAR * argv[])
****
>{
> DCB dcb;
> HANDLE hCom;
> BOOL fSuccess;
> char *pcCommPort = "COM1";
****
First, why are you using an obsolete data type like 'char'? Why are you declaring a
variable at all?
The correct code would at the very least be
LPTSTR CommPort = _T("COM1");
but that is not really general; the correct name is actually
_T("\\\\.\\COM1")
because the string you use is only good for COM1..COM9, and fails utterly with COM10.
****
>
> hCom = CreateFile( pcCommPort,
> GENERIC_READ | GENERIC_WRITE,
> 0, // must be opened with exclusive-access
> NULL, // no security attributes
> OPEN_EXISTING, // must use OPEN_EXISTING
> 0, // not overlapped I/O
****
Which is only one of about a dozen possible values you could use here; why single out
FILE_FLAG_OVERLAPPED as being the only flag of meaning?
****
> NULL // hTemplate must be NULL for comm devices
> );
>
> if (hCom == INVALID_HANDLE_VALUE)
> {
> // Handle the error.
> printf ("CreateFile failed with error %d.\n", GetLastError());
> return (1);
> }
>
> // Build on the current configuration, and skip setting the size
> // of the input and output buffers with SetupComm.
>
> fSuccess = GetCommState(hCom, &dcb);
*****
Did you actually READ THE DOCUMENTATION about DCB? Error 87 is EXACTLY the correct
response; you failed to initialize the first element, the DCBlength field. This could be
done by writing
DCB dcb = { sizeof(DCB) };
or by explicitly assigning the lenght. The error code is correct; you provided an invalid
parameter!
joe
*****
>
> if (!fSuccess)
> {
> // Handle the error.
> printf ("GetCommState failed with error %d.\n", GetLastError());
> return (2);
> }
>
> // Fill in DCB: 57,600 bps, 8 data bits, no parity, and 1 stop bit.
>
> dcb.BaudRate = CBR_57600; // set the baud rate
> dcb.ByteSize = 8; // data size, xmit, and rcv
> dcb.Parity = NOPARITY; // no parity bit
> dcb.StopBits = ONESTOPBIT; // one stop bit
>
> fSuccess = SetCommState(hCom, &dcb);
>
> if (!fSuccess)
> {
> // Handle the error.
> printf ("SetCommState failed with error %d.\n", GetLastError());
> return (3);
> }
>
> printf ("Serial port %s successfully reconfigured.\n", pcCommPort);
> return (0);
>}