Software Application Development. FT31xD Android Programmers Guide



Similar documents
Software Application Development. FT311D Android programmers guide

Application Note AN_241. FTDI_AOA_HyperTerm_User_Manual

Application Note AN_208. FT311D and FT312D Demo_APK_User_GuideFT311D and FT312D Demo_APK_User_Guide

Command Processor for MPSSE and MCU Host Bus Emulation Modes

Embedded Systems Design Course Applying the mbed microcontroller

Application Note AN_243. FT312D USB Host to UART Cable Application

Application Note AN_242

Introduction: Implementation of the MVI56-MCM module for modbus communications:

Serial Communications

Data sheet Wireless UART firmware version 4.02

Develop a Dallas 1-Wire Master Using the Z8F1680 Series of MCUs

Software User Guide UG-461

Application Note. AN_136_Hi-Speed Mini Module EEPROM Disaster Recovery

Implementing SPI Master and Slave Functionality Using the Z8 Encore! F083A

Future Technology Devices International Ltd

Future Technology Devices International Ltd. FT311D

Application Note AN_299. FT800_FT801_Internal_Clock _Trimming

Future Technology Devices International Ltd

Master-Touch and ValuMass. Modbus Communications. INSTRUCTION MANUAL (Rev. 2.1)

VDIP1. Vinculum VNC1L Module. Datasheet

DS Wire Digital Thermometer and Thermostat

Serial Communications

DS1621 Digital Thermometer and Thermostat

AN601 I2C 2.8 Communication Protocol. SM130 SM130 - Mini APPLICATION NOTE

PC Base Adapter Daughter Card UART GPIO. Figure 1. ToolStick Development Platform Block Diagram

Elettronica dei Sistemi Digitali Costantino Giaconia SERIAL I/O COMMON PROTOCOLS

Technical Note. TN_134 FTDI Android D2XX Driver

Vinco Development Module. Datasheet

APPLICATION PROGRAMMING INTERFACE

MODULE BOUSSOLE ÉLECTRONIQUE CMPS03 Référence :

DS1621 Digital Thermometer and Thermostat

FPGA INTEGRATION MANUAL SATURN-SIL 2 MODULES. Dictionary Code. Edition 01. Revision 00. Number of pages 18

Application Note AN_209. AN_209 PDIUSBD12 to FT120 Migration Guide

Application Note AN_185. Vinculum-II UART to USB HID Class Host Bridge

Lab Experiment 1: The LPC 2148 Education Board

SPI I2C LIN Ethernet. u Today: Wired embedded networks. u Next lecture: CAN bus u Then: wireless embedded network

Using the HT46R46 I/O Ports to Implement Half-Duplex SPI Communication

Freescale Semiconductor, I

Part 1. MAX BIT DAC with an Arduino Board. MIDI to Voltage Converter Part1

FTDI Chip. VM800P Datasheet Embedded Video Engine Plus Module. VM800P Embedded Video Engine Plus Module Datasheet Version 1.0

AND8336. Design Examples of On Board Dual Supply Voltage Logic Translators. Prepared by: Jim Lepkowski ON Semiconductor.

GTS-4E Hardware User Manual. Version: V1.1.0 Date:

ARM Thumb Microcontrollers. Application Note. Software ISO 7816 I/O Line Implementation. Features. Introduction

Technical Note. TN_147 Java D2xx for Android

Serial Communications / Protocol in AirTest Products

Installation and Operation Manual TAP Application on the Open Java Server

RN-131-PICTAIL & RN-171-PICTAIL Evaluation Boards

Software Application Development. D2XX Programmer's Guide

MSP430 USB Communications Device Class (CDC) API User s Guide, v0.7

SKP16C62P Tutorial 1 Software Development Process using HEW. Renesas Technology America Inc.

White Paper WP_001. Connecting Peripherals to an Android Platform

In-System Programmer USER MANUAL RN-ISP-UM RN-WIFLYCR-UM

How to develop your own app

FT4232H Mini Module. USB Hi-Speed FT4232H Evaluation Module. Datasheet

PCAN-MicroMod Universal I/O Module with CAN Interface. User Manual. Document version ( )

AN1754 APPLICATION NOTE

Single channel data transceiver module WIZ2-434

USB2.0 <=> I2C V4.4. Konverter Kabel und Box mit Galvanischetrennung

Data Acquisition Module with I2C interface «I2C-FLEXEL» User s Guide

Guangzhou HC Information Technology Co., Ltd. Product Data Sheet

I2C PRESSURE MONITORING THROUGH USB PROTOCOL.

Technical Note TN_158. What is the Camera Parallel Interface?

Table 1 below is a complete list of MPTH commands with descriptions. Table 1 : MPTH Commands. Command Name Code Setting Value Description

Data Sheet. Adaptive Design ltd. Arduino Dual L6470 Stepper Motor Shield V th November L6470 Stepper Motor Shield

FLYPORT Wi-Fi G

DKWF121 WF121-A B/G/N MODULE EVALUATION BOARD

FT2232H Mini Module. USB Hi-Speed FT2232H Evaluation Module. Datasheet

NB3H5150 I2C Programming Guide. I2C/SMBus Custom Configuration Application Note

Future Technology Devices International Ltd. USB-Key. Datasheet

User s Manual of Board Microcontroller ET-MEGA2560-ADK ET-MEGA2560-ADK

TURBO PROGRAMMER USB, MMC, SIM DEVELOPMENT KIT

Application Note AN_254. FT800 Designs With Visual TFT

AVR1309: Using the XMEGA SPI. 8-bit Microcontrollers. Application Note. Features. 1 Introduction SCK MOSI MISO SS

USER GUIDE EDBG. Description

Bluetooth for device discovery. Networking Guide

AVR151: Setup and Use of the SPI. Introduction. Features. Atmel AVR 8-bit Microcontroller APPLICATION NOTE

AN141 SMBUS COMMUNICATION FOR SMALL FORM FACTOR DEVICE FAMILIES. 1. Introduction. 2. Overview of the SMBus Specification. 2.1.

Implementing SPI Communication Between MSP430 G2452 and LTC ADC

Application Note 120 Communicating Through the 1-Wire Master

EVAL-UFDC-1/UFDC-1M-16

TTL-232R-PCB. TTL to USB Serial Converter PCB. Datasheet

M85 OpenCPU Solution Presentation

Getting Started with IntelleView POS Administrator Software

Programming Interface. for. Bus Master IDE Controller. Revision 1.0

Embedded Component Based Programming with DAVE 3

TTL-232R-3V3 USB to TTL Serial Converter Cable

USB Human Interface Joystick Demonstration Create a HID USB Device (sample Joystick) By Jared St.Clare, October 2009 Version 1

CAM-VGA100 User Manual

Serial port interface for microcontroller embedded into integrated power meter

eztcp Technical Document Modbus/TCP of eztcp Caution: Specifications of this document may be changed without prior notice for improvement.

PM1122 INT DIGITAL INTERFACE REMOTE

Future Technology Devices International Ltd. FTDI Drivers Installation guide for. Windows 7

BLUETOOTH SERIAL PORT PROFILE. iwrap APPLICATION NOTE

Appendix B RCS11 Remote Communications

Wifi Web Server Module w TF Socket User s Guide

Virtual Integrated Design Getting started with RS232 Hex Com Tool v6.0

Quick Installation. A Series of Intelligent Bar Code Reader with NeuroFuzzy Decoding. Quick Installation

CP2110-EK CP2110 EVALUATION KIT USER S GUIDE. 1. Kit Contents. 2. Relevant Documentation. 3. Software Setup

DECT Module UM-9802 Datasheet

Transcription:

Future Technology Devices International Ltd. Software Application Development FT31xD Android Programmers Guide Document Reference No.: FT_000532 Issue Date: 2013-05-21 Android programmers guide describes User APIs for Android open accessory development. The Android application is divided into two layer, User Layer and FT311D/FT312D layer. User layer is not aware of USB communication and calls the APIs exposed by the FT311D/FT312D layer. Future Technology Devices International Limited (FTDI) Unit 1, 2 Seaward Place, Centurion Business Park, Glasgow G41 1HH United Kingdom Tel.: +44 (0) 141 429 2777 Fax: + 44 (0) 141 429 2758 E-Mail (Support): support1@ftdichip.com Web: http://www.ftdichip.com Copyright 2013 Future Technology Devices International Limited

