我正在尝试与连接到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/

10-11 15:32