1
0
mirror of https://github.com/arduino/Arduino.git synced 2025-02-26 20:54:22 +01:00

Update FTDI drivers to version 2.12.36.4

This commit is contained in:
Cristian Maglie 2021-09-01 00:56:19 +02:00
parent 23a023219b
commit e4412d8cc3
24 changed files with 2651 additions and 1384 deletions

View File

@ -1,1067 +1,1667 @@
/*++ /*++
Copyright © 2001-2011 Future Technology Devices International Limited Copyright © 2001-2021 Future Technology Devices International Limited
THIS SOFTWARE IS PROVIDED BY FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED "AS IS" THIS SOFTWARE IS PROVIDED BY FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
OF SUBSTITUTE GOODS OR SERVICES LOSS OF USE, DATA, OR PROFITS OR BUSINESS INTERRUPTION) OF SUBSTITUTE GOODS OR SERVICES LOSS OF USE, DATA, OR PROFITS OR BUSINESS INTERRUPTION)
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
FTDI DRIVERS MAY BE USED ONLY IN CONJUNCTION WITH PRODUCTS BASED ON FTDI PARTS. FTDI DRIVERS MAY BE USED ONLY IN CONJUNCTION WITH PRODUCTS BASED ON FTDI PARTS.
FTDI DRIVERS MAY BE DISTRIBUTED IN ANY FORM AS LONG AS LICENSE INFORMATION IS NOT MODIFIED. FTDI DRIVERS MAY BE DISTRIBUTED IN ANY FORM AS LONG AS LICENSE INFORMATION IS NOT MODIFIED.
IF A CUSTOM VENDOR ID AND/OR PRODUCT ID OR DESCRIPTION STRING ARE USED, IT IS THE IF A CUSTOM VENDOR ID AND/OR PRODUCT ID OR DESCRIPTION STRING ARE USED, IT IS THE
RESPONSIBILITY OF THE PRODUCT MANUFACTURER TO MAINTAIN ANY CHANGES AND SUBSEQUENT WHQL RESPONSIBILITY OF THE PRODUCT MANUFACTURER TO MAINTAIN ANY CHANGES AND SUBSEQUENT WHQL
RE-CERTIFICATION AS A RESULT OF MAKING THESE CHANGES. RE-CERTIFICATION AS A RESULT OF MAKING THESE CHANGES.
Module Name: Module Name:
ftd2xx.h ftd2xx.h
Abstract: Abstract:
Native USB device driver for FTDI FT232x, FT245x, FT2232x and FT4232x devices Native USB device driver for FTDI FT232x, FT245x, FT2232x, FT4232x, FT2233H and FT4233H devices
FTD2XX library definitions FTD2XX library definitions
Environment: Environment:
kernel & user mode kernel & user mode
--*/ --*/
#ifndef FTD2XX_H #ifndef FTD2XX_H
#define FTD2XX_H #define FTD2XX_H
// The following ifdef block is the standard way of creating macros #ifdef _WIN32
// which make exporting from a DLL simpler. All files within this DLL // Compiling on Windows
// are compiled with the FTD2XX_EXPORTS symbol defined on the command line. #include <windows.h>
// This symbol should not be defined on any project that uses this DLL.
// This way any other project whose source files include this file see // The following ifdef block is the standard way of creating macros
// FTD2XX_API functions as being imported from a DLL, whereas this DLL // which make exporting from a DLL simpler. All files within this DLL
// sees symbols defined with this macro as being exported. // are compiled with the FTD2XX_EXPORTS symbol defined on the command line.
// This symbol should not be defined on any project that uses this DLL.
#ifdef FTD2XX_EXPORTS // This way any other project whose source files include this file see
#define FTD2XX_API __declspec(dllexport) // FTD2XX_API functions as being imported from a DLL, whereas this DLL
#else // sees symbols defined with this macro as being exported.
#define FTD2XX_API __declspec(dllimport)
#endif #ifdef FTD2XX_EXPORTS
#define FTD2XX_API __declspec(dllexport)
#elif defined(FTD2XX_STATIC)
typedef PVOID FT_HANDLE; // Avoid decorations when linking statically to D2XX.
typedef ULONG FT_STATUS; #define FTD2XX_API
// Static D2XX depends on these Windows libs:
// #pragma comment(lib, "setupapi.lib")
// Device status #pragma comment(lib, "advapi32.lib")
// #pragma comment(lib, "user32.lib")
enum { #else
FT_OK, #define FTD2XX_API __declspec(dllimport)
FT_INVALID_HANDLE, #endif
FT_DEVICE_NOT_FOUND,
FT_DEVICE_NOT_OPENED, #else // _WIN32
FT_IO_ERROR, // Compiling on non-Windows platform.
FT_INSUFFICIENT_RESOURCES, #include "WinTypes.h"
FT_INVALID_PARAMETER, // No decorations needed.
FT_INVALID_BAUD_RATE, #define FTD2XX_API
FT_DEVICE_NOT_OPENED_FOR_ERASE, #endif // _WIN32
FT_DEVICE_NOT_OPENED_FOR_WRITE,
FT_FAILED_TO_WRITE_DEVICE, typedef PVOID FT_HANDLE;
FT_EEPROM_READ_FAILED, typedef ULONG FT_STATUS;
FT_EEPROM_WRITE_FAILED,
FT_EEPROM_ERASE_FAILED, //
FT_EEPROM_NOT_PRESENT, // Device status
FT_EEPROM_NOT_PROGRAMMED, //
FT_INVALID_ARGS, enum {
FT_NOT_SUPPORTED, FT_OK,
FT_OTHER_ERROR, FT_INVALID_HANDLE,
FT_DEVICE_LIST_NOT_READY, FT_DEVICE_NOT_FOUND,
}; FT_DEVICE_NOT_OPENED,
FT_IO_ERROR,
FT_INSUFFICIENT_RESOURCES,
#define FT_SUCCESS(status) ((status) == FT_OK) FT_INVALID_PARAMETER,
FT_INVALID_BAUD_RATE,
//
// FT_OpenEx Flags FT_DEVICE_NOT_OPENED_FOR_ERASE,
// FT_DEVICE_NOT_OPENED_FOR_WRITE,
FT_FAILED_TO_WRITE_DEVICE,
#define FT_OPEN_BY_SERIAL_NUMBER 1 FT_EEPROM_READ_FAILED,
#define FT_OPEN_BY_DESCRIPTION 2 FT_EEPROM_WRITE_FAILED,
#define FT_OPEN_BY_LOCATION 4 FT_EEPROM_ERASE_FAILED,
FT_EEPROM_NOT_PRESENT,
// FT_EEPROM_NOT_PROGRAMMED,
// FT_ListDevices Flags (used in conjunction with FT_OpenEx Flags FT_INVALID_ARGS,
// FT_NOT_SUPPORTED,
FT_OTHER_ERROR,
#define FT_LIST_NUMBER_ONLY 0x80000000 FT_DEVICE_LIST_NOT_READY,
#define FT_LIST_BY_INDEX 0x40000000 };
#define FT_LIST_ALL 0x20000000
#define FT_LIST_MASK (FT_LIST_NUMBER_ONLY|FT_LIST_BY_INDEX|FT_LIST_ALL) #define FT_SUCCESS(status) ((status) == FT_OK)
// //
// Baud Rates // FT_OpenEx Flags
// //
#define FT_BAUD_300 300 #define FT_OPEN_BY_SERIAL_NUMBER 1
#define FT_BAUD_600 600 #define FT_OPEN_BY_DESCRIPTION 2
#define FT_BAUD_1200 1200 #define FT_OPEN_BY_LOCATION 4
#define FT_BAUD_2400 2400
#define FT_BAUD_4800 4800 #define FT_OPEN_MASK (FT_OPEN_BY_SERIAL_NUMBER | \
#define FT_BAUD_9600 9600 FT_OPEN_BY_DESCRIPTION | \
#define FT_BAUD_14400 14400 FT_OPEN_BY_LOCATION)
#define FT_BAUD_19200 19200
#define FT_BAUD_38400 38400 //
#define FT_BAUD_57600 57600 // FT_ListDevices Flags (used in conjunction with FT_OpenEx Flags
#define FT_BAUD_115200 115200 //
#define FT_BAUD_230400 230400
#define FT_BAUD_460800 460800 #define FT_LIST_NUMBER_ONLY 0x80000000
#define FT_BAUD_921600 921600 #define FT_LIST_BY_INDEX 0x40000000
#define FT_LIST_ALL 0x20000000
//
// Word Lengths #define FT_LIST_MASK (FT_LIST_NUMBER_ONLY|FT_LIST_BY_INDEX|FT_LIST_ALL)
//
//
#define FT_BITS_8 (UCHAR) 8 // Baud Rates
#define FT_BITS_7 (UCHAR) 7 //
// #define FT_BAUD_300 300
// Stop Bits #define FT_BAUD_600 600
// #define FT_BAUD_1200 1200
#define FT_BAUD_2400 2400
#define FT_STOP_BITS_1 (UCHAR) 0 #define FT_BAUD_4800 4800
#define FT_STOP_BITS_2 (UCHAR) 2 #define FT_BAUD_9600 9600
#define FT_BAUD_14400 14400
// #define FT_BAUD_19200 19200
// Parity #define FT_BAUD_38400 38400
// #define FT_BAUD_57600 57600
#define FT_BAUD_115200 115200
#define FT_PARITY_NONE (UCHAR) 0 #define FT_BAUD_230400 230400
#define FT_PARITY_ODD (UCHAR) 1 #define FT_BAUD_460800 460800
#define FT_PARITY_EVEN (UCHAR) 2 #define FT_BAUD_921600 921600
#define FT_PARITY_MARK (UCHAR) 3
#define FT_PARITY_SPACE (UCHAR) 4 //
// Word Lengths
// //
// Flow Control
// #define FT_BITS_8 (UCHAR) 8
#define FT_BITS_7 (UCHAR) 7
#define FT_FLOW_NONE 0x0000
#define FT_FLOW_RTS_CTS 0x0100 //
#define FT_FLOW_DTR_DSR 0x0200 // Stop Bits
#define FT_FLOW_XON_XOFF 0x0400 //
// #define FT_STOP_BITS_1 (UCHAR) 0
// Purge rx and tx buffers #define FT_STOP_BITS_2 (UCHAR) 2
//
#define FT_PURGE_RX 1 //
#define FT_PURGE_TX 2 // Parity
//
//
// Events #define FT_PARITY_NONE (UCHAR) 0
// #define FT_PARITY_ODD (UCHAR) 1
#define FT_PARITY_EVEN (UCHAR) 2
typedef void (*PFT_EVENT_HANDLER)(DWORD,DWORD); #define FT_PARITY_MARK (UCHAR) 3
#define FT_PARITY_SPACE (UCHAR) 4
#define FT_EVENT_RXCHAR 1
#define FT_EVENT_MODEM_STATUS 2 //
#define FT_EVENT_LINE_STATUS 4 // Flow Control
//
//
// Timeouts #define FT_FLOW_NONE 0x0000
// #define FT_FLOW_RTS_CTS 0x0100
#define FT_FLOW_DTR_DSR 0x0200
#define FT_DEFAULT_RX_TIMEOUT 300 #define FT_FLOW_XON_XOFF 0x0400
#define FT_DEFAULT_TX_TIMEOUT 300
//
// // Purge rx and tx buffers
// Device types //
// #define FT_PURGE_RX 1
#define FT_PURGE_TX 2
typedef ULONG FT_DEVICE;
//
enum { // Events
FT_DEVICE_BM, //
FT_DEVICE_AM,
FT_DEVICE_100AX, typedef void(*PFT_EVENT_HANDLER)(DWORD, DWORD);
FT_DEVICE_UNKNOWN,
FT_DEVICE_2232C, #define FT_EVENT_RXCHAR 1
FT_DEVICE_232R, #define FT_EVENT_MODEM_STATUS 2
FT_DEVICE_2232H, #define FT_EVENT_LINE_STATUS 4
FT_DEVICE_4232H,
FT_DEVICE_232H //
}; // Timeouts
//
//
// Bit Modes #define FT_DEFAULT_RX_TIMEOUT 300
// #define FT_DEFAULT_TX_TIMEOUT 300
#define FT_BITMODE_RESET 0x00 //
#define FT_BITMODE_ASYNC_BITBANG 0x01 // Device types
#define FT_BITMODE_MPSSE 0x02 //
#define FT_BITMODE_SYNC_BITBANG 0x04
#define FT_BITMODE_MCU_HOST 0x08 typedef ULONG FT_DEVICE;
#define FT_BITMODE_FAST_SERIAL 0x10
#define FT_BITMODE_CBUS_BITBANG 0x20 enum {
#define FT_BITMODE_SYNC_FIFO 0x40 FT_DEVICE_BM,
FT_DEVICE_AM,
// FT_DEVICE_100AX,
// FT232R CBUS Options EEPROM values FT_DEVICE_UNKNOWN,
// FT_DEVICE_2232C,
FT_DEVICE_232R,
#define FT_232R_CBUS_TXDEN 0x00 // Tx Data Enable FT_DEVICE_2232H,
#define FT_232R_CBUS_PWRON 0x01 // Power On FT_DEVICE_4232H,
#define FT_232R_CBUS_RXLED 0x02 // Rx LED FT_DEVICE_232H,
#define FT_232R_CBUS_TXLED 0x03 // Tx LED FT_DEVICE_X_SERIES,
#define FT_232R_CBUS_TXRXLED 0x04 // Tx and Rx LED FT_DEVICE_4222H_0,
#define FT_232R_CBUS_SLEEP 0x05 // Sleep FT_DEVICE_4222H_1_2,
#define FT_232R_CBUS_CLK48 0x06 // 48MHz clock FT_DEVICE_4222H_3,
#define FT_232R_CBUS_CLK24 0x07 // 24MHz clock FT_DEVICE_4222_PROG,
#define FT_232R_CBUS_CLK12 0x08 // 12MHz clock FT_DEVICE_900,
#define FT_232R_CBUS_CLK6 0x09 // 6MHz clock FT_DEVICE_930,
#define FT_232R_CBUS_IOMODE 0x0A // IO Mode for CBUS bit-bang FT_DEVICE_UMFTPD3A,
#define FT_232R_CBUS_BITBANG_WR 0x0B // Bit-bang write strobe FT_DEVICE_2233HP,
#define FT_232R_CBUS_BITBANG_RD 0x0C // Bit-bang read strobe FT_DEVICE_4233HP,
FT_DEVICE_2232HP,
// FT_DEVICE_4232HP,
// FT232H CBUS Options EEPROM values FT_DEVICE_233HP,
// FT_DEVICE_232HP,
FT_DEVICE_2232HA,
#define FT_232H_CBUS_TRISTATE 0x00 // Tristate FT_DEVICE_4232HA,
#define FT_232H_CBUS_RXLED 0x01 // Rx LED FT_DEVICE_232RN,
#define FT_232H_CBUS_TXLED 0x02 // Tx LED };
#define FT_232H_CBUS_TXRXLED 0x03 // Tx and Rx LED
#define FT_232H_CBUS_PWREN 0x04 // Power Enable //
#define FT_232H_CBUS_SLEEP 0x05 // Sleep // Bit Modes
#define FT_232H_CBUS_DRIVE_0 0x06 // Drive pin to logic 0 //
#define FT_232H_CBUS_DRIVE_1 0x07 // Drive pin to logic 1
#define FT_232H_CBUS_IOMODE 0x08 // IO Mode for CBUS bit-bang #define FT_BITMODE_RESET 0x00
#define FT_232H_CBUS_TXDEN 0x09 // Tx Data Enable #define FT_BITMODE_ASYNC_BITBANG 0x01
#define FT_232H_CBUS_CLK30 0x0A // 30MHz clock #define FT_BITMODE_MPSSE 0x02
#define FT_232H_CBUS_CLK15 0x0B // 15MHz clock #define FT_BITMODE_SYNC_BITBANG 0x04
#define FT_232H_CBUS_CLK7_5 0x0C // 7.5MHz clock #define FT_BITMODE_MCU_HOST 0x08
#define FT_BITMODE_FAST_SERIAL 0x10
#define FT_BITMODE_CBUS_BITBANG 0x20
#ifdef __cplusplus #define FT_BITMODE_SYNC_FIFO 0x40
extern "C" {
#endif //
// FT232R CBUS Options EEPROM values
//
FTD2XX_API
FT_STATUS WINAPI FT_Open( #define FT_232R_CBUS_TXDEN 0x00 // Tx Data Enable
int deviceNumber, #define FT_232R_CBUS_PWRON 0x01 // Power On
FT_HANDLE *pHandle #define FT_232R_CBUS_RXLED 0x02 // Rx LED
); #define FT_232R_CBUS_TXLED 0x03 // Tx LED
#define FT_232R_CBUS_TXRXLED 0x04 // Tx and Rx LED
FTD2XX_API #define FT_232R_CBUS_SLEEP 0x05 // Sleep
FT_STATUS WINAPI FT_OpenEx( #define FT_232R_CBUS_CLK48 0x06 // 48MHz clock
PVOID pArg1, #define FT_232R_CBUS_CLK24 0x07 // 24MHz clock
DWORD Flags, #define FT_232R_CBUS_CLK12 0x08 // 12MHz clock
FT_HANDLE *pHandle #define FT_232R_CBUS_CLK6 0x09 // 6MHz clock
); #define FT_232R_CBUS_IOMODE 0x0A // IO Mode for CBUS bit-bang
#define FT_232R_CBUS_BITBANG_WR 0x0B // Bit-bang write strobe
FTD2XX_API #define FT_232R_CBUS_BITBANG_RD 0x0C // Bit-bang read strobe
FT_STATUS WINAPI FT_ListDevices(
PVOID pArg1, //
PVOID pArg2, // FT232H CBUS Options EEPROM values
DWORD Flags //
);
#define FT_232H_CBUS_TRISTATE 0x00 // Tristate
FTD2XX_API #define FT_232H_CBUS_TXLED 0x01 // Tx LED
FT_STATUS WINAPI FT_Close( #define FT_232H_CBUS_RXLED 0x02 // Rx LED
FT_HANDLE ftHandle #define FT_232H_CBUS_TXRXLED 0x03 // Tx and Rx LED
); #define FT_232H_CBUS_PWREN 0x04 // Power Enable
#define FT_232H_CBUS_SLEEP 0x05 // Sleep
FTD2XX_API #define FT_232H_CBUS_DRIVE_0 0x06 // Drive pin to logic 0
FT_STATUS WINAPI FT_Read( #define FT_232H_CBUS_DRIVE_1 0x07 // Drive pin to logic 1
FT_HANDLE ftHandle, #define FT_232H_CBUS_IOMODE 0x08 // IO Mode for CBUS bit-bang
LPVOID lpBuffer, #define FT_232H_CBUS_TXDEN 0x09 // Tx Data Enable
DWORD dwBytesToRead, #define FT_232H_CBUS_CLK30 0x0A // 30MHz clock
LPDWORD lpBytesReturned #define FT_232H_CBUS_CLK15 0x0B // 15MHz clock
); #define FT_232H_CBUS_CLK7_5 0x0C // 7.5MHz clock
FTD2XX_API //
FT_STATUS WINAPI FT_Write( // FT X Series CBUS Options EEPROM values
FT_HANDLE ftHandle, //
LPVOID lpBuffer,
DWORD dwBytesToWrite, #define FT_X_SERIES_CBUS_TRISTATE 0x00 // Tristate
LPDWORD lpBytesWritten #define FT_X_SERIES_CBUS_TXLED 0x01 // Tx LED
); #define FT_X_SERIES_CBUS_RXLED 0x02 // Rx LED
#define FT_X_SERIES_CBUS_TXRXLED 0x03 // Tx and Rx LED
FTD2XX_API #define FT_X_SERIES_CBUS_PWREN 0x04 // Power Enable
FT_STATUS WINAPI FT_IoCtl( #define FT_X_SERIES_CBUS_SLEEP 0x05 // Sleep
FT_HANDLE ftHandle, #define FT_X_SERIES_CBUS_DRIVE_0 0x06 // Drive pin to logic 0
DWORD dwIoControlCode, #define FT_X_SERIES_CBUS_DRIVE_1 0x07 // Drive pin to logic 1
LPVOID lpInBuf, #define FT_X_SERIES_CBUS_IOMODE 0x08 // IO Mode for CBUS bit-bang
DWORD nInBufSize, #define FT_X_SERIES_CBUS_TXDEN 0x09 // Tx Data Enable
LPVOID lpOutBuf, #define FT_X_SERIES_CBUS_CLK24 0x0A // 24MHz clock
DWORD nOutBufSize, #define FT_X_SERIES_CBUS_CLK12 0x0B // 12MHz clock
LPDWORD lpBytesReturned, #define FT_X_SERIES_CBUS_CLK6 0x0C // 6MHz clock
LPOVERLAPPED lpOverlapped #define FT_X_SERIES_CBUS_BCD_CHARGER 0x0D // Battery charger detected
); #define FT_X_SERIES_CBUS_BCD_CHARGER_N 0x0E // Battery charger detected inverted
#define FT_X_SERIES_CBUS_I2C_TXE 0x0F // I2C Tx empty
FTD2XX_API #define FT_X_SERIES_CBUS_I2C_RXF 0x10 // I2C Rx full
FT_STATUS WINAPI FT_SetBaudRate( #define FT_X_SERIES_CBUS_VBUS_SENSE 0x11 // Detect VBUS
FT_HANDLE ftHandle, #define FT_X_SERIES_CBUS_BITBANG_WR 0x12 // Bit-bang write strobe
ULONG BaudRate #define FT_X_SERIES_CBUS_BITBANG_RD 0x13 // Bit-bang read strobe
); #define FT_X_SERIES_CBUS_TIMESTAMP 0x14 // Toggle output when a USB SOF token is received
#define FT_X_SERIES_CBUS_KEEP_AWAKE 0x15 //
FTD2XX_API
FT_STATUS WINAPI FT_SetDivisor(
FT_HANDLE ftHandle, // Driver types
USHORT Divisor #define FT_DRIVER_TYPE_D2XX 0
); #define FT_DRIVER_TYPE_VCP 1
FTD2XX_API
FT_STATUS WINAPI FT_SetDataCharacteristics(
FT_HANDLE ftHandle, #ifdef __cplusplus
UCHAR WordLength, extern "C" {
UCHAR StopBits, #endif
UCHAR Parity
);
#ifdef FTD2XX_STATIC
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_SetFlowControl( FT_STATUS WINAPI FT_Initialise(
FT_HANDLE ftHandle, void
USHORT FlowControl, );
UCHAR XonChar,
UCHAR XoffChar FTD2XX_API
); void WINAPI FT_Finalise(
void
FTD2XX_API );
FT_STATUS WINAPI FT_ResetDevice( #endif // FTD2XX_STATIC
FT_HANDLE ftHandle
); FTD2XX_API
FT_STATUS WINAPI FT_Open(
FTD2XX_API int deviceNumber,
FT_STATUS WINAPI FT_SetDtr( FT_HANDLE *pHandle
FT_HANDLE ftHandle );
);
FTD2XX_API
FTD2XX_API FT_STATUS WINAPI FT_OpenEx(
FT_STATUS WINAPI FT_ClrDtr( PVOID pArg1,
FT_HANDLE ftHandle DWORD Flags,
); FT_HANDLE *pHandle
);
FTD2XX_API
FT_STATUS WINAPI FT_SetRts( FTD2XX_API
FT_HANDLE ftHandle FT_STATUS WINAPI FT_ListDevices(
); PVOID pArg1,
PVOID pArg2,
FTD2XX_API DWORD Flags
FT_STATUS WINAPI FT_ClrRts( );
FT_HANDLE ftHandle
); FTD2XX_API
FT_STATUS WINAPI FT_Close(
FTD2XX_API FT_HANDLE ftHandle
FT_STATUS WINAPI FT_GetModemStatus( );
FT_HANDLE ftHandle,
ULONG *pModemStatus FTD2XX_API
); FT_STATUS WINAPI FT_Read(
FT_HANDLE ftHandle,
FTD2XX_API LPVOID lpBuffer,
FT_STATUS WINAPI FT_SetChars( DWORD dwBytesToRead,
FT_HANDLE ftHandle, LPDWORD lpBytesReturned
UCHAR EventChar, );
UCHAR EventCharEnabled,
UCHAR ErrorChar, FTD2XX_API
UCHAR ErrorCharEnabled FT_STATUS WINAPI FT_Write(
); FT_HANDLE ftHandle,
LPVOID lpBuffer,
FTD2XX_API DWORD dwBytesToWrite,
FT_STATUS WINAPI FT_Purge( LPDWORD lpBytesWritten
FT_HANDLE ftHandle, );
ULONG Mask
); FTD2XX_API
FT_STATUS WINAPI FT_IoCtl(
FTD2XX_API FT_HANDLE ftHandle,
FT_STATUS WINAPI FT_SetTimeouts( DWORD dwIoControlCode,
FT_HANDLE ftHandle, LPVOID lpInBuf,
ULONG ReadTimeout, DWORD nInBufSize,
ULONG WriteTimeout LPVOID lpOutBuf,
); DWORD nOutBufSize,
LPDWORD lpBytesReturned,
FTD2XX_API LPOVERLAPPED lpOverlapped
FT_STATUS WINAPI FT_GetQueueStatus( );
FT_HANDLE ftHandle,
DWORD *dwRxBytes FTD2XX_API
); FT_STATUS WINAPI FT_SetBaudRate(
FT_HANDLE ftHandle,
FTD2XX_API ULONG BaudRate
FT_STATUS WINAPI FT_SetEventNotification( );
FT_HANDLE ftHandle,
DWORD Mask, FTD2XX_API
PVOID Param FT_STATUS WINAPI FT_SetDivisor(
); FT_HANDLE ftHandle,
USHORT Divisor
FTD2XX_API );
FT_STATUS WINAPI FT_GetStatus(
FT_HANDLE ftHandle, FTD2XX_API
DWORD *dwRxBytes, FT_STATUS WINAPI FT_SetDataCharacteristics(
DWORD *dwTxBytes, FT_HANDLE ftHandle,
DWORD *dwEventDWord UCHAR WordLength,
); UCHAR StopBits,
UCHAR Parity
FTD2XX_API );
FT_STATUS WINAPI FT_SetBreakOn(
FT_HANDLE ftHandle FTD2XX_API
); FT_STATUS WINAPI FT_SetFlowControl(
FT_HANDLE ftHandle,
FTD2XX_API USHORT FlowControl,
FT_STATUS WINAPI FT_SetBreakOff( UCHAR XonChar,
FT_HANDLE ftHandle UCHAR XoffChar
); );
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_SetWaitMask( FT_STATUS WINAPI FT_ResetDevice(
FT_HANDLE ftHandle, FT_HANDLE ftHandle
DWORD Mask );
);
FTD2XX_API
FTD2XX_API FT_STATUS WINAPI FT_SetDtr(
FT_STATUS WINAPI FT_WaitOnMask( FT_HANDLE ftHandle
FT_HANDLE ftHandle, );
DWORD *Mask
); FTD2XX_API
FT_STATUS WINAPI FT_ClrDtr(
FTD2XX_API FT_HANDLE ftHandle
FT_STATUS WINAPI FT_GetEventStatus( );
FT_HANDLE ftHandle,
DWORD *dwEventDWord FTD2XX_API
); FT_STATUS WINAPI FT_SetRts(
FT_HANDLE ftHandle
FTD2XX_API );
FT_STATUS WINAPI FT_ReadEE(
FT_HANDLE ftHandle, FTD2XX_API
DWORD dwWordOffset, FT_STATUS WINAPI FT_ClrRts(
LPWORD lpwValue FT_HANDLE ftHandle
); );
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_WriteEE( FT_STATUS WINAPI FT_GetModemStatus(
FT_HANDLE ftHandle, FT_HANDLE ftHandle,
DWORD dwWordOffset, ULONG *pModemStatus
WORD wValue );
);
FTD2XX_API
FTD2XX_API FT_STATUS WINAPI FT_SetChars(
FT_STATUS WINAPI FT_EraseEE( FT_HANDLE ftHandle,
FT_HANDLE ftHandle UCHAR EventChar,
); UCHAR EventCharEnabled,
UCHAR ErrorChar,
// UCHAR ErrorCharEnabled
// structure to hold program data for FT_Program function );
//
typedef struct ft_program_data { FTD2XX_API
FT_STATUS WINAPI FT_Purge(
DWORD Signature1; // Header - must be 0x00000000 FT_HANDLE ftHandle,
DWORD Signature2; // Header - must be 0xffffffff ULONG Mask
DWORD Version; // Header - FT_PROGRAM_DATA version );
// 0 = original
// 1 = FT2232C extensions FTD2XX_API
// 2 = FT232R extensions FT_STATUS WINAPI FT_SetTimeouts(
// 3 = FT2232H extensions FT_HANDLE ftHandle,
// 4 = FT4232H extensions ULONG ReadTimeout,
// 5 = FT232H extensions ULONG WriteTimeout
);
WORD VendorId; // 0x0403
WORD ProductId; // 0x6001 FTD2XX_API
char *Manufacturer; // "FTDI" FT_STATUS WINAPI FT_GetQueueStatus(
char *ManufacturerId; // "FT" FT_HANDLE ftHandle,
char *Description; // "USB HS Serial Converter" DWORD *dwRxBytes
char *SerialNumber; // "FT000001" if fixed, or NULL );
WORD MaxPower; // 0 < MaxPower <= 500
WORD PnP; // 0 = disabled, 1 = enabled FTD2XX_API
WORD SelfPowered; // 0 = bus powered, 1 = self powered FT_STATUS WINAPI FT_SetEventNotification(
WORD RemoteWakeup; // 0 = not capable, 1 = capable FT_HANDLE ftHandle,
// DWORD Mask,
// Rev4 (FT232B) extensions PVOID Param
// );
UCHAR Rev4; // non-zero if Rev4 chip, zero otherwise
UCHAR IsoIn; // non-zero if in endpoint is isochronous FTD2XX_API
UCHAR IsoOut; // non-zero if out endpoint is isochronous FT_STATUS WINAPI FT_GetStatus(
UCHAR PullDownEnable; // non-zero if pull down enabled FT_HANDLE ftHandle,
UCHAR SerNumEnable; // non-zero if serial number to be used DWORD *dwRxBytes,
UCHAR USBVersionEnable; // non-zero if chip uses USBVersion DWORD *dwTxBytes,
WORD USBVersion; // BCD (0x0200 => USB2) DWORD *dwEventDWord
// );
// Rev 5 (FT2232) extensions
// FTD2XX_API
UCHAR Rev5; // non-zero if Rev5 chip, zero otherwise FT_STATUS WINAPI FT_SetBreakOn(
UCHAR IsoInA; // non-zero if in endpoint is isochronous FT_HANDLE ftHandle
UCHAR IsoInB; // non-zero if in endpoint is isochronous );
UCHAR IsoOutA; // non-zero if out endpoint is isochronous
UCHAR IsoOutB; // non-zero if out endpoint is isochronous FTD2XX_API
UCHAR PullDownEnable5; // non-zero if pull down enabled FT_STATUS WINAPI FT_SetBreakOff(
UCHAR SerNumEnable5; // non-zero if serial number to be used FT_HANDLE ftHandle
UCHAR USBVersionEnable5; // non-zero if chip uses USBVersion );
WORD USBVersion5; // BCD (0x0200 => USB2)
UCHAR AIsHighCurrent; // non-zero if interface is high current FTD2XX_API
UCHAR BIsHighCurrent; // non-zero if interface is high current FT_STATUS WINAPI FT_SetWaitMask(
UCHAR IFAIsFifo; // non-zero if interface is 245 FIFO FT_HANDLE ftHandle,
UCHAR IFAIsFifoTar; // non-zero if interface is 245 FIFO CPU target DWORD Mask
UCHAR IFAIsFastSer; // non-zero if interface is Fast serial );
UCHAR AIsVCP; // non-zero if interface is to use VCP drivers
UCHAR IFBIsFifo; // non-zero if interface is 245 FIFO FTD2XX_API
UCHAR IFBIsFifoTar; // non-zero if interface is 245 FIFO CPU target FT_STATUS WINAPI FT_WaitOnMask(
UCHAR IFBIsFastSer; // non-zero if interface is Fast serial FT_HANDLE ftHandle,
UCHAR BIsVCP; // non-zero if interface is to use VCP drivers DWORD *Mask
// );
// Rev 6 (FT232R) extensions
// FTD2XX_API
UCHAR UseExtOsc; // Use External Oscillator FT_STATUS WINAPI FT_GetEventStatus(
UCHAR HighDriveIOs; // High Drive I/Os FT_HANDLE ftHandle,
UCHAR EndpointSize; // Endpoint size DWORD *dwEventDWord
UCHAR PullDownEnableR; // non-zero if pull down enabled );
UCHAR SerNumEnableR; // non-zero if serial number to be used
UCHAR InvertTXD; // non-zero if invert TXD FTD2XX_API
UCHAR InvertRXD; // non-zero if invert RXD FT_STATUS WINAPI FT_ReadEE(
UCHAR InvertRTS; // non-zero if invert RTS FT_HANDLE ftHandle,
UCHAR InvertCTS; // non-zero if invert CTS DWORD dwWordOffset,
UCHAR InvertDTR; // non-zero if invert DTR LPWORD lpwValue
UCHAR InvertDSR; // non-zero if invert DSR );
UCHAR InvertDCD; // non-zero if invert DCD
UCHAR InvertRI; // non-zero if invert RI FTD2XX_API
UCHAR Cbus0; // Cbus Mux control FT_STATUS WINAPI FT_WriteEE(
UCHAR Cbus1; // Cbus Mux control FT_HANDLE ftHandle,
UCHAR Cbus2; // Cbus Mux control DWORD dwWordOffset,
UCHAR Cbus3; // Cbus Mux control WORD wValue
UCHAR Cbus4; // Cbus Mux control );
UCHAR RIsD2XX; // non-zero if using D2XX driver
// FTD2XX_API
// Rev 7 (FT2232H) Extensions FT_STATUS WINAPI FT_EraseEE(
// FT_HANDLE ftHandle
UCHAR PullDownEnable7; // non-zero if pull down enabled );
UCHAR SerNumEnable7; // non-zero if serial number to be used
UCHAR ALSlowSlew; // non-zero if AL pins have slow slew //
UCHAR ALSchmittInput; // non-zero if AL pins are Schmitt input // structure to hold program data for FT_EE_Program, FT_EE_ProgramEx, FT_EE_Read
UCHAR ALDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA // and FT_EE_ReadEx functions
UCHAR AHSlowSlew; // non-zero if AH pins have slow slew //
UCHAR AHSchmittInput; // non-zero if AH pins are Schmitt input typedef struct ft_program_data {
UCHAR AHDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR BLSlowSlew; // non-zero if BL pins have slow slew DWORD Signature1; // Header - must be 0x00000000
UCHAR BLSchmittInput; // non-zero if BL pins are Schmitt input DWORD Signature2; // Header - must be 0xffffffff
UCHAR BLDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA DWORD Version; // Header - FT_PROGRAM_DATA version
UCHAR BHSlowSlew; // non-zero if BH pins have slow slew // 0 = original
UCHAR BHSchmittInput; // non-zero if BH pins are Schmitt input // 1 = FT2232 extensions
UCHAR BHDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA // 2 = FT232R extensions
UCHAR IFAIsFifo7; // non-zero if interface is 245 FIFO // 3 = FT2232H extensions
UCHAR IFAIsFifoTar7; // non-zero if interface is 245 FIFO CPU target // 4 = FT4232H extensions
UCHAR IFAIsFastSer7; // non-zero if interface is Fast serial // 5 = FT232H extensions
UCHAR AIsVCP7; // non-zero if interface is to use VCP drivers
UCHAR IFBIsFifo7; // non-zero if interface is 245 FIFO WORD VendorId; // 0x0403
UCHAR IFBIsFifoTar7; // non-zero if interface is 245 FIFO CPU target WORD ProductId; // 0x6001
UCHAR IFBIsFastSer7; // non-zero if interface is Fast serial char *Manufacturer; // "FTDI"
UCHAR BIsVCP7; // non-zero if interface is to use VCP drivers char *ManufacturerId; // "FT"
UCHAR PowerSaveEnable; // non-zero if using BCBUS7 to save power for self-powered designs char *Description; // "USB HS Serial Converter"
// char *SerialNumber; // "FT000001" if fixed, or NULL
// Rev 8 (FT4232H) Extensions WORD MaxPower; // 0 < MaxPower <= 500
// WORD PnP; // 0 = disabled, 1 = enabled
UCHAR PullDownEnable8; // non-zero if pull down enabled WORD SelfPowered; // 0 = bus powered, 1 = self powered
UCHAR SerNumEnable8; // non-zero if serial number to be used WORD RemoteWakeup; // 0 = not capable, 1 = capable
UCHAR ASlowSlew; // non-zero if AL pins have slow slew //
UCHAR ASchmittInput; // non-zero if AL pins are Schmitt input // Rev4 (FT232B) extensions
UCHAR ADriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA //
UCHAR BSlowSlew; // non-zero if AH pins have slow slew UCHAR Rev4; // non-zero if Rev4 chip, zero otherwise
UCHAR BSchmittInput; // non-zero if AH pins are Schmitt input UCHAR IsoIn; // non-zero if in endpoint is isochronous
UCHAR BDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA UCHAR IsoOut; // non-zero if out endpoint is isochronous
UCHAR CSlowSlew; // non-zero if BL pins have slow slew UCHAR PullDownEnable; // non-zero if pull down enabled
UCHAR CSchmittInput; // non-zero if BL pins are Schmitt input UCHAR SerNumEnable; // non-zero if serial number to be used
UCHAR CDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA UCHAR USBVersionEnable; // non-zero if chip uses USBVersion
UCHAR DSlowSlew; // non-zero if BH pins have slow slew WORD USBVersion; // BCD (0x0200 => USB2)
UCHAR DSchmittInput; // non-zero if BH pins are Schmitt input //
UCHAR DDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA // Rev 5 (FT2232) extensions
UCHAR ARIIsTXDEN; // non-zero if port A uses RI as RS485 TXDEN //
UCHAR BRIIsTXDEN; // non-zero if port B uses RI as RS485 TXDEN UCHAR Rev5; // non-zero if Rev5 chip, zero otherwise
UCHAR CRIIsTXDEN; // non-zero if port C uses RI as RS485 TXDEN UCHAR IsoInA; // non-zero if in endpoint is isochronous
UCHAR DRIIsTXDEN; // non-zero if port D uses RI as RS485 TXDEN UCHAR IsoInB; // non-zero if in endpoint is isochronous
UCHAR AIsVCP8; // non-zero if interface is to use VCP drivers UCHAR IsoOutA; // non-zero if out endpoint is isochronous
UCHAR BIsVCP8; // non-zero if interface is to use VCP drivers UCHAR IsoOutB; // non-zero if out endpoint is isochronous
UCHAR CIsVCP8; // non-zero if interface is to use VCP drivers UCHAR PullDownEnable5; // non-zero if pull down enabled
UCHAR DIsVCP8; // non-zero if interface is to use VCP drivers UCHAR SerNumEnable5; // non-zero if serial number to be used
// UCHAR USBVersionEnable5; // non-zero if chip uses USBVersion
// Rev 9 (FT232H) Extensions WORD USBVersion5; // BCD (0x0200 => USB2)
// UCHAR AIsHighCurrent; // non-zero if interface is high current
UCHAR PullDownEnableH; // non-zero if pull down enabled UCHAR BIsHighCurrent; // non-zero if interface is high current
UCHAR SerNumEnableH; // non-zero if serial number to be used UCHAR IFAIsFifo; // non-zero if interface is 245 FIFO
UCHAR ACSlowSlewH; // non-zero if AC pins have slow slew UCHAR IFAIsFifoTar; // non-zero if interface is 245 FIFO CPU target
UCHAR ACSchmittInputH; // non-zero if AC pins are Schmitt input UCHAR IFAIsFastSer; // non-zero if interface is Fast serial
UCHAR ACDriveCurrentH; // valid values are 4mA, 8mA, 12mA, 16mA UCHAR AIsVCP; // non-zero if interface is to use VCP drivers
UCHAR ADSlowSlewH; // non-zero if AD pins have slow slew UCHAR IFBIsFifo; // non-zero if interface is 245 FIFO
UCHAR ADSchmittInputH; // non-zero if AD pins are Schmitt input UCHAR IFBIsFifoTar; // non-zero if interface is 245 FIFO CPU target
UCHAR ADDriveCurrentH; // valid values are 4mA, 8mA, 12mA, 16mA UCHAR IFBIsFastSer; // non-zero if interface is Fast serial
UCHAR Cbus0H; // Cbus Mux control UCHAR BIsVCP; // non-zero if interface is to use VCP drivers
UCHAR Cbus1H; // Cbus Mux control //
UCHAR Cbus2H; // Cbus Mux control // Rev 6 (FT232R) extensions
UCHAR Cbus3H; // Cbus Mux control //
UCHAR Cbus4H; // Cbus Mux control UCHAR UseExtOsc; // Use External Oscillator
UCHAR Cbus5H; // Cbus Mux control UCHAR HighDriveIOs; // High Drive I/Os
UCHAR Cbus6H; // Cbus Mux control UCHAR EndpointSize; // Endpoint size
UCHAR Cbus7H; // Cbus Mux control UCHAR PullDownEnableR; // non-zero if pull down enabled
UCHAR Cbus8H; // Cbus Mux control UCHAR SerNumEnableR; // non-zero if serial number to be used
UCHAR Cbus9H; // Cbus Mux control UCHAR InvertTXD; // non-zero if invert TXD
UCHAR IsFifoH; // non-zero if interface is 245 FIFO UCHAR InvertRXD; // non-zero if invert RXD
UCHAR IsFifoTarH; // non-zero if interface is 245 FIFO CPU target UCHAR InvertRTS; // non-zero if invert RTS
UCHAR IsFastSerH; // non-zero if interface is Fast serial UCHAR InvertCTS; // non-zero if invert CTS
UCHAR IsFT1248H; // non-zero if interface is FT1248 UCHAR InvertDTR; // non-zero if invert DTR
UCHAR FT1248CpolH; // FT1248 clock polarity - clock idle high (1) or clock idle low (0) UCHAR InvertDSR; // non-zero if invert DSR
UCHAR FT1248LsbH; // FT1248 data is LSB (1) or MSB (0) UCHAR InvertDCD; // non-zero if invert DCD
UCHAR FT1248FlowControlH; // FT1248 flow control enable UCHAR InvertRI; // non-zero if invert RI
UCHAR IsVCPH; // non-zero if interface is to use VCP drivers UCHAR Cbus0; // Cbus Mux control
UCHAR PowerSaveEnableH; // non-zero if using ACBUS7 to save power for self-powered designs UCHAR Cbus1; // Cbus Mux control
UCHAR Cbus2; // Cbus Mux control
} FT_PROGRAM_DATA, *PFT_PROGRAM_DATA; UCHAR Cbus3; // Cbus Mux control
UCHAR Cbus4; // Cbus Mux control
FTD2XX_API UCHAR RIsD2XX; // non-zero if using D2XX driver
FT_STATUS WINAPI FT_EE_Program( //
FT_HANDLE ftHandle, // Rev 7 (FT2232H) Extensions
PFT_PROGRAM_DATA pData //
); UCHAR PullDownEnable7; // non-zero if pull down enabled
UCHAR SerNumEnable7; // non-zero if serial number to be used
FTD2XX_API UCHAR ALSlowSlew; // non-zero if AL pins have slow slew
FT_STATUS WINAPI FT_EE_ProgramEx( UCHAR ALSchmittInput; // non-zero if AL pins are Schmitt input
FT_HANDLE ftHandle, UCHAR ALDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
PFT_PROGRAM_DATA pData, UCHAR AHSlowSlew; // non-zero if AH pins have slow slew
char *Manufacturer, UCHAR AHSchmittInput; // non-zero if AH pins are Schmitt input
char *ManufacturerId, UCHAR AHDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
char *Description, UCHAR BLSlowSlew; // non-zero if BL pins have slow slew
char *SerialNumber UCHAR BLSchmittInput; // non-zero if BL pins are Schmitt input
); UCHAR BLDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR BHSlowSlew; // non-zero if BH pins have slow slew
FTD2XX_API UCHAR BHSchmittInput; // non-zero if BH pins are Schmitt input
FT_STATUS WINAPI FT_EE_Read( UCHAR BHDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
FT_HANDLE ftHandle, UCHAR IFAIsFifo7; // non-zero if interface is 245 FIFO
PFT_PROGRAM_DATA pData UCHAR IFAIsFifoTar7; // non-zero if interface is 245 FIFO CPU target
); UCHAR IFAIsFastSer7; // non-zero if interface is Fast serial
UCHAR AIsVCP7; // non-zero if interface is to use VCP drivers
FTD2XX_API UCHAR IFBIsFifo7; // non-zero if interface is 245 FIFO
FT_STATUS WINAPI FT_EE_ReadEx( UCHAR IFBIsFifoTar7; // non-zero if interface is 245 FIFO CPU target
FT_HANDLE ftHandle, UCHAR IFBIsFastSer7; // non-zero if interface is Fast serial
PFT_PROGRAM_DATA pData, UCHAR BIsVCP7; // non-zero if interface is to use VCP drivers
char *Manufacturer, UCHAR PowerSaveEnable; // non-zero if using BCBUS7 to save power for self-powered designs
char *ManufacturerId, //
char *Description, // Rev 8 (FT4232H) Extensions
char *SerialNumber //
); UCHAR PullDownEnable8; // non-zero if pull down enabled
UCHAR SerNumEnable8; // non-zero if serial number to be used
FTD2XX_API UCHAR ASlowSlew; // non-zero if A pins have slow slew
FT_STATUS WINAPI FT_EE_UASize( UCHAR ASchmittInput; // non-zero if A pins are Schmitt input
FT_HANDLE ftHandle, UCHAR ADriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
LPDWORD lpdwSize UCHAR BSlowSlew; // non-zero if B pins have slow slew
); UCHAR BSchmittInput; // non-zero if B pins are Schmitt input
UCHAR BDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
FTD2XX_API UCHAR CSlowSlew; // non-zero if C pins have slow slew
FT_STATUS WINAPI FT_EE_UAWrite( UCHAR CSchmittInput; // non-zero if C pins are Schmitt input
FT_HANDLE ftHandle, UCHAR CDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
PUCHAR pucData, UCHAR DSlowSlew; // non-zero if D pins have slow slew
DWORD dwDataLen UCHAR DSchmittInput; // non-zero if D pins are Schmitt input
); UCHAR DDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR ARIIsTXDEN; // non-zero if port A uses RI as RS485 TXDEN
FTD2XX_API UCHAR BRIIsTXDEN; // non-zero if port B uses RI as RS485 TXDEN
FT_STATUS WINAPI FT_EE_UARead( UCHAR CRIIsTXDEN; // non-zero if port C uses RI as RS485 TXDEN
FT_HANDLE ftHandle, UCHAR DRIIsTXDEN; // non-zero if port D uses RI as RS485 TXDEN
PUCHAR pucData, UCHAR AIsVCP8; // non-zero if interface is to use VCP drivers
DWORD dwDataLen, UCHAR BIsVCP8; // non-zero if interface is to use VCP drivers
LPDWORD lpdwBytesRead UCHAR CIsVCP8; // non-zero if interface is to use VCP drivers
); UCHAR DIsVCP8; // non-zero if interface is to use VCP drivers
//
FTD2XX_API // Rev 9 (FT232H) Extensions
FT_STATUS WINAPI FT_SetLatencyTimer( //
FT_HANDLE ftHandle, UCHAR PullDownEnableH; // non-zero if pull down enabled
UCHAR ucLatency UCHAR SerNumEnableH; // non-zero if serial number to be used
); UCHAR ACSlowSlewH; // non-zero if AC pins have slow slew
UCHAR ACSchmittInputH; // non-zero if AC pins are Schmitt input
FTD2XX_API UCHAR ACDriveCurrentH; // valid values are 4mA, 8mA, 12mA, 16mA
FT_STATUS WINAPI FT_GetLatencyTimer( UCHAR ADSlowSlewH; // non-zero if AD pins have slow slew
FT_HANDLE ftHandle, UCHAR ADSchmittInputH; // non-zero if AD pins are Schmitt input
PUCHAR pucLatency UCHAR ADDriveCurrentH; // valid values are 4mA, 8mA, 12mA, 16mA
); UCHAR Cbus0H; // Cbus Mux control
UCHAR Cbus1H; // Cbus Mux control
FTD2XX_API UCHAR Cbus2H; // Cbus Mux control
FT_STATUS WINAPI FT_SetBitMode( UCHAR Cbus3H; // Cbus Mux control
FT_HANDLE ftHandle, UCHAR Cbus4H; // Cbus Mux control
UCHAR ucMask, UCHAR Cbus5H; // Cbus Mux control
UCHAR ucEnable UCHAR Cbus6H; // Cbus Mux control
); UCHAR Cbus7H; // Cbus Mux control
UCHAR Cbus8H; // Cbus Mux control
FTD2XX_API UCHAR Cbus9H; // Cbus Mux control
FT_STATUS WINAPI FT_GetBitMode( UCHAR IsFifoH; // non-zero if interface is 245 FIFO
FT_HANDLE ftHandle, UCHAR IsFifoTarH; // non-zero if interface is 245 FIFO CPU target
PUCHAR pucMode UCHAR IsFastSerH; // non-zero if interface is Fast serial
); UCHAR IsFT1248H; // non-zero if interface is FT1248
UCHAR FT1248CpolH; // FT1248 clock polarity - clock idle high (1) or clock idle low (0)
FTD2XX_API UCHAR FT1248LsbH; // FT1248 data is LSB (1) or MSB (0)
FT_STATUS WINAPI FT_SetUSBParameters( UCHAR FT1248FlowControlH; // FT1248 flow control enable
FT_HANDLE ftHandle, UCHAR IsVCPH; // non-zero if interface is to use VCP drivers
ULONG ulInTransferSize, UCHAR PowerSaveEnableH; // non-zero if using ACBUS7 to save power for self-powered designs
ULONG ulOutTransferSize
); } FT_PROGRAM_DATA, *PFT_PROGRAM_DATA;
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_SetDeadmanTimeout( FT_STATUS WINAPI FT_EE_Program(
FT_HANDLE ftHandle, FT_HANDLE ftHandle,
ULONG ulDeadmanTimeout PFT_PROGRAM_DATA pData
); );
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_GetDeviceInfo( FT_STATUS WINAPI FT_EE_ProgramEx(
FT_HANDLE ftHandle, FT_HANDLE ftHandle,
FT_DEVICE *lpftDevice, PFT_PROGRAM_DATA pData,
LPDWORD lpdwID, char *Manufacturer,
PCHAR SerialNumber, char *ManufacturerId,
PCHAR Description, char *Description,
LPVOID Dummy char *SerialNumber
); );
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_StopInTask( FT_STATUS WINAPI FT_EE_Read(
FT_HANDLE ftHandle FT_HANDLE ftHandle,
); PFT_PROGRAM_DATA pData
);
FTD2XX_API
FT_STATUS WINAPI FT_RestartInTask( FTD2XX_API
FT_HANDLE ftHandle FT_STATUS WINAPI FT_EE_ReadEx(
); FT_HANDLE ftHandle,
PFT_PROGRAM_DATA pData,
FTD2XX_API char *Manufacturer,
FT_STATUS WINAPI FT_SetResetPipeRetryCount( char *ManufacturerId,
FT_HANDLE ftHandle, char *Description,
DWORD dwCount char *SerialNumber
); );
FTD2XX_API FTD2XX_API
FT_STATUS WINAPI FT_ResetPort( FT_STATUS WINAPI FT_EE_UASize(
FT_HANDLE ftHandle FT_HANDLE ftHandle,
); LPDWORD lpdwSize
);
FTD2XX_API
FT_STATUS WINAPI FT_CyclePort( FTD2XX_API
FT_HANDLE ftHandle FT_STATUS WINAPI FT_EE_UAWrite(
); FT_HANDLE ftHandle,
PUCHAR pucData,
DWORD dwDataLen
// );
// Win32-type functions
// FTD2XX_API
FT_STATUS WINAPI FT_EE_UARead(
FTD2XX_API FT_HANDLE ftHandle,
FT_HANDLE WINAPI FT_W32_CreateFile( PUCHAR pucData,
LPCTSTR lpszName, DWORD dwDataLen,
DWORD dwAccess, LPDWORD lpdwBytesRead
DWORD dwShareMode, );
LPSECURITY_ATTRIBUTES lpSecurityAttributes,
DWORD dwCreate,
DWORD dwAttrsAndFlags, typedef struct ft_eeprom_header {
HANDLE hTemplate FT_DEVICE deviceType; // FTxxxx device type to be programmed
); // Device descriptor options
WORD VendorId; // 0x0403
FTD2XX_API WORD ProductId; // 0x6001
BOOL WINAPI FT_W32_CloseHandle( UCHAR SerNumEnable; // non-zero if serial number to be used
FT_HANDLE ftHandle // Config descriptor options
); WORD MaxPower; // 0 < MaxPower <= 500
UCHAR SelfPowered; // 0 = bus powered, 1 = self powered
FTD2XX_API UCHAR RemoteWakeup; // 0 = not capable, 1 = capable
BOOL WINAPI FT_W32_ReadFile( // Hardware options
FT_HANDLE ftHandle, UCHAR PullDownEnable; // non-zero if pull down in suspend enabled
LPVOID lpBuffer, } FT_EEPROM_HEADER, *PFT_EEPROM_HEADER;
DWORD nBufferSize,
LPDWORD lpBytesReturned,
LPOVERLAPPED lpOverlapped // FT232B EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
); typedef struct ft_eeprom_232b {
// Common header
FTD2XX_API FT_EEPROM_HEADER common; // common elements for all device EEPROMs
BOOL WINAPI FT_W32_WriteFile( } FT_EEPROM_232B, *PFT_EEPROM_232B;
FT_HANDLE ftHandle,
LPVOID lpBuffer,
DWORD nBufferSize, // FT2232 EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
LPDWORD lpBytesWritten, typedef struct ft_eeprom_2232 {
LPOVERLAPPED lpOverlapped // Common header
); FT_EEPROM_HEADER common; // common elements for all device EEPROMs
// Drive options
FTD2XX_API UCHAR AIsHighCurrent; // non-zero if interface is high current
DWORD WINAPI FT_W32_GetLastError( UCHAR BIsHighCurrent; // non-zero if interface is high current
FT_HANDLE ftHandle // Hardware options
); UCHAR AIsFifo; // non-zero if interface is 245 FIFO
UCHAR AIsFifoTar; // non-zero if interface is 245 FIFO CPU target
FTD2XX_API UCHAR AIsFastSer; // non-zero if interface is Fast serial
BOOL WINAPI FT_W32_GetOverlappedResult( UCHAR BIsFifo; // non-zero if interface is 245 FIFO
FT_HANDLE ftHandle, UCHAR BIsFifoTar; // non-zero if interface is 245 FIFO CPU target
LPOVERLAPPED lpOverlapped, UCHAR BIsFastSer; // non-zero if interface is Fast serial
LPDWORD lpdwBytesTransferred, // Driver option
BOOL bWait UCHAR ADriverType; // non-zero if interface is to use VCP drivers
); UCHAR BDriverType; // non-zero if interface is to use VCP drivers
} FT_EEPROM_2232, *PFT_EEPROM_2232;
FTD2XX_API
BOOL WINAPI FT_W32_CancelIo(
FT_HANDLE ftHandle // FT232R EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
); typedef struct ft_eeprom_232r {
// Common header
FT_EEPROM_HEADER common; // common elements for all device EEPROMs
// // Drive options
// Win32 COMM API type functions UCHAR IsHighCurrent; // non-zero if interface is high current
// // Hardware options
typedef struct _FTCOMSTAT { UCHAR UseExtOsc; // Use External Oscillator
DWORD fCtsHold : 1; UCHAR InvertTXD; // non-zero if invert TXD
DWORD fDsrHold : 1; UCHAR InvertRXD; // non-zero if invert RXD
DWORD fRlsdHold : 1; UCHAR InvertRTS; // non-zero if invert RTS
DWORD fXoffHold : 1; UCHAR InvertCTS; // non-zero if invert CTS
DWORD fXoffSent : 1; UCHAR InvertDTR; // non-zero if invert DTR
DWORD fEof : 1; UCHAR InvertDSR; // non-zero if invert DSR
DWORD fTxim : 1; UCHAR InvertDCD; // non-zero if invert DCD
DWORD fReserved : 25; UCHAR InvertRI; // non-zero if invert RI
DWORD cbInQue; UCHAR Cbus0; // Cbus Mux control
DWORD cbOutQue; UCHAR Cbus1; // Cbus Mux control
} FTCOMSTAT, *LPFTCOMSTAT; UCHAR Cbus2; // Cbus Mux control
UCHAR Cbus3; // Cbus Mux control
typedef struct _FTDCB { UCHAR Cbus4; // Cbus Mux control
DWORD DCBlength; /* sizeof(FTDCB) */ // Driver option
DWORD BaudRate; /* Baudrate at which running */ UCHAR DriverType; // non-zero if using D2XX driver
DWORD fBinary: 1; /* Binary Mode (skip EOF check) */ } FT_EEPROM_232R, *PFT_EEPROM_232R;
DWORD fParity: 1; /* Enable parity checking */
DWORD fOutxCtsFlow:1; /* CTS handshaking on output */
DWORD fOutxDsrFlow:1; /* DSR handshaking on output */ // FT2232H EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
DWORD fDtrControl:2; /* DTR Flow control */ typedef struct ft_eeprom_2232h {
DWORD fDsrSensitivity:1; /* DSR Sensitivity */ // Common header
DWORD fTXContinueOnXoff: 1; /* Continue TX when Xoff sent */ FT_EEPROM_HEADER common; // common elements for all device EEPROMs
DWORD fOutX: 1; /* Enable output X-ON/X-OFF */ // Drive options
DWORD fInX: 1; /* Enable input X-ON/X-OFF */ UCHAR ALSlowSlew; // non-zero if AL pins have slow slew
DWORD fErrorChar: 1; /* Enable Err Replacement */ UCHAR ALSchmittInput; // non-zero if AL pins are Schmitt input
DWORD fNull: 1; /* Enable Null stripping */ UCHAR ALDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
DWORD fRtsControl:2; /* Rts Flow control */ UCHAR AHSlowSlew; // non-zero if AH pins have slow slew
DWORD fAbortOnError:1; /* Abort all reads and writes on Error */ UCHAR AHSchmittInput; // non-zero if AH pins are Schmitt input
DWORD fDummy2:17; /* Reserved */ UCHAR AHDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
WORD wReserved; /* Not currently used */ UCHAR BLSlowSlew; // non-zero if BL pins have slow slew
WORD XonLim; /* Transmit X-ON threshold */ UCHAR BLSchmittInput; // non-zero if BL pins are Schmitt input
WORD XoffLim; /* Transmit X-OFF threshold */ UCHAR BLDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
BYTE ByteSize; /* Number of bits/byte, 4-8 */ UCHAR BHSlowSlew; // non-zero if BH pins have slow slew
BYTE Parity; /* 0-4=None,Odd,Even,Mark,Space */ UCHAR BHSchmittInput; // non-zero if BH pins are Schmitt input
BYTE StopBits; /* 0,1,2 = 1, 1.5, 2 */ UCHAR BHDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
char XonChar; /* Tx and Rx X-ON character */ // Hardware options
char XoffChar; /* Tx and Rx X-OFF character */ UCHAR AIsFifo; // non-zero if interface is 245 FIFO
char ErrorChar; /* Error replacement char */ UCHAR AIsFifoTar; // non-zero if interface is 245 FIFO CPU target
char EofChar; /* End of Input character */ UCHAR AIsFastSer; // non-zero if interface is Fast serial
char EvtChar; /* Received Event character */ UCHAR BIsFifo; // non-zero if interface is 245 FIFO
WORD wReserved1; /* Fill for now. */ UCHAR BIsFifoTar; // non-zero if interface is 245 FIFO CPU target
} FTDCB, *LPFTDCB; UCHAR BIsFastSer; // non-zero if interface is Fast serial
UCHAR PowerSaveEnable; // non-zero if using BCBUS7 to save power for self-powered designs
typedef struct _FTTIMEOUTS { // Driver option
DWORD ReadIntervalTimeout; /* Maximum time between read chars. */ UCHAR ADriverType; // non-zero if interface is to use VCP drivers
DWORD ReadTotalTimeoutMultiplier; /* Multiplier of characters. */ UCHAR BDriverType; // non-zero if interface is to use VCP drivers
DWORD ReadTotalTimeoutConstant; /* Constant in milliseconds. */ } FT_EEPROM_2232H, *PFT_EEPROM_2232H;
DWORD WriteTotalTimeoutMultiplier; /* Multiplier of characters. */
DWORD WriteTotalTimeoutConstant; /* Constant in milliseconds. */
} FTTIMEOUTS,*LPFTTIMEOUTS; // FT4232H EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
typedef struct ft_eeprom_4232h {
// Common header
FTD2XX_API FT_EEPROM_HEADER common; // common elements for all device EEPROMs
BOOL WINAPI FT_W32_ClearCommBreak( // Drive options
FT_HANDLE ftHandle UCHAR ASlowSlew; // non-zero if A pins have slow slew
); UCHAR ASchmittInput; // non-zero if A pins are Schmitt input
UCHAR ADriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
FTD2XX_API UCHAR BSlowSlew; // non-zero if B pins have slow slew
BOOL WINAPI FT_W32_ClearCommError( UCHAR BSchmittInput; // non-zero if B pins are Schmitt input
FT_HANDLE ftHandle, UCHAR BDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
LPDWORD lpdwErrors, UCHAR CSlowSlew; // non-zero if C pins have slow slew
LPFTCOMSTAT lpftComstat UCHAR CSchmittInput; // non-zero if C pins are Schmitt input
); UCHAR CDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR DSlowSlew; // non-zero if D pins have slow slew
FTD2XX_API UCHAR DSchmittInput; // non-zero if D pins are Schmitt input
BOOL WINAPI FT_W32_EscapeCommFunction( UCHAR DDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
FT_HANDLE ftHandle, // Hardware options
DWORD dwFunc UCHAR ARIIsTXDEN; // non-zero if port A uses RI as RS485 TXDEN
); UCHAR BRIIsTXDEN; // non-zero if port B uses RI as RS485 TXDEN
UCHAR CRIIsTXDEN; // non-zero if port C uses RI as RS485 TXDEN
FTD2XX_API UCHAR DRIIsTXDEN; // non-zero if port D uses RI as RS485 TXDEN
BOOL WINAPI FT_W32_GetCommModemStatus( // Driver option
FT_HANDLE ftHandle, UCHAR ADriverType; // non-zero if interface is to use VCP drivers
LPDWORD lpdwModemStatus UCHAR BDriverType; // non-zero if interface is to use VCP drivers
); UCHAR CDriverType; // non-zero if interface is to use VCP drivers
UCHAR DDriverType; // non-zero if interface is to use VCP drivers
FTD2XX_API } FT_EEPROM_4232H, *PFT_EEPROM_4232H;
BOOL WINAPI FT_W32_GetCommState(
FT_HANDLE ftHandle,
LPFTDCB lpftDcb // FT232H EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
); typedef struct ft_eeprom_232h {
// Common header
FTD2XX_API FT_EEPROM_HEADER common; // common elements for all device EEPROMs
BOOL WINAPI FT_W32_GetCommTimeouts( // Drive options
FT_HANDLE ftHandle, UCHAR ACSlowSlew; // non-zero if AC bus pins have slow slew
FTTIMEOUTS *pTimeouts UCHAR ACSchmittInput; // non-zero if AC bus pins are Schmitt input
); UCHAR ACDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR ADSlowSlew; // non-zero if AD bus pins have slow slew
FTD2XX_API UCHAR ADSchmittInput; // non-zero if AD bus pins are Schmitt input
BOOL WINAPI FT_W32_PurgeComm( UCHAR ADDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
FT_HANDLE ftHandle, // CBUS options
DWORD dwMask UCHAR Cbus0; // Cbus Mux control
); UCHAR Cbus1; // Cbus Mux control
UCHAR Cbus2; // Cbus Mux control
FTD2XX_API UCHAR Cbus3; // Cbus Mux control
BOOL WINAPI FT_W32_SetCommBreak( UCHAR Cbus4; // Cbus Mux control
FT_HANDLE ftHandle UCHAR Cbus5; // Cbus Mux control
); UCHAR Cbus6; // Cbus Mux control
UCHAR Cbus7; // Cbus Mux control
FTD2XX_API UCHAR Cbus8; // Cbus Mux control
BOOL WINAPI FT_W32_SetCommMask( UCHAR Cbus9; // Cbus Mux control
FT_HANDLE ftHandle, // FT1248 options
ULONG ulEventMask UCHAR FT1248Cpol; // FT1248 clock polarity - clock idle high (1) or clock idle low (0)
); UCHAR FT1248Lsb; // FT1248 data is LSB (1) or MSB (0)
UCHAR FT1248FlowControl; // FT1248 flow control enable
FTD2XX_API // Hardware options
BOOL WINAPI FT_W32_GetCommMask( UCHAR IsFifo; // non-zero if interface is 245 FIFO
FT_HANDLE ftHandle, UCHAR IsFifoTar; // non-zero if interface is 245 FIFO CPU target
LPDWORD lpdwEventMask UCHAR IsFastSer; // non-zero if interface is Fast serial
); UCHAR IsFT1248; // non-zero if interface is FT1248
UCHAR PowerSaveEnable; //
FTD2XX_API // Driver option
BOOL WINAPI FT_W32_SetCommState( UCHAR DriverType; // non-zero if interface is to use VCP drivers
FT_HANDLE ftHandle, } FT_EEPROM_232H, *PFT_EEPROM_232H;
LPFTDCB lpftDcb
);
// FT X Series EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
FTD2XX_API typedef struct ft_eeprom_x_series {
BOOL WINAPI FT_W32_SetCommTimeouts( // Common header
FT_HANDLE ftHandle, FT_EEPROM_HEADER common; // common elements for all device EEPROMs
FTTIMEOUTS *pTimeouts // Drive options
); UCHAR ACSlowSlew; // non-zero if AC bus pins have slow slew
UCHAR ACSchmittInput; // non-zero if AC bus pins are Schmitt input
FTD2XX_API UCHAR ACDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
BOOL WINAPI FT_W32_SetupComm( UCHAR ADSlowSlew; // non-zero if AD bus pins have slow slew
FT_HANDLE ftHandle, UCHAR ADSchmittInput; // non-zero if AD bus pins are Schmitt input
DWORD dwReadBufferSize, UCHAR ADDriveCurrent; // valid values are 4mA, 8mA, 12mA, 16mA
DWORD dwWriteBufferSize // CBUS options
); UCHAR Cbus0; // Cbus Mux control
UCHAR Cbus1; // Cbus Mux control
FTD2XX_API UCHAR Cbus2; // Cbus Mux control
BOOL WINAPI FT_W32_WaitCommEvent( UCHAR Cbus3; // Cbus Mux control
FT_HANDLE ftHandle, UCHAR Cbus4; // Cbus Mux control
PULONG pulEvent, UCHAR Cbus5; // Cbus Mux control
LPOVERLAPPED lpOverlapped UCHAR Cbus6; // Cbus Mux control
); // UART signal options
UCHAR InvertTXD; // non-zero if invert TXD
UCHAR InvertRXD; // non-zero if invert RXD
// UCHAR InvertRTS; // non-zero if invert RTS
// Device information UCHAR InvertCTS; // non-zero if invert CTS
// UCHAR InvertDTR; // non-zero if invert DTR
UCHAR InvertDSR; // non-zero if invert DSR
typedef struct _ft_device_list_info_node { UCHAR InvertDCD; // non-zero if invert DCD
ULONG Flags; UCHAR InvertRI; // non-zero if invert RI
ULONG Type; // Battery Charge Detect options
ULONG ID; UCHAR BCDEnable; // Enable Battery Charger Detection
DWORD LocId; UCHAR BCDForceCbusPWREN; // asserts the power enable signal on CBUS when charging port detected
char SerialNumber[16]; UCHAR BCDDisableSleep; // forces the device never to go into sleep mode
char Description[64]; // I2C options
FT_HANDLE ftHandle; WORD I2CSlaveAddress; // I2C slave device address
} FT_DEVICE_LIST_INFO_NODE; DWORD I2CDeviceId; // I2C device ID
UCHAR I2CDisableSchmitt; // Disable I2C Schmitt trigger
// Device information flags // FT1248 options
enum { UCHAR FT1248Cpol; // FT1248 clock polarity - clock idle high (1) or clock idle low (0)
FT_FLAGS_OPENED = 1, UCHAR FT1248Lsb; // FT1248 data is LSB (1) or MSB (0)
FT_FLAGS_HISPEED = 2 UCHAR FT1248FlowControl; // FT1248 flow control enable
}; // Hardware options
UCHAR RS485EchoSuppress; //
UCHAR PowerSaveEnable; //
FTD2XX_API // Driver option
FT_STATUS WINAPI FT_CreateDeviceInfoList( UCHAR DriverType; // non-zero if interface is to use VCP drivers
LPDWORD lpdwNumDevs } FT_EEPROM_X_SERIES, *PFT_EEPROM_X_SERIES;
);
FTD2XX_API // FT4222H EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
FT_STATUS WINAPI FT_GetDeviceInfoList( typedef struct ft_eeprom_4222h {
FT_DEVICE_LIST_INFO_NODE *pDest, // Common header
LPDWORD lpdwNumDevs FT_EEPROM_HEADER common; // common elements for all device EEPROMs
); CHAR Revision; // 'A', 'B', 'C', or 'D'.
UCHAR I2C_Slave_Address;
FTD2XX_API // Suspend
FT_STATUS WINAPI FT_GetDeviceInfoDetail( UCHAR SPISuspend; // 0 for "Disable SPI, tristate pins", 2 for "Keep SPI pin status", 3 for "Enable SPI pin control"
DWORD dwIndex, UCHAR SuspendOutPol; // 0 for negative, 1 for positive (not implemented on Rev A)
LPDWORD lpdwFlags, UCHAR EnableSuspendOut; // non-zero to enable (not implemented on Rev A)
LPDWORD lpdwType, // QSPI
LPDWORD lpdwID, UCHAR Clock_SlowSlew; // non-zero if clock pin has slow slew
LPDWORD lpdwLocId, UCHAR Clock_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
LPVOID lpSerialNumber, UCHAR IO0_SlowSlew; // non-zero if IO0 pin has slow slew
LPVOID lpDescription, UCHAR IO1_SlowSlew; // non-zero if IO1 pin has slow slew
FT_HANDLE *pftHandle UCHAR IO2_SlowSlew; // non-zero if IO2 pin has slow slew
); UCHAR IO3_SlowSlew; // non-zero if IO3 pin has slow slew
UCHAR IO_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR SlaveSelect_PullUp; // non-zero to enable pull up
// UCHAR SlaveSelect_PullDown; // non-zero to enable pull down
// Version information UCHAR SlaveSelect_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
// UCHAR SlaveSelect_SlowSlew; // non-zero if slave select pin has slow slew
UCHAR MISO_Suspend; // 2 for push-low, 3 for push high, 0 and 1 reserved
FTD2XX_API UCHAR SIMO_Suspend; // 2 for push-low, 3 for push high, 0 and 1 reserved
FT_STATUS WINAPI FT_GetDriverVersion( UCHAR IO2_IO3_Suspend; // 2 for push-low, 3 for push high, 0 and 1 reserved
FT_HANDLE ftHandle, UCHAR SlaveSelect_Suspend; // 0 for no-change (not implemented on Rev A), 2 for push-low, 3 for push high, 1 reserved
LPDWORD lpdwVersion // GPIO
); UCHAR GPIO0_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
UCHAR GPIO1_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
FTD2XX_API UCHAR GPIO2_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
FT_STATUS WINAPI FT_GetLibraryVersion( UCHAR GPIO3_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
LPDWORD lpdwVersion UCHAR GPIO0_SlowSlew; // non-zero if IO0 pin has slow slew
); UCHAR GPIO1_SlowSlew; // non-zero if IO0 pin has slow slew
UCHAR GPIO2_SlowSlew; // non-zero if IO0 pin has slow slew
UCHAR GPIO3_SlowSlew; // non-zero if IO0 pin has slow slew
FTD2XX_API UCHAR GPIO0_PullDown; // non-zero to enable pull down
FT_STATUS WINAPI FT_Rescan( UCHAR GPIO1_PullDown; // non-zero to enable pull down
void UCHAR GPIO2_PullDown; // non-zero to enable pull down
); UCHAR GPIO3_PullDown; // non-zero to enable pull down
UCHAR GPIO0_PullUp; // non-zero to enable pull up
FTD2XX_API UCHAR GPIO1_PullUp; // non-zero to enable pull up
FT_STATUS WINAPI FT_Reload( UCHAR GPIO2_PullUp; // non-zero to enable pull up
WORD wVid, UCHAR GPIO3_PullUp; // non-zero to enable pull up
WORD wPid UCHAR GPIO0_OpenDrain; // non-zero to enable open drain
); UCHAR GPIO1_OpenDrain; // non-zero to enable open drain
UCHAR GPIO2_OpenDrain; // non-zero to enable open drain
FTD2XX_API UCHAR GPIO3_OpenDrain; // non-zero to enable open drain
FT_STATUS WINAPI FT_GetComPortNumber( UCHAR GPIO0_Suspend; // 0 for no-change, 1 for input (not implemented on Rev A), 2 for push-low, 3 for push high
FT_HANDLE ftHandle, UCHAR GPIO1_Suspend; // 0 for no-change, 1 for input (not implemented on Rev A), 2 for push-low, 3 for push high
LPLONG lpdwComPortNumber UCHAR GPIO2_Suspend; // 0 for no-change, 1 for input (not implemented on Rev A), 2 for push-low, 3 for push high
); UCHAR GPIO3_Suspend; // 0 for no-change, 1 for input (not implemented on Rev A), 2 for push-low, 3 for push high
UCHAR FallingEdge; // non-zero to change GPIO on falling edge
// BCD
// UCHAR BCD_Disable; // non-zero to disable BCD
// FT232H additional EEPROM functions UCHAR BCD_OutputActiveLow; // non-zero to set BCD output active low
// UCHAR BCD_Drive; // valid values are 4mA, 8mA, 12mA, 16mA
} FT_EEPROM_4222H, *PFT_EEPROM_4222H;
FTD2XX_API
FT_STATUS WINAPI FT_EE_ReadConfig(
FT_HANDLE ftHandle, // Power Delivery structures for use with FT_EEPROM_Read and FT_EEPROM_Program
UCHAR ucAddress, // PDO Configuration structure, mA supported values 0 to 10230mA, mV supported values 0 to 51100mV
PUCHAR pucValue // This is part of the FT_EEPROM_PD structure.
); typedef struct ft_eeprom_PD_PDO_mv_ma {
USHORT PDO1ma; // PDO1 mA
FTD2XX_API USHORT PDO1mv; // PDO1 mV
FT_STATUS WINAPI FT_EE_WriteConfig( USHORT PDO2ma; // PDO2 mA
FT_HANDLE ftHandle, USHORT PDO2mv; // PDO2 mV
UCHAR ucAddress, USHORT PDO3ma; // PDO3 mA
UCHAR ucValue USHORT PDO3mv; // PDO3 mV
); USHORT PDO4ma; // PDO4 mA
USHORT PDO4mv; // PDO4 mV
FTD2XX_API USHORT PDO5ma; // PDO5 mA (FTx233HP only)
FT_STATUS WINAPI FT_EE_ReadECC( USHORT PDO5mv; // PDO5 mV (FTx233HP only)
FT_HANDLE ftHandle, USHORT PDO6ma; // PDO6 mA (FTx233HP only)
UCHAR ucOption, USHORT PDO6mv; // PDO6 mV (FTx233HP only)
LPWORD lpwValue USHORT PDO7ma; // PDO7 mA (FTx233HP only)
); USHORT PDO7mv; // PDO7 mV (FTx233HP only)
} FT_EEPROM_PD_PDO_mv_ma;
FTD2XX_API
FT_STATUS WINAPI FT_GetQueueStatusEx( // PD EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
FT_HANDLE ftHandle, // This is appended to the end of the base device structure. e_g.
DWORD *dwRxBytes // struct {
); // FT_EEPROM_xxx base;
// FT_EEPROM_PD pd;
// };
#ifdef __cplusplus // Device GPIO values are:
} // FTx233HP - 0 to 7, 15 for N/A
#endif // FTx232HP - 0 to 3, 15 for N/A
typedef struct ft_eeprom_pd {
// Configuration
#endif /* FTD2XX_H */ UCHAR srprs; // non-zero to enable Sink Request Power Role Swap
UCHAR sraprs; // non-zero to enable Sink Accept PR Swap
UCHAR srrprs; // non-zero to enable Source Request PR SWAP
UCHAR saprs; // non-zero to enable Source Accept PR SWAP
UCHAR vconns; // non-zero to enable vConn Swap
UCHAR passthru; // non-zero to enable Pass Through (FTx233HP only)
UCHAR extmcu; // non-zero to enable External MCU
UCHAR pd2en; // non-zero to enable PD2 (FTx233HP only)
UCHAR pd1autoclk; // non-zero to enable PD1 Auto Clock
UCHAR pd2autoclk; // non-zero to enable PD2 Auto Clock (FTx233HP only)
UCHAR useefuse; // non-zero to Use EFUSE
UCHAR extvconn; // non-zero to enable External vConn
// GPIO Configuration
UCHAR count; // GPIO Count, supported values are 0 to 7
UCHAR gpio1; // GPIO Number 1, supports device GPIO values
UCHAR gpio2; // GPIO Number 2, supports device GPIO values
UCHAR gpio3; // GPIO Number 3, supports device GPIO values
UCHAR gpio4; // GPIO Number 4, supports device GPIO values
UCHAR gpio5; // GPIO Number 5, supports device GPIO values (FTx233HP only)
UCHAR gpio6; // GPIO Number 6, supports device GPIO values (FTx233HP only)
UCHAR gpio7; // GPIO Number 7, supports device GPIO values (FTx233HP only)
UCHAR pd1lden; // PD1 Load Enable, supports device GPIO values
UCHAR pd2lden; // PD2 Load Enable, supports device GPIO values (FTx233HP only)
UCHAR dispin; // Discharge Pin, supports device GPIO values
UCHAR disenbm; // Discharge Enable BM, 0 for "Drive Hi", 1 for "Drive Low", 2 for "Input Mode", 3 for "Don't Care"
UCHAR disdisbm; // Discharge Disable BM, 0 for "Drive Hi", 1 for "Drive Low", 2 for "Input Mode", 3 for "Don't Care"
UCHAR ccselect; // CC Select Indicator, supports device GPIO values
// ISET Configuration
UCHAR iset1; // ISET1, supports device GPIO values
UCHAR iset2; // ISET2, supports device GPIO values
UCHAR iset3; // ISET3, supports device GPIO values
UCHAR extiset; // non-zero to enable EXTEND_ISET
UCHAR isetpd2; // non-zero to enable ISET_PD2
UCHAR iseten; // non-zero to set ISET_ENABLED
// BM Configuration, 0 for "Drive Hi", 1 for "Drive Low", 2 for "Input Mode", 3 for "Don't Care"
UCHAR PDO1_GPIO[7]; // PDO1 GPIO1 to GPIO7
UCHAR PDO2_GPIO[7]; // PDO2 GPIO1 to GPIO7
UCHAR PDO3_GPIO[7]; // PDO3 GPIO1 to GPIO7
UCHAR PDO4_GPIO[7]; // PDO4 GPIO1 to GPIO7
UCHAR PDO5_GPIO[7]; // PDO5 GPIO1 to GPIO7 (FTx233HP only)
UCHAR PDO6_GPIO[7]; // PDO6 GPIO1 to GPIO7 (FTx233HP only)
UCHAR PDO7_GPIO[7]; // PDO7 GPIO1 to GPIO7 (FTx233HP only)
UCHAR VSET0V_GPIO[7]; // PDO7 GPIO1 to GPIO7
UCHAR VSAFE5V_GPIO[7]; // PDO7 GPIO1 to GPIO7
FT_EEPROM_PD_PDO_mv_ma BM_PDO_Sink;
FT_EEPROM_PD_PDO_mv_ma BM_PDO_Source;
FT_EEPROM_PD_PDO_mv_ma BM_PDO_Sink_2; // (FTx233HP only)
// PD Timers
UCHAR srt; // Sender Response Timer
UCHAR hrt; // Hard Reset Timer
UCHAR sct; // Source Capability Timer
UCHAR dit; // Discover Identity Timer
USHORT srcrt; // Source Recover Timer
USHORT trt; // Transition Timer
USHORT sofft; // Source off timer
USHORT nrt; // No Response Timer
USHORT swct; // Sink Wait Capability Timer
USHORT snkrt; // Sink Request Timer
UCHAR dt; // Discharge Timer
UCHAR cnst; // Chunk not supported timer
USHORT it; // Idle Timer
// PD Control
UCHAR i2caddr; // I2C Address (hex)
UINT prou; // Power Reserved for OWN use
UINT trim1; // TRIM1
UINT trim2; // TRIM2
UCHAR extdc; // non-zero to enable ETERNAL_DC_POWER
} FT_EEPROM_PD, *PFT_EEPROM_PD;
// FT2233HP EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
// FT2232H with power delivery
typedef struct _ft_eeprom_2233hp
{
FT_EEPROM_2232H ft2232h;
FT_EEPROM_PD pd;
} FT_EEPROM_2233HP, *PFT_EEPROM_2233HP;
// FT4233HP EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
// FT4232H with power delivery
typedef struct _ft_eeprom_4233hp
{
FT_EEPROM_4232H ft4232h;
FT_EEPROM_PD pd;
} FT_EEPROM_4233HP, *PFT_EEPROM_4233HP;
// FT2232HP EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
// FT2232H with power delivery
typedef struct _ft_eeprom_2232hp
{
FT_EEPROM_2232H ft2232h;
FT_EEPROM_PD pd;
} FT_EEPROM_2232HP, *PFT_EEPROM_2232HP;
// FT4232HP EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
// FT4232H with power delivery
typedef struct _ft_eeprom_4232hp
{
FT_EEPROM_4232H ft4232h;
FT_EEPROM_PD pd;
} FT_EEPROM_4232HP, *PFT_EEPROM_4232HP;
// FT233HP EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
// FT233H with power delivery
typedef struct _ft_eeprom_233hp
{
FT_EEPROM_232H ft232h;
FT_EEPROM_PD pd;
} FT_EEPROM_233HP, *PFT_EEPROM_233HP;
// FT232HP EEPROM structure for use with FT_EEPROM_Read and FT_EEPROM_Program
// FT232H with power delivery
typedef struct _ft_eeprom_232hp
{
FT_EEPROM_232H ft232h;
FT_EEPROM_PD pd;
} FT_EEPROM_232HP, *PFT_EEPROM_232HP;
FTD2XX_API
FT_STATUS WINAPI FT_EEPROM_Read(
FT_HANDLE ftHandle,
void *eepromData,
DWORD eepromDataSize,
char *Manufacturer,
char *ManufacturerId,
char *Description,
char *SerialNumber
);
FTD2XX_API
FT_STATUS WINAPI FT_EEPROM_Program(
FT_HANDLE ftHandle,
void *eepromData,
DWORD eepromDataSize,
char *Manufacturer,
char *ManufacturerId,
char *Description,
char *SerialNumber
);
FTD2XX_API
FT_STATUS WINAPI FT_SetLatencyTimer(
FT_HANDLE ftHandle,
UCHAR ucLatency
);
FTD2XX_API
FT_STATUS WINAPI FT_GetLatencyTimer(
FT_HANDLE ftHandle,
PUCHAR pucLatency
);
FTD2XX_API
FT_STATUS WINAPI FT_SetBitMode(
FT_HANDLE ftHandle,
UCHAR ucMask,
UCHAR ucEnable
);
FTD2XX_API
FT_STATUS WINAPI FT_GetBitMode(
FT_HANDLE ftHandle,
PUCHAR pucMode
);
FTD2XX_API
FT_STATUS WINAPI FT_SetUSBParameters(
FT_HANDLE ftHandle,
ULONG ulInTransferSize,
ULONG ulOutTransferSize
);
FTD2XX_API
FT_STATUS WINAPI FT_SetDeadmanTimeout(
FT_HANDLE ftHandle,
ULONG ulDeadmanTimeout
);
#ifndef _WIN32
// Extra functions for non-Windows platforms to compensate
// for lack of .INF file to specify Vendor and Product IDs.
FTD2XX_API
FT_STATUS FT_SetVIDPID(
DWORD dwVID,
DWORD dwPID
);
FTD2XX_API
FT_STATUS FT_GetVIDPID(
DWORD * pdwVID,
DWORD * pdwPID
);
FTD2XX_API
FT_STATUS WINAPI FT_GetDeviceLocId(
FT_HANDLE ftHandle,
LPDWORD lpdwLocId
);
#endif // _WIN32
FTD2XX_API
FT_STATUS WINAPI FT_GetDeviceInfo(
FT_HANDLE ftHandle,
FT_DEVICE *lpftDevice,
LPDWORD lpdwID,
PCHAR SerialNumber,
PCHAR Description,
LPVOID Dummy
);
FTD2XX_API
FT_STATUS WINAPI FT_StopInTask(
FT_HANDLE ftHandle
);
FTD2XX_API
FT_STATUS WINAPI FT_RestartInTask(
FT_HANDLE ftHandle
);
FTD2XX_API
FT_STATUS WINAPI FT_SetResetPipeRetryCount(
FT_HANDLE ftHandle,
DWORD dwCount
);
FTD2XX_API
FT_STATUS WINAPI FT_ResetPort(
FT_HANDLE ftHandle
);
FTD2XX_API
FT_STATUS WINAPI FT_CyclePort(
FT_HANDLE ftHandle
);
//
// Win32-type functions
//
FTD2XX_API
FT_HANDLE WINAPI FT_W32_CreateFile(
LPCTSTR lpszName,
DWORD dwAccess,
DWORD dwShareMode,
LPSECURITY_ATTRIBUTES lpSecurityAttributes,
DWORD dwCreate,
DWORD dwAttrsAndFlags,
HANDLE hTemplate
);
FTD2XX_API
BOOL WINAPI FT_W32_CloseHandle(
FT_HANDLE ftHandle
);
FTD2XX_API
BOOL WINAPI FT_W32_ReadFile(
FT_HANDLE ftHandle,
LPVOID lpBuffer,
DWORD nBufferSize,
LPDWORD lpBytesReturned,
LPOVERLAPPED lpOverlapped
);
FTD2XX_API
BOOL WINAPI FT_W32_WriteFile(
FT_HANDLE ftHandle,
LPVOID lpBuffer,
DWORD nBufferSize,
LPDWORD lpBytesWritten,
LPOVERLAPPED lpOverlapped
);
FTD2XX_API
DWORD WINAPI FT_W32_GetLastError(
FT_HANDLE ftHandle
);
FTD2XX_API
BOOL WINAPI FT_W32_GetOverlappedResult(
FT_HANDLE ftHandle,
LPOVERLAPPED lpOverlapped,
LPDWORD lpdwBytesTransferred,
BOOL bWait
);
FTD2XX_API
BOOL WINAPI FT_W32_CancelIo(
FT_HANDLE ftHandle
);
//
// Win32 COMM API type functions
//
typedef struct _FTCOMSTAT {
DWORD fCtsHold : 1;
DWORD fDsrHold : 1;
DWORD fRlsdHold : 1;
DWORD fXoffHold : 1;
DWORD fXoffSent : 1;
DWORD fEof : 1;
DWORD fTxim : 1;
DWORD fReserved : 25;
DWORD cbInQue;
DWORD cbOutQue;
} FTCOMSTAT, *LPFTCOMSTAT;
typedef struct _FTDCB {
DWORD DCBlength; /* sizeof(FTDCB) */
DWORD BaudRate; /* Baudrate at which running */
DWORD fBinary : 1; /* Binary Mode (skip EOF check) */
DWORD fParity : 1; /* Enable parity checking */
DWORD fOutxCtsFlow : 1; /* CTS handshaking on output */
DWORD fOutxDsrFlow : 1; /* DSR handshaking on output */
DWORD fDtrControl : 2; /* DTR Flow control */
DWORD fDsrSensitivity : 1; /* DSR Sensitivity */
DWORD fTXContinueOnXoff : 1; /* Continue TX when Xoff sent */
DWORD fOutX : 1; /* Enable output X-ON/X-OFF */
DWORD fInX : 1; /* Enable input X-ON/X-OFF */
DWORD fErrorChar : 1; /* Enable Err Replacement */
DWORD fNull : 1; /* Enable Null stripping */
DWORD fRtsControl : 2; /* Rts Flow control */
DWORD fAbortOnError : 1; /* Abort all reads and writes on Error */
DWORD fDummy2 : 17; /* Reserved */
WORD wReserved; /* Not currently used */
WORD XonLim; /* Transmit X-ON threshold */
WORD XoffLim; /* Transmit X-OFF threshold */
BYTE ByteSize; /* Number of bits/byte, 4-8 */
BYTE Parity; /* 0-4=None,Odd,Even,Mark,Space */
BYTE StopBits; /* FT_STOP_BITS_1 or FT_STOP_BITS_2 */
char XonChar; /* Tx and Rx X-ON character */
char XoffChar; /* Tx and Rx X-OFF character */
char ErrorChar; /* Error replacement char */
char EofChar; /* End of Input character */
char EvtChar; /* Received Event character */
WORD wReserved1; /* Fill for now. */
} FTDCB, *LPFTDCB;
typedef struct _FTTIMEOUTS {
DWORD ReadIntervalTimeout; /* Maximum time between read chars. */
DWORD ReadTotalTimeoutMultiplier; /* Multiplier of characters. */
DWORD ReadTotalTimeoutConstant; /* Constant in milliseconds. */
DWORD WriteTotalTimeoutMultiplier; /* Multiplier of characters. */
DWORD WriteTotalTimeoutConstant; /* Constant in milliseconds. */
} FTTIMEOUTS, *LPFTTIMEOUTS;
FTD2XX_API
BOOL WINAPI FT_W32_ClearCommBreak(
FT_HANDLE ftHandle
);
FTD2XX_API
BOOL WINAPI FT_W32_ClearCommError(
FT_HANDLE ftHandle,
LPDWORD lpdwErrors,
LPFTCOMSTAT lpftComstat
);
FTD2XX_API
BOOL WINAPI FT_W32_EscapeCommFunction(
FT_HANDLE ftHandle,
DWORD dwFunc
);
FTD2XX_API
BOOL WINAPI FT_W32_GetCommModemStatus(
FT_HANDLE ftHandle,
LPDWORD lpdwModemStatus
);
FTD2XX_API
BOOL WINAPI FT_W32_GetCommState(
FT_HANDLE ftHandle,
LPFTDCB lpftDcb
);
FTD2XX_API
BOOL WINAPI FT_W32_GetCommTimeouts(
FT_HANDLE ftHandle,
FTTIMEOUTS *pTimeouts
);
FTD2XX_API
BOOL WINAPI FT_W32_PurgeComm(
FT_HANDLE ftHandle,
DWORD dwMask
);
FTD2XX_API
BOOL WINAPI FT_W32_SetCommBreak(
FT_HANDLE ftHandle
);
FTD2XX_API
BOOL WINAPI FT_W32_SetCommMask(
FT_HANDLE ftHandle,
ULONG ulEventMask
);
FTD2XX_API
BOOL WINAPI FT_W32_GetCommMask(
FT_HANDLE ftHandle,
LPDWORD lpdwEventMask
);
FTD2XX_API
BOOL WINAPI FT_W32_SetCommState(
FT_HANDLE ftHandle,
LPFTDCB lpftDcb
);
FTD2XX_API
BOOL WINAPI FT_W32_SetCommTimeouts(
FT_HANDLE ftHandle,
FTTIMEOUTS *pTimeouts
);
FTD2XX_API
BOOL WINAPI FT_W32_SetupComm(
FT_HANDLE ftHandle,
DWORD dwReadBufferSize,
DWORD dwWriteBufferSize
);
FTD2XX_API
BOOL WINAPI FT_W32_WaitCommEvent(
FT_HANDLE ftHandle,
PULONG pulEvent,
LPOVERLAPPED lpOverlapped
);
//
// Device information
//
typedef struct _ft_device_list_info_node {
ULONG Flags;
ULONG Type;
ULONG ID;
DWORD LocId;
char SerialNumber[16];
char Description[64];
FT_HANDLE ftHandle;
} FT_DEVICE_LIST_INFO_NODE;
// Device information flags
enum {
FT_FLAGS_OPENED = 1,
FT_FLAGS_HISPEED = 2
};
FTD2XX_API
FT_STATUS WINAPI FT_CreateDeviceInfoList(
LPDWORD lpdwNumDevs
);
FTD2XX_API
FT_STATUS WINAPI FT_GetDeviceInfoList(
FT_DEVICE_LIST_INFO_NODE *pDest,
LPDWORD lpdwNumDevs
);
FTD2XX_API
FT_STATUS WINAPI FT_GetDeviceInfoDetail(
DWORD dwIndex,
LPDWORD lpdwFlags,
LPDWORD lpdwType,
LPDWORD lpdwID,
LPDWORD lpdwLocId,
LPVOID lpSerialNumber,
LPVOID lpDescription,
FT_HANDLE *pftHandle
);
//
// Version information
//
FTD2XX_API
FT_STATUS WINAPI FT_GetDriverVersion(
FT_HANDLE ftHandle,
LPDWORD lpdwVersion
);
FTD2XX_API
FT_STATUS WINAPI FT_GetLibraryVersion(
LPDWORD lpdwVersion
);
FTD2XX_API
FT_STATUS WINAPI FT_Rescan(
void
);
FTD2XX_API
FT_STATUS WINAPI FT_Reload(
WORD wVid,
WORD wPid
);
FTD2XX_API
FT_STATUS WINAPI FT_GetComPortNumber(
FT_HANDLE ftHandle,
LPLONG lpdwComPortNumber
);
//
// FT232H additional EEPROM functions
//
FTD2XX_API
FT_STATUS WINAPI FT_EE_ReadConfig(
FT_HANDLE ftHandle,
UCHAR ucAddress,
PUCHAR pucValue
);
FTD2XX_API
FT_STATUS WINAPI FT_EE_WriteConfig(
FT_HANDLE ftHandle,
UCHAR ucAddress,
UCHAR ucValue
);
FTD2XX_API
FT_STATUS WINAPI FT_EE_ReadECC(
FT_HANDLE ftHandle,
UCHAR ucOption,
LPWORD lpwValue
);
FTD2XX_API
FT_STATUS WINAPI FT_GetQueueStatusEx(
FT_HANDLE ftHandle,
DWORD *dwRxBytes
);
FTD2XX_API
FT_STATUS WINAPI FT_ComPortIdle(
FT_HANDLE ftHandle
);
FTD2XX_API
FT_STATUS WINAPI FT_ComPortCancelIdle(
FT_HANDLE ftHandle
);
FTD2XX_API
FT_STATUS WINAPI FT_VendorCmdGet(
FT_HANDLE ftHandle,
UCHAR Request,
UCHAR *Buf,
USHORT Len
);
FTD2XX_API
FT_STATUS WINAPI FT_VendorCmdSet(
FT_HANDLE ftHandle,
UCHAR Request,
UCHAR *Buf,
USHORT Len
);
FTD2XX_API
FT_STATUS WINAPI FT_VendorCmdGetEx(
FT_HANDLE ftHandle,
USHORT wValue,
UCHAR *Buf,
USHORT Len
);
FTD2XX_API
FT_STATUS WINAPI FT_VendorCmdSetEx(
FT_HANDLE ftHandle,
USHORT wValue,
UCHAR *Buf,
USHORT Len
);
#ifdef __cplusplus
}
#endif
#endif /* FTD2XX_H */

View File

@ -1,153 +1,565 @@
; FTDIBUS.INF ; FTDIBUS.INF
; ;
; Copyright © 2000-2011 Future Technology Devices International Limited ; Copyright © 2000-2021 Future Technology Devices International Limited
; ;
; USB serial converter driver installation file for Windows 2000, XP, Server 2003, Vista, Server 2008, ; USB serial converter driver installation file for Windows 7, Windows 8, Windows 8.1, Windows 10,
; Windows 7 and Server 2008 R2 (x86 and x64). ; Server 2008 R2, Server 2012 R2 and Server 2016.
; ;
; ;
; THIS SOFTWARE IS PROVIDED BY FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED ``AS IS'' AND ANY EXPRESS ; IMPORTANT NOTICE: PLEASE READ CAREFULLY BEFORE INSTALLING THE RELEVANT
; OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ; SOFTWARE: This licence agreement (Licence) is a legal agreement between you (Licensee or
; FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED ; you) and Future Technology Devices International Limited of 2 Seaward Place, Centurion Business
; BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, ; Park, Glasgow G41 1HH, Scotland (UK Company Number SC136640) (Licensor or we) for use of
; BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS ; driver software provided by the Licensor(Software).
; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ;
; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF ; BY INSTALLING OR USING THIS SOFTWARE YOU AGREE TO THE TERMS OF THIS LICENCE
; THE POSSIBILITY OF SUCH DAMAGE. ; WHICH WILL BIND YOU. IF YOU DO NOT AGREE TO THE TERMS OF THIS LICENCE, WE ARE
; UNWILLING TO LICENSE THE SOFTWARE TO YOU AND YOU MUST DISCONTINUE
; FTDI DRIVERS MAY BE USED ONLY IN CONJUNCTION WITH PRODUCTS BASED ON FTDI PARTS. ; INSTALLATION OF THE SOFTWARE NOW.
;
; FTDI DRIVERS MAY BE DISTRIBUTED IN ANY FORM AS LONG AS LICENSE INFORMATION IS NOT MODIFIED. ; 1. GRANT AND SCOPE OF LICENCE
;
; IF A CUSTOM VENDOR ID AND/OR PRODUCT ID OR DESCRIPTION STRING ARE USED, IT IS THE RESPONSIBILITY OF ; 1.1 In consideration of you agreeing to abide by the terms of this Licence, the Licensor hereby
; THE PRODUCT MANUFACTURER TO MAINTAIN ANY CHANGES AND SUBSEQUENT WHQL RE-CERTIFICATION AS A RESULT OF ; grants to you a non-exclusive, non-transferable, royalty free licence to use the Software on
; MAKING THESE CHANGES. ; the terms of this Licence.
; ;
; 1.2 In this Licence a "Genuine FTDI Component" means an item of hardware that was
; manufactured for, and sold by, the Licensor or a member of the Licensor's group of
[Version] ; companies. It does not include any counterfeit or fake products.
Signature="$Windows NT$" ;
DriverPackageType=PlugAndPlay ; 1.3 If you are a manufacturer of a device that includes a Genuine FTDI Component (each a
DriverPackageDisplayName=%DESC% ; "Device") then you may install the Software onto that device. If you are a seller or distributor
Class=USB ; of a Device then you may distribute the Software with the Device. If you are a user of a
ClassGUID={36fc9e60-c465-11cf-8056-444553540000} ; Device then you may install the Software on the Device, or onto a computer system in order
Provider=%FTDI% ; to use the Device.
CatalogFile=ftdibus.cat ;
DriverVer=03/18/2011,2.08.14 ; 1.4 In each of those cases you may:
;
[SourceDisksNames] ; 1.4.1 install and use the Software for your purposes only; and
1=%DriversDisk%,,, ;
; 1.4.2 only use the Software in conjunction with products based on and/or incorporating a
[SourceDisksFiles] ; Genuine FTDI Component.
ftdibus.sys = 1,i386 ;
ftbusui.dll = 1,i386 ; 1.5 The Software will not function properly on or with a component that is not a Genuine FTDI
ftd2xx.dll = 1,i386 ; Component. Use of the Software as a driver for, or installation of the Software onto, a
FTLang.Dll = 1,i386 ; component that is not a Genuine FTDI Component, including without limitation counterfeit
; components, MAY IRRETRIEVABLY DAMAGE THAT COMPONENT. It is the Licensee's
[SourceDisksFiles.amd64] ; responsibility to make sure that all chips it installs the Software on, or uses the Software as a
ftdibus.sys = 1,amd64 ; driver for, are Genuine FTDI Components. If in doubt then contact the Licensor.
ftbusui.dll = 1,amd64 ;
ftd2xx64.dll = 1,amd64 ; 2. If a custom vendor ID and/or product ID or description string are used, it is the responsibility of
ftd2xx.dll = 1,i386 ; the product manufacturer to maintain any changes and subsequent WHQL re-certification as
FTLang.Dll = 1,amd64 ; a result of making these changes.
;
[DestinationDirs] ; 3. LICENSEE'S UNDERTAKINGS
FtdiBus.NT.Copy = 10,system32\drivers ;
FtdiBus.NT.Copy2 = 10,system32 ; 3.1 Except as expressly set out in this Licence or as permitted by any local law, you undertake:
FtdiBus.NTamd64.Copy = 10,system32\drivers ;
FtdiBus.NTamd64.Copy2 = 10,system32 ; 3.1.1 not to copy the Software, except where such copying is incidental to normal use of
FtdiBus.NTamd64.Copy3 = 10,syswow64 ; the Software or where it is necessary for the purpose of back-up or operational
; security;
;
[Manufacturer] ; 3.1.2 not to rent, lease, sub-license, loan, translate, merge, adapt, vary or modify the
%Ftdi%=FtdiHw,NTamd64 ; Software or any part of it;
;
[FtdiHw] ; 3.1.3 not to make alterations to, or modifications of, the whole or any part of the Software
%USB\VID_0403&PID_6001.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6001 ; nor permit the Software or any part of it to be combined with, or become
%USB\VID_0403&PID_6010&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6010&MI_00 ; incorporated in, any other programs;
%USB\VID_0403&PID_6010&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6010&MI_01 ;
%USB\VID_0403&PID_6011&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_00 ; 3.1.4 not to disassemble, de-compile, reverse engineer or create derivative works based
%USB\VID_0403&PID_6011&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_01 ; on the whole or any part of the Software;
%USB\VID_0403&PID_6011&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_02 ;
%USB\VID_0403&PID_6011&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_03 ; 3.1.5 to keep all copies of the Software secure;
%USB\VID_0403&PID_6014.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6014 ;
; 3.1.6 to include the copyright notice of the Licensor on all entire and partial copies of the
[FtdiHw.NTamd64] ; Software in any form; and
%USB\VID_0403&PID_6001.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6001 ;
%USB\VID_0403&PID_6010&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6010&MI_00 ; 3.1.7 not to provide, or otherwise make available, the Software in any form, in whole or in
%USB\VID_0403&PID_6010&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6010&MI_01 ; part (including, but not limited to, program listings, object and source program
%USB\VID_0403&PID_6011&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_00 ; listings, object code and source code) to any person.
%USB\VID_0403&PID_6011&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_01 ;
%USB\VID_0403&PID_6011&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_02 ; 4. INTELLECTUAL PROPERTY RIGHTS
%USB\VID_0403&PID_6011&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_03 ;
%USB\VID_0403&PID_6014.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6014 ; 4.1 You acknowledge that all intellectual property rights in the Software throughout the world
; belong to the Licensor, that rights in the Software are licensed (not sold) to you, and that you
[ControlFlags] ; have no rights in, or to, the Software other than the right to use them in accordance with the
ExcludeFromSelect=* ; terms of this Licence.
;
[FtdiBus.NT] ; 5. WARRANTY
CopyFiles=FtdiBus.NT.Copy,FtdiBus.NT.Copy2 ;
AddReg=FtdiBus.NT.AddReg ; 5.1 To the maximum extent permitted by applicable law, the software is provided "as is".
;
[FtdiBus.NTamd64] ; 5.2 All implied warranties, implied conditions and/or implied licences are excluded from this
CopyFiles=FtdiBus.NTamd64.Copy,FtdiBus.NTamd64.Copy2,FtdiBus.NTamd64.Copy3 ; Licence, including but not limited to implied warranties of quality and/or fitness for purpose (in
AddReg=FtdiBus.NT.AddReg ; all cases) to the fullest extent permitted by law.
;
[FtdiBus.NT.Services] ; 5.3 You acknowledge that the Software has not been developed to meet your individual
AddService = FTDIBUS, 0x00000002, FtdiBus.NT.AddService ; requirements and that the Software may not be uninterrupted or free of bugs or errors.
;
[FtdiBus.NTamd64.Services] ; 6. LICENSOR'S LIABILITY
AddService = FTDIBUS, 0x00000002, FtdiBus.NT.AddService ;
; 6.1 To the maximum extent permitted by applicable law, in no event shall the Licensor be liable
[FtdiBus.NT.AddService] ; for any:
DisplayName = %SvcDesc% ;
ServiceType = 1 ; SERVICE_KERNEL_DRIVER ; 6.1.1 special loss or damage;
StartType = 3 ; SERVICE_DEMAND_START ;
ErrorControl = 1 ; SERVICE_ERROR_NORMAL ; 6.1.2 incidental loss or damage;
ServiceBinary = %10%\system32\drivers\ftdibus.sys ;
LoadOrderGroup = Base ; 6.1.3 indirect or consequential loss or damage:
AddReg = FtdiBus.NT.AddService.AddReg ;
; 6.1.4 loss of income;
[FtdiBus.NT.AddReg] ;
HKR,,DevLoader,,*ntkern ; 6.1.5 loss of business;
HKR,,NTMPDriver,,ftdibus.sys ;
HKR,,EnumPropPages32,,"ftbusui.dll,FTBUSUIPropPageProvider" ; 6.1.6 loss of profits;
;
[FtdiBus.NT.AddService.AddReg] ; 6.1.7 loss of revenue;
;HKR,Parameters,"LocIds",1,31,00,00,00,32,00,00,00,00 ;
;HKR,Parameters,"RetryResetCount",0x10001,50 ; 6.1.8 loss of contracts;
;
; 6.1.9 business interruption;
[FtdiBus.NT.Copy] ;
ftdibus.sys ; 6.1.10 loss of the use of money or anticipated savings;
;
[FtdiBus.NT.Copy2] ; 6.1.11 loss of information;
ftbusui.dll ;
ftd2xx.dll ; 6.1.12 loss of opportunity;
FTLang.dll ;
; 6.1.13 loss of goodwill or reputation; and/or
[FtdiBus.NTamd64.Copy] ;
ftdibus.sys ; 6.1.14 loss of, damage to or corruption of data;
;
[FtdiBus.NTamd64.Copy2] ; (in each case) of any kind howsoever arising and whether caused by delict (including
ftbusui.dll ; negligence), breach of contract or otherwise.
ftd2xx.dll,ftd2xx64.dll ;
FTLang.dll ; 6.2 FTDI's total liability to you in relation to the Software shall not exceed 500 US Dollars.
;
[FtdiBus.NTamd64.Copy3] ; 6.3 Nothing in this Licence limits or excludes liability for death or personal injury or for fraud.
ftd2xx.dll ;
; 7. TERMINATION
[Strings] ;
Ftdi="FTDI" ; 7.1 The Licensor may terminate this Licence immediately if:
DESC="CDM Driver Package - Bus/D2XX Driver" ;
DriversDisk="FTDI USB Drivers Disk" ; 7.1.1 you fail to comply with any of the terms and conditions of the Licence; or
USB\VID_0403&PID_6001.DeviceDesc="USB Serial Converter" ;
USB\VID_0403&PID_6010&MI_00.DeviceDesc="USB Serial Converter A" ; 7.1.2 you commence or participate in any legal proceedings against the Licensor.
USB\VID_0403&PID_6010&MI_01.DeviceDesc="USB Serial Converter B" ;
USB\VID_0403&PID_6011&MI_00.DeviceDesc="USB Serial Converter A" ; 7.2 Upon termination:
USB\VID_0403&PID_6011&MI_01.DeviceDesc="USB Serial Converter B" ;
USB\VID_0403&PID_6011&MI_02.DeviceDesc="USB Serial Converter C" ; 7.2.1 all rights granted to you under this Licence shall cease;
USB\VID_0403&PID_6011&MI_03.DeviceDesc="USB Serial Converter D" ;
USB\VID_0403&PID_6014.DeviceDesc="USB Serial Converter" ; 7.2.2 you must cease all activities authorised by this Licence; and
SvcDesc="USB Serial Converter Driver" ;
ClassName="USB" ; 7.2.3 you must immediately delete or remove the Software from all computer equipment
; in your possession and immediately destroy all copies of the Software then in your
; possession, custody or control.
;
; 8. TRANSFER OF RIGHTS AND OBLIGATIONS
;
; 8.1 You may not transfer, assign, charge or otherwise dispose of this Licence, or any of your
; rights or obligations arising under it.
;
; 8.2 The Licensor may transfer, assign, charge, sub-contract or otherwise dispose of this Licence,
; or any of his rights or obligations arising under it, at any time during the term of the Licence.
;
; 9. WAIVER
;
; 9.1 If the Licensor fails, at any time during the term of this Licence, to insist on strict performance
; of any of your obligations under this Licence, or if the Licensor fails to exercise any of the
; rights or remedies to which he is entitled under this Licence, this shall not constitute a waiver
; of such rights or remedies and shall not relieve you from compliance with such obligations.
;
; 9.2 A waiver by the Licensor of any default shall not constitute a waiver of any subsequent
; default.
;
; 9.3 No waiver by the Licensor of any of these terms and conditions shall be effective unless it is
; expressly stated to be a waiver and is communicated to you in writing.
;
; 10. SEVERABILITY
;
; If any of the terms of this Licence are determined by any competent authority to be invalid,
; unlawful or unenforceable to any extent, such term, condition or provision will to that extent be
; severed from the remaining terms, conditions and provisions which will continue to be valid to
; the fullest extent permitted by law.
;
; 11. ENTIRE AGREEMENT
;
; 11.1 This Licence constitutes the whole agreement between us and supersedes any previous
; arrangement, understanding or agreement between us, relating to the licensing of the
; Software.
;
; 11.2 Each party acknowledges that in entering into this Licence it does not rely on any statement,
; representation, warranty or understanding other than those expressly set out in this Licence.
; Each party agrees that it will have no remedy in respect of any statement, representation,
; warranty or understanding that is not expressly set out in this Licence. Each party agrees that
; its only remedy in respect of those representations, statements, assurances and warranties
; that are set out in this Licence will be for breach of contract in accordance with the terms of
; this Licence.
;
; 11.3 The parties agree that nothing in this Licence will limit or exclude any liability they may have
; for fraud.
;
; 12. MISCELLANEOUS
;
; 12.1 This Licence does not create a partnership or joint venture between the parties to it, nor
; authorise a party to act as agent for the other.
;
; 12.2 This Licence does not create any legal rights enforceable by any third party.
;
; 12.3 This Licence may only be varied by express written legal agreement between the parties.
;
; 13. LAW AND JURISDICTION
;
; This Licence, its subject matter or its formation (including non-contractual disputes or claims)
; shall be governed by and construed in accordance with Scots law and submitted to the non-
; exclusive jurisdiction of the Scottish courts.
;
[Version]
Signature="$Windows NT$"
DriverPackageType=PlugAndPlay
DriverPackageDisplayName=%DESC%
Class=USB
ClassGUID={36fc9e60-c465-11cf-8056-444553540000}
Provider=%FTDI%
CatalogFile=ftdibus.cat
DriverVer=07/05/2021,2.12.36.4
[SourceDisksNames]
1=%DriversDisk%,,,
[SourceDisksFiles]
ftdibus.sys = 1,i386
ftbusui.dll = 1,i386
ftd2xx.dll = 1,i386
FTLang.Dll = 1,i386
[SourceDisksFiles.amd64]
ftdibus.sys = 1,amd64
ftbusui.dll = 1,amd64
ftd2xx64.dll = 1,amd64
ftd2xx.dll = 1,i386
FTLang.Dll = 1,amd64
[DestinationDirs]
FtdiBus.NT.Copy = 10,system32\drivers
FtdiBus.NT.Copy2 = 10,system32
FtdiBus.NTamd64.Copy = 10,system32\drivers
FtdiBus.NTamd64.Copy2 = 10,system32
FtdiBus.NTamd64.Copy3 = 10,syswow64
[Manufacturer]
%Ftdi%=FtdiHw,NTamd64
[FtdiHw]
%USB\VID_0403&PID_6001.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6001
%USB\VID_0403&PID_6010&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6010&MI_00
%USB\VID_0403&PID_6010&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6010&MI_01
%USB\VID_0403&PID_6011&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_00
%USB\VID_0403&PID_6011&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_01
%USB\VID_0403&PID_6011&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_02
%USB\VID_0403&PID_6011&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6011&MI_03
%USB\VID_0403&PID_6014.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6014
%USB\VID_0403&PID_6015.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6015
%USB\VID_0403&PID_601B&REV_1400.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601B&REV_1400
%USB\VID_0403&PID_601B&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601B&MI_00
%USB\VID_0403&PID_601B&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601B&MI_01
%USB\VID_0403&PID_601B&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601B&MI_02
%USB\VID_0403&PID_601B&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601B&MI_03
%USB\VID_0403&PID_601C&REV_1700.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601C&REV_1700
%USB\VID_0403&PID_601C&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601C&MI_00
%USB\VID_0403&PID_601C&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601C&MI_01
%USB\VID_0403&PID_601C&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601C&MI_02
%USB\VID_0403&PID_601C&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_601C&MI_03
%USB\VID_0403&PID_0FEC.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_0FEC
%USB\VID_0403&PID_6031&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6031&MI_00
%USB\VID_0403&PID_6031&REV_2400.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6031&REV_2400
%USB\VID_0403&PID_6032&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6032&MI_00
%USB\VID_0403&PID_6032&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6032&MI_01
%USB\VID_0403&PID_6033&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6033&MI_00
%USB\VID_0403&PID_6033&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6033&MI_01
%USB\VID_0403&PID_6033&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6033&MI_02
%USB\VID_0403&PID_6034&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6034&MI_00
%USB\VID_0403&PID_6034&REV_2500.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6034&REV_2500
%USB\VID_0403&PID_6035&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6035&MI_00
%USB\VID_0403&PID_6035&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6035&MI_01
%USB\VID_0403&PID_6036&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6036&MI_00
%USB\VID_0403&PID_6036&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6036&MI_01
%USB\VID_0403&PID_6036&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6036&MI_02
%USB\VID_0403&PID_6037&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6037&MI_00
%USB\VID_0403&PID_6037&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6037&MI_01
%USB\VID_0403&PID_6037&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6037&MI_02
%USB\VID_0403&PID_6037&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6037&MI_03
%USB\VID_0403&PID_6038&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6038&MI_00
%USB\VID_0403&PID_6038&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6038&MI_01
%USB\VID_0403&PID_6038&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6038&MI_02
%USB\VID_0403&PID_6038&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6038&MI_03
%USB\VID_0403&PID_6038&MI_04.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6038&MI_04
%USB\VID_0403&PID_6039&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6039&MI_00
%USB\VID_0403&PID_6039&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6039&MI_01
%USB\VID_0403&PID_6039&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6039&MI_02
%USB\VID_0403&PID_6039&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6039&MI_03
%USB\VID_0403&PID_6039&MI_04.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6039&MI_04
%USB\VID_0403&PID_6039&MI_05.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6039&MI_05
%USB\VID_0403&PID_603A&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_00
%USB\VID_0403&PID_603A&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_01
%USB\VID_0403&PID_603A&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_02
%USB\VID_0403&PID_603A&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_03
%USB\VID_0403&PID_603A&MI_04.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_04
%USB\VID_0403&PID_603A&MI_05.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_05
%USB\VID_0403&PID_603A&MI_06.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603A&MI_06
%USB\VID_0403&PID_603E.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_603E
%USB\VID_0403&PID_6040&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6040&MI_00
%USB\VID_0403&PID_6040&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6040&MI_01
%USB\VID_0403&PID_6041&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6041&MI_00
%USB\VID_0403&PID_6041&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6041&MI_01
%USB\VID_0403&PID_6041&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6041&MI_02
%USB\VID_0403&PID_6041&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6041&MI_03
%USB\VID_0403&PID_6042&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6042&MI_00
%USB\VID_0403&PID_6042&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6042&MI_01
%USB\VID_0403&PID_6043&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6043&MI_00
%USB\VID_0403&PID_6043&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6043&MI_01
%USB\VID_0403&PID_6043&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6043&MI_02
%USB\VID_0403&PID_6043&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6043&MI_03
%USB\VID_0403&PID_6044.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6044
%USB\VID_0403&PID_6045.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6045
%USB\VID_0403&PID_6047&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6047&MI_00
%USB\VID_0403&PID_6047&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6047&MI_01
%USB\VID_0403&PID_6048&MI_00.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6048&MI_00
%USB\VID_0403&PID_6048&MI_01.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6048&MI_01
%USB\VID_0403&PID_6048&MI_02.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6048&MI_02
%USB\VID_0403&PID_6048&MI_03.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6048&MI_03
%USB\VID_0403&PID_6049.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_6049
%USB\VID_0403&PID_0000.DeviceDesc%=FtdiBus.NT,USB\VID_0403&PID_0000
[FtdiHw.NTamd64]
%USB\VID_0403&PID_6001.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6001
%USB\VID_0403&PID_6010&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6010&MI_00
%USB\VID_0403&PID_6010&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6010&MI_01
%USB\VID_0403&PID_6011&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_00
%USB\VID_0403&PID_6011&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_01
%USB\VID_0403&PID_6011&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_02
%USB\VID_0403&PID_6011&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6011&MI_03
%USB\VID_0403&PID_6014.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6014
%USB\VID_0403&PID_6015.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6015
%USB\VID_0403&PID_601B&REV_1400.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601B&REV_1400
%USB\VID_0403&PID_601B&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601B&MI_00
%USB\VID_0403&PID_601B&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601B&MI_01
%USB\VID_0403&PID_601B&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601B&MI_02
%USB\VID_0403&PID_601B&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601B&MI_03
%USB\VID_0403&PID_601C&REV_1700.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601C&REV_1700
%USB\VID_0403&PID_601C&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601C&MI_00
%USB\VID_0403&PID_601C&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601C&MI_01
%USB\VID_0403&PID_601C&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601C&MI_02
%USB\VID_0403&PID_601C&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_601C&MI_03
%USB\VID_0403&PID_0FEC.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_0FEC
%USB\VID_0403&PID_6031&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6031&MI_00
%USB\VID_0403&PID_6031&REV_2400.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6031&REV_2400
%USB\VID_0403&PID_6032&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6032&MI_00
%USB\VID_0403&PID_6032&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6032&MI_01
%USB\VID_0403&PID_6033&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6033&MI_00
%USB\VID_0403&PID_6033&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6033&MI_01
%USB\VID_0403&PID_6033&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6033&MI_02
%USB\VID_0403&PID_6034&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6034&MI_00
%USB\VID_0403&PID_6034&REV_2500.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6035&REV_2500
%USB\VID_0403&PID_6035&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6035&MI_00
%USB\VID_0403&PID_6035&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6035&MI_01
%USB\VID_0403&PID_6036&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6036&MI_00
%USB\VID_0403&PID_6036&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6036&MI_01
%USB\VID_0403&PID_6036&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6036&MI_02
%USB\VID_0403&PID_6037&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6037&MI_00
%USB\VID_0403&PID_6037&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6037&MI_01
%USB\VID_0403&PID_6037&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6037&MI_02
%USB\VID_0403&PID_6037&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6037&MI_03
%USB\VID_0403&PID_6038&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6038&MI_00
%USB\VID_0403&PID_6038&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6038&MI_01
%USB\VID_0403&PID_6038&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6038&MI_02
%USB\VID_0403&PID_6038&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6038&MI_03
%USB\VID_0403&PID_6038&MI_04.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6038&MI_04
%USB\VID_0403&PID_6039&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6039&MI_00
%USB\VID_0403&PID_6039&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6039&MI_01
%USB\VID_0403&PID_6039&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6039&MI_02
%USB\VID_0403&PID_6039&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6039&MI_03
%USB\VID_0403&PID_6039&MI_04.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6039&MI_04
%USB\VID_0403&PID_6039&MI_05.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6039&MI_05
%USB\VID_0403&PID_603A&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_00
%USB\VID_0403&PID_603A&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_01
%USB\VID_0403&PID_603A&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_02
%USB\VID_0403&PID_603A&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_03
%USB\VID_0403&PID_603A&MI_04.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_04
%USB\VID_0403&PID_603A&MI_05.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_05
%USB\VID_0403&PID_603A&MI_06.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603A&MI_06
%USB\VID_0403&PID_603E.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_603E
%USB\VID_0403&PID_6040&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6040&MI_00
%USB\VID_0403&PID_6040&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6040&MI_01
%USB\VID_0403&PID_6041&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6041&MI_00
%USB\VID_0403&PID_6041&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6041&MI_01
%USB\VID_0403&PID_6041&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6041&MI_02
%USB\VID_0403&PID_6041&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6041&MI_03
%USB\VID_0403&PID_6042&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6042&MI_00
%USB\VID_0403&PID_6042&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6042&MI_01
%USB\VID_0403&PID_6043&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6043&MI_00
%USB\VID_0403&PID_6043&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6043&MI_01
%USB\VID_0403&PID_6043&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6043&MI_02
%USB\VID_0403&PID_6043&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6043&MI_03
%USB\VID_0403&PID_6044.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6044
%USB\VID_0403&PID_6045.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6045
%USB\VID_0403&PID_6047&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6047&MI_00
%USB\VID_0403&PID_6047&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6047&MI_01
%USB\VID_0403&PID_6048&MI_00.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6048&MI_00
%USB\VID_0403&PID_6048&MI_01.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6048&MI_01
%USB\VID_0403&PID_6048&MI_02.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6048&MI_02
%USB\VID_0403&PID_6048&MI_03.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6048&MI_03
%USB\VID_0403&PID_6049.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_6049
%USB\VID_0403&PID_0000.DeviceDesc%=FtdiBus.NTamd64,USB\VID_0403&PID_0000
[ControlFlags]
ExcludeFromSelect=*
[FtdiBus.NT]
CopyFiles=FtdiBus.NT.Copy,FtdiBus.NT.Copy2
AddReg=FtdiBus.NT.AddReg
[FtdiBus.NTamd64]
CopyFiles=FtdiBus.NTamd64.Copy,FtdiBus.NTamd64.Copy2,FtdiBus.NTamd64.Copy3
AddReg=FtdiBus.NT.AddReg
[FtdiBus.NT.Services]
AddService = FTDIBUS, 0x00000002, FtdiBus.NT.AddService, FtdiBus.NT.EventLog_Inst
[FtdiBus.NTamd64.Services]
AddService = FTDIBUS, 0x00000002, FtdiBus.NT.AddService, FtdiBus.NT.EventLog_Inst
[FtdiBus.NT.AddService]
DisplayName = %SvcDesc%
ServiceType = 1 ; SERVICE_KERNEL_DRIVER
StartType = 3 ; SERVICE_DEMAND_START
ErrorControl = 1 ; SERVICE_ERROR_NORMAL
ServiceBinary = %10%\system32\drivers\ftdibus.sys
LoadOrderGroup = Base
[FtdiBus.NT.AddReg]
HKR,,DevLoader,,*ntkern
HKR,,NTMPDriver,,ftdibus.sys
HKR,,EnumPropPages32,,"ftbusui.dll,FTBUSUIPropPageProvider"
[FtdiBus.NT.EventLog_Inst]
AddReg = FtdiBus.NT.EventLog_Inst.AddReg
[FtdiBus.NT.EventLog_Inst.AddReg]
HKR,,EventMessageFile,0x00020000,"%%SystemRoot%%\System32\IoLogMsg.dll;%%SystemRoot%%\System32\drivers\ftdibus.sys"
HKR,,TypesSupported,0x00010001,7
[FtdiBus.NT.HW]
AddReg=FtdiBus.NT.HW.AddReg
[FtdiBus.NTamd64.HW]
AddReg=FtdiBus.NT.HW.AddReg
[FtdiBus.NT.HW.AddReg]
;HKR,,"ConfigData",0x00010001,0x00000012
[FtdiBus.NT.Copy]
ftdibus.sys
[FtdiBus.NT.Copy2]
ftbusui.dll
ftd2xx.dll
FTLang.dll
[FtdiBus.NTamd64.Copy]
ftdibus.sys
[FtdiBus.NTamd64.Copy2]
ftbusui.dll
ftd2xx.dll,ftd2xx64.dll
FTLang.dll
[FtdiBus.NTamd64.Copy3]
ftd2xx.dll
[Strings]
Ftdi="FTDI"
DESC="CDM Driver Package - Bus/D2XX Driver"
DriversDisk="FTDI USB Drivers Disk"
USB\VID_0403&PID_6001.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6010&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6010&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6011&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6011&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6011&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6011&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6014.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6015.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_601B&REV_1400.DeviceDesc="FT4222 Mode 3 Device"
USB\VID_0403&PID_601B&MI_00.DeviceDesc="FT4222 Interface A"
USB\VID_0403&PID_601B&MI_01.DeviceDesc="FT4222 Interface B"
USB\VID_0403&PID_601B&MI_02.DeviceDesc="FT4222 Interface C"
USB\VID_0403&PID_601B&MI_03.DeviceDesc="FT4222 Interface D"
USB\VID_0403&PID_601C&REV_1700.DeviceDesc="FT4222H Mode 3 Device"
USB\VID_0403&PID_601C&MI_00.DeviceDesc="FT4222H Interface A"
USB\VID_0403&PID_601C&MI_01.DeviceDesc="FT4222H Interface B"
USB\VID_0403&PID_601C&MI_02.DeviceDesc="FT4222H Interface C"
USB\VID_0403&PID_601C&MI_03.DeviceDesc="FT4222H Interface D"
USB\VID_0403&PID_0FEC.DeviceDesc="UMFT4222PROG"
USB\VID_0403&PID_6031&MI_00.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6031&REV_2400.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6032&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6032&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6033&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6033&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6033&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6034&MI_00.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6034&REV_2500.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6035&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6035&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6036&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6036&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6036&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6037&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6037&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6037&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6037&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6038&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6038&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6038&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6038&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6038&MI_04.DeviceDesc="USB Serial Converter E"
USB\VID_0403&PID_6039&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6039&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6039&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6039&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6039&MI_04.DeviceDesc="USB Serial Converter E"
USB\VID_0403&PID_6039&MI_05.DeviceDesc="USB Serial Converter F"
USB\VID_0403&PID_603A&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_603A&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_603A&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_603A&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_603A&MI_04.DeviceDesc="USB Serial Converter E"
USB\VID_0403&PID_603A&MI_05.DeviceDesc="USB Serial Converter F"
USB\VID_0403&PID_603A&MI_06.DeviceDesc="USB Serial Converter G"
USB\VID_0403&PID_603E.DeviceDesc="UMFTPD3A Programming Board"
USB\VID_0403&PID_6040&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6040&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6041&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6041&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6041&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6041&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6042&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6042&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6043&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6043&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6043&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6043&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6044.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6045.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_6047&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6047&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6048&MI_00.DeviceDesc="USB Serial Converter A"
USB\VID_0403&PID_6048&MI_01.DeviceDesc="USB Serial Converter B"
USB\VID_0403&PID_6048&MI_02.DeviceDesc="USB Serial Converter C"
USB\VID_0403&PID_6048&MI_03.DeviceDesc="USB Serial Converter D"
USB\VID_0403&PID_6049.DeviceDesc="USB Serial Converter"
USB\VID_0403&PID_0000.DeviceDesc="USB Serial Converter"
SvcDesc="USB Serial Converter Driver"
ClassName="USB"

View File

@ -1,164 +1,419 @@
; FTDIPORT.INF ; FTDIPORT.INF
; ;
; Copyright © 2000-2011 Future Technology Devices International Limited ; Copyright © 2000-2021 Future Technology Devices International Limited
; ;
; USB serial port driver installation file for Windows 2000, XP, Server 2003, Vista, Server 2008, ; USB serial port driver installation file for Windows 7, Windows 8, Windows 8.1, Windows 10,
; Windows 7 and Server 2008 R2 (x86 and x64). ; Server 2008 R2, Server 2012 R2 and Server 2016.
;
; ;
; THIS SOFTWARE IS PROVIDED BY FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED ``AS IS'' AND ANY EXPRESS ;
; OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ; IMPORTANT NOTICE: PLEASE READ CAREFULLY BEFORE INSTALLING THE RELEVANT
; FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL FUTURE TECHNOLOGY DEVICES INTERNATIONAL LIMITED ; SOFTWARE: This licence agreement (Licence) is a legal agreement between you (Licensee or
; BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, ; you) and Future Technology Devices International Limited of 2 Seaward Place, Centurion Business
; BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS ; Park, Glasgow G41 1HH, Scotland (UK Company Number SC136640) (Licensor or we) for use of
; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ; driver software provided by the Licensor(Software).
; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF ;
; THE POSSIBILITY OF SUCH DAMAGE. ; BY INSTALLING OR USING THIS SOFTWARE YOU AGREE TO THE TERMS OF THIS LICENCE
; WHICH WILL BIND YOU. IF YOU DO NOT AGREE TO THE TERMS OF THIS LICENCE, WE ARE
; FTDI DRIVERS MAY BE USED ONLY IN CONJUNCTION WITH PRODUCTS BASED ON FTDI PARTS. ; UNWILLING TO LICENSE THE SOFTWARE TO YOU AND YOU MUST DISCONTINUE
; INSTALLATION OF THE SOFTWARE NOW.
; FTDI DRIVERS MAY BE DISTRIBUTED IN ANY FORM AS LONG AS LICENSE INFORMATION IS NOT MODIFIED. ;
; 1. GRANT AND SCOPE OF LICENCE
; IF A CUSTOM VENDOR ID AND/OR PRODUCT ID OR DESCRIPTION STRING ARE USED, IT IS THE RESPONSIBILITY OF ;
; THE PRODUCT MANUFACTURER TO MAINTAIN ANY CHANGES AND SUBSEQUENT WHQL RE-CERTIFICATION AS A RESULT OF ; 1.1 In consideration of you agreeing to abide by the terms of this Licence, the Licensor hereby
; MAKING THESE CHANGES. ; grants to you a non-exclusive, non-transferable, royalty free licence to use the Software on
; ; the terms of this Licence.
;
; 1.2 In this Licence a "Genuine FTDI Component" means an item of hardware that was
[Version] ; manufactured for, and sold by, the Licensor or a member of the Licensor's group of
Signature="$Windows NT$" ; companies. It does not include any counterfeit or fake products.
DriverPackageType=PlugAndPlay ;
DriverPackageDisplayName=%DESC% ; 1.3 If you are a manufacturer of a device that includes a Genuine FTDI Component (each a
Class=Ports ; "Device") then you may install the Software onto that device. If you are a seller or distributor
ClassGUID={4d36e978-e325-11ce-bfc1-08002be10318} ; of a Device then you may distribute the Software with the Device. If you are a user of a
Provider=%FTDI% ; Device then you may install the Software on the Device, or onto a computer system in order
CatalogFile=ftdiport.cat ; to use the Device.
DriverVer=03/18/2011,2.08.14 ;
; 1.4 In each of those cases you may:
[SourceDisksNames] ;
1=%DriversDisk%,,, ; 1.4.1 install and use the Software for your purposes only; and
;
[SourceDisksFiles] ; 1.4.2 only use the Software in conjunction with products based on and/or incorporating a
ftser2k.sys=1,i386 ; Genuine FTDI Component.
ftserui2.dll=1,i386 ;
ftcserco.dll = 1,i386 ; 1.5 The Software will not function properly on or with a component that is not a Genuine FTDI
; Component. Use of the Software as a driver for, or installation of the Software onto, a
[SourceDisksFiles.amd64] ; component that is not a Genuine FTDI Component, including without limitation counterfeit
ftser2k.sys=1,amd64 ; components, MAY IRRETRIEVABLY DAMAGE THAT COMPONENT. It is the Licensee's
ftserui2.dll=1,amd64 ; responsibility to make sure that all chips it installs the Software on, or uses the Software as a
ftcserco.dll = 1,amd64 ; driver for, are Genuine FTDI Components. If in doubt then contact the Licensor.
;
[DestinationDirs] ; 2. If a custom vendor ID and/or product ID or description string are used, it is the responsibility of
FtdiPort.NT.Copy=10,system32\drivers ; the product manufacturer to maintain any changes and subsequent WHQL re-certification as
FtdiPort.NT.CopyUI=10,system32 ; a result of making these changes.
FtdiPort.NT.CopyCoInst=10,system32 ;
; 3. LICENSEE'S UNDERTAKINGS
[ControlFlags] ;
ExcludeFromSelect=* ; 3.1 Except as expressly set out in this Licence or as permitted by any local law, you undertake:
;
[Manufacturer] ; 3.1.1 not to copy the Software, except where such copying is incidental to normal use of
%FTDI%=FtdiHw,NTamd64 ; the Software or where it is necessary for the purpose of back-up or operational
; security;
[FtdiHw] ;
%VID_0403&PID_6001.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6001 ; 3.1.2 not to rent, lease, sub-license, loan, translate, merge, adapt, vary or modify the
%VID_0403&PID_6010.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6010 ; Software or any part of it;
%VID_0403&PID_6011.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6011 ;
%VID_0403&PID_6014.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6014 ; 3.1.3 not to make alterations to, or modifications of, the whole or any part of the Software
; nor permit the Software or any part of it to be combined with, or become
[FtdiHw.NTamd64] ; incorporated in, any other programs;
%VID_0403&PID_6001.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6001 ;
%VID_0403&PID_6010.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6010 ; 3.1.4 not to disassemble, de-compile, reverse engineer or create derivative works based
%VID_0403&PID_6011.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6011 ; on the whole or any part of the Software;
%VID_0403&PID_6014.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6014 ;
; 3.1.5 to keep all copies of the Software secure;
[FtdiPort.NT.AddService] ;
DisplayName = %SvcDesc% ; 3.1.6 to include the copyright notice of the Licensor on all entire and partial copies of the
ServiceType = 1 ; SERVICE_KERNEL_DRIVER ; Software in any form; and
StartType = 3 ; SERVICE_DEMAND_START ;
ErrorControl = 1 ; SERVICE_ERROR_NORMAL ; 3.1.7 not to provide, or otherwise make available, the Software in any form, in whole or in
ServiceBinary = %10%\system32\drivers\ftser2k.sys ; part (including, but not limited to, program listings, object and source program
LoadOrderGroup = Base ; listings, object code and source code) to any person.
;
; 4. INTELLECTUAL PROPERTY RIGHTS
; -------------- Serenum Driver install section ;
[SerEnum_AddService] ; 4.1 You acknowledge that all intellectual property rights in the Software throughout the world
DisplayName = %SerEnum.SvcDesc% ; belong to the Licensor, that rights in the Software are licensed (not sold) to you, and that you
ServiceType = 1 ; SERVICE_KERNEL_DRIVER ; have no rights in, or to, the Software other than the right to use them in accordance with the
StartType = 3 ; SERVICE_DEMAND_START ; terms of this Licence.
ErrorControl = 1 ; SERVICE_ERROR_NORMAL ;
ServiceBinary = %12%\serenum.sys ; 5. WARRANTY
LoadOrderGroup = PNP Filter ;
; 5.1 To the maximum extent permitted by applicable law, the software is provided "as is".
[FtdiPort.NT.AddReg] ;
HKR,,EnumPropPages32,,"ftserui2.dll,SerialPortPropPageProvider" ; 5.2 All implied warranties, implied conditions and/or implied licences are excluded from this
; Licence, including but not limited to implied warranties of quality and/or fitness for purpose (in
[FtdiPort.NT.Copy] ; all cases) to the fullest extent permitted by law.
ftser2k.sys ;
; 5.3 You acknowledge that the Software has not been developed to meet your individual
[FtdiPort.NT.CopyUI] ; requirements and that the Software may not be uninterrupted or free of bugs or errors.
ftserui2.dll ;
; 6. LICENSOR'S LIABILITY
[FtdiPort.NT.CopyCoInst] ;
ftcserco.dll ; 6.1 To the maximum extent permitted by applicable law, in no event shall the Licensor be liable
; for any:
[FtdiPort.NT] ;
CopyFiles=FtdiPort.NT.Copy,FtdiPort.NT.CopyUI ; 6.1.1 special loss or damage;
AddReg=FtdiPort.NT.AddReg ;
; 6.1.2 incidental loss or damage;
[FtdiPort.NTamd64] ;
CopyFiles=FtdiPort.NT.Copy,FtdiPort.NT.CopyUI ; 6.1.3 indirect or consequential loss or damage:
AddReg=FtdiPort.NT.AddReg ;
; 6.1.4 loss of income;
[FtdiPort.NT.HW] ;
AddReg=FtdiPort.NT.HW.AddReg ; 6.1.5 loss of business;
;
[FtdiPort.NTamd64.HW] ; 6.1.6 loss of profits;
AddReg=FtdiPort.NT.HW.AddReg ;
; 6.1.7 loss of revenue;
;
[FtdiPort.NT.Services] ; 6.1.8 loss of contracts;
AddService = FTSER2K, 0x00000002, FtdiPort.NT.AddService ;
AddService = Serenum,,SerEnum_AddService ; 6.1.9 business interruption;
DelService = FTSERIAL ;
; 6.1.10 loss of the use of money or anticipated savings;
[FtdiPort.NTamd64.Services] ;
AddService = FTSER2K, 0x00000002, FtdiPort.NT.AddService ; 6.1.11 loss of information;
AddService = Serenum,,SerEnum_AddService ;
DelService = FTSERIAL ; 6.1.12 loss of opportunity;
;
; 6.1.13 loss of goodwill or reputation; and/or
[FtdiPort.NT.HW.AddReg] ;
HKR,,"UpperFilters",0x00010000,"serenum" ; 6.1.14 loss of, damage to or corruption of data;
HKR,,"ConfigData",1,11,00,3F,3F,10,27,00,00,88,13,00,00,C4,09,00,00,E2,04,00,00,71,02,00,00,38,41,00,00,9C,80,00,00,4E,C0,00,00,34,00,00,00,1A,00,00,00,0D,00,00,00,06,40,00,00,03,80,00,00,00,00,00,00,D0,80,00,00 ;
HKR,,"MinReadTimeout",0x00010001,0 ; (in each case) of any kind howsoever arising and whether caused by delict (including
HKR,,"MinWriteTimeout",0x00010001,0 ; negligence), breach of contract or otherwise.
HKR,,"LatencyTimer",0x00010001,16 ;
; 6.2 FTDI's total liability to you in relation to the Software shall not exceed 500 US Dollars.
;
[FtdiPort.NT.CoInstallers] ; 6.3 Nothing in this Licence limits or excludes liability for death or personal injury or for fraud.
AddReg=FtdiPort.NT.CoInstallers.AddReg ;
CopyFiles=FtdiPort.NT.CopyCoInst ; 7. TERMINATION
;
[FtdiPort.NTamd64.CoInstallers] ; 7.1 The Licensor may terminate this Licence immediately if:
AddReg=FtdiPort.NT.CoInstallers.AddReg ;
CopyFiles=FtdiPort.NT.CopyCoInst ; 7.1.1 you fail to comply with any of the terms and conditions of the Licence; or
;
[FtdiPort.NT.CoInstallers.AddReg] ; 7.1.2 you commence or participate in any legal proceedings against the Licensor.
HKR,,CoInstallers32,0x00010000,"ftcserco.Dll,FTCSERCoInstaller" ;
; 7.2 Upon termination:
;
;---------------------------------------------------------------; ; 7.2.1 all rights granted to you under this Licence shall cease;
;
[Strings] ; 7.2.2 you must cease all activities authorised by this Licence; and
FTDI="FTDI" ;
DESC="CDM Driver Package - VCP Driver" ; 7.2.3 you must immediately delete or remove the Software from all computer equipment
DriversDisk="FTDI USB Drivers Disk" ; in your possession and immediately destroy all copies of the Software then in your
PortsClassName = "Ports (COM & LPT)" ; possession, custody or control.
VID_0403&PID_6001.DeviceDesc="USB Serial Port" ;
VID_0403&PID_6010.DeviceDesc="USB Serial Port" ; 8. TRANSFER OF RIGHTS AND OBLIGATIONS
VID_0403&PID_6011.DeviceDesc="USB Serial Port" ;
VID_0403&PID_6014.DeviceDesc="USB Serial Port" ; 8.1 You may not transfer, assign, charge or otherwise dispose of this Licence, or any of your
SvcDesc="USB Serial Port Driver" ; rights or obligations arising under it.
SerEnum.SvcDesc="Serenum Filter Driver" ;
; 8.2 The Licensor may transfer, assign, charge, sub-contract or otherwise dispose of this Licence,
; or any of his rights or obligations arising under it, at any time during the term of the Licence.
;
; 9. WAIVER
;
; 9.1 If the Licensor fails, at any time during the term of this Licence, to insist on strict performance
; of any of your obligations under this Licence, or if the Licensor fails to exercise any of the
; rights or remedies to which he is entitled under this Licence, this shall not constitute a waiver
; of such rights or remedies and shall not relieve you from compliance with such obligations.
;
; 9.2 A waiver by the Licensor of any default shall not constitute a waiver of any subsequent
; default.
;
; 9.3 No waiver by the Licensor of any of these terms and conditions shall be effective unless it is
; expressly stated to be a waiver and is communicated to you in writing.
;
; 10. SEVERABILITY
;
; If any of the terms of this Licence are determined by any competent authority to be invalid,
; unlawful or unenforceable to any extent, such term, condition or provision will to that extent be
; severed from the remaining terms, conditions and provisions which will continue to be valid to
; the fullest extent permitted by law.
;
; 11. ENTIRE AGREEMENT
;
; 11.1 This Licence constitutes the whole agreement between us and supersedes any previous
; arrangement, understanding or agreement between us, relating to the licensing of the
; Software.
;
; 11.2 Each party acknowledges that in entering into this Licence it does not rely on any statement,
; representation, warranty or understanding other than those expressly set out in this Licence.
; Each party agrees that it will have no remedy in respect of any statement, representation,
; warranty or understanding that is not expressly set out in this Licence. Each party agrees that
; its only remedy in respect of those representations, statements, assurances and warranties
; that are set out in this Licence will be for breach of contract in accordance with the terms of
; this Licence.
;
; 11.3 The parties agree that nothing in this Licence will limit or exclude any liability they may have
; for fraud.
;
; 12. MISCELLANEOUS
;
; 12.1 This Licence does not create a partnership or joint venture between the parties to it, nor
; authorise a party to act as agent for the other.
;
; 12.2 This Licence does not create any legal rights enforceable by any third party.
;
; 12.3 This Licence may only be varied by express written legal agreement between the parties.
;
; 13. LAW AND JURISDICTION
;
; This Licence, its subject matter or its formation (including non-contractual disputes or claims)
; shall be governed by and construed in accordance with Scots law and submitted to the non-
; exclusive jurisdiction of the Scottish courts.
;
[Version]
Signature="$Windows NT$"
DriverPackageType=PlugAndPlay
DriverPackageDisplayName=%DESC%
Class=Ports
ClassGUID={4d36e978-e325-11ce-bfc1-08002be10318}
Provider=%FTDI%
CatalogFile=ftdiport.cat
DriverVer=07/05/2021,2.12.36.4
[SourceDisksNames]
1=%DriversDisk%,,,
[SourceDisksFiles]
ftser2k.sys=1,i386
ftserui2.dll=1,i386
ftcserco.dll = 1,i386
[SourceDisksFiles.amd64]
ftser2k.sys=1,amd64
ftserui2.dll=1,amd64
ftcserco.dll = 1,amd64
[DestinationDirs]
FtdiPort.NT.Copy=10,system32\drivers
FtdiPort.NT.CopyUI=10,system32
FtdiPort.NT.CopyCoInst=10,system32
[ControlFlags]
ExcludeFromSelect=*
[Manufacturer]
%FTDI%=FtdiHw,NTamd64
[FtdiHw]
%VID_0403&PID_6001.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6001
%VID_0403&PID_6010.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6010
%VID_0403&PID_6011.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6011
%VID_0403&PID_6014.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6014
%VID_0403&PID_6015.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6015
%VID_0403&PID_6031.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6031
%VID_0403&PID_6032.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6032
%VID_0403&PID_6033.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6033
%VID_0403&PID_6034.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6034
%VID_0403&PID_6035.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6035
%VID_0403&PID_6036.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6036
%VID_0403&PID_6037.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6037
%VID_0403&PID_6038.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6038
%VID_0403&PID_6039.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6039
%VID_0403&PID_603A.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_603A
%VID_0403&PID_6040.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6040
%VID_0403&PID_6041.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6041
%VID_0403&PID_6042.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6042
%VID_0403&PID_6043.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6043
%VID_0403&PID_6044.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6044
%VID_0403&PID_6045.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6045
%VID_0403&PID_6047.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6047
%VID_0403&PID_6048.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6048
%VID_0403&PID_6049.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_6049
%VID_0403&PID_0000.DeviceDesc%=FtdiPort.NT,FTDIBUS\COMPORT&VID_0403&PID_0000
[FtdiHw.NTamd64]
%VID_0403&PID_6001.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6001
%VID_0403&PID_6010.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6010
%VID_0403&PID_6011.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6011
%VID_0403&PID_6014.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6014
%VID_0403&PID_6015.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6015
%VID_0403&PID_6031.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6031
%VID_0403&PID_6032.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6032
%VID_0403&PID_6033.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6033
%VID_0403&PID_6034.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6034
%VID_0403&PID_6035.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6035
%VID_0403&PID_6036.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6036
%VID_0403&PID_6037.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6037
%VID_0403&PID_6038.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6038
%VID_0403&PID_6039.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6039
%VID_0403&PID_603A.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_603A
%VID_0403&PID_6040.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6040
%VID_0403&PID_6041.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6041
%VID_0403&PID_6042.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6042
%VID_0403&PID_6043.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6043
%VID_0403&PID_6044.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6044
%VID_0403&PID_6045.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6045
%VID_0403&PID_6047.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6047
%VID_0403&PID_6048.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6048
%VID_0403&PID_6049.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_6049
%VID_0403&PID_0000.DeviceDesc%=FtdiPort.NTamd64,FTDIBUS\COMPORT&VID_0403&PID_0000
[FtdiPort.NT.AddService]
DisplayName = %SvcDesc%
ServiceType = 1 ; SERVICE_KERNEL_DRIVER
StartType = 3 ; SERVICE_DEMAND_START
ErrorControl = 1 ; SERVICE_ERROR_NORMAL
ServiceBinary = %10%\system32\drivers\ftser2k.sys
LoadOrderGroup = Base
; -------------- Serenum Driver install section
[SerEnum_AddService]
DisplayName = %SerEnum.SvcDesc%
ServiceType = 1 ; SERVICE_KERNEL_DRIVER
StartType = 3 ; SERVICE_DEMAND_START
ErrorControl = 1 ; SERVICE_ERROR_NORMAL
ServiceBinary = %12%\serenum.sys
LoadOrderGroup = PNP Filter
[FtdiPort.NT.AddReg]
HKR,,EnumPropPages32,,"ftserui2.dll,SerialPortPropPageProvider"
[FtdiPort.NT.Copy]
ftser2k.sys
[FtdiPort.NT.CopyUI]
ftserui2.dll
[FtdiPort.NT.CopyCoInst]
ftcserco.dll
[FtdiPort.NT]
CopyFiles=FtdiPort.NT.Copy,FtdiPort.NT.CopyUI
AddReg=FtdiPort.NT.AddReg
[FtdiPort.NTamd64]
CopyFiles=FtdiPort.NT.Copy,FtdiPort.NT.CopyUI
AddReg=FtdiPort.NT.AddReg
[FtdiPort.NT.HW]
AddReg=FtdiPort.NT.HW.AddReg
[FtdiPort.NTamd64.HW]
AddReg=FtdiPort.NT.HW.AddReg
[FtdiPort.NT.Services]
AddService = FTSER2K, 0x00000002, FtdiPort.NT.AddService
AddService = Serenum,,SerEnum_AddService
DelService = FTSERIAL
[FtdiPort.NTamd64.Services]
AddService = FTSER2K, 0x00000002, FtdiPort.NT.AddService
AddService = Serenum,,SerEnum_AddService
DelService = FTSERIAL
[FtdiPort.NT.HW.AddReg]
HKR,,"UpperFilters",0x00010000,"serenum"
HKR,,"ConfigData",1,11,00,3F,3F,10,27,00,00,88,13,00,00,C4,09,00,00,E2,04,00,00,71,02,00,00,38,41,00,00,9C,80,00,00,4E,C0,00,00,34,00,00,00,1A,00,00,00,0D,00,00,00,06,40,00,00,03,80,00,00,00,00,00,00,D0,80,00,00
HKR,,"MinReadTimeout",0x00010001,0
HKR,,"MinWriteTimeout",0x00010001,0
HKR,,"LatencyTimer",0x00010001,16
[FtdiPort.NT.CoInstallers]
AddReg=FtdiPort.NT.CoInstallers.AddReg
CopyFiles=FtdiPort.NT.CopyCoInst
[FtdiPort.NTamd64.CoInstallers]
AddReg=FtdiPort.NT.CoInstallers.AddReg
CopyFiles=FtdiPort.NT.CopyCoInst
[FtdiPort.NT.CoInstallers.AddReg]
HKR,,CoInstallers32,0x00010000,"ftcserco.Dll,FTCSERCoInstaller"
;---------------------------------------------------------------;
[Strings]
FTDI="FTDI"
DESC="CDM Driver Package - VCP Driver"
DriversDisk="FTDI USB Drivers Disk"
PortsClassName = "Ports (COM & LPT)"
VID_0403&PID_6001.DeviceDesc="USB Serial Port"
VID_0403&PID_6010.DeviceDesc="USB Serial Port"
VID_0403&PID_6011.DeviceDesc="USB Serial Port"
VID_0403&PID_6014.DeviceDesc="USB Serial Port"
VID_0403&PID_6015.DeviceDesc="USB Serial Port"
VID_0403&PID_6031.DeviceDesc="USB Serial Port"
VID_0403&PID_6032.DeviceDesc="USB Serial Port"
VID_0403&PID_6033.DeviceDesc="USB Serial Port"
VID_0403&PID_6034.DeviceDesc="USB Serial Port"
VID_0403&PID_6035.DeviceDesc="USB Serial Port"
VID_0403&PID_6036.DeviceDesc="USB Serial Port"
VID_0403&PID_6037.DeviceDesc="USB Serial Port"
VID_0403&PID_6038.DeviceDesc="USB Serial Port"
VID_0403&PID_6039.DeviceDesc="USB Serial Port"
VID_0403&PID_603A.DeviceDesc="USB Serial Port"
VID_0403&PID_6040.DeviceDesc="USB Serial Port"
VID_0403&PID_6041.DeviceDesc="USB Serial Port"
VID_0403&PID_6042.DeviceDesc="USB Serial Port"
VID_0403&PID_6043.DeviceDesc="USB Serial Port"
VID_0403&PID_6044.DeviceDesc="USB Serial Port"
VID_0403&PID_6045.DeviceDesc="USB Serial Port"
VID_0403&PID_6047.DeviceDesc="USB Serial Port"
VID_0403&PID_6048.DeviceDesc="USB Serial Port"
VID_0403&PID_6049.DeviceDesc="USB Serial Port"
VID_0403&PID_0000.DeviceDesc="USB Serial Port"
SvcDesc="USB Serial Port Driver"
SerEnum.SvcDesc="Serenum Filter Driver"