Table of Contents 1 Preface... 3 1.1 Acronyms and Abbreviations... 3 1.2 References... 3 2 Introduction... 4 2.1 Android Device... 5 2.2 FT311D... 5 2.3 FT312D... 5 2.4 Accessories... 5 3 FT311D/FT312D UART interface... 6 3.1 FT311D/FT312D UART-User Layer... 6 3.1.1 SetConfig... 6 3.1.2 SendData... 6 3.1.3 ReadData... 6 3.2 FT311D/FT312D FT311-UART Layer... 7 3.2.1 SetConfig... 7 3.2.2 SendData... 7 3.2.3 ReadData... 7 4 FT311D GPIO Interface... 9 4.1 FT311D GPIO-User Layer... 9 4.1.1 ConfigPort... 9 4.1.2 ReadPort... 9 4.1.3 WritePort... 9 4.1.4 ResetPort... 9 4.2 FT311D FT311-GPIO Layer... 10 4.2.1 ConfigPort... 10 4.2.2 ReadPort... 10 4.2.3 WritePort... 10 4.2.4 ResetPort... 11 5 FT311D PWM Interface... 12 5.1 FT311D PWM-User Layer... 12 5.1.1 SetPeriod... 12 5.1.2 SetDutyCycle... 12 5.1.3 Reset... 12 5.2 FT311D FT311-PWM Layer... 12 5.2.1 SetPeriod... 13 5.2.2 SetDutyCycle... 13 5.2.3 Reset... 13 6 FT311D I 2 C Master Interface... 14 6.1 FT311D I 2 C-User Layer... 14 6.1.1 SetFrequency... 14 6.1.2 ReadData... 14 6.1.3 WriteData... 15 6.1.4 Reset... 15 6.2 FT311D FT311-I2C Layer... 15 6.2.1 SetFrequency... 16 6.2.2 WriteData... 16 6.2.3 ReadData... 16 6.2.4 Reset... 17 7 FT311D SPI Slave Interface... 18 7.1 FT311D SPI Slave-User Layer... 18 7.1.1 SetConfig... 18 7.1.2 SendData... 18 7.1.3 ReadData... 19 7.1.4 Reset... 19 7.2 FT311D FT311-SPISlave Layer... 19 7.2.1 SetConfig... 19 7.2.2 SendData... 19 7.2.3 ReadData... 20 7.2.4 Reset... 20 8 FT311D SPI Master Interface... 21 Copyright 2012-2013 Future Technology Devices International Limited 1

8.1 FT311D SPIMaster-User layer... 21 8.1.1 SetConfig... 21 8.1.2 SendData... 21 8.1.3 ReadData... 21 8.1.4 Reset... 22 8.2 FT311D FT311-SPIMaster Layer... 22 8.2.1 SetConfig... 22 8.2.2 SendData... 22 8.2.3 ReadData... 23 8.2.4 Reset... 23 9 Annex A : UART... 24 10 Annex B : GPIO... 25 11 Annex C : PWM... 26 12 Annex D : I2C... 27 13 Annex E : SPI Slave... 30 14 Annex F : SPI Master... 31 15 Appendix A List of Tables & Figures... 33 15.1 List of Tables... 33 15.2 List of Figures... 33 16 APPENDIX B - Contact Information... 50 17 Appendix C - Revision History... 51 Copyright 2012-2013 Future Technology Devices International Limited 2

1 Preface The FT31xD interface is a proprietary interface for Android Open Accessory development. The FT311D IC provides UART/GPIO/PWM/I2C Master/SPI Slave/SPI Master interfaces for Android devices. The FT312D IC provides an enhanced UART interface for Android devices. Android applications can use these interfaces to communicate with their accessories. Any software code examples given in this document are for information only. The examples are not guaranteed and are not supported by FTDI. 1.1 Acronyms and Abbreviations Terms Description USB Universal Serial Bus FT311D FTDIChip's interface chip for Android Open Accessory development. FT312D FTDIChip's enhanced UART interface chip for Android Open Accessory development. Table 1.1 : Acronyms and Abbreviations 1.2 References FT311D datasheet FT312D datasheet Android Develpers, http://developer.android.com/index.html Copyright 2012-2013 Future Technology Devices International Limited 3

2 Introduction FTDI provides the FT311D and FT312D interface chips for USB Android Open Accessory development. The FT311D provides UART/GPIO/PWM/I2C Master/SPI slave /SPI Master interfaces for Android devices to communicate with their accessories. The FT312D provides a UART interface for Android devices to communicate with their accessories. Android Device (2.3.4 or Higher) USB Device USB USB Host FT311D GPIO/UART/I2C/SPI/PWM Accessories (Robotic ARM, keypads, MCU etc) Figure 2.1 : Android Open Accessory Module with FT311D Android Device (2.3.4 or Higher) USB Device USB USB Host FT312D UART Accessories (Robotic ARM, keypads, MCU etc) Figure 2.2 : Android Open Accessory Module with FT312D Android Open Accessory development requires an Android Device with Android 2.3.4 or higher and FTDI Chip s interface chip, FT311D/FT312D. Users can choose any one of the interfaces provided by FT311D to connect their accessories. This document will specify commands and data protocol for communication between Android Devices and the FT311D/FT312D chip. The Interface between FT311D/FT312D and Accessory follow the standard protocol of the selected Interface. Copyright 2012-2013 Future Technology Devices International Limited 4

As both FT311D/FT312D are interface chips, most of the application control and behavior is implemented in Android device and accessory. 2.1 Android Device Android devices with Android 3.1 or higher version. This document and examples applies to Android 3.1 and above (the Android API changed from version 2.3.4 to 3.1). The android application is launched based on the parameters like manufacturer, model and version defined in the AndroidManifest.xml file. For application development using FT311D/FT312D, Android applications are divided into two parts: Android FTDI FT31xD App <Interface>-User Layer FT311-<Interface> layer Figure 2.3 : Android FTDI FT31xD Application <Interface>-User layer: this layer is not aware of USB interface between Android Device and FT311D/FT312D. The FT311D provides GPIO, UART, PWM, I2C master, SPI slave and SPI Master interfaces. The FT312D provides UART interface. The Android developer will implement their application in this layer and call the functions implemented by FTDI in FT311-<Interface> layer, defined for each supported interface. For reference code, see the Annex for the respective interface. FT311-<Interface> layer: This layer implememts FT311<Interface>Interface class. This layer also implements the USB communication between Android device and FT311D/FT312D. The FT311<Interface>Interface class implements function for <Interface>-User layer to use. Using these functions <Interface>-User layer can talk to FT311D/FT312D. Here Interface could be one of GPIO/UART/PWM/I2C Master/SPI Slave/SPI Master. For communication protocol and data packet format see the sections below for each interface in FT311-<Interface> layer. Note: <Interface>-User layer and FT311-<Interface> layer are 2 java files. The 2 java files have to be compiled together to form the android package file. The different interfaces are selected based on the FT311D/FT312D device connected to the androidandroid device. During USB device enumeration the manufacturer, model and version strings are received from the FT311D/FT312D host device. The androidandroid device matches these strings with the AndroidManifest.xml file to launch the correct application. Each application will support only one interface. The application in the androidandroid device communicatecommunicates to the FT311D/FT312D device using command packets. 2.2 FT311D FT311D acts as USB Host for Android Device. FT311D provides GPIO/PWM/I2C Master/UART/SPI Slave/SPI Master interfaces to connect to accessories. 2.3 FT312D FT312D acts as USB Host for Android Device. FT312D provides a UART interface to connect to accessories. 2.4 Accessories Accessories connects on one of FT311D s GPIO/UART/I2C Master/PWM/SPI Slave/SPI Master interfaces. Accessories can connect on FT312D's UART interface. Accessories could be robotic controllers, keypads, touchpads MCUs etc. Copyright 2012-2013 Future Technology Devices International Limited 5

