我在Windows上与 USB设备通信时遇到问题。我不能使用libusb或WinUSB,因为我有一个特定的驱动程序(Silabs USB到UART,这是USB到串行桥)。这就是我初始化设备文件,发送和读取数据并关闭句柄的方式。
HANDLE hDevFile = CreateFile(L"\\??\\USB#VID_10C4&PID_EA60#0001#{a5dcbf10-6530-11d2-901f-00c04fb951ed}",
GENERIC_READ | GENERIC_WRITE, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED, NULL);
PurgeComm(hDevFile, PURGE_TXABORT | PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR);
DCB dcbInitState;
GetCommState(hDevFile, &dcbInitState);
DCB dcbNewState = dcbInitState;
dcbNewState.BaudRate = 57600;
dcbNewState.Parity = NOPARITY;
dcbNewState.ByteSize = 8;
dcbNewState.StopBits = ONESTOPBIT;
if (SetCommState(hDevFile, &dcbNewState) == 0)
{
printf("Could not set COM state. Error: %i", GetLastError());
return -1;
}
Sleep(60);
BYTE outData[8];
outData[0] = 0x53;
outData[1] = 0x10;
outData[2] = 0x04;
outData[3] = 0x10;
outData[4] = 0x40;
outData[5] = outData[3] ^ outData[4];
outData[6] = 0xAA;
outData[7] = 0x00;
DWORD dwWritten;
if (!WriteData(hDevFile, outData, 8, &dwWritten))
{
printf("Could not write data. Error: %i", GetLastError());
return -1;
}
BYTE inData[8];
DWORD dwRead;
if (!ReadData(hDevFile, inData, 8, &dwRead, 2000))
{
printf("Could not read data. Error: %i", GetLastError());
return -1;
}
SetCommState(hDevFile, &dcbInitState);
Sleep(60);
CloseHandle(hDevFile);
hDevFile = INVALID_HANDLE_VALUE;
(我从注册表中获得了设备的符号名称,但为了使我的问题简洁起见,我已经跳过了这一部分。WriteData()和ReadData()是自定义函数,可以相应地进行读写)。
问题在于SetCommState()返回零值。 GetLastError()返回122,即 ERROR_INSUFFICIENT_BUFFER 。
现在的问题是PurgeComm()也会生成ERROR_INSUFFICIENT_BUFFER。 CreateFile()给出ERROR_SUCCESS,因此必须正确打开。
怎么了?我错过了什么?
编辑:我尝试枚举COM端口并发现了一件有趣的事情-我的计算机上没有COM端口。即使设备已连接并启用,但存在驱动程序和所有其他东西。我还尝试强制将\\。\ COM1,\\。\ COM2等作为CreateFile的文件名,但是没有运气。每次都有ERROR_FILE_NOT_FOUND。
请帮忙。这对我来说非常重要。
最佳答案
因为这是CP210x设备,所以它是虚拟COM端口,因此应在CreateFile中将其打开。当您说尝试使用\。\ COMx时,您的想法是正确的,您只需要找出CP210x设备已分配到哪个COM端口,就不会收到ERROR_FILE_NOT_FOUND
错误。您可以通过在设备管理器中查找找到:
看一看Serial Communications Guide for the CP210x,这说明了如何对设备进行这些类型的调用,甚至还有一个COM端口发现功能,可以帮助您动态地找到COMxx名称。它还具有随附的软件AN197SW.zip。