Application Note AN_159 Vinculum-II Firmware Flash Programming Document Reference No.: FT_000358 Version 2.0 Issue Date: 2011-12-08 This document describes three ways to program and update firmware on the Vinculum-II (VNC2) USB host controller. Programming a ROM file via the debugger interface. Programming a ROM file over UART. Re-flashing a ROM file using a flash disc drive. Use of FTDI devices in life support and/or safety applications is entirely at the user’s risk, and the user agrees to defend, indemnify and hold harmless FTDI from any and all damages, claims, suits or expense resulting from such use. Future Technology Devices International Limited (FTDI) Unit 1, 2 Seaward Place, Glasgow G41 1HH, United Kingdom Tel.: +44 (0) 141 429 2777 Fax: + 44 (0) 141 429 2758 Web Site: http://ftdichip.com Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Table of Contents 1 Introduction .................................................................................................................................... 3 2 IDE Tool Suite .................................................................................................................................. 4 2.1 3 4 5 2.1.1 Debug or Release Build ................................................................................................... 5 2.1.2 Build Completion............................................................................................................. 6 Programming a ROM File via the Debugger Interface .................................................................... 7 3.1 Hardware Requirements ......................................................................................................... 7 3.2 Hardware Example .................................................................................................................. 7 3.3 Procedure – Program Using IDE .............................................................................................. 7 3.4 Procedure – Program using VINPRG.exe ................................................................................ 8 Programming a ROM file over UART............................................................................................. 10 4.1 Hardware Requirements ....................................................................................................... 10 4.2 Hardware Example ................................................................................................................ 10 4.3 Procedure .............................................................................................................................. 10 Re-flashing a ROM File Using a Flash Drive ................................................................................... 12 5.1 Hardware Requirements ....................................................................................................... 12 5.2 Software Requirements ........................................................................................................ 12 5.3 Principles ............................................................................................................................... 12 5.4 Components .......................................................................................................................... 13 5.5 Firmware Update Sample Procedure .................................................................................... 14 5.5.1 Program FirmwareUpdate ............................................................................................ 15 5.5.2 Store User Firmware on USB Memory Stick ................................................................. 15 5.6 6 IDE Tool Suite – Create a ROM file .......................................................................................... 4 Building the Flash Update Into a Custom Design .................................................................. 17 5.6.1 FAT File System ............................................................................................................. 18 5.6.2 Firmware Update Library .............................................................................................. 18 5.6.3 “Hello World” – Firmware Update File Code Example ................................................. 20 5.6.4 “Hello World” Sample – Re-Flash Steps ........................................................................ 21 Contact Information...................................................................................................................... 24 Appendix A – References ...................................................................................................................... 25 1 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Document References....................................................................................................................... 25 Acronyms and Abbreviations ............................................................................................................ 25 Appendix B – List of Figures .................................................................................................................. 26 List of Figures .................................................................................................................................... 26 Appendix C – Revision History .............................................................................................................. 27 2 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 1 Introduction The VNC2 device is a programmable SoC device with a powerful embedded microprocessor core and dual USB host or slave interfaces, large RAM and flash capacity and the ability to develop and customise firmware using the VNC2 Toolchain. This application note describes how to program or re-flash a ROM file into the flash memory of the VNC2 device. VNC2 firmware in a ROM file format can be programmed into the flash of the device by three methods: Programming a ROM file via the VNC2 debugger/programmer moduleinterface. Programming a ROM file over UART. Re-flashing a ROM file using a flash drive. VNC2 devices are produced as blank devices. These blank devices can only be programmed over UART or the debug interface. Re-flashing or upgrading over USB can only be performed after an initial firmware is programmed to the VNC2. VNC2 devices can also be programmed before being assembled in a system using the VPROG1 VNC stand alone programmer – see (www.ftdichip.com) Note: Any sample code provided in this note is for illustration purposes and is not guaranteed or supported. 3 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 2 IDE Tool Suite The Integrated Development Environment (IDE) is FTDI’s Toolchain that allows the user to open and edit sample C programs from FTDI or develop their own C programs. The IDE is used to build or compile the C program into a ROM file. This ROM file is programmed to the flash of the VNC2 device. The IDE is a free download from FTDI web site with sample projects including two Vinculum-I (VNC1L) firmware versions that have been re-written for VNC2 (V2DAP and V2DPS). 2.1 IDE Tool Suite – Create a ROM file C programs can be compiled using the IDE build as shown in Figure 2.1 IDE Build. In this example the V2DAP project is opened from the samples folder and is being built. Full details on opening a C project and building the ROM file are available in the getting started guide found within the IDE help pages (Figure 2.2 IDE Getting Started Guide). Figure 2.1 IDE Build 4 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Figure 2.2 IDE Getting Started Guide 2.1.1 Debug or Release Build The C code can be compiled as either a release or a debug build, the option is a pull down selection in the Build tab as shown is Figure 2.3. If further debug and testing of the code is required it is recommended to select the debug option. After an application has been successfully tested it is recommended to subsequently build the application in Release mode. This will have the effect of reducing the overall ROM file size but will now not allow any further debugging using the IDE. Figure 2.3 Debug or Release Build 5 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 2.1.2 Clearance No.: FTDI# 198 Build Completion On completion of a successful build of the code without errors, the IDE messages window will display: [VinL.exe] : 0 errors, 0 warnings and 0 informational messages The ROM file will be located within either the debug or release folders: e.g. \My Documents\FTDI\Firmware\Samples\1.2.2-SP1\Firmware\VNC1L\V2DAP\Debug 6 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 3 Programming a ROM File via the Debugger Interface The IDE is used to program the VNC2 with a ROM file for the first time (blank device) or to reprogram a previously installed firmware. 3.1 Hardware Requirements There are several options to provide the debug interface: VNC2 debug port as defined in AN_138 Vinculum-II Debug Interface Description o Available on Vinco and V2DIP modules o Included on a customer target design VNC2 Debugger/Programmer Module USB A to mini-B cable Note that the V2-EVAL includes the debug interface that connects directly to the host PC running the VNC2 Toolchain. 3.2 Hardware Example Figure 3.1 shows an example of the V2DIP1-48 module connected to the Debugger/Programmer module. A USB A to Mini-B Cable is then required to connect the debugger/programmer to the PC. Figure 3.1 V2DIP1 connected to the VNC2 Debugger/Programmer Module 3.3 Procedure – Program Using IDE When a ROM file has been successfully generated, as described within section 2.1, it can be programmed into the flash of the VNC2. Connect the Debugger/Programmer module into V2DIP1 module’s debug port. Connect a USB A to Mini-B Cable from the PC to the Mini-B connector on the Debugger/Programmer module. In the IDE Debug tab, the VNC2 that is connected will be shown in the interface area. The “Flash” button can be pressed to start the programming the most recently compiled ROM file. A different ROM file can be selected by clicking the small down-arrow below “Flash”. 7 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Completion of the programming will be display within the messages window. The “Verify” button may be used to check the contents of the flash. This requires Prog_Loader V1.7 or above. If this version of Prog_loader is not in the flash then the message "Cannot verify flash contents! Use latest version of the program loader." will be displayed. Contact support for more information. 3.4 Procedure – Program using VINPRG.exe The ROM file can be programmed to the VNC2 using the command line programming tool – VINPRG.exe. The tool is installed with the IDE setup file and is located at: C:\Program Files\FTDI\Vinculum II Toolchain\Tools\bin\VinPrg.exe Open a command prompt and type vinprg to view the available commands. Perform the vinprg –a command to determine what hardware is connected to the debugger module. In this case, the debug interface is identified as “VII Eval Board B” 8 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Perform the vindprg -d command to program the ROM file. In this example the file C:\pwmbreathe.rom is programmed to the VII Eval Board via channel B. vinprg -d "VII Eval Board B" "C:\pwmbreathe.rom" 9 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 4 Programming a ROM file over UART A blank VNC2 can be programmed over UART using the FTDI utility FT_Prog with a ROM file. FT_Prog can also be use to upgrade previously installed firmware. VNC2 support requires FT_Prog version 1.12 or newer. 4.1 Hardware Requirements VNC2 module or customers designed VNC2 PCB with UART pins connected to a PC via either a TTL232R-3V3 cable or customers designed serial bridge. 4.2 Hardware Example Figure 4.1 is an example where an FTDI TTL-232R-3V3 cable is used to program a V2DIP1 module over UART. To enable the bootloader mode, the PROG# pin must be driven low and VNC2 must then be reset by driving the RESET# pin low then high. The UART connections of the cable are connected to the default UART pins on the module. In this case, a short was made by connecting PROG# to GND prior to applying power to the module. This is shown at the bottom right of Figure 4.1 VCC 6 pin header 0.1in pitch VCC RTS# 6 6 RXD 5 5 TXD 4 VCC 3 GREEN IO15-uart_cts YELLOW IO12-uart_txd 4 FTDI TTL-232R CABLE 1.8m ORANGE IO13-uart_rxd 3 RED CTS# 2 2 GND 1 1 IO14-uart_rts BROWN Gnd BLACK G n d P r o g Figure 4.1 TTL-232R-3V3 Cable to V2DIP1-48 Module via UART 4.3 Procedure FT_Prog is used to program the VNC2 with a ROM file. FT_Prog is available from the FTDI website utilities page (version 1.12 or later supports VNC2). Select the flash ROM tab at the top of the window. Select VNC2 from the pull down tab. Select interface. Select the location where the ROM file resides. Press the program button. Perform a hard reset (power cycle) prior to running the firmware. Figure 4.2 is an example of programming the VNC2 Evaluation board revision 2 with the V2DAP firmware. 10 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Figure 4.2 FT_Prog Programming Utility 11 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 5 Re-flashing a ROM File Using a Flash Drive The VNC2 is distributed as a blank device which can be programmed with an application by the two methods (UART or debug interface) previously described in this document. The VNC2 device can be programmed with re-flasher firmware that allows subsequent application firmware to be upgraded from a USB memory stick. The re-flasher firmware code is separate from the application code and is not overwritten when the application firmware is update. The re-flasher firmware must be programmed into the VNC2 flash over UART or debug interface .This firmware is programmed into an area of flash of the VNC2 that will not be overwritten by the user firmware. To permit the firmware update an application needs to include a Firmware Update library which can read a file from a FAT format disk and instruct the re-flasher firmware to program that into the flash memory of the VNC2. The “FirmwareUpdate” sample in the General sample section provides an example of how to create an application that will find an update file on a USB memory stick and program that into flash. The source code for the application is provided as an example and is neither guaranteed nor supported by FTDI. Currently the only re-flasher firmware is ReflashFATFile.rom which will program an application ROM file from a FAT format disk. 5.1 Hardware Requirements VNC2 module or customers designed PCB with USB Type A connector on a USB channel of the VNC2 chip configured as host. Memory stick / Flash Drive formatted in a supported file system (FAT16 or FAT32) 5.2 Software Requirements VNC2 IDE Command prompt – cmd.exe (In windows select Start – Run cmd.exe) V2Eval Board Terminal Vinprg – included within IDE (C:\Program Files\FTDI\Vinculum II Toolchain\Tools\bin) 5.3 Principles The principle of operation is that the application selects a file on a disk which contains a valid ROM image. The file must be accessible by the FAT file system driver or API and must be opened by the application before it calls the Firmware Update library. The Firmware Update library will validate the ROM file before calling the re-flasher firmware. The re-flasher firmware is stored at the end the flash memory on the VNC2. This essentially forms a second application on the VNC2 which performs the actual update of the flash ROM on the VNC2 and overwrites the main application. The Firmware Update library is called with a handle to a FAT file and the address of the Re-flasher code. There is an option to instruct the reflasher firmware to provide feedback through the UART or a GPIO pin. During a firmware update the re-flasher code can output a dot trail to UART or toggle a GPIO line. A fail will be a constant low GPIO line or an exclamation mark (!) on the UART. A pass will result in the GPIO line set high or a carriage return on UART. 12 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 These options are set when calling the Firmware Update library. The parameters for the feedback options are shown in the FirmwareUpdate.h file. They can be bitwise ORed together to have UART and multiple GPIO pins provide feedback. When complete, the CPU will reset and run the new program. 5.4 Components The Re-flasher code is supplied as both an object file which must be linked to an address that will not be overwritten by the main application, and as a ROM file which is linked to address 0x1c000. The recommended location of the re-flasher firmware is 0x1f000 which is 8kB from the top of flash, leaving 248kB of flash available for the main application. Addresses of data in flash are all word addresses. 0x1FFFF Re- flasher 0x1f000 Free space Application Reserved 0x0000 Figure 5.1 Flash Memory 13 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 5.5 Firmware Update Sample Procedure VINPRG.exe is used to program the Re-flasher ROM code to an area within flash that is not used by the user application. Run VINPRG using command prompt: Firstly detect the debugger interface name using the list all debugger interfaces vinprg –a Use the debugger interface name within the following command: vinprg -o 0x1f000 -d "V2EVAL Board C" "c:\Program Files\FTDI\Vinculum II Toolchain\Firmware\Drivers\images\ReflashFATFile.rom" Parameters: -o 0x1f000 offset to start programming at 0x1f000 -d " V2EVAL Board C " debugger interface description 14 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 5.5.1 Clearance No.: FTDI# 198 Program FirmwareUpdate Open the project FirmwareUpdateApp.vproj located within the samples section of the IDE. Build and program FirmwareUpdateApp.c to the VNC2. 5.5.2 Store User Firmware on USB Memory Stick Select the ROM file to be programmed and put it onto the flash disk and rename it as “FWUPDATE.ROM”. This can be the ROM file of any of the samples, however, if the ROM file for this sample (FirmwareUpdate) is used then the update will run over and over. In 15 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 this example V2DAP.ROM has been renamed FWUPDATE.ROM. Open V2Eval Board Terminal (or similar e.g. TTY, HyperTerminal), and press reset on the board. 16 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 The code will wait at the starting prompt until the USB memory stick is plugged in. During programming, a trail of dots will be sent to the UART interface and (if using a V2EVAL board) LED0 will flash. When programming is complete, a carriage return (“\r”) will be sent to the UART and the LED will be turned off. If an error occurs then an exclamation mark will be sent to the UART and the LED will be set on permanently. After successful programming the VNC2 will be reset and run the updated code. In the example shown the V2DAP prompt can now be observed. 5.6 Building the Flash Update Into a Custom Design A custom design must include two key components in order to allow future flash updates (e.g. updating ROM in the field using the Flash disk). • FAT file system and required libraries, typically BOMS and USBHost. • Firmware Update library These libraries must be included by the App Wizard or by using the Manage Libraries and Manage Headers method. The “Hello World” application example available within the VNC2 IDE was edited to describe an example of building the flash update into a VNC2 project. The “GPIOKitt” application example also found in VNC2 IDE was used as updated project. 17 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 5.6.1 Clearance No.: FTDI# 198 FAT File System The FAT file system must be initialised and able to access the disk where the firmware update ROM file is stored. The stdio library, FAT file system driver or FAT file system API may be used to open the firmware update ROM file in the application before calling the firmware update library. 5.6.2 Firmware Update Library The header file for the firmware update library must be included and the location (in ROM) of the firmware re-flasher noted. The “Hello World” application example was edited as follows: Right click the Project Library window and select manage header files. Select FirmwareUpdate.h and press Add. Right click the Project Library window and select manage libraries. 18 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Select FirmwareUpdateFATfile.a and press Add. Edit HelloWord.c #define REFLASHER_OFFSET 0x1f000 #include "FirmwareUpdate.h" 19 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 5.6.3 Clearance No.: FTDI# 198 “Hello World” – Firmware Update File Code Example Firmware Update File code was added into the “Helloworld.c” file to check a disk for a firmware update. //Global Variables extern rom int userDataArea[4]; unsigned char param1Data[11]; ** ** ** ** Checks a disk for a firmware update file. Parameters: param1: filename of update Returns: none Comments: Checks for BOMS disk and valid FAT file system*/ void diskCheckFwu() { char *strChangeMain = "Change MAIN\r"; unsigned char status; int verFile, verROM; FILE *file; // check for firmware update file: "FTRFBV2.FTD" file = fopen((char *) param1Data, "r"); if (file != NULL) { status = fseek(file, 0x20, SEEK_SET); if (status == 0) { status = fread(&verFile, 4,1, file); if (status == 4) { verROM = userDataArea[0]; verROM |= userDataArea[1] << 8; verROM |= userDataArea[2] << 16; verROM |= userDataArea[3] << 24; if (verFile != verROM) { status = fseek(file, 0, SEEK_SET); status = FirmwareUpdateFATFileFeedback(file, 0x1f000, FIRMWARE_UPDATE_FEEDBACK_UART); } } } fclose(file); } } The function “diskCheckFwu()” was then called from the “firmware ()” function as shown below: char *updateFile = "FTRFBV2.FTD"; vos_memcpy(param1Data, updateFile, 11); diskCheckFwu(); 20 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 5.6.4 Clearance No.: FTDI# 198 “Hello World” Sample – Re-Flash Steps VINPRG.exe is used to program the Re-flasher ROM code to an area within flash that is not used by the user application. Run VINPRG using command prompt: Firstly detect the debugger interface name using the list all debugger interfaces vinprg –a Use the debugger interface name within the following command: vinprg -o 0x1f000 -d "V2EVAL Board C" "c:\Program Files\FTDI\Vinculum II Toolchain\Firmware\Drivers\images\ReflashFATFile.rom" Parameters: -o 0x1f000 offset to start programming at 0x1f000 -d " V2EVAL Board C " debugger interface description 21 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Use the IDE to program “Hello World” application to the chip Choose a ROM file that you want to flash to the VNC2, put it onto the flash disk and rename it as “FTRFBV2.FTD”. In this example GPIOKitt.ROM has been renamed FTRFBV2.FTD Open a COM port terminal program e.g. TTY, HyperTerminal and press reset on the board. In this example the V2-EVAL Terminal Utility was used. The code will wait at the starting prompt until the USB memory stick is plugged in. 22 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 During programming, a trail of dots will be sent to the UART interface and (if using a V2EVAL board) LED0 will flash. A successful update will take approximately 10 to 20 seconds after which activity on the flash disk will cease and the dots will end. The VNC2 CPU will be halted upon completion so a power cycle is required before the new firmware will be activated. 23 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 6 Contact Information Head Office – Glasgow, UK Branch Office – Hillsboro, Oregon, USA 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 Future Technology Devices International Limited (USA) 7235 NW Evergreen Parkway, Suite 600 Hillsboro, OR 97123-5803 USA Tel: +1 (503) 547 0988 Fax: +1 (503) 547 0987 E-mail (Sales) E-mail (Support) E-mail (General Enquiries) sales1@ftdichip.com support1@ftdichip.com admin1@ftdichip.com 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 Branch Office – Shanghai, China 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 Future Technology Devices International Limited (China) Room 408, 317 Xianxia Road, Shanghai, 200051 China Tel: +86 21 62351596 Fax: +86 21 62351595 E-mail (Sales) E-mail (Support) E-mail (General Enquiries) E-mail (Sales) E-mail (Support) E-mail (General Enquiries) tw.sales1@ftdichip.com tw.support1@ftdichip.com tw.admin1@ftdichip.com cn.sales@ftdichip.com cn.support@ftdichip.com cn.admin@ftdichip.com Web Site http://ftdichip.com System and equipment manufacturers and designers are responsible to ensure that their systems, and any Future Technology Devices International Ltd (FTDI) devices incorporated in their systems, meet all applicable safety, regulatory and system-level performance requirements. All application-related information in this document (including application descriptions, suggested FTDI devices and other materials) is provided for reference only. While FTDI has taken care to assure it is accurate, this information is subject to customer confirmation, and FTDI disclaims all liability for system designs and for any applications assistance provided by FTDI. Use of FTDI devices in life support and/or safety applications is entirely at the user’s risk, and the user agrees to defend, indemnify and hold harmless FTDI from any and all damages, claims, suits or expense resulting from such use. This document is subject to change without notice. No freedom to use patents or other intellectual property rights is implied by the publication of this document. Neither the whole nor any part of the information contained in, or the product described in this document, may be adapted or reproduced in any material or electronic form without the prior written consent of the copyright holder. Future Technology Devices International Ltd, Unit 1, 2 Seaward Place, Centurion Business Park, Glasgow G41 1HH, United Kingdom. Scotland Registered Company Number: SC136640 24 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Appendix A – References Document References VNC2 Data sheet Vinculum-II Toolchain Vinculum-II Tool Chain Getting Started Guide V2DIP1-48 Data sheet Vinculum-II Debug Interface Description Migrating Vinculum Designs From VNC1L to VNC2-48L1A Acronyms and Abbreviations Terms Description FAT File allocation Table FT_Prog FTDI Programming application. IDE Integrated Development Environment SoC System on chip USB Universal Serial Bus USB-IF USB Implementers Forum VNC1L Vinculum-I First Generation Embedded Dual USB Host Controller IC VNC2 Vinculum-II Second Generation Embedded Dual USB Host Controller IC 25 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Appendix B – List of Figures List of Figures Figure 2.1 IDE Build ............................................................................................................ 4 Figure 2.2 IDE Getting Started Guide .................................................................................... 5 Figure 2.3 Debug or Release Build ......................................................................................... 5 Figure 3.1 V2DIP1 connected to the VNC2 Debugger/Programmer Module ................................. 7 Figure 4.1 TTL-232R-3V3 Cable to V2DIP1-48 Module via UART .............................................. 10 Figure 4.2 FT_Prog Programming Utility ............................................................................... 11 Figure 5.1 Flash Memory .................................................................................................... 13 26 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Appendix C – Revision History Document Title: AN_159 Vinculum-II Firmware Flash Programming Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Product Page: http://www.ftdichip.com/Products/ICs/VNC2.htm Document Feedback: Send Feedback Revision Changes Date 1.0 Initial Release 2011-02-04 Updated sections 5.4, 5.5 and 5.6. Also added more description to other sections. Added “Hello World” application example demonstrate the reflasher in a custom build 2.0 to 2011-12-08 Edited Figure 5.1 Changed the re-flasher 0x1c000 to 0x1f000. firmware location from Updated format to new template. 27 Copyright © 2011 Future Technology Devices International Limited Application Note AN_159 Vinculum-II Firmware Flash Programming Version 2.0 Document Reference No.: FT_000358 Clearance No.: FTDI# 198 Revision Record Sheet Authors Gavin Moore Filename AN_159_Vinculum-II_Firmware_Flash_Programming.docx Revision Date Details 1.0 2011-02-04 Initial Release 2.0 2011-10-14 Updated to new template Sign Off Signatory Signature Date Managing Director Principal Hardware Engineer Principal Software Engineer Senior Marketing Manager Sales Manager Clearance Approval (Please delete unnecessary conditions upon purposes!) - This Document is cleared for Future Technology Devices International use and unrestricted circulation. FTDI# 198 Clearance Number (Where applicable for external communications) 28 Copyright © 2011 Future Technology Devices International Limited