3 FT311D/FT312D UART interface FT311D and FT312D provide a UART interface, with baud rates from 300 to 921600. The FT311D and FT312D UART transmits data in NRZ data format. FTDI Chip provides FT311UARTInterface class with SetConfig, ReadData, WriteData routines for UART operations and ResumeAccessory, DestroyAccessory for support functions to resume and destroy the accessory operations. For the use of the functions, please see Annex A. The method to add FT311UARTInterface.java into the project in Eclipse environment is: Copy the file into the src directory, e.g src\com\<package name>. Write click on the project name in eclipse package explore, then select new->file->src->com-> package name ->advanced->link to the file. Android FTDI FT311D/ FT312D App UART-User Layer FT311-UART layer USB FT311D/ FT312D UART UART Figure 3.1 : Android FTDI FT31xD UART Application 3.1 FT311D/FT312D UART-User Layer This section describes User APIs of FT311UARTInterface class. 3.1.1 SetConfig Android developers use SetConfig(int baudrate, byte databits, byte stopbits, byte parity,byte flowcontrol) function of FT311UARTInterface class to set baud rate, data bits, stop bits, parity and flow control of FT311D/FT312D UART interface. Note: The Android application must send this configuration before sending any application data. Public void SetConfig(int baudrate, byte databits, byte stopbits, byte parity,byte flowcontrol) baudrate: baud rate, min 300, max 921600, default set to 9600. databits: data bits, 7: 7-bit databits, 8: 8-data bits, default 8-data bits. stopbits: stop bits, 1: 1-stop bits, 2: 2-stop bits, default is set to 1-stop bits. Parity: parity 0: none, 1:odd, 2:even,3:mark and 4:space. default is set to none. flowcontrol: flow control, 0: none, 1-cts/rts, default is set to none. 3.1.2 SendData Android developers use SendData(int numbytes, byte[] buffer) function of FT311UARTInterface class to send the data to FT311D/FT312D UART interface. Public void SendData(int numbytes, byte[] buffer). numbytes: number of bytes to transmit, maximum 256 per transfer. Buffer: pointer to data buffer. 3.1.3 ReadData Android developers use ReadData(int numbytes, byte[] buffer, int []actualnumbytes) function of FT311UARTInterface class to receive UART data. Public void ReadData(int numbytes, byte[] buffer, int []actualnumbytes). numbytes: number of bytes to read, MAX 256 per transfer. Buffer: pointer to buffer pointer. actualnumbytes: the actual number of bytes received. Copyright 2012-2013 Future Technology Devices International Limited 6

3.2 FT311D/FT312D FT311-UART Layer FT311-UART layer implements FT311UARTInterface class. The Android user uses the functions of this class to control,configure UART interfaces. All functions with FT311D and FT312D are the same. The communication between Android device and FT311D/FT312D is done using the maximum 256 bytes long array of 8-bit data. uartdata Table 3.1: UART command format Name Length(byte) Description uartdata N array of N bytes to transfer. The data value. Table 3.2: UART command packet parameters 3.2.1 SetConfig Public void SetConfig(int baudrate, byte databits, byte stopbits, byte parity, byte flowcontrol) The FT311-UART layer sends the 8-bytes of below packet for this command. The remaining bytes of uartdata are reserved for this command. The command packet values for this command are: Name Length Descriptions uartdata[0..3] 4 First 4 bytes holds the baud rate, in little endian format. uartdata[4] 1 Data bits. 7: for 7-bit data bits. 8: for 8-bit data bits. uartdata[5] 1 Number of stop bits. 1: 1- stop bits 2: 2- stop bits. uartdata[6] 1 Parity. 0: none. 1: odd 2: even. 3: mark 4: space uartdata[7] 1 Flow control. 0: none 1: hardware (CTS/RTS) Table 3.3: UART SetConfig command parameters 3.2.2 SendData Public void SendData(int numbytes, byte [] buffer) Android FT311-UART layer uses this command packet to send data using FT311D/FT312D UART interface. Command details are given below: Name Length(byte) Description uartdata N Data to be send. Array of N bytes to be transmitted, maximum 256 bytes. Table 3.4: UART SendData command parameters 3.2.3 ReadData Public void ReadData(int numbytes, byte[] buffer, int []actualnumbytes) Copyright 2012-2013 Future Technology Devices International Limited 7

FT311D/FT312D sends the received data on its UART interface to Android FT311-UART layer in the below packet format. Read Data details are given below: Name Length(byte) Values uartdata N UART data received on the UART interface, maximum 256 bytes. Table 3.5: UART ReadData command parameters Copyright 2012-2013 Future Technology Devices International Limited 8

4 FT311D GPIO Interface FT311D provides 7 GPIOs, that can be configured as input or output. The GPIOs are internally pulled up. By default the IOs are configured as Inputs. FTDI Chip provides FT311GPIOInterface class with ReadPort, WritePort, ConfigPort, ResetPort methods for port operations and ResumeAccessory, DestroyAccessory for support functions to resume and destroy the accessory operations. For the use of the functions, see Annex B. The Android application needs to include FT311GPIOInterface.java file into the project and call the above mentioned class functions to configure, read port, write port and reset port. The method to add FT311GPIOInterface.java into the project in Eclipse environment is: Copy the file into the src directory, e.g src\com\<package name>. Write click on the project name in eclipse package explore, then select new->file->src->com-> package name ->advanced->link to the file. Android FTDI FT311 App GPIO-User Layer FT311-GPIO layer USB FT311D GPIO GPIO Figure 4.1 : Android FTDI FT311D GPIO Application 4.1 FT311D GPIO-User Layer This section describes the User Interface APIs available for GPIO Interface to control, read, write GPIOs. The below listed functions are implemented in FT311-GPIO Interface layer. 4.1.1 ConfigPort Android developer calls the ConfigPort(byte configoutmap, byte configinmap) to configure the FT311D GPIO pins as input or output. Public void ConfigPort(byte configoutmap, byte configinmap). configoutmap: the bits set in this bitmap will be configured as output, bit 0 configuring GPIO0 and so on. configinmap: the bits in this map will be configured as Input, bit 0 configuring GPIO0 and so on. If there is an overlap of input and output bitmap, input bitmap takes precedance. 4.1.2 ReadPort Android developer uses ReadPort() routine of FT311GPIOInterface class to read the FT311D input ports. Public byte ReadPort(). Return value is current level on input signals. 4.1.3 WritePort Android developer uses WritePort(byte outdata) function of FT311GPIOInterface class to write FT311D output ports. The output configured ports will only be driven. Public void WritePort(byte outdata). outdata: the bitmap of output port data, bit 0 corrosponds to GPIO0. 4.1.4 ResetPort Android developer uses ResetPort() function of FT311GPIOInterface class to reset GPIO interface. This command will set all the IOs into input mode. Public void ResetPort(). Copyright 2012-2013 Future Technology Devices International Limited 9

4.2 FT311D FT311-GPIO Layer This layer implements the FT311GPIOInterface class. This class implements User Interface APIs and communicates with the FT311D using USB. FT311-GPIO Interface converts read, write, reset and config port commands into 4 bytes packet format to communicate with FT311D. The first byte, gpiocmd, in the table should be transferred first, and so on. gpiocmd rdwrdata outmap inmap Table 4.1: GPIO command packet format Name Length (bytes) Description gpiocmd 1 GPIO command(configure/ read/write) rdwrdata 1 Read/write data outmap 1 OUTPUT bitmap of port bits, the bits set in this bitmap will be configured as output. inmap 1 INPUT bitmap of port bits, the bits set in this bitmap will be configure as input. Table 4.2: GPIO command packet parameters 4.2.1 ConfigPort Public void ConfigPort(byte outmap, byte inmap). Android FT311-GPIO layer sends the below packet to configure the GPIOs. By default the GPIOs are configured as inputs with internally pulled up. The packet for ConfgPort is as below: Name Length (bytes) Values gpiocmd 1 0x11 rdwrdata 1 0x00, reserved, not used for this command. outmap 1 Bitmap of output port IOs, set bits will be configured as output. inmap 1 Bitmap of input port IOs, set bits will be configured as INPUT. Table 4.3: GPIO ConfigPort command parameters 4.2.2 ReadPort Public byte ReadPort(). FT311D sends the port data to Android layer, whenever there is a change in the signal levels on input ports. Note: this data packet is from FT311D to Android, not from FT311-GPIO layer to FT311D. The packet format for this command is as below: Name Length (bytes) Values gpiocmd 1 0x12 rdwrdata 1 GPIO status outmap 1 0x00 reserved inmap 1 0x00, reserved Table 4.4: GPIO ReadPort command parameters Note: Only input pins are read. 4.2.3 WritePort Public void WritePort(byte outdata). Android FT311-GPIO Layer sends the below packet for a WritePort command. The Android GPIO Write command packet fields are as follows: Name Length (bytes) Values gpiocmd 1 0x13 rdwrdata 1 GPIO data Copyright 2012-2013 Future Technology Devices International Limited 10

