我正在尝试与连接到EasySync USB2-H-5004-M USB到RS485转换器的USB设备进行通讯,但波特率为3750000,但在OSX上。
我有一些在Windows上工作的c++代码,并且刚刚设法使其在OSX上编译(使用D2XX dylib而不是dll),但是我在某处与通讯存在问题,我不确定从哪里开始以及如何解决这个问题。
我正在使用openFrameworks / c++,列出设备的方法如下所示:
int FTDI::enumerateDevices(){
DWORD numDevs;
FT_STATUS ftStatus = FT_CreateDeviceInfoList(&numDevs);
numPortsFound = 0;
if (ftStatus == FT_OK) {
ofLog(OF_LOG_NOTICE, "Number of FTDI devices is %d",numDevs);
devicesList = (FT_DEVICE_LIST_INFO_NODE*)malloc(sizeof(FT_DEVICE_LIST_INFO_NODE)*numDevs);
ftStatus = FT_GetDeviceInfoList(devicesList, &numDevs);
if (ftStatus == FT_OK) {
printf("\n");
for (int i = 0; i < numDevs; i++) {
ofLog(OF_LOG_VERBOSE, "Dev %d:",i);
ofLog(OF_LOG_VERBOSE, " Flags=0x%x",devicesList[i].Flags);
ofLog(OF_LOG_VERBOSE, " Type=0x%x",devicesList[i].Type);
ofLog(OF_LOG_VERBOSE, " ID=0x%x",devicesList[i].ID);
ofLog(OF_LOG_VERBOSE, " LocId=0x%x",devicesList[i].LocId);
ofLog(OF_LOG_VERBOSE, " SerialNumber=%s",devicesList[i].SerialNumber);
ofLog(OF_LOG_VERBOSE, " Description=%s",devicesList[i].Description);
ofLog(OF_LOG_VERBOSE, " ftHandle=0x%x\n",devicesList[i].ftHandle);
}
numPortsFound = numDevs;
} else {
ofLog(OF_LOG_ERROR, "FTD2XX::FT_GetDeviceInfoList() failed");
}
} else {
ofLog(OF_LOG_ERROR, "FTD2XX::FT_CreateDeviceInfoList() failed");
}
return numPortsFound;
}
问题是在OSX上我得到以下输出:
[notice ] Number of FTDI devices is 4
[verbose] Dev 0:
[verbose] Flags=0x1
[verbose] Type=0x3
[verbose] ID=0x0
[verbose] LocId=0x0
[verbose] SerialNumber=
[verbose] Description=
[verbose] ftHandle=0x0
[verbose] Dev 1:
[verbose] Flags=0x1
[verbose] Type=0x3
[verbose] ID=0x0
[verbose] LocId=0x0
[verbose] SerialNumber=
[verbose] Description=
[verbose] ftHandle=0x0
[verbose] Dev 2:
[verbose] Flags=0x1
[verbose] Type=0x3
[verbose] ID=0x0
[verbose] LocId=0x0
[verbose] SerialNumber=
[verbose] Description=
[verbose] ftHandle=0x0
[verbose] Dev 3:
[verbose] Flags=0x1
[verbose] Type=0x3
[verbose] ID=0x0
[verbose] LocId=0x0
[verbose] SerialNumber=
[verbose] Description=
[verbose] ftHandle=0x0
[ error ] failed to register FTDI device with serial FTWVZVEBA in internal register
[ error ] error opening port with serial: FTWVZVEBA
看起来不正确。例如在Windows上,在端口A /通道1 /设备索引0上,我看到以下信息:
[verbose] Dev 0:
[verbose] Flags=0x2
[verbose] Type=0x7
[verbose] ID=0x4036011
[verbose] LocId=0x02111
[verbose] SerialNumber=FTWVZVEBA
[verbose] Description=USB2-H-5004-M A
[verbose] ftHandle=0x0
快速浏览/ dev看起来不错:
ls /dev/tty.*
/dev/tty.Bluetooth-Incoming-Port /dev/tty.usbserial-FTWVZVEBB
/dev/tty.Bluetooth-Modem /dev/tty.usbserial-FTWVZVEBC
/dev/tty.usbmodemfa131 /dev/tty.usbserial-FTWVZVEBD
通过系统信息,我得到:
USB2-H-5004-M:
Product ID: 0x6011
Vendor ID: 0x0403 (Future Technology Devices International Limited)
Version: 8.00
Serial Number: FTWVZVEB
Speed: Up to 480 Mb/sec
Manufacturer: FTDI
Location ID: 0xfd120000 / 4
Current Available (mA): 500
Current Required (mA): 200
我已经按照FTDI OSX Installation Guide(pdf链接)中的指示安装了D2XX驱动程序,但是我不确定我丢失/做错了什么。
如何使用FTDI D2XX库与设备正确通信?
最佳答案
为了充实我的评论,因为它似乎已经回答了这里的核心问题:Mac OS 10.9(Mavericks)现在附带了内核扩展,其作用类似于FTDI的VCP驱动程序。它为检测到的FTDI USB到串行设备创建一个虚拟的通讯端口,这意味着如果您之前需要它,则不再需要安装VCP驱动程序。
但是,在it breaks any application using FTDI's D2XX library中,这具有不幸的副作用。这表现为D2XX功能无法连接到FTDI设备,即使他们可以看到它。解决方法是,您可以手动卸载kext:
sudo kextunload -b com.apple.driver.AppleUSBFTDI
但是它将在下次启动时重新加载自身。
作为更永久的解决方案,我一直在让我的应用程序检测是否已加载此kext(通过尝试通过D2XX函数进行连接并查看它们是否失败),并使用更传统的
open()
等调用来连接到串行接口(interface)。端口作为备用。我不确定它们使用的VCP样式的kext是否能像D2XX一样提供足够的灵活性。
关于c++ - 如何在OSX上使用FTDI D2XX库?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19778678/