2014-09-02 20:16:20 +00:00
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; ;;
|
2015-01-08 20:10:22 +00:00
|
|
|
;; Copyright (C) KolibriOS team 2004-2015. All rights reserved. ;;
|
2014-09-02 20:16:20 +00:00
|
|
|
;; Distributed under terms of the GNU General Public License ;;
|
|
|
|
;; ;;
|
|
|
|
;; Include file for apps which want to use FTDI device ;;
|
|
|
|
;; ;;
|
|
|
|
;; GNU GENERAL PUBLIC LICENSE ;;
|
|
|
|
;; Version 2, June 1991 ;;
|
|
|
|
;; ;;
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
;Bitmode constants
|
|
|
|
BITMODE_RESET = 0x00 ;Switch off bitbang mode, back to regular serial FIFO
|
|
|
|
BITMODE_BITBANG= 0x01 ;Classical asynchronous bitbang mode, introduced with B-type chips */
|
|
|
|
BITMODE_MPSSE = 0x02 ;MPSSE mode, available on 2232x chips */
|
|
|
|
BITMODE_SYNCBB = 0x04 ;Synchronous bitbang mode, available on 2232x and R-type chips */
|
|
|
|
BITMODE_MCU = 0x08 ;MCU Host Bus Emulation mode, available on 2232x chips */
|
|
|
|
;CPU-style fifo mode gets set via EEPROM (cuurenntly EEPROM burn not supported in KolibriOS)
|
|
|
|
BITMODE_OPTO = 0x10 ;Fast Opto-Isolated Serial Interface Mode, available on 2232x chips */
|
|
|
|
BITMODE_CBUS = 0x20 ;Bitbang on CBUS pins of R-type chips, configure in EEPROM before */
|
|
|
|
BITMODE_SYNCFF = 0x40 ;Single Channel Synchronous FIFO mode, available on 2232H chips */
|
|
|
|
BITMODE_FT1284 = 0x80 ;FT1284 mode, available on 232H chips
|
|
|
|
|
|
|
|
;Line property constants
|
|
|
|
;parity
|
|
|
|
NONE = 0 shl 8
|
|
|
|
ODD = 1 shl 8
|
|
|
|
EVEN = 2 shl 8
|
|
|
|
MARK = 3 shl 8
|
|
|
|
SPACE = 4 shl 8
|
|
|
|
;stop bits
|
|
|
|
STOP_BIT_1 = 0 shl 11
|
|
|
|
STOP_BIT_15 = 1 shl 11
|
|
|
|
STOP_BIT_2 = 2 shl 11
|
|
|
|
;break type
|
|
|
|
BREAK_OFF = 0 shl 14
|
2015-04-14 20:33:54 +00:00
|
|
|
BREAK_ON = 1 shl 14
|
2014-09-02 20:16:20 +00:00
|
|
|
;number of bits has to be at lower byte
|
|
|
|
|
|
|
|
;Flow control
|
|
|
|
SIO_DISABLE_FLOW_CTRL = 0x0
|
|
|
|
SIO_RTS_CTS_HS = (0x1 shl 8)
|
|
|
|
SIO_DTR_DSR_HS = (0x2 shl 8)
|
|
|
|
SIO_XON_XOFF_HS= (0x4 shl 8)
|
|
|
|
|
|
|
|
;Chip types
|
|
|
|
TYPE_AM = 0
|
|
|
|
TYPE_BM = 1
|
|
|
|
TYPE_2232C = 2
|
|
|
|
TYPE_R = 3
|
|
|
|
TYPE_2232H = 4
|
|
|
|
TYPE_4232H = 5
|
|
|
|
TYPE_232H = 6
|
|
|
|
TYPE_230X = 7
|
|
|
|
|
|
|
|
;IO codes
|
|
|
|
;Get list of detected ftdi chips
|
|
|
|
FTDI_GET_LIST = 1
|
|
|
|
;Acquire lock on ftdi device
|
|
|
|
;[input+8] - none
|
|
|
|
;[output] - PID device is locked by
|
|
|
|
FTDI_LOCK = 2
|
|
|
|
;Unlock ftdi device
|
|
|
|
;[input+8] - none
|
|
|
|
;[output] - 0 if unclock success, overwise PID device is locked by
|
|
|
|
FTDI_UNLOCK = 3
|
|
|
|
;[output] - chunksize
|
|
|
|
FTDI_GET_WRITE_CHUNKSIZE = 4
|
|
|
|
;[output] - chunksize
|
|
|
|
FTDI_GET_READ_CHUNKSIZE = 5
|
|
|
|
;[input+8] - chunksize
|
|
|
|
FTDI_SET_WRITE_CHUNKSIZE = 6
|
|
|
|
;[input+8] - chunksize
|
|
|
|
FTDI_SET_READ_CHUNKSIZE = 7
|
|
|
|
;Writes data in chunks to the chip
|
|
|
|
;[input+8] - size of data, [input+12] - beginning of data
|
|
|
|
FTDI_WRITE_DATA = 8
|
|
|
|
;Reads data in chunks from the chip
|
|
|
|
;[input+8] - size of data, [output] - red data
|
|
|
|
FTDI_READ_DATA = 9
|
|
|
|
;Sets the chip baud rate
|
|
|
|
;[input+8] - baudrate
|
|
|
|
FTDI_SET_BAUDRATE = 10
|
|
|
|
;Enable/disable bitbang modes
|
|
|
|
;[input+8] - 0xnnnnXXYY, where XX-bitmask, YY-bitmode
|
|
|
|
FTDI_SET_BITMODE = 11
|
|
|
|
;Set rts line high
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_SET_RTS_HIGH = 12
|
|
|
|
;Set rts line low
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_SET_RTS_LOW = 13
|
|
|
|
;Set dtr line high
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_SET_DTR_HIGH = 14
|
|
|
|
;Set dtr line low
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_SET_DTR_LOW = 15
|
|
|
|
;Resets the ftdi device
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_USB_RESET = 16
|
|
|
|
;Set flowcontrol for ftdi chip
|
|
|
|
;dword[input+8] - one of flow control constants
|
|
|
|
FTDI_SET_FLOW_CONTROL = 17
|
|
|
|
;Set the special event character
|
|
|
|
;[input+8] - 0xnnnnXXYY, where XX-1/0(enable/disable), YY-event char
|
|
|
|
FTDI_SET_EVENT_CHAR = 18
|
|
|
|
;Set error character
|
|
|
|
;[input+8] - 0xnnnnXXYY, where XX-1/0(enable/disable), YY-error char
|
|
|
|
FTDI_SET_ERROR_CHAR = 19
|
|
|
|
;FTDI chip keeps data in the internal buffer for a specific
|
|
|
|
;amount of time if the buffer is not full yet to decrease
|
|
|
|
;load on the usb bus
|
|
|
|
;[input+8] - 0xnnnnXXXX, where XX-latency
|
|
|
|
FTDI_SET_LATENCY_TIMER = 20
|
|
|
|
;Get latency timer
|
|
|
|
;[output] - latency
|
|
|
|
FTDI_GET_LATENCY_TIMER = 21
|
|
|
|
;Directly read pin state, circumventing the read buffer. Useful for bitbang mode
|
|
|
|
;[output] - pins' values
|
|
|
|
FTDI_READ_PINS = 22
|
|
|
|
;This function allows the retrieve the two status bytes of the device.
|
|
|
|
;The device sends these bytes also as a header for each read access
|
|
|
|
;where they are discarded by ftdi_read_data(). The chip generates
|
|
|
|
;the two stripped status bytes in the absence of data every 40 ms
|
|
|
|
;
|
|
|
|
; Layout of the first byte:
|
|
|
|
; - B0..B3 - must be 0
|
|
|
|
; - B4 Clear to send (CTS)
|
|
|
|
; 0 = inactive
|
|
|
|
; 1 = active
|
|
|
|
; - B5 Data set ready (DTS)
|
|
|
|
; 0 = inactive
|
|
|
|
; 1 = active
|
|
|
|
; - B6 Ring indicator (RI)
|
|
|
|
; 0 = inactive
|
|
|
|
; 1 = active
|
|
|
|
; - B7 Receive line signal detect (RLSD)
|
|
|
|
; 0 = inactive
|
|
|
|
; 1 = active
|
|
|
|
|
|
|
|
; Layout of the second byte:
|
|
|
|
; - B0 Data ready (DR)
|
|
|
|
; - B1 Overrun error (OE)
|
|
|
|
; - B2 Parity error (PE)
|
|
|
|
; - B3 Framing error (FE)
|
|
|
|
; - B4 Break interrupt (BI)
|
|
|
|
; - B5 Transmitter holding register (THRE)
|
|
|
|
; - B6 Transmitter empty (TEMT)
|
|
|
|
; - B7 Error in RCVR FIFO
|
|
|
|
;[output] - poll modem status
|
|
|
|
FTDI_POLL_MODEM_STATUS = 23
|
|
|
|
;Set (RS232) line characteristics
|
|
|
|
;dword[input+8] - line property constants combination
|
|
|
|
FTDI_SET_LINE_PROPERTY = 24
|
|
|
|
;Clears the read buffer on the chip
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_PURGE_RX_BUFFER = 25
|
|
|
|
;Clears the write buffer on the chip
|
|
|
|
;[input+8] - none
|
|
|
|
FTDI_PURGE_RX_BUFFER = 26
|
|
|
|
|
|
|
|
;Structures
|
|
|
|
;list layout from FTDI_GET_LIST
|
|
|
|
struct dev_list
|
|
|
|
size dd ?
|
|
|
|
nodes rd size*sizeof.node
|
|
|
|
ends
|
|
|
|
|
|
|
|
struct node
|
|
|
|
islocked dd ? ; Will be 'LCKD', if dev is already locked; or 'NLKD', if dev is free
|
|
|
|
chip_type dd ? ; FTDI chip type (see Chip types constants)
|
|
|
|
dev_handle dd ? ; Device handle, value the same as in in_buf_map.dev_handle
|
|
|
|
ends
|
|
|
|
|
|
|
|
;input buffer map for requests above FTDI_GET_LIST
|
|
|
|
struc in_buf_map
|
|
|
|
pid dd ? ; Should be PID of application using this file
|
|
|
|
dev_handle dd ? ; Should be value acquired from one of dev_list's nodes
|
2015-04-14 20:33:54 +00:00
|
|
|
ends
|