outmap 1 0x00, reserved for this command inmap 1 0x00, reserved for this command. Table 4.5: GPIO WritePort command parameters Note: Only output pins are written with the value in rdwrdata. 4.2.4 ResetPort Public void ResetPort(). Android FT311-GPIO layer sends the below 4 byte packet to reset the GPIO interface of the FT311D GPIO. This command resets the GPIO module, and configures all GPIOs as inputs. Name Length(bytes) Values gpiocmd 1 0x14 rdwrdata 1 0x00, reserved for this command. inmap 1 0x00, reserved for this command. outmap 1 0x00, reserved for this command. Table 4.6: GPIO ResetPort command parameters Copyright 2012-2013 Future Technology Devices International Limited 11

5 FT311D PWM Interface FT311D provides 4 PWM channels, pwm0..pwm3. All PWM channels have the same frequency (period). Android applications can specify the frequency of all 4 channels with different duty cycles. FTDI Chip provides FT311PWMInterface class with SetPeriod, SetDutyCycle and Reset methods for PWM operations and ResumeAccessory, DestroyAccessory for support functions to resume and destroy the accessory operations. For the use of the functions, please see Annex C. The Android application needs to include FT311PWMInterface.java file into the project and call the above mentioned class functions to set period, duty cycle and reset. The method to add FT311PWMInterface.java into the project in Eclipse environment is: Copy the file into the src directory, e.g src\com\<package name>. Write click on the project name in eclipse package explore, then select new->file->src->com-> package name ->advanced->link to the file. Android FTDI FT311 App PWM-User Layer FT311-PWM layer USB FT311D PWM PWM Figure 5.1 : Android FTDI FT311D PWM Application 5.1 FT311D PWM-User Layer This section describes the methods of FT311PWMInterface class to be used in User Application layer. 5.1.1 SetPeriod Android developer uses SetPeriod(int period) function of FT311PWMInterface class to set the period of all PWM channels. Public void SetPeriod(int period); Function to set the period of PWM channels. period: period in milliseconds. 1..250, MAX 250 msecs, Minimum 1 msec. 5.1.2 SetDutyCycle Android developer uses SetDutyCycle(byte pwmchannel, byte dutycycle) function of FT311PWMInterface Class to set the duty cycle of the pwm channel. Public void SetDutyCycle(byte pwmchannel, byte dutycycle): function to set the duty cycle of specified pwm channel. pwmchannel: channel number, should be between 0..3 dutycycle: the percentage value of the duty cycle,e.g. to set 50% duty cycle, specify this value as 50. Minimum 5% and Maximum 95%. 5.1.3 Reset FT311PWMInterface class provides Reset() function for Android user to Reset the PWM interface. This function brings the PWM interface to its default state. In the default state, the period is 1msec, and the duty cyle of all the channels is 0. Public void Reset(). 5.2 FT311D FT311-PWM Layer This layer implements the User API for PWM-User interface. FT311PWMInterface class uses the below 4 byte packet format to communicate with FT311D The data is send in the order listed in the table 4.1. For fields of more than one byte, LSB should be sent first. pwmcmd pwmnumber cmddata Table 5.1: PWM command packet format Copyright 2012-2013 Future Technology Devices International Limited 12

Name Length(bytes) Description pwmcmd 1 PWM command. set period, set duty cycle. pwmnumber 1 PWM channel number. cmddata 2 Command Data, depends on type of the command. Table 5.2: PWM command packet parameters 5.2.1 SetPeriod Public void SetPeriod(int period). Android FT311-PWM layer sends the SetPeriod packet to set the period of all channels. The period will be same for all channels. For PWM set period, the PWM packet fields are described below: Name Length(bytes) Description pwmcmd 1 0x21 pwmnumber 1 0x00, reserved for this command packet cmddata 2 Period in milliseconds, MAX 250 and minimum 1 milliseconds. Table 5.3: PWM SetPeriod command parameters 5.2.2 SetDutyCycle Public void SetDutyCycle(byte pwmchannel, byte dutycycle). Android FT311-PWM layer sends SetDutyCycle packet to set the duty cycle of individual channels. Before this command, period for the PWMs should be set. For PWM set duty cycle, the PWM packet fields are described below: Name Length(bytes) Description pwmcmd 1 0x22 pwmnumber 1 Pwm channel number, should be from 0..3. cmddata 2 Duty cycle in numerical percentage(%) number.e.g to set 50% duty, set this value to 50. Minimum 5%, max 95 %. Table 5.4: PWM SetDutyCycle command parameters 5.2.3 Reset Public void Reset(). Android FT311-PWM layer sends this command to reset the PWM module into default state, i.e. set the period to 1 msecms and set the duty cycle of all channels to zero. The command packet for this command is as follows: Name Length(bytes) Description pwmcmd 1 0x23 pwmnumber 1 0x00, reserved for this command. cmddata 2 0x00, reserved for this command. Table 5.5: PWM Reset command parameters Copyright 2012-2013 Future Technology Devices International Limited 13

6 FT311D I 2 C Master Interface FT311D provides I 2 C master interface, running Max 92 Khz. FT311D does not provide I 2 C slave functionality. Note: FT311D I 2 C master does not support clock stretching, or multi-master support. FTDI Chip provides FT311I2CInterface class with Reset, SetFrequency, ReadData and WriteData routines for I 2 C operations and ResumeAccessory, DestroyAccessory for support functions to resume and destroy the accessory operations. For the use of the functions, please see Annex D The Android application needs to include FT311I2CInterface.java file into the project. The method to add FT311I2CInterface.java into the project in Eclipse environment is: Copy the file into their src directory, e.g src\com\<package name>. Right click on the project name in eclipse package explore, then select new->file->src->com-> package name ->advanced->link to the file. Android FTDI FT311 App I2C-User Layer FT311-I2C layer USB FT311D I2C Master I2C Figure 6.1 : Android FTDI FT311D I 2 C Master Application 6.1 FT311D I 2 C-User Layer This section describes the User APIs of FT311I2CInterface class to control, read,and write I²C bus. 6.1.1 SetFrequency FT311D provides a set of values in units of KHz for I 2 C frequency. The user has to call SetFrequency(byte freq) function of FT311I2CInterface class to set the frequency of I 2 C interface. By default it s set to 92Khz. Public void SetFrequency(byte freq). Freq: frequency in units of KHz. The supported values are: 23,44,60,92. 6.1.2 ReadData Android developer uses ReadData(byte i2cdeviceaddress, byte transferoptions, byte numbytes,byte[] buffer, byte []actualbytes) function to read data. Public byte ReadData(byte i2cdeviceaddress, byte transferoptions,byte numbytes,byte[] buffer,byte []actualbytes) I2cDeviceAddress: 7-bits address of I 2 C device. transferoptions: specifies the data transfer options. The bit position defined for each of the options are, BIT0: if set then a start condition is generated in the I 2 C bus before the transfer begins. A bit mask is defined for this option in file I2CDemoActivity.java as boption.start_bit BIT1: if set then a stop condition is generated in the I 2 C bus after the transfer ends. A bit mask is defined for this option in file I2CDemoActivity.java as boption.stop_bit BIT2: some I 2 C slaves require the I 2 C master to generate a NAK for the last data byte read. Setting this bit enables working with such I 2 C slaves. A bit mask is defined for this options in file I2CDemoActivity.java as boption.nack_last_byte BIT3: the deviceaddress parameter is ignored if this bit is set. This feature may be useful in generating a special I 2 C bus conditions that do not require any address to be passed. A bit mask is defined for this options in file I2CDemoActivity.java as boption.no_device_address Bit4-7: Reserved numbytes: number of bytes to read, maximum 252 bytes per transaction. buffer: an array of bytes. actualbytes: the number of actual bytes read. Copyright 2012-2013 Future Technology Devices International Limited 14

The return value is a 8-bit bitmap of status, as described below: Bit Value/description 0 command status. 1: error, general error 0: command passed. 1 1: nack, device can not accept any more data. 2 1: invalid address. 3..7 Reserved for future use. Table 6.1: I 2 C Read return status This command will complete with one of the following status bits: Bit 0: set or cleared. Bit 2: set, invalid device address. 6.1.3 WriteData Android Developers use WriteData(byte i2cdeviceaddress,byte transferoptions,byte numbytes, byte[] buffer, byte [] actualnumbytes) function to write the I 2 C data to slave. Public byte WriteData(byte i2cdeviceaddress, byte transferoptions, byte numbytes, byte [] buffer,byte [] actualnumbytes). I2cDeviceAddress: 7-bit device address transferoptions: specifies the data transfer options.the bit position defined for each of the options are, BIT0: if set then a start condition is generated in the I 2 C bus before the transfer begins. A bit mask is defined for this options in file I2CDemoActivity.java as boption.start_bit BIT1: if set then a stop condition is generated in the I 2 C bus after the transfer ends. A bit mask is defined for this options in file I2CDemoActivity.java as boption.stop_bit BIT2: Reserved BIT3: the deviceaddress parameter is ignored if this bit is set. This feature may be useful in generating a special I 2 C bus conditions that do not require any address to be passed. A bit mask is defined for this options in file I2CDemoActivity.java as boption.no_device_address Bit4-7: Reserved numbytes: number of bytes to write,maximum 252 bytes per transfer. buffer: array of bytes to data. actualnumbytes: actual number of bytes send. Returns value is a bitmap of 8-bits as below: Bit Value/description 0 command status. 1: error, general error 0: command passed. 1 1: nack, device can not accept any more data. 2 1: inavlid address. 3..7 Reserved for future use. Table 6.2: I 2 C Write return status The command can complete with: Bit 0: set or clear. Bit 1: set or clear, if set, check the actual length parameter to check the written bytes. Bit 2: Invalid address bit 2 set. 6.1.4 Reset Android developers use Reset() function of FT311I2CInterface class to reset the interface. This function will set the I 2 C interface to default state, 92 KHZ frequency. Public void Reset(). 6.2 FT311D FT311-I2C Layer This layer implements the I²C-User layer functions in FT311I2CInterface class. FT311I2CInterface class uses 5 bytes command packet to communicate with I 2 C slave. The packet bytes are sent in the order listed in table 5.3, first column byte goes first and so on. i2ccmd i2ccmddata0 I2cCmdData1 i2cdatalength i2cdata Copyright 2012-2013 Future Technology Devices International Limited 15

Table 6.3: I 2 C command packet format Name Length(bytes) Description i2ccmd 1 I 2 C command; read, write, set frequency, reset. i2ccmddata0 1 I 2 C command specific data0. i2ccmddata1 1 I 2 C command specific data1. i2cdatalength 1 The number of read/write bytes, maximum per command packet 252 bytes. i2cdata N Array of data bytes, maximum N is 252 bytes per transfer. Table 6.4: I 2 C command packet parameters 6.2.1 SetFrequency Public void SetFrequency(byte freq). Android FT311-I2C interface class, sends the below packet format for this command: Name Length(bytes) Values i2ccmd 1 0x31 i2ccmddata0 1 Frequency value, in KHz units of freq. Possible values are 23,44, 60 and 92. I2cCmdData1 1 0x00, reserved for this command. i2cdatalength 1 0x00, reserved not used for this command. i2cdata 1 0x00, reserved not used for this command. Table 6.5: I 2 C SetFrequency command parameters 6.2.2 WriteData Public byte WriteData(byte i2cdeviceaddress, byte address, byte numbytes, byte [] buffer,byte []actualnumbytes). Android FT311-I2C layer sends the below packet for this command. The command values are : Name Length(bytes) Values i2ccmd 1 0x32 i2ccmddata0 1 I 2 C device address, 7-bit. I2cCmdData1 1 Data transfer options. i2cdatalength 1 n,length of the data to be transferred, Max value of n per transfer is 252 bytes. i2ccmddata N Array of n bytes that Android wants to write.max data length is 252 bytes. Table 6.6: I 2 C WriteData command parameters FT311D sends to Android FT311-I2C layer the below response after completion of this command. Name Length(bytes) Values i2ccmd 1 0x32 i2ccmddata0 1 Status. I2cCmdData1 1 0x00, reserved i2cdatalength 1 Actual data bytes written, max 252 bytes. Table 6.7: I 2 C WriteData response parameters Status byte for the WriteData command is: Bit Value/description 0 This bit is only effective if Bit 0 is cleared. 1: error, general error 0: command passed. 1 1:nack, device can not accept any more data. 2 1:inavlid address. 3..7 Reserved for future use. Table 6.8: I 2 C WriteData return status 6.2.3 ReadData Public byte ReadData(byte i2cdeviceaddress, byte address, byte numbytes, byte [] buffer,byte []actualnumbytes). Copyright 2012-2013 Future Technology Devices International Limited 16

Android FT311-I²C layer sends the below packet to FT311D for this command. The command values are: Name Length(bytes) Values i2ccmd 1 0x33 i2ccmddata0 1 I 2 C device address i2ccmddata1 1 Data transfer options. i2cdatalength 1 n, Length of the data to be read, maximum 252 bytes per transfer. Table 6.9: I 2 C ReadData command parameters FT311D sends read data back to Android device FT311-I²C layer in the below format. Name Length(byte) Values i2ccmd 1 0x33 I2cCmdData0 1 Status. I2cCmdData1 1 0x00, reserved i2cdatalength 1 Length of the read data, max 252 bytes I2cData N Array of N bytes, N max is 252 Table 6.10: I 2 C ReadData response parameters Status byte for ReadData command is: Bit Value/description 0 command status: 1: error, general error 0: command passed. 1 1: nack, device can not accept any more data. 2 1: invalid address. 3..7 Reserved for future use. Table 6.11: I 2 C ReadData return status 6.2.4 Reset Public void Reset() Android FT311-I²C layer creates the below packet for this command. Name Length(byte) Values I2cCmd 1 0x34 I2cCmdData0 1 0x00, reserved I2cCmdData1 1 0x00, reserved I2cDataLength 1 0x00, reserved I2cdata 1 0x00, reserved. Table 6.12: I 2 C Reset command parameters Copyright 2012-2013 Future Technology Devices International Limited 17

7 FT311D SPI Slave Interface FT311D provides a SPI slave interface with supported clock rates of upto 24MHz. SPI slave will transfer data in MSBit/LSBit of byte based on the configuration. FTDI Chip provides FT311SPISlaveInterface class with SetConfig, SendData, ReadData, Reset routines for SPI Slave operations and ResumeAccessory, DestroyAccessory for support functions to resume and destroy the accessory operations. For the use of the functions, please see Annex E. The Android application needs to include FT311SPISlaveInterface.java file into the project and call the FT311SPISlaveInterface functions. The method to add FT311SPISlaveInterface.java into the project in Eclipse environment is: Copy the file into the src directory, e.g src\com\<package name>. Write click on the project name in eclipse package explore, then select new->file->src->com-> package name ->advanced->link to the file. Android FTDI FT311 App SPISlave-User Layer FT311-SPISlave layer USB FT311D SPI Slave SPI Figure 7.1 : Android FTDI FT311D SPI Slave Application 7.1 FT311D SPI Slave-User Layer This layer uses the User functions of FT311-SPISlave layer to configure, read, and write SPI slave interface. 7.1.1 SetConfig Android developers use SetConfig(byte clockphase, byte dataorder) function of FT311SPISlaveInterface class to config clock phase and data order of the SPI slave. Public void SetConfig(byte clockphase, byte dataorder). clockphase: Clock phase variable values for different modes, default is set to mode 1. 0: CPOL=0, CPHA=0. 1: CPOL=0, CPHA=1.(default) 2: CPOL=1, CPHA=0. 3: CPOL=1, CPHA=1. dataorder: order of data on the SPI bus 0: MSB 1: LSB 7.1.2 SendData Android developers use SendData(byte numbytes, byte[] buffer, byte[] actualnumbytes) of FT311SPISlaveInterface class to send data to the SPI master. Public byte SendData(byte numbytes, byte[] buffer, byte []actualnumbytes). numbyte: number of bytes to transfer, maximum 255 per transfer. buffer: array of buffer. actualnumbytes : actual number of bytes send Note: The SPI transactions are host initiated, so once this command is initiated by the SPI slave, the data is queued for the SPI host to read. If the SPI host did not issue read/write, the data will stay in queue and the SPI slave can not queue anymore data. Copyright 2012-2013 Future Technology Devices International Limited 18

7.1.3 ReadData Android developers use ReadData(byte numbytes, byte [] buffer, byte []actualnumbytes) function of FT311SPISlaveInterface class to Read data. Public byte ReadData(byte numbytes, byte [] buffer, byte []actualnumbytes). numbytes: number of bytes to read. buffer: array of length of numbytes. actualnumbytes: actual number of bytes read, max 255 bytes. 7.1.4 Reset Android developers use Reset() function of FT311SPISlaveInterface to reset the SPI slave interface of the FT311D. The default setting sets the clock phase and polarity to mode 1. Public void Reset(). 7.2 FT311D FT311-SPISlave Layer Android FT311-SPISlave layer implements FT311SPISlaveInterface class. The function implemented in this class are used by SPISlave-User layer to communicate with FT311D The communication between Android device and FT311D is done using the below defined packet format. spicmd Table 7.1: SPI Slave command format spidata Name Lentgh (bytes) Description spicmd 1 FT311D communication protocol command. spidata[n] N An array of 8-bits to hold read/write SPI data.value of N should be less than or equal 255 bytes Table 7.2: SPI Slave command packet parameters 7.2.1 SetConfig Public void SetConfig(byte clockphase, byte dataorder). The Android FT311-SPISlave layer uses this command to set clock polarity and phase of FT311D SPI slave Interface. The command packet values are provided below: Name Length(bytes) Values spicmd 1 0x51 spidata 1 Clock phase. 0: CPOL=0, CPHA=0. 1: CPOL=0, CPHA=1. default 2: CPOL=1, CPHA=0. 3: CPOL=1, CPHA=1. spidataorder 1 Data order on the SPI bus 0: MSB 1: LSB Table 7.3: SPI Slave SetConfig command parameters 7.2.2 SendData Public byte SendData(byte numbytes, byte[] buffer, byte []actualnumbytes). The Android device can schedule data to be sent to the SPI Master, eventually the SPI Master has to initiate a read command to read this data. Android FT311-SPISlave layer creates the below packet to transmit the SPI data. Name Length(byte) Values spicmd 1 0x52 spidata[n] N Array of N bytes, specified by numbytes. Maximum length is 255 bytes. Table 7.4: SPI Slave SendData command parameters Copyright 2012-2013 Future Technology Devices International Limited 19

FT311D sends the below command back to Android FT311-SPISlave layer in response to this command. Name Length(byte) Values spicmd 1 0x52 spidatalength 1 Length of send data bytes Table 7.5: SPI Slave response parameters 7.2.3 ReadData FT311D will send the received data from SPI Master to Android application s FT311-SPISlave layer. SPISlave-User layer can read this data with ReadData command as described in section 7.1.3. FT311D sends the data to Android FT311-SPISlave layer in below mentioned format: Name Length(byte) Value spicmd 1 0x53 spidata[n] N Array of N bytes send by SPI Master, maximum length is 255. Table 7.6: SPI Slave ReadData command parameters 7.2.4 Reset Android FT311-SPISlave class uses this function to reset the SPI Slave into default state. The one byte packet for this command is as below: Name Length(byte) Values spicmd 1 0x54 Table 7.7: SPI Slave Reset command parameters Copyright 2012-2013 Future Technology Devices International Limited 20

8 FT311D SPI Master Interface FT311D provides a SPI master supporting max clock rate of 24 Mhz. FT311D s SPI master will transfer data in MSBit/LSBit of byte based on the configuration. FTDIChip provides FT311SPIMasterInterface class with SetConfig, SendData, ReadData and Reset routines for SPI Master operations and ResumeAccessory, DestroyAccessory for Android support. For the use of the functions, please see Annex F. The Android Application needs to include FT311SPIMasterInterface.java file into the project and call the FT311SPIMasterInterface functions. The method to add FT311SPIMasterInterface.java into the project in Eclipse environment is: Copy the file into the src directory, e.g src\com\<package name>. Write click on the project name in eclipse package explore, then select new->file->src->com-> package name ->advanced->link to the file. Android FTDI FT311 App SPIMaster-User Layer FT311-SPIMaster layer USB FT311D SPI Master SPI Figure 8.1 : Android FTDI FT311D SPI Master Application 8.1 FT311D SPIMaster-User layer This layer uses the functions of FT311-SPIMaster layer, implemented in FT311SPIMasterInterface.java file, to configure SPI interface, read, write SPI data. 8.1.1 SetConfig Android developers use SetConfig(byte clockphase, byte dataorder, int clockspeed) function of FT311SPIMasterInterface class to configure clock phase, data order and clock speed of SPI Master interface. Public void SetConfig(byte clockphase,byte dataorder, int clockspeed). clockphase: Clock phase and polarity of SPI master interface, default is set to mode 1. 0: CPOL=0, CPHA=0 (mode 0). 1: CPOL=0, CPHA=1 (mode 1). 2: CPOL=1, CPHA=0 (mode 2). 3: CPOL=1, CPHA=1 (mode 3). dataorder: data oder on the SPI bus 0: MSB 1:LSB clockspeed:frequency of SPI interface. Defaut is set to 3 MHz and maximum is 24Mhz. 8.1.2 SendData Android developers use SendData(byte numbytes, byte[] buffer, byte []numbytessend) function of FT311SPIMasterInterface class to send the data to SPI slave. SPI master sends data in MSBit/LSBit first format. public byte SendData(byte numbytes, byte [] buffer, byte [] numbytessend). numbytes: number of bytes to send. maximum is 255. buffer: pointer to data to transmit. numbytessend: the actual bytes send. 8.1.3 ReadData Android developers use ReadData(byte numbytes, byte[] buffer, byte [] numbytesread) function of FT311SPIMasterInterface class to read SPI data. The buffer values are set to 0xff for SPI Master Read operation. Public byte ReadData(byte numbytes, byte[] buffer, byte [] numbytesread). Copyright 2012-2013 Future Technology Devices International Limited 21

numbytes: number of bytes to read. Maximum value is 255. Buffer: pointer to buffer to read data into. numbytesread: actual number of bytes read. 8.1.4 Reset Android developers use Reset() function of FT311SPIMasterInterface class to reset the SPI Master interface. It resets the SPI interface to default state, i.e SPI clock frequency of 3Mhz, clock and phase to mode 1 and data order to MSB. Public void Reset(void). 8.2 FT311D FT311-SPIMaster Layer This layer implements FT311SPIMasterInterface class. The functions use a Maximum 256 byte long packet format to communicate with FT311D. The format of Packet is described below for each command. Table 8.1 The packet for SPI master to communicate with FT311D spicmd Table 8.1: SPI Master command format spidata Name Length Description spicmd 1 SPI command identifier. spidata N SPI master command data. Maximum length is 255. Table 8.2: SPI Master command packet parameters 8.2.1 SetConfig Public void SetConfig(byte clockphase, byte dataorder, int clockspeed). Android FT311-SPIMaster layer sends the 4 bytes packet format for this command. The command packet for this command is as follows: Name Length Description spicmd 1 0x61 spidata[0] 1 clockphase, the clock phase and polarity value to configure SPI master. 0: CPOL=0, CPHA=0 (mode 0). 1: CPOL=0, CPHA=1 (mode 1). 2: CPOL=1, CPHA=0 (mode 2). 3: CPOL=1, CPHA=1 (mode 3). spidata[1] 1 Data order on the SPI bus 0: MSB 1: LSB spidata[2..5] 4 clockspeed, The baud rate in little endian format. Max is 24Mhz, default is set to 3 Mhz Table 8.3: SPI Master Setconfig command parameters 8.2.2 SendData Public byte SendData(byte numbytes, byte [] buffer, byte [] numbytessend). Android FT311-SPIMaster layer sends the below packet format for this comamnd. Name Length Description spicmd 1 0x62, command identifier for SPI master Send Data. spidata[n] numbytes The pointer to buffer to send. The buffer length can not be more than 255. Table 8.4: SPI Master SendData command parameters In response to this command, the FT311D sends the below packet to the Android FT311-SPIMaster layer: Name Lentgh Description spicmd 1 0x62 spidata[n] numbytes The data read while sending the data Copyright 2012-2013 Future Technology Devices International Limited 22

Table 8.5: SPI Master SendData response parameters to SPI slave 8.2.3 ReadData Public byte ReadData(byte numbytes,byte [] buffer, byte []numbytesread). Android FT311-SPIMaster layer sends the 2 byte long packet for this command. The command packet for ReadData is as follows: Name Length Description spicmd 1 0x63 spidata[n] numbytes numbytes long buffer, with values set to 0xff. The max value of numbytes should be less than or equal to 255. Table 8.6: SPI Master ReadData command parameters In response to this command, the FT311D sends the read data to FT311-SPIMaster layer. The FT311D uses the below packet to send the read data to Android: Name Length Description spicmd 1 0x63 spidata[n] numbytes numbytes long buffer pointer with values read from SPI slave. The maximum value of numbytes should be less than or equal to 255. Table 8.7: SPI Master ReadData response parameters 8.2.4 Reset Public void Reset(). This command will reset the SPI master interface into default state, i.e clock frequency of 3Mhz, clock phase and polarity to mode 1 and data order to MSB. The Android FT311-SPIMaster layer sends 1 packet for this command. Name Length Description spicmd 1 0x64 Table 8.8: SPI Master Reset command parameters Copyright 2012-2013 Future Technology Devices International Limited 23

9 Annex A : UART /* configure the UART */ configbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub configbutton.setbackgroundresource(drawable.start); uartinterface.setconfig(baudrate, databit, stopbit, parity, flowcontrol); ); /* read data */ public void run() while(true) Message msg = mhandler.obtainmessage(); try Thread.sleep(50); catch(interruptedexception e) status = uartinterface.readdata((byte)64, readbuffer, actualnumbytes); mhandler.sendmessage(msg); /*write data*/ writebutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub writebutton.setbackgroundresource(drawable.start); if(writetext.length()!= 0x00) numbytes = (byte)writetext.length(); for(count=0;count<numbytes;count++) writebuffer[count] = writetext.gettext().charat(count); status = uartinterface.senddata(numbytes, writebuffer); ); Copyright 2012-2013 Future Technology Devices International Limited 24

10 Annex B : GPIO /*user code to configure port data*/ configbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub configbutton.setbackgroundresource(drawable.start); togglebutton0.setchecked(false); togglebutton1.setchecked(false); togglebutton2.setchecked(false); togglebutton3.setchecked(false); togglebutton4.setchecked(false); togglebutton5.setchecked(false); togglebutton6.setchecked(false); outdata &= ~outmap; writedata.settext("0x" + Integer.toHexString(outData & 0xff)); gpiointerface.configport(outmap, inmap); ); /*user code to read the accessory data*/ readbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub readbutton.setbackgroundresource(drawable.start); indata = gpiointerface.readport(); ProcessReadData(inData); ); /*user code to write port*/ writebutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub writebutton.setbackgroundresource(drawable.start); /*send only the output mapped data*/ outdata &= outmap; writedata.settext("0x" + Integer.toHexString(outData & 0xff)); gpiointerface.writeport(outdata); ); Copyright 2012-2013 Future Technology Devices International Limited 25

11 Annex C : PWM /* set the period */ periodbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub periodbutton.setbackgroundresource(drawable.start); /*read the period value*/ if(periodvalue.length() == 0x00) periodvalue.settext("1"); period = Integer.parseInt(periodValue.getText().toString()); /*take care of zero*/ if(period == 0x00) period = 1; periodvalue.settext("1"); pwminterface.setperiod(period); ); /* set duty cycle */ public void onprogresschanged(seekbar seekbar, int progress, boolean fromuser) // TODO Auto-generated method stub dutycycle = (byte)progress; dutycycle1value.settext(integer.tostring(progress));; pwminterface.setdutycycle((byte)1,dutycycle); Copyright 2012-2013 Future Technology Devices International Limited 26

12 Annex D : I2C /*Set the frequency*/ freqbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub /*read the bytes from the write box*/ if(freqtext.length()!= 0) deviceaddress = (byte) Integer.parseInt(freqText.getText().toString()); else deviceaddress = 92; /*default*/ ); freqtext.settext(integer.tostring(deviceaddress)); i2cinterface.setfrequency(deviceaddress); /*read data from the I2C slave */ readbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub readbutton.setbackgroundresource(drawable.start); /*for every read, clear the previous read*/ readtext.settext(""); status = 0x00; /*do the sanity checks*/ /*device address?*/ if(deviceaddresstext.length() == 0) status = 0x4; /*address to read from*/ if(addresstext.length() == 0) status = 0x04; /*if all good, then only proceed to read*/ if(status == 0x00) deviceaddress = (byte) Integer.parseInt(deviceAddressText.getText().toString()); numbytes = (byte)integer.parseint(numbytestext.gettext().tostring()); address = (byte)integer.parseint(addresstext.gettext().tostring()); /*blocking call*/ byte transferoptions; transferoptions = boption.start_bit; bytecount = 0; writebuffer[bytecount++] = address; /* write the address first without stop condition */ status = i2cinterface.writedata(deviceaddress, transferoptions, bytecount, writebuffer, actualnumbytes); Copyright 2012-2013 Future Technology Devices International Limited 27

/*read the bytes from the text box*/ transferoptions=(boption.start_bit boption.stop_bit boption.nack_last_byte); status = i2cinterface.readdata(deviceaddress, transferoptions, numbytes, readbuffer, actualnumbytes); /*for(count = 0;count<(actualNumBytes[0]-1);count++) readtext.append(integer.tostring(readbuffer[count])); readtext.append(","); readtext.append(integer.tostring(readbuffer[count]));*/ char [] displayreadbuffer; displayreadbuffer = new char[60]; int displayactualnumbytes; displayactualnumbytes = actualnumbytes[0]; for(count = 0;count<(actualNumBytes[0]);count++) displayreadbuffer[count] = (char)readbuffer[count]; readtext.append(string.copyvalueof(displayreadbuffer,0, displayactualnumbytes)); ); statustext.settext("0x"+integer.tohexstring(status)); /* write data to I2C slave device */ writebutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub writebutton.setbackgroundresource(drawable.start); /*by default, status is good*/ status = 0x00; /*do the sanity checks for required values*/ /*device address needed??*/ if(writedeviceaddresstext.length() == 0) status = 0x4; /*the write values have to be specified*/ if(writetext.length() == 0) status = 1; /*general error*/ /*also need the address to write to*/ if(writeaddresstext.length() == 0) status = 0x04; /*if all good??/* if(status == 0x00) /*read the bytes from the write box*/ deviceaddress = (byte) Integer.parseInt(writeDeviceAddressText.getText().toString()); numbytes = (byte) writetext.length(); address = (byte)integer.parseint(writeaddresstext.gettext().tostring()); Copyright 2012-2013 Future Technology Devices International Limited 28

); /*parse the string*/ bytecount = 0; tempcount = 0; /* insert 1 byte address at the start, add 1 address byte*/ writebuffer[bytecount++] = address; bytecount += (byte)writetext.length(); for(count=0;count<numbytes;count++) writebuffer[count+1] = (byte)writetext.gettext().charat(count); /* subtract 1 for the address byte */ writenumbytestext.settext(integer.tostring(bytecount-1)); /*blocking call*/ byte transferoptions; transferoptions = (boption.start_bit boption.stop_bit); status = i2cinterface.writedata(deviceaddress, transferoptions, bytecount, writebuffer, actualnumbytes); writestatustext.settext("0x"+integer.tohexstring(status)); Copyright 2012-2013 Future Technology Devices International Limited 29

13 Annex E : SPI Slave /*config SPI Slave interface */ configbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) configbutton.setbackgroundresource(drawable.start); clockphasemode = (byte)clockphasespinner.getselecteditemposition(); dataorderselected = (byte)dataorderspinner.getselecteditemposition(); spisinterface.setconfig(clockphasemode,dataorderselected); ); /* read data */ public void run() while(true) Message msg = mhandler.obtainmessage(); try Thread.sleep(50); catch(interruptedexception e) numreadwritten[0] = 0x00; status = spisinterface.readdata((byte)64, readbuffer, numreadwritten); mhandler.sendmessage(msg); /*write data*/ writebutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub writebutton.setbackgroundresource(drawable.start); numreadwritten[0] = 0x00; /*parse the string*/ bytecount = 0; tempcount = 0; /*read the bytes from the write box*/ if(writetext.length()!= 0) bytecount = (byte)writetext.length(); for(count=0; count < bytecount; count++) readbuffer[count] = (byte)writetext.gettext().charat(count); /*send only when there is something to be send*/ if(bytecount!= 0x00) status = spisinterface.senddata(bytecount, readbuffer, numreadwritten); writestatustext.settext(integer.tostring(numreadwritten[0])); ); Copyright 2012-2013 Future Technology Devices International Limited 30

14 Annex F : SPI Master /*config the SPI Master Interface*/ configbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) configbutton.setbackgroundresource(drawable.start); if(clockfreqtext.length() == 0x00) clockfreqtext.settext(integer.tostring(3000000)); ); clockphasemode = (byte)clockphasespinner.getselecteditemposition(); dataorderselected = (byte)dataorderspinner.getselecteditemposition(); clockfreq = Integer.parseInt(clockFreqText.getText().toString()); spiminterface.setconfig(clockphasemode, dataorderselected, clockfreq); /* read data */ readbutton.setonclicklistener(new View.OnClickListener() @Override public void onclick(view v) // TODO Auto-generated method stub readbutton.setbackgroundresource(drawable.start); numreadwritten[0] = 0x00; if(numbytestext.length()!= 0) numbytes = (byte)integer.parseint(numbytestext.gettext().tostring()); for(count=0;count<numbytes;count++) readwritebuffer[count]=(byte)0xff; status = spiminterface.readdata(numbytes, readwritebuffer, numreadwritten); char [] displayreadbuffer; displayreadbuffer = new char[64]; int displayactualnumbytes; displayactualnumbytes = numreadwritten[0]; for(count = 0;count<(numReadWritten[0]);count++) displayreadbuffer[count] = (char)readwritebuffer[count]; readtext.append(string.copyvalueof(displayreadbuffer, 0, displayactualnumbytes)); ); statustext.settext(integer.tostring(numreadwritten[0])); /*write data*/ writebutton.setonclicklistener(new View.OnClickListener() Copyright 2012-2013 Future Technology Devices International Limited 31

@Override public void onclick(view v) // TODO Auto-generated method stub writebutton.setbackgroundresource(drawable.start); numreadwritten[0] = 0x00; /*parse the string*/ bytecount = 0; tempcount = 0; /*read the bytes from the write box*/ if(writetext.length()!= 0) numbytes = (byte) writetext.length(); bytecount = (byte)writetext.length(); for(count=0; count < bytecount; count++) readwritebuffer[count] = (byte)writetext.gettext().charat(count); /*send only when there is something to be send*/ if(bytecount!= 0x00) status = spiminterface.senddata(bytecount, readwritebuffer, numreadwritten); ); writestatustext.settext(integer.tostring(numreadwritten[0])); Copyright 2012-2013 Future Technology Devices International Limited 32

15 Appendix A List of Tables & Figures 15.1 List of Tables Table 1.1 : Acronyms and Abbreviations... 3 Table 3.1: UART command format... 7 Table 3.2: UART command packet parameters... 7 Table 3.3: UART SetConfig command parameters... 7 Table 3.4: UART SendData command parameters... 7 Table 3.5: UART ReadData command parameters... 8 Table 4.1: GPIO command packet format... 10 Table 4.2: GPIO command packet parameters... 10 Table 4.3: GPIO ConfigPort command parameters... 10 Table 4.4: GPIO ReadPort command parameters... 10 Table 4.5: GPIO WritePort command parameters... 11 Table 4.6: GPIO ResetPort command parameters... 11 Table 5.1: PWM command packet format... 12 Table 5.2: PWM command packet parameters... 13 Table 5.3: PWM SetPeriod command parameters... 13 Table 5.4: PWM SetDutyCycle command parameters... 13 Table 5.5: PWM Reset command parameters... 13 Table 6.1: I 2 C Read return status... 15 Table 6.2: I 2 C Write return status... 15 Table 6.3: I 2 C command packet format... 16 Table 6.4: I 2 C command packet parameters... 16 Table 6.5: I 2 C SetFrequency command parameters... 16 Table 6.6: I 2 C WriteData command parameters... 16 Table 6.7: I 2 C WriteData response parameters... 16 Table 6.8: I 2 C WriteData return status... 16 Table 6.9: I 2 C ReadData command parameters... 17 Table 6.10: I 2 C ReadData response parameters... 17 Table 6.11: I 2 C ReadData return status... 17 Table 6.12: I 2 C Reset command parameters... 17 Table 7.1: SPI Slave command format... 19 Table 7.2: SPI Slave command packet parameters... 19 Table 7.3: SPI Slave SetConfig command parameters... 19 Table 7.5: SPI Slave response parameters... 20 Table 7.6: SPI Slave ReadData command parameters... 20 Table 8.1: SPI Master command format... 22 Table 8.2: SPI Master command packet parameters... 22 Table 8.3: SPI Master Setconfig command parameters... 22 Table 8.4: SPI Master SendData command parameters... 22 Table 8.5: SPI Master SendData response parameters... 23 Table 8.6: SPI Master ReadData command parameters... 23 Table 8.7: SPI Master ReadData response parameters... 23 Table 8.8: SPI Master Reset command parameters... 23 15.2 List of Figures Figure 2.1 : Android Open Accessory Module with FT311D... 4 Figure 2.2 : Android Open Accessory Module with FT312D... 4 Figure 2.3 : Android FTDI FT31xD Application... 5 Figure 3.1 : Android FTDI FT31xD UART Application... 6 Figure 4.1 : Android FTDI FT311D GPIO Application... 9 Figure 5.1 : Android FTDI FT311D PWM Application... 12 Figure 6.1 : Android FTDI FT311D I 2 C Master Application... 14 Figure 7.1 : Android FTDI FT311D SPI Slave Application... 18 Figure 8.1 : Android FTDI FT311D SPI Master Application... 21 Copyright 2012-2013 Future Technology Devices International Limited 33

16 APPENDIX B - Contact Information Head Office Glasgow, UK Future Technology Devices International Limited Unit 1, 2 Seaward Place, Centurion Business Park Glasgow G41 1HH United Kingdom Tel: +44 (0) 141 429 2777 Fax: +44 (0) 141 429 2758 E-mail (Sales) E-mail (Support) E-mail (General Enquiries) sales1@ftdichip.com support1@ftdichip.com admin1@ftdichip.com Branch Office Tigard, Oregon, USA Future Technology Devices International Limited (USA) 7130 SW Fir Loop Tigard, OR 97223 USA Tel: +1 (503) 547 0988 Fax: +1 (503) 547 0987 E-Mail (Sales) E-Mail (Support) E-Mail (General Enquiries) us.sales@ftdichip.com us.support@ftdichip.com us.admin@ftdichip.com Branch Office Taipei, Taiwan Future Technology Devices International Limited (Taiwan) 2F, No. 516, Sec. 1, NeiHu Road Taipei 114 Taiwan, R.O.C. Tel: +886 (0) 2 8791 3570 Fax: +886 (0) 2 8791 3576 E-mail (Sales) E-mail (Support) E-mail (General Enquiries) tw.sales1@ftdichip.com tw.support1@ftdichip.com tw.admin1@ftdichip.com Branch Office Shanghai, China Room 1103, No. 666 West Huaihai Road, Shanghai, 200052 China Tel: +86 21 62351596 Fax: +86 21 62351595 E-mail (Sales) E-mail (Support) E-mail (General Enquiries) cn.sales@ftdichip.com cn.support@ftdichip.com cn.admin@ftdichip.com FT311D and FT312D are parts of Future Technology Devices International Ltd. Neither the whole nor any part of the information contained in, or the product described in this manual, may be adapted or reproduced in any material or electronic form without the prior written consent of the copyright holder. This product and its documentation are supplied on an as-is basis and no warranty as to their suitability for any particular purpose is either made or implied. Future Technology Devices International Ltd will not accept any claim for damages howsoever arising as a result of use or failure of this product. Your statutory rights are not affected. This product or any variant of it is not intended for use in any medical appliance, device or system in which the failure of the product might reasonably be expected to result in personal injury. This document provides preliminary information that may be subject to change without notice. No freedom to use patents or other intellectual property rights is implied by the publication of this document. Future Technology Devices International Ltd, Unit 1, 2 Seaward Place, Centurion Business Park, Glasgow G41 1HH United Kingdom. Scotland Registered Number: SC136640 Copyright 2012-2013 Future Technology Devices International Limited 50

17 Appendix C - Revision History Document Title: FT31xD Android Programmers Guide Document Reference No.: FT_000532 Clearance No.: FTDI# 307 Product Page: http://www.ftdichip.com/ftproducts.htm Document Feedback: Send Feedback Version 1.0 Initial Release Updated to include FT312D Copyright 2012-2013 Future Technology Devices International Limited 51