# FlashPro Express for Software v11.7 User's Guide NOTE: PDF files are intended to be viewed on the printed page; links and cross-references in this PDF file may point to external files and generate an error when clicked. View the online help included with software to enable all linked content. # **Table of Contents** | FlashPro Express | | |-------------------------------------|----| | Getting Started | 9 | | FlashPro Express Interface | 10 | | Programming Settings and Operations | | | Programmer Settings | | | Chain Programming | 22 | | Chain OrderSelecting an Action | | | Tcl Commands - FlashPro Express | | | Electrical Parameters | 78 | | Electrical Specifications | 82 | | Electrical Specifications | 84 | | FlashPro Express Reference | 90 | | Product Support | 94 | # FlashPro Express FlashPro Express is Microsemi's programming tool designed from the ground up to address secured programming assurance in production programming house environments. FlashPro Express supports SmartFusion2, IGLOO2, RTG4, SmartFusion, IGLOO, ProASIC3, Fusion, and ProASICPLUS devices in the Windows OS environments and supports SmartFusion2, IGLOO2, and RTG4 in the Linux OS environments. You can install FlashPro Express two ways: - Integrated with Libero FlashPro Express is installed automatically when Libero is installed. FlashPro express is used by Libero to perform the programming tasks, for SmartFusion2, IGLOO2, and RTG4, as part of the design flow. - Stand-Alone FlashPro Express is also available as a standalone installation. This mode is primarily used for production programming or lab programming on machines in which a full version of Libero is not required. When installed using the standalone installation, FlashPro Express is joined by the predecessor product FlashPro. View the detailed Install Instructions and System Requirements at the Flashpro Express software page: http://www.microsemi.com/products/fpga-soc/design-resources/programming/flashproexpress#overview # Secure Job Programming Job programming is the concept of using a single file to program a Microsemi device or chain of Microsemi devices using encrypted bitstreams. The single job file contains all of the information necessary to setup FlashPro Express as well as the encrypted bitstream images for the devices in the job. Once a job file is created it can be handed off securely to production programming houses or contract engineering facilities to load the Microsemi images during manufacturing. Job projects can be exported from Libero and imported into stand alone FlashPro Express providing a clean delineation between design flow and production programming. # Migrating FlashPro Projects to FlashPro Express Existing FlashPro projects (\*.pro) files are now called Job Project files in FlashPro Express. These Job Projects can be opened with FlashPro Express to take advantage of Linux programming support and the simplified tool targeted for operators in a production floor environment. FlashPro projects that were created in single mode will not be supported with this tool. Microsemi recommends that you convert these projects to chain mode projects. To convert the project to a chain project, do the following steps: - 1. Open the FlashPro project (\*.pro) in FlashPro. - 2. Locate the loaded STAPL file by one of two methods: The log will print "STAPL file '<stapl\_path>' has been loaded successfully." <stapl\_path> is the location of the STAPL file loaded. ``` Software Version: 11.5.0.15 Warning: Unable to find file: '\\dms\progval\SARs\61910\topdefault.stp'. Marning: Using local backup copy: 'D:\test_projectData\topdefault.stp'. STAPL file 'D:\test_projectUprojectData\topdefault.stp' has been loaded successfully. DESIGN: top; CHECKSUM: F673; ALG_VERSION: 2 | | | All | Errors | Warnings | Info | ``` Within the Single Device Configuration Window there is a field STAPL\_FILE\_NAME, which displays the location of the STAPL file loaded. - 3. Switch the project to chain mode by one of the two methods: - a. Press the chain button from the toolbar. - b. From the Tools menu, select Mode->Chain Programming. - 4. Load the STAPL file in chain mode by adding a Microsemi device in the chain. - a. From the File menu, select Configuration->Add Microsemi Devices from Files. - b. Browse to the location of the STAPL file and click Open. - 5. To save the project, from the File menu, select Save Project. - 6. You may now open the project using FlashPro Express. When moving FlashPro project (\*.pro) files to another machine, Microsemi recommends that you archive the entire project folder, copy it to the new machine, extract it locally, then load the job project within FlashPro Express. FlashPro Express will only open a job project if a programmer is connected to the machine, at least one Microsemi device has programmed enabled, and all enabled Microsemi devices have a bitstream file loaded. # Supported Families - FlashPro Express FlashPro Express programs all the devices from all the following device families: - SmartFusion2 FPGAs - IGLOO2 FPGAs - RTG4 FPGAs - SmartFusion FPGAs - IGLOO FPGAs - ProASIC3 FPGAs - Fusion FPGAs - ProASIC PLUS FPGAs FlashPro Express ONLY; not supported in Libero SOC. When we specify a family name, we refer to the device family and all its derivatives, unless otherwise specified. See the table below for a list of supported device families and their derivatives: Table 1 · Product Families and Derivatives | Device<br>Family | Family<br>Derivatives | Description | |------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SmartFusion2 | N/A | Address fundamental requirements for advanced security, high reliability and low power in critical industrial, military, aviation, communications and medical applications. | | IGLOO2 | N/A | Low-power mixed-signal programmable solution | | RTG4 | N/A | Radiation-tolerant programmable solution | | SmartFusion | SmartFusion | SmartFusion intelligent mixed-signal FPGAs are the only devices that integrate an FPGA, ARM Cortex-M3, and programmable analog, offering full customization and IP protection. | | <u>Fusion</u> | N/A | Mixed-signal FPGA integrating ProASIC3 FPGA fabric, programmable analog block, support for ARM® Cortex <sup>TM</sup> -M1 soft processors, and flash memory into a monolithic device. | | <u>IGLOO</u> | IGLOO | The ultra-low-power, programmable solution | | | IGLOOe | Higher density IGLOO FPGAs with six PLLs and additional I/O standards | | | IGLOO nano | The industry's lowest power, smallest size solution | | | IGLOO PLUS | The low-power FPGA with enhanced I/O capabilities | | ProASIC3 | ProASIC3 | The low-power, low-cost, FPGA solution | | | ProASIC3E | Higher density ProASIC3 FPGAs with six PLLs and additional I/O standards | | | ProASIC3<br>nano | Lowest cost solution with enhanced I/O capabilities | | | ProASIC3L | The FPGA that balances low power, performance, and low cost | | | Automotive<br>ProASIC3 | ProASIC3 FPGAs qualified for automotive applications | | | Military<br>ProASIC3/EL | Military temperature A3PE600L, A3P1000, and A3PE3000L | | | RT ProASIC3 | Radiation-tolerant RT3PE600L and RT3PE3000L | | ProASIC<br>PLUS | N/A | Supported by FlashPro Express ONLY- not supported by Libero SoC. | # Installing FlashPro Express Software and Hardware See the FlashPro Express Installation Instructions on the <u>Microsemi website</u> for information on supported platforms, how to install FlashPro Express software/hardware and relevant system requirements. View the detailed Install Instructions and System Requirements at the FlashPro Express software page: <a href="http://www.microsemi.com/products/fpga-soc/design-resources/programming/FlashPro#overview">http://www.microsemi.com/products/fpga-soc/design-resources/programming/FlashPro#overview</a> # **Getting Started** # Starting FlashPro Express You can start the FlashPro Express software from **Programs > Microsemi FlashPro Express vx.x > FlashPro Express**. If you installed the program in a folder other than FlashPro Express, choose that folder from the **Programs** menu. # FlashPro Express Interface The main FlashPro Express UI consists of a list of programmers and a chain table, as shown in the figure below. This view displays the programmers connected to the machine, and the devices within the JTAG chain specified in the job project file (PRO) file, as shown in the figure below. - Hover over the programmer Info icon to display more information about a programmer. - Click the Name field to change a programmer name. - · Click the checkbox to enable or disable a programmer. - · Right-click a programmer to Ping, Self-Test, Scan, Check Chain or Remove it from the list. - Additional information about a device and programming file, if loaded, can be viewed by hovering over the info icon of that device. - Devices specified as disabled in the job project (\*.pro) file are shown disabled and their HighZ value is displayed in the column header. - Device/Programmer States: - IDLE: The devices/programmers are idle and not executing any programming action. - DISABLED: Devices that are not enabled for programming - PASSED: The last programming operation passed - FAILED: The last programming operation failed Figure 1 · FlashPro Express Programmers and Chain Table # Load a Job Project To get started in FlashPro Express you must load a job project (\*.pro file). To do so, from the **Project** menu choose **Open Job Project**. A job project will open if: - At least 1 programmer is connected - At least 1 Microsemi device is enabled for programming - · Any enabled Microsemi device for programming must have a bitstream file loaded Note: FlashPro projects (\*.pro) created in single chain mode are not supported with this tool. You must create a chain mode project with the existing programming files within FlashPro prior to using FlashPro Express. #### To open a project: - 1. From the **Project** menu, choose **Open Job Project**. The **Open Project** dialog box appears. - 2. Find your project file or type in your project file name in the **File name** field. - 3. Click Open. Figure 2 · FlashPro Express Launch Screen # Saving a Job Project Click the **Save** button on the toolbar, or from the **Project** menu choose **Save Job Project** to save your project. # Parallel Programming with FlashPro5/4/3/3X Parallel programming enables you to program multiple Microsemi devices in parallel with multiple programmers. In parallel programming, all targeted devices are programmed with the same programming file (STAPL). The targeted device or chain configuration that is connected to each programmer must be identical. The FlashPro Express software together with the FlashPro5/4/3/3X programmers supports parallel programming via a USB port. You can connect up to sixteen FlashPro5/4/3/3X's to a PC via a USB v1.1 or a USB v2.0 port. FlashPro5/4/3/3X requires a self-powered hub. Connecting FlashPro5/4/3/3X (a USB v2.0 enabled programmer) to USB v1.1 port increases device programming time due to a slow data transfer rate on the USB v1.1 port in comparison to a USB v2.0 port. Note: FlashPro (USB/LPT1) or FlashPro Lite programmers do not support parallel programming. The following figure illustrates how you can connect a FlashPro5/4/3/3X programmer for parallel programming. Figure 3 · Connecting a FlashPro5/4/3/3X Programmer An independent thread processes the STAPL file during parallel programming. In an Microsemi test, parallel programming is approximately five times faster than programming 16 devices sequentially. Note: Microsemi has tested Belkin PCI-USB cards and hubs. We have found that parallel programming works best with the vendor's latest driver installed and with the matching hubs. # **Chain Programming Tutorial** This tutorial demonstrates how to use FlashPro Express to program a multi-device, multi-programmer chain. This tutorial uses the production programming flow that exports a programming job from Libero SoC, which includes chain configuration, programmer settings, and bitstream files for programming, and creates a job project from a programming job. The figure below shows the chain used in this tutorial. M2S050T is device 1 and A3P250 is device 3. Device 1 is the first device to be programmed in the chain and device 2 is the last; device 3 is disabled and will not be programmed. Figure 4 · Chain Programming Devices #### To program a chain: - 1. From the Project menu, choose Create Job Project from Programming Job. - 2. Click **Browse** to load a Programming Job File, and specify your **FlashPro Express job project location**. Click **OK** to continue, as shown in the figure below. Figure 5 · Create Job Project from Programming Job FlashPro Express displays your Job Project and programmers, as shown in the figure below. The Device/Programmer states are: - IDLE: The devices/programmers are idle and not executing any programming action - DISABLED: Devices that are not enabled for programming - · PASSED: The last programming operation passed - FAILED: The last programming operation failed Figure 6 · FlashPro Express with Loaded Job Project See the Export Programming Job topic for information on how to generate a Programming Job file. - 3. Click the **Refresh/Rescan** button if your programmer is not listed. Hover your mouse over the **Info** icon to view device info. If a device is Disabled for programming the HighZ status appears in the GUI, as shown in the figure above. - 4. Set the Programming Action in the dropdown menu to PROGRAM, as shown in the figure below. Figure 7 · Programming Action Set to PROGRAM - Click RUN. Detailed individual programmer and device status information appears in the Programmer List. Your programmer status (PASSED or FAILED) appears in the Programmer Status Bar, as shown in the figure below. - Hover your mouse over the Programmer Status Bar to display information on the programmers. - Hover over the FAILED status to list all programmers that failed programming. - Hover over the PASSED status to list all the programmers that programmed successfully. Figure 8 · Chain Programming Complete View the Log for Messages, Errors, Warnings and Info generated during programming. # Creating a Job Project from a Programming Job Once you are ready to hand off your design for production you can create a job project. To do so: In Libero SoC run Export Programming Job to create a container that will be used to transfer programming configuration information, including programming files, to the production programming tool FlashPro Express. Figure 9 · Export Programming Job In FlashPro Express, from the Project menu choose Create Job Project From a Programming Job. You will be prompted to specify the Programming Job File location that you just exported from Libero and the location of where to store the FlashPro Express Job Project. The Job Project name automatically uses the programming job name and cannot be changed. Click OK and a new Job Project will be created and opened for production programming. Figure 10 · Create Job Project Dialog Box # **Programming Settings and Operations** #### Introduction The FlashPro Express software enables you to connect multiple programmers to your computer. With each programmer you select, you can connect the programmer, perform a self-test, customize, add, and remove and analyze the JTAG chain, as shown in the figure below. Figure 11 · FlashPro Express Right-Click Menu # **Programmer Settings** The Programmer Settings dialog box includes setting options for FlashPro5/4/3/3X, FlashPro Lite and FlashPro. Note: You can set the TCK setting in the PDB/STAPL file by selecting the TCK frequency in the Programmer Settings dialog box. Limitation of the TCK frequency for the selected programmer: - FlashPro supports 1-4 MHz - FlashPro Lite is limited to 1, 2, or 4 MHz only. - FlashPro 4/3/3X supports 1-64 MHz. - FlashPro5 supports 1-10 MHz Limitation of the TCK frequency for the target device: - IGLOO, ProASIC3, and Fusion 10MHz to 20MHz - ProASICPLUS and ProASIC 10 MHz. During execution, the frequency set by the FREQUENCY statement in the PDB/STAPL file will override the TCK frequency setting selected by you in the Programmer Settings dialog box unless the **Force TCK Frequency** checkbox is selected. #### To set your programmer settings: 1. From the **Tools** menu, choose **Programmer Settings**. The **Programmer Settings** dialog box appears (as shown in the figure below). Figure 12 · Programmer Settings Dialog Box for FlashPro Express - 2. Click a programmer tab and check the appropriate settings for your programmer. - 3. Click **OK**. #### FlashPro Programmer Settings Choose your programmer settings for FlashPro (see figure above). If you choose to add the Force TCK Frequency, select the appropriate MHz frequency. After you have made your selection(s), click **OK**. #### **Default Settings** - The Vpp, Vpn, Vdd(I), and Vddp options are checked (Vddp is set to 2.5V) to instruct the FlashPro Express programmer(s) to supply Vpp, Vpn, Vdd(I) and Vddp. - The Drive TRST option is unchecked to instruct the FlashPro Express programmer(s) NOT to drive the TRST pin. - The Force TCK Frequency option is unchecked to instruct FlashPro Express to use the TCK frequency specified by the Frequency statement in the STAPL file(s). #### FlashPro Lite Programmer Settings If you choose to add the Force TCK Frequency, select the appropriate MHz frequency. After you have made your selection(s), click $\mathbf{OK}$ . #### **Default Settings** - The Vpp and Vpn options are checked to instruct the FlashPro Express Lite programmer(s) to supply Vpp and Vpn. - The Drive TRST option is unchecked to instruct the FlashPro Express Lite programmer(s) NOT to drive the TRST pin. - The Force TCK Frequency option is unchecked to instruct the FlashPro Express Lite to use the TCK frequency specified by the Frequency statement in the STAPL file(s). #### FlashPro5/4/3/3X Programmer Settings For FlashPro5/4/3/3X, you have the option of choosing the Set Vpump setting or the Force TCK Frequency. If you choose the Force TCK Frequency, select the appropriate MHz frequency. For FlashPro4/3X settings, you have the option of switching the TCK mode between Free running clock and Discrete clocking. After you have made your selections(s), click **OK**. #### **Default Settings** - The Vpump option is checked to instruct the FlashPro5/4/3/3X programmer(s) to supply Vpump to the device. - The Force TCK Frequency option is unchecked to instruct the FlashPro5/4/3/3X to use the TCK frequency specified by the Frequency statement in the PDB/STAPL file(s). - FlashPro5/4/3/3X default TCK mode setting is Free running clock #### TCK Setting (ForceTCK Frequency) If **Force TCK Frequency** is checked (in the **Programmer Setting**) then the selected TCK value is set for the programmer and the Frequency statement in the PDB/STAPL file is ignored. Note: FlashPro Lite RevA supports only 4MHz on TCK. #### **Default TCK frequency** When the PDB/STAPL file or Chain does not exist, the default TCK frequency is set to 4MHz. In the **Single Device File Programming** mode, FlashPro Express will parse through the file and search for the "freq" keyword and the "MAX\_FREQ" Note field, which are expected in all Microsemi flash device files. The FlashPro Express software uses the lesser value of the two as the default TCK frequency. In **Chain Programming** mode, when more than one Microsemi flash device is targeted in the chain, the FlashPro Express software passes through all of the files and searches for the "freq" keyword and the "MAX\_FREQ" **Note** field. The FlashPro Express software uses the lesser value of all the TCK frequency settings and the "MAX\_FREQ" **Note** field values. # **Ping Programmers** #### To ping a programmer(s): Right-click a programmer and choose Ping. Note: You can click the Refresh/Rescan for Programmers button to quickly ping new programmers. ### Performing a Self-Test #### To perform a self-test: Right-click the programmer you want to self-test and choose Self Test. Note: You must connect the programmer to the self-test board that comes with your programmer before performing a self-test. Note: Self-test is not supported with FlashPro5/4 or FlashPro Lite programmers. These programmers are rigorously tested at the factory during production. # Scanning and Checking a Chain The scan chain operation scans and analyzes the JTAG chain connected to programmer(s) you have selected and checks that chain scanned matches the chain configured in FlashPro Express. #### To scan a chain: Right-click the programmer you want to scan and choose Scan and check chain. # **Enabling and Disabling Programmers** After <u>loading a job project</u>, you can enable/disable or remove a programmer and can also ping, self-test, run scan and check chain on any of the connected programmers. These actions are available in the shortcut menu (right-click) for each of the programmers listed in the programmer column. **Click the checkbox** next to a programmer in the Programmer column to enable or disable it. The programmer is enabled when there is a tick mark in the checkbox and disabled when the checkbox is empty. # Renaming a Programmer Enter the new programmer name in the **Programmer** window to rename the programmer. By default, the programmer name is the same as the programmer ID. # Removing a Programmer #### To remove a programmer: Right-click the programmer and choose Remove. # Chain Programming ### **Chain Order** Chain Programming enables you to program several devices at one time. The order of devices in the chain imported from Job Project must match the physical chain to be programmed. The TDO for the first device connects to the programmer, and the last device's TDI connects to the programmer. The devices in the chain go in order from a device's TDI into the next device's TDO, as shown in the figure below. Figure 13 · Chain Order # Multiple Device Chain Programming The FlashPro Express software enables direct chain programming without generating a chain STAPL file. Each device will be programmed in sequential order starting from device 1 to device N. See example below. For more information about chain order, see the Chain Order help topic. TDI > Device N > Device N-1 > ... > Device 2 > Device 1 > TDO #### **Device Programming Compatibility** SmartFusion2, IGLOO2, RTG4, SmartFusion, IGLOO, ProASIC3, Fusion families can be programmed in the same chain. #### **Programmer Support** FlashPro5/4/3/3X supports the SmartFusion2, IGLOO2, RTG4, SmartFusion, IGLOO, ProASIC3, Fusion family devices. The Vpump on FlashPro5/4/3/3X is designed to support the programming of only one device. Please make sure that Vpump, Vcc and Vjtag are provided on board for chain programming. Connect the Vpump to the header as the Flashpro Express software will attempt to check for all external supplies, including Vpump, to ensure successful programming. There is no limitation to the chain length; however, ensure that the JTAG signal integrity and the timing are preserved. # Selecting an Action FlashPro Express supports the following programming actions: - DEVICE INFO - ENC\_DATA\_AUTHENTICATION encrypted bitstream files for SmartFusion, IGLOO, ProASIC3/E and Fusion; bitstream files for SmartFusion2, IGLOO2, and RTG4. If an enabled device for programming does not contain this action in the chain, then the action will error out. - ERASE - PROGRAM - READ\_IDCODE - VERIFY #### To configure a programming action: Select an action from the Programming Action dropdown menu in FlashPro Express, as shown in the figure below. Figure 14 · FlashPro Express Programming Actions # Tcl Commands - FlashPro Express # About TCL Commands - FlashPro Express Tcl Command Reference A Tcl (Tool Command Language) file contains scripts for simple or complex tasks. You can run scripts from the Windows command line or store and run a series of Tcl commands in a \*.tcl batch file. The Tcl commands supported by FlashPro Express are listed in the table below. Note: Tcl commands are case sensitive. However, their arguments are not. | Command | Action | |----------------------------|------------------------------------------------------------------------------------------------| | close project | Closes the FlashPro project | | configure flashpro prg | Changes FlashPro programmer settings | | configure_flashpro3_prg | Changes FlashPro3 programmer settings | | configure flashpro4 prg | Changes FlashPro 4 programmer settings | | configure flashpro5 prg | Changes FlashPro 5 programmer settings | | configure_flashproLite_prg | Changes FlashPro Lite programmer settings | | create job | Create a job in FlashPro Express | | dump_tcl_support | Unloads the list of supported FlashPro Tcl commands | | enable_serialization | Enables or disables serialization programming. | | open project | Opens a FlashPro project | | ping prg | Pings one or more programmers | | refresh_prg_list | Refreshes the programmer list | | remove prg | Removes the programmer from the programmer list | | run selected actions | Runs the selected action on the specified programmer and returns the exit code from the action | | save log | Saves the log file | | save_project | Saves the FlashPro project | | scan_chain_prg | Runs scan chain on a programmer | | select serial range | Selects the range of indexes to program. | | self test prg | Runs Self-Test on a programmer | | set_prg_name | Changes the user name of a programmer | | Command | Action | |----------------------------|-------------------------------------------------------| | set_programming_action | Selects the action for a device | | set serialization log file | Sets the path and name of the serialization log file. | # Running Tcl Scripts from within FlashPro Express Instead of running scripts from the command line, you can use FlashPro Express's Execute Script dialog box to run a script. #### To execute a Tcl script file within FlashPro Express: 1. From the File menu, choose Execute Script to display the Run Script dialog box. Figure 15 · Run Script Dialog Box - 2. Click the **Browse** button to display the **Open** dialog box, in which you can navigate to the folder containing the script file to open. When you click **Open**, FlashPro Express enters the full path and script filename into the Run Script dialog box for you. - 3. In the Arguments box, enter the arguments to pass to your Tcl script. Separate each argument by a space character. For information about accessing arguments passed to a Tcl script, see - 4. Click Run. # Running Tcl Scripts from the Command Line You can run Tcl scripts from your Windows or Linux command line. #### To execute a Tcl script file in the FlashPro Express software from a shell command line: At the prompt, type the path to the Microsemi software followed by the word "SCRIPT" and a colon, and then the name of the script file as follows: <location of Microsemi software>/bin/FPExpress.exe SCRIPT:<filename> The example below executes in batch mode the script foo.tcl: <location of Microsemi software>/bin/FPExpress.exe script:foo.tcl The example below executes in batch mode the script foo.tcl and exports the log in the file foo.txt. <location of Microsemi software>/bin/FPExpress.exe script:foo.tcl logfile:foo.txt The example below executes in batch mode the script *foo.tcl*, creates a console where the log is displayed briefly, and exports the log in the file *foo.txt*: <location of Microsemi software>/bin/FPExpress.exe script:foo.tcl console\_mode:brief logfile:foo.txt If you leave console\_mode unspecified or set it to 'hide' FlashPro Express executes without a console window. If you want to leave the console window open you can run the script with the console\_mode parameter set to 'show', as in the following example: <location of Microsemi software>/bin/FPExpress.exe script:foo.tcl console\_mode:show logfile:foo.txt If you want to pass arguments to the Tcl script from the command line, then use the "SCRIPT\_ARGS" variable as follows: <location of Microsemi software>/bin/FPExpress.exe SCRIPT:<filename> SCRIPT\_ARGS:"param1 param2 param3" Arguments passed to a Tcl script can be accessed through the Tcl variables *argc* and *argv*. The example below demonstrates how a Tcl script accesses these arguments: ``` puts "Script name: $argv0" puts "Number of arguments: $argc" set i 0 foreach arg $argv { puts "Arg $i : $arg" incr i } ``` Note: Script names can contain spaces if the script name is protected with double quotes: FPExpress script: "FPExpress tcl/foo 1.tcl" # Exporting Tcl Scripts from within FlashPro Express To export a set of Tcl commands from the FlashPro Express history: - 1. From the File menu, choose Export Script File. - Enter the filename and click Save. The Export Script Options dialog appears (as shown in the figure below). Figure 16 · Script Export Options Dialog Box Check the **Include commands from current project only** to export commands of the current project only. You can specify the filename formatting by selecting **Relative filenames** (relative to the current directory) or **Qualified filenames**(absolute path, including the directory name). 4. Click OK. # close\_project Closes the FlashPro or FlashPro Express project. close\_project #### **Arguments** None #### **Supported Families** ΑII #### **Exceptions** None #### **Example** close\_project # complete\_prog\_job Tcl command; completes the current open job and generates a Job Status container including cryptographically signed Job Ticket end certifiers and Certificates of Conformance (if enabled) of the programmed devices. It archives ticket data from the HSM database. The resultant Job Status container can be imported into Job Manager and validated using U-HSM. If the job status file is not specified, the information is printed in the log window, and no Job Status container is created for subsequent verification. The HSM Job can only be completed if the number of devices in each HSM ticket has been exhausted. If devices remain, the job can only be terminated by using the "-terminate" option. ``` complete_prog_job [-job_status_file path]\ [-terminate] ``` NOTE: This command will fail if there are devices left in any HSM ticket and the terminate option is not used. #### **Arguments** [-job\_status\_file path] Full path to the output Job Status container which contains End-Job Certifier and CofCs. If not specified, information will be printed in the log window. [-terminate] This option will terminate the HSM job even if there are devices left in any HSM ticket. This parameter is optional if the number of devices in all tickets have been exhausted. #### **Supported Families** SmartFusion2, IGLOO2 #### See Also: SPPS User Guide User HSM Installation Guide Manufacturer HSM Installation Guide Job Manager User Guide # configure\_flashpro\_prg Changes FlashPro programmer settings. #### **Arguments** ``` -vpp {ON|OFF} ``` Enables FlashPro programmer to drive VPP. Set to ON to drive VPP. ``` -vpn {ON|OFF} ``` Enables FlashPro programmer to drive VPN; set to ON to drive VPN. ``` -vddl {ON|OFF} ``` Enables FlashPro programmer to drive VDDL; set to ON to drive VDDL. ``` -force_vddp {ON|OFF} ``` Enables FlashPro programmer to drive VDDP; set to ON to drive VDDP. ``` -vddp \{2.5|3.3\} ``` Sets VDDP to 2.5 or 3.3 volts. ``` -drive_trst {ON|OFF} ``` Enables FlashPro programmer to drive TRST; set to ON to drive TRST. ``` -force_freq {ON|OFF} ``` Forces the FlashPro software to use the TCK frequency specified by the software rather than the TCK frequency specified in the programmer file. ``` -freq {freq} ``` Specifies the TCK frequency in MHz. ### **Supported Families** ProASIC PLUS, ProASIC #### **Exceptions** None #### **Example** The following example enables the FlashPro programmer to drive the VPP, VPN, VDDL, VDDP, sets the drive voltage to 3.3v, disables the driver for TRST, and does not force the programmer to use the TCK frequency specified in the software. ``` configure\_flashpro\_prg -vpp \{ON\} -vpn \{ON\} -vddl \{ON\} -force\_vddp \{ON\} -vddp \{3.3\} -drive\_trst \{OFF\} -force\_freq \{OFF\} \\ ``` # configure\_flashpro3\_prg Changes FlashPro3 programmer settings. #### **Arguments** 28 ``` -vpump {ON|OFF} ``` Enables FlashPro programmer to drive VPUMP. Set to ON to drive VPUMP. ``` -clk_mode {discrete_clk|free_running_clk} ``` Specifies free running or discrete TCK. ``` -force_freq {ON|OFF} ``` Forces the FlashPro software to use the TCK frequency specified by the software rather than the TCK frequency specified in the programmer file. ``` -freq {freq} ``` Specifies the TCK frequency in MHz. #### **Supported Families** SmartFusion, IGLOO, ProASIC3 and Fusion #### **Exceptions** None #### **Example** The following example sets the VPUMP option to ON, TCK to free running, and uses the TCK frequency specified in the programmer file (force\_freq is set to OFF): ``` configure\_flashpro3\_prg - vpump \ \{ON\} - clk\_mode \ \{free\_running\_clk\} - force\_freq \ \{OFF\} - freq \ \{4\} ``` The following example sets VPUMP to ON, TCK to discrete, forces the FlashPro software to use the TCK frequency specified in the software (-force\_freq is set to ON) at a frequency of 2 MHz. ``` configure_flashpro3_prg -vpump {ON} -clk_mode {discrete_clk} -force_freq {ON} -freq {2} ``` # configure\_flashpro4\_prg Changes FlashPro4 programmer settings. #### **Arguments** ``` -vpump {ON|OFF} ``` Enables FlashPro4 programmer to drive VPUMP. Set to ON to drive VPUMP. ``` -clk_mode {discrete_clk|free_running_clk} ``` Specifies free running or discrete TCK. ``` -force_freq {ON|OFF} ``` Forces the FlashPro software to use the TCK frequency specified by the software rather than the TCK frequency specified in the programmer file. ``` -freq {freq} ``` Specifies the TCK frequency in MHz. #### **Supported Families** SmartFusion, IGLOO, ProASIC3 and Fusion #### **Exceptions** None #### **Example** The following example sets the VPUMP option to ON and uses a free running TCK at a frequency of 4 MHz (force\_freq is set to OFF). ``` \label{lem:configure_flashpro4_prg} $$\operatorname{ON} -\operatorname{clk_mode} \{free\_running\_clk\} -\operatorname{force\_freq} \{OFF\} -\operatorname{freq} \{4\}$ ``` The following example sets the VPUMP option to ON, uses a discrete TCK and sets force\_freq to ON at 2 MHz. ``` \verb|configure_flashpro4_prg -vpump {ON} -clk_mode {discrete_clk} -force_freq {ON} -freq {2} \\ ``` # configure\_flashpro5\_prg Tcl command; changes FlashPro5 programmer settings. #### **Arguments** ``` -vpump {ON | OFF} ``` Enables FlashPro5 programmer to drive VPUMP. Set to ON to drive VPUMP. ``` -clk_mode {free_running_clk} ``` Specifies free running TCK. ``` -programming_method {jtag | spi_slave} ``` Specifies the programming method to use. spi\_slave works only with SF2 and IGLOO2. Default is jtag. -force\_freq {ON|OFF} Forces the FlashPro software to use the TCK frequency specified by the software rather than the TCK frequency specified in the programmer file. ``` -freq {freq} ``` Specifies the TCK frequency in MHz. #### **Supported Families** RT ProASIC3, SmartFusion, IGLOO, ProASIC3, Fusion, SmartFusion2, IGLOO2, RTG4 #### **Exceptions** None #### **Example** The following example sets the VPUMP option to ON and uses a free running TCK at a frequency of 4 MHz (force\_freq is set to OFF). ``` configure_flashpro5_prg -vpump {ON} -clk_mode {free_running_clk} -force_freq {OFF} -freq {4} ``` The following example sets the VPUMP option to ON, uses a free running TCK and sets force\_freq to ON at 2 MHz. ``` configure_flashpro5_prg -vpump {ON} -clk_mode {free_running_clk} -force_freq {ON} -freq {2} ``` # configure\_flashproLite\_prg Changes FlashPro Lite programmer settings. #### **Arguments** ``` -vpp {ON | OFF} ``` Enables FlashPro programmer to drive VPP. Set to ON to drive VPP. ``` -vpn {ON|OFF} ``` Enables FlashPro programmer to drive VPN; set to ON to drive VPN. ``` -drive_trst {ON|OFF} ``` Enables FlashPro programmer to drive TRST; set to ON to drive TRST. ``` -force_freq {ON|OFF} ``` Forces the FlashPro software to use the TCK frequency specified by the software rather than the TCK frequency specified in the programmer file. ``` -freq {freq} ``` Specifies the TCK frequency in MHz. #### **Supported Families** ProASIC<sup>PLUS</sup> #### **Exceptions** None #### **Example** The following example sets the programmer to drive the VPP, drive VPN, drive the TRST and uses the frequency set by the programmer file (sets force\_freq to OFF): ``` configure_flashprolite_prg -vpp {ON} -vpn {ON} -drive_trst {ON} -force_freq {OFF} ``` # create\_job\_project Tcl command; creates a Flashpro Express job using the programming job exported from Libero. ``` create_job_project -job_project_location location -job_file path -overwrite 0/1 ``` #### **Arguments** ``` -job_project_location location ``` Specifies the location for your FlashPro Express job project. ``` -job_file path ``` Path to the Libero job file that is used as input to create the Flashpro Express job project. ``` -overwrite 0/1 ``` Set value to 1 to overwrite your existing job project. . #### **Supported Families** SmartFusion2, IGLOO2, RTG4 #### **Exceptions** None #### **Example** The following example creates a job project named test.job in the \fpexpress directory. It does not overwrite the existing job project. ``` create_job_project \ -job_project_location {D:\fpexpress} \ ``` -job\_file {D:\test\designer\test\export\test.job} -overwrite 0\ # dump\_tcl\_support Unloads the list of supported FlashPro or FlashPro Express Tcl commands. ``` dump_tcl_support -file {file} ``` #### **Arguments** -file {file} #### **Supported Families** ΑII #### **Exceptions** None #### **Example** The following example dumps your Tcl commands into the file 'tcldump.tcl' ``` dump_tcl_support -file {tcldump.tcl} ``` # enable\_serialization This Tcl command enables or disables serialization programming. ``` enable_serialization -name {device_name} -enable {true|false} ``` #### **Arguments** -name Specifies the device name. -enable Enables (true) or disables (false) serialization programming. #### **Exceptions** Must be a Microsemi Device #### **Supported Families** See the Tcl Commands and Supported Families table for the list of families that support this command. #### **Example** enable\_serialization -name $M2S/M2GL050\{T|S|TS\}$ -enable true ### get\_job\_status Tcl command; exports status of current open job. The job status contains number of devices left for each HSM ticket. If job status file is not specified, the information is printed in the log window. #### **Arguments** [-job\_status\_file path] Path to the output FlashPro Express job status container. The job status file can be sent to the Job Manager application and Certificates of Conformance (if available) validated using the U-HSM. [-archive] Moves the HSM ticket log files from the HSM ticket database to the HSM ticket archive. The archive folder was specified during HSM installation and setup. **NOTE**: If no job\_status\_file is specified, the archive option prints the Certificates of Conformance in the log window without exporting them. #### **Supported Families** SmartFusion2, IGLOO2 #### See Also SPPS User Guide Manufacturer HSM Installation Guide User HSM Installation Guide Job Manager User Guide # open\_project Opens a FlashPro or FlashPro Express project. ``` open_project -project {project} ``` #### **Arguments** -project {project} Specifies the location and name of the project you wish to open. ### **Supported Families** ΑII ### **Exceptions** None #### **Example** Opens the 'FPPrj1.pro' project from the FPProject1 directory ``` open_project -project {./FPProject1/FPPrj1.pro} ``` ### ping\_prg Pings one or more programmers. ``` ping_prg (-name {name})* ``` #### **Arguments** -name $\{name\}$ Specifies the programmer to be pinged. Repeat this argument for multiple programmers. #### **Supported Families** ΔII #### **Exceptions** None #### **Example** The following example pings the programmers 'FP300085' and 'FP30086'. ``` ping_prg -name {FP300085} -name {FP300086} ``` # process\_job\_request Tcl command; processes a job request received from Job Manager. It is part of the Job Ticket generation process. NOTE1: This command does not require a FlashPro Express project to be created or opened. NOTE2: HSM parameters must be configured using set\_hsm\_params before processing job request. #### **Arguments** ``` -request_file path Full file name of job request file. -reply_file path Full file name of job reply file. -overwrite_reply {TRUE | FALSE} TRUE allows overwriting of any pre-existing reply_file. ``` #### **Supported Families** SmartFusion2 and IGLOO2 #### **Example** ``` process_job_request \ -request_file {D:/flashpro_files/jobmgr_project12/cm_request.req} \ -reply_file {D:/flashpro_files/jobmgr_project12/cm_reply.rep} \ -overwrite_reply {TRUE} ``` #### See Also SPPS User Guide Job Manager User Guide set hsm\_params # refresh\_prg\_list Refreshes the programmer list. This is most often used to have FlashPro or FlashPro Express detect a programmer that you have just connected. ``` refresh_prg_list ``` #### **Arguments** None #### **Supported Families** ΑII #### **Exceptions** None #### **Example** refresh\_prg\_list # remove\_all\_hsm\_tickets Tcl command; removes all HSM tickets from the HSM. ``` remove_all_hsm_tickets ``` #### **NOTES** - This command should be used very carefully since it removes all the HSM tickets, rendering any FlashPro Express jobs based on those tickets to be unusable. This is only provided for emergency ticket cleanup. - 2. This command is only available if FlashPro Express was invoked as follows: ``` FPExpress ENABLE_HSM_TICKETS_REMOVAL:1 ``` 3. This command does not require a FlashPro Express project to be created or opened. #### **Supported Families** SmartFusion2, IGLOO2 #### See Also SPPS User Guide Job Manager User Guide complete\_prog\_job ### remove\_prg Removes the programmer from the programmer list. ``` remove_prg (-name {name})* ``` #### **Arguments** -name { *name* } \* Specifies the programmer to be removed. You can repeat this argument for multiple programmers. #### **Supported Families** ΑII #### **Exceptions** None #### **Example** The following example removes the programmer '03178' from the programmer list: ``` remove_prg (name {03178})* ``` ### run selected actions Runs the selected action on the specified programmer and returns the exit code from the action. If no programmer name is specified, the action is run on all connected programmers. Only one exit code is returned, so return code cannot be used when action is run on more than one programmer. A programming file must be loaded. ``` run_selected_actions [(-name {name})*] ``` #### **Arguments** ``` -name {name} ``` Optional argument that specifies the programmer name. You can repeat this argument for multiple programmers. #### **Supported Families** ΑII #### **Exceptions** None #### **Example** The following example runs the selected actionS on the programmers 'FP30085' and 'FP30086'. ``` run_selected_actions -name {FP300085} -name {FP300086} ``` Example using return code: ``` if {[catch {run_selected_actions} return_val]} {puts "Error running Action"} else {puts "exit code $return_val"} ``` Example returning exit code to the command line (returns exit 99 on script failure, otherwise returns exit code from selected action): ``` if {[catch {run_selected_actions} return_val]}{exit 99} else {exit $return_val} ``` # save\_log Saves the log file. ``` save_log -file {file} ``` #### **Arguments** ``` -file {file} ``` Specifies the log filename. #### **Supported Families** ΑII #### **Exceptions** None #### **Example** The following example saves the log file with the name 'my\_logfile1.log': ``` save_log -file {my_logfile1.log} ``` ### save\_project Saves the FlashPro or FlashPro Express project. save\_project #### **Arguments** None #### **Supported Families** ΑII #### **Exceptions** None #### **Example** save\_project # scan\_chain\_prg In single mode, this command runs scan chain on a programmer. In chain mode, this command runs scan and check chain on a programmer if devices have been added in the grid. ``` scan_chain_prg [(-name {name})+] ``` #### **Arguments** -name $\{name\}$ Specifies the programmer name. #### **Supported Families** ΑII #### **Exceptions** None #### **Example** The following example runs scan chain on a single programmer (single mode) named '21428': ``` scan_chain_prg -name {21428} ``` # select\_serial\_range This Tcl command selects the range of indexes to program. select\_serial\_range -name device\_name -from\_data start\_index\_to\_program -to\_data end\_index\_to\_program #### **Arguments** -name Specifies the device name. -from\_data Specifies the start index to program. -to\_data Specifies the end index. ## **Supported Families** See the Tcl Commands and Supported Families table for the list of families that support this command. #### **Exceptions** Must be a Microsemi Device #### **Example** ``` select_serial_range -name M2S/M2GL050{T|S|TS} -from_data 3 -to_data 5 ``` ## self\_test\_prg Runs Self-Test on a programmer. ``` self_test_prg (-name {name})* ``` #### **Arguments** ``` -name {name} ``` Specifies the programmer name. You can repeat this argument for multiple programmers. ## **Supported Families** ΑII #### **Exceptions** None #### **Example** The following examples runs the self test on the programmer '30175': ``` self_test_prg (-name {30175})* ``` # set\_hsm\_params Tcl command; saves the HSM parameters for the FlashPro Express application. These parameters remain in effect until overridden by another invocation of this command. ``` set_hsm_params -hsm_server_name hsm_server \ -hsm_type_u {TRUE | FALSE} \ -m_hsm_uuid m_uuid \ ``` ``` -ftp_username | \ -ftp_password | ftp_password | ``` **NOTE1**: The HSM parameters are persistent between multiple FlashPro Express sessions on the same computer. NOTE2: HSM parameters only need to be set for HSM flow jobs. #### **Arguments** ``` -hsm_server hsm_server Name or IP address of HSM server computer -hsm_type_u {TRUE|FALSE} TRUE FlashPro Express will use the Manufacturer features of the User HSM. FALSE FlashPro Express will use a Manufacturer HSM. -m_hsm_uuid m_uuid UUID of HSM to be used for FlashPro Express tasks. -ftp_username ftp_username User name to access the HSM files via FTP server. -ftp_password ftp_password ``` Password to access the HSM files via FTP server. #### **Supported Families** SmartFusion2 and IGLOO2 #### **Example** ## set\_prg\_name Changes the user name of a programmer. ``` set_prg_name -name {name} -new_name {new_name} ``` ## **Arguments** ``` -name {name} Identifies the old programmer name. -new_name {new_name} Specifies the new programmer name. ``` #### **Supported Families** All devices supported by FlashPro. #### **Exceptions** None #### **Example** The following example changes the name of the programmer 'FP300086' to 'FP3Prg2': ``` set_prg_name -name {FP300086} -new_name {FP3Prg2} ``` # set\_programming\_action Selects the action for a device. The device name parameter must be specified only in chain programming mode. A programming file must be loaded. The device must be a Microsemidevice. ``` set_programming_action [-name {name}] -action {action} ``` ## **Arguments** ``` -name {name} Specifies the device name. -action {action} Specifies the action. ``` ## **Supported Families** SmartFusion, IGLOO, ProASIC3, Fusion #### **Exceptions** Must be a Microsemi device #### **Example** The following example sets the programming action in single programming mode: ``` set_programming_action -action {PROGRAM} And in chain programming mode: set_programming_action -name {MyDevicel} -action {ERASE} ``` ## set\_programming\_file Sets the programming file for a device. Either the *file* or the *no\_file* flag must be specified. A programming file must be loaded. The device must be a Microsemi device. ``` set_programming_file [-name {name}] [-file {file}] [-no_file { }] ``` #### **Arguments** ``` -name {name} Specifies the device name. This argument must be specified only in chain programming mode. -file {file} Specifies the programming file. -no_file Specifies to unload the current programming file. ``` ## **Supported Families** SmartFusion, IGLOO, ProASIC3, Fusion #### **Exceptions** Must be a Microsemi device. #### **Examples** In single programming mode: ``` set_programming_file -file {e:/design/pdb/TopA3P250.pdb} In chain programming mode: ``` set\_programming\_file -name {MyDevice2} -file {e:/design/pdb/TopA3P250.pdb} set\_programming\_file -name {MyDevice1} -no\_file # set\_serialization\_log\_file This Tcl command sets the path and name of the serialization log file. ``` set_serialization_log_file -file {log_file_path} ``` #### **Arguments** -file Specifies the serialization log file path and name #### **Supported Families** See the Tcl Commands and Supported Families table for the list of families that support this command. #### **Exceptions** Must be a Microsemi Device #### **Example** set\_serialization\_log\_file -file {C:/local\_z\_folder/work/my\_serial\_log} | Error Code | Exit<br>Code | Exit Message | Possible Solution | Possible Cause | |------------|--------------|----------------------------------------------------------------|-------------------------------------|---------------------------------------------------------------------------| | | 0 | Passed (no error) | - | - | | 0x8001 | -24 | Failure to read<br>DSN | disable "System Controller Suspend | Device is in System Controller<br>Suspend Mode<br>Check board connections | | 0x8002 | 5 | Failure to configure device programming at 1.2/1.0 VCC voltage | cause the issue during | Unstable voltage level<br>Signal integrity issues<br>oJTAG pins | | 0x8032 | 5 | Device is busy | Monitor related power supplies that | Unstable VDDIx voltage level | | Error Code | Exit<br>Code | Exit Message | Possible Solution | Possible Cause | |----------------------------------|--------------|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | | | | cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. | | | 0x8003 | 5 | Failed to enter programming mode | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. Tie DEVRST_N to HIGH prior to programming the device. | Unstable voltage level Signal integrity issues on JTAG pins DEVRST_N is tied to LOW | | 0x8004 | 6 | Failed to verify IDCODE | Choose the correct programming file and select the correct device in the chain. Measure JTAG pins and noise for reflection. If TRST is left floating then add pull-up to pin. Reduce the length of Ground connection. | Incorrect programming file Incorrect device in chain Signal integrity issues on JTAG pins | | 0x<br>80<br>05<br>0x<br>80<br>06 | 10 | Failed to program eNVM | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. | Unstable voltage level.<br>Signal integrity issues on JTAG pins. | | 0x8007 | 11 | Failed to verify<br>FPGA Array<br>Failed to verify<br>Fabric<br>Configuration<br>Failed to verify<br>Security | Verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG | Device is programmed with a different design or the component is blank. Unstable voltage level. Signal integrity issues on JTAG pins. | | Error Code | Exit Message<br>Code | | Possible Solution | Possible Cause | |------------------|----------------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | | | | signals for noise or reflection. | | | 0x8008<br>0x8009 | 11 | Failed to verify eNVM | Verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. | Device is programmed with a different design. Unstable voltage level. Signal integrity issues on JTAG pins. | | 0x8010 | -35 | Failed to unlock<br>User Pass Key 1 | Provide a programming file with a pass key that matches pass key programmed into the device. | Pass key in file does not match device | | 0x8011 | -35 | Failed to unlock<br>User Pass Key 2 | Provide a programming file with a pass key that matches pass key programmed into the device. | Pass key in file does not match device | | 0x8012 | -35 | Failed to unlock debug pass key | Provide a programming file with a pass key that matches pass key programmed into the device. | Pass key in file does not match device | | 0x8013 | -18 | Digest request<br>from SPI/JTAG<br>is protected by<br>User Pass Key 1 | Provide a programming file with a pass key that matches pass key programmed into the device. | Digest request from SPI/JTAG is protected by user pass key 1. Lock bit has been configured in the Debug Policy within SPM (Security Policy Manager) | | 0x8014 | -19 | Failed to verify digest | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. | Unstable voltage level<br>Signal integrity issues on JTAG pins | | 0x8015 | -20 | FPGA Fabric<br>digest<br>verification: FAIL | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed FPGA Fabric is either erased or the data has been corrupted or tampered with | | 0x8016 | -20 | eNVM_0 digest | Use the same programming file | Programming bitstream components | | Error Code | Exit<br>Code | Exit Message | Possible Solution | Possible Cause | |--------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | | | verification: FAIL | that was used to program the device. | do not match components programmed eNVM_0 data has been corrupted or tampered with | | 0x8017 | -20 | eNVM_1 digest verification: FAIL | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed eNVM_1 data has been corrupted or tampered with | | 0x8018 | -20 | User security policies segment digest verification: FAIL | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed User security policy segment data has been corrupted or tampered with | | 0x8019 | -20 I | | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed User key set 1 segment data has been corrupted or tampered with | | 0x801A | -20 | | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed User key set 2 segment data has been corrupted or tampered with | | 0x801B -20 | | Factory row and factory key segment digest verification: FAIL | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed Factory row and factory key segment data has been corrupted or tampered with | | | | Fabric<br>configuration<br>segment digest<br>verification: FAIL | Use the same programming file that was used to program the device. | Programming bitstream components do not match components programmed. Fabric configuration segment data has been corrupted or tampered with | | Ox 80 1D Device security prevented operation Ox 80 1E | | Run DEVICE_INFO to view security features that are protected. Provide a bitstream file with a user pass key 1 that matches the user pass key 1 programmed into the device. | The device is protected with user pass key 1 and the bitstream file does not contain user pass key 1. User pass key 1 in the bitstream file does not match the device. | | | 0x801F | -22 | Authentication | Program the device prior to running | Running VERIFY action on a blank | | Error Code | Code Exit Exit Messag | | Possible Solution | Possible Cause | |------------------|-----------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x8020 | | Error<br>Bitstream or data<br>is corrupted or<br>noisy | VERIFY action Regenerate bitstream file. | device. Bitstream file has been corrupted Bitstream was incorrectly generated | | 0x8021<br>0x8022 | -23 | Authentication<br>Error<br>Invalid/Corrupted<br>encryption key | encryption key that matches that on<br>the device.<br>Run DEVICE_INFO action to verify<br>that the device has no security. If<br>the device does not have secuirty,<br>you cannot erase it. | File contains an encrypted key that does not match the device Attempting to erase a device with no security using master security file File contains user encryption key, but device has not been programmed with the user encryption key Device has user encryption key 1/2 enforced and you are attempting to reprogram security settings | | 0x8023<br>0x8024 | -24 | Authentication<br>Error<br>Back level not<br>satisfied | | Design version is not higher than the back-level programmed device | | 0x8025<br>0x8026 | -25 | Authentication<br>Error<br>DSN binding<br>mismatch | Use the correct programming file with a DSN that matches the DSN of the target device being programmed. | DSN specified in programming file does not match the device being programmed | | 0x8027<br>0x8028 | -26 | Authentication<br>Error<br>Insufficient<br>device<br>capabilities | Generate a programming file with the correct capabilities for the target device. | Device does not support the capabilities specified in programming file | | 0x8029<br>0x802A | -27 | Authentication<br>Error<br>Incorrect<br>DEVICEID | Choose the correct programming file and select the correct device in chain. Measure JTAG pins and noise or reflection. If TRST is left floating, then add pull-up to pin. Reduce the length of ground connection. | Incorrect programming file Incorrect device in chain Signal integrity issues on JTAG pins | | 0x802B<br>0x802C | -28 | Authentication<br>Error<br>Programming file<br>is outdated, | Generate programming file with latest version of Libero SoC. | Programming file version is out of date | | Error Code | Exit<br>Code | Exit Message | Possible Solution | Possible Cause | | |------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | please<br>regenerate | | | | | 0x802F | -30 | JTAG interface<br>is protected by<br>UPK1 | User needs to provide correct UPK1 to unlock device. | Invalid or no UPK1 is provided | | | 0x8030<br>0x8031 | -31 | Authentication Error Invalid or inaccessible Device Certificate | User can program a valid application code. This can be done with SoftConsole. FAB_RESET_N should be tied to HIGH. | M2S090 Rev. A or M2S150 Rev. A: Either certificate is corrupted or the user hasn't provided the application code in the eNVM or provided invalid application code FAB_RESET_N is tied to ground | | | 0x8032<br>0x8033<br>0x8034<br>0x8035<br>0x8036<br>0x8037<br>0x8038<br>0x8039 | -32 | Instruction timed out | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. | Unstable voltage level<br>Signal integrity issues on JTAG pins | | | 0x8040 | -22 | Authentication<br>Error<br>Bitstream or data<br>is corrupted or<br>noisy | Program the device prior to running VERIFY action Regenerate bitstream file. | Running VERIFY action on a blank<br>device.<br>Bitstream file has been corrupted<br>Bitstream was incorrected generated | | | 0x8041 | -23 | Authentication<br>Error<br>Invalid/Corrupted<br>encryption key | the device. | File contains an encrypted key that does not match the device File contains user encryption key, but device has not been programmed with the user encryption key Attempting to erase a device with no security using master security file Device has user encryption key 1/2 enforced and you are attempting to reprogram security settings | | | 0x8042 | -24 | Authentication<br>Error<br>Back level not<br>satisfied | Generate a programming file with a design version higher than the back level version. | Design version is not higher than the back-level programmed device | | | Error Code | Exit<br>Code | Exit Message | Possible Solution | Possible Cause | |------------|--------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x8043 | -25 | Authentication<br>Error<br>DSN binding<br>mismatch | Use the correct programming file with a DSN that matches the DSN of the target device being programmed. | DSN specified in programming file does not match the device being programmed | | 0x8044 | -26 | Authentication<br>Error<br>Insufficient<br>device<br>capabilities | Generate a programming file with the correct capabilities for the target device. | Device does not support the capabilities specified in programming file | | 0x8045 | -27 | Authentication<br>Error<br>Incorrect<br>DEVICEID | Choose the correct programming file and select the correct device in chain. Measure JTAG pins and noise or reflection. If TRST is left floating, then add pull-up to pin. Reduce the length of ground connection. | Incorrect programming file Incorrect device in chain Signal integrity issues on JTAG pins | | 0x8046 | -28 | Authentication<br>Error<br>Unsupported<br>bitstream<br>protocol version | Generate programming file with latest version of Libero SoC. | Old programming file | | 0x8048 | -31 | Authentication Error Invalid or inaccessible Device Certificate | User can program a valid application code. This can be done with SoftConsole. FAB_RESET_N should be tied to HIGH. | M2S090 Rev. A or M2S150 Rev. A:<br>Either certificate is corrupted or the<br>user hasn't provided the application<br>code in the eNVM or provided invalid<br>application code<br>FAB_RESET_N is tied to ground | | 0x8049 | 11 | Failed to verify eNVM | with the correct data/design. | Device is programmed with a different design. Unstable voltage level. Signal integrity issues on JTAG pins. | | 8x804A | 10 | Failed to program eNVM | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more | Unstable voltage level.<br>Signal integrity issues on JTAG pins. | | Error Code | Exit<br>Code | Exit Message | Possible Solution | Possible Cause | |------------|--------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x804B | -21 | Device security prevented operation | information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. Run DEVICE_INFO to view security features that are protected. Provide a bitstream file with a user pass key 1 that matches the user pass key 1 programmed into the device. | The device is protected with user pass key 1 and the bitstream file does not contain user pass key 1. User pass key 1 in the bitstream file does not match the device. | | 0x804C | 11 | Failed to verify<br>FPGA Array<br>Failed to verify<br>Fabric<br>Configuration<br>Failed to<br>verifySecurity | Verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor JTAG supply pins during programming; measure JTAG signals for noise or reflection. | Device is programmed with a different design or the component is blank. Unstable voltage level. Signal integrity issues on JTAG pins. | | 0x804D | -36 | <hsm related<br="">error message<br/>based on<br/>scenario&gt;</hsm> | Check if HSM the communication path to HSM is up. Make sure project is loaded properly and that HSM tickets have not been cleaned. | HSM communication error. HSM call returns error. | The table below lists exit codes for SmartFusion, IGLOO, ProASIC3 and Fusion devices in software v8.6 and ABOVE only. See the <u>Device Exit Codes for pre-v8.6 Software</u> help topic for exit codes for older versions. Note: Exit codes with positive integers are reserved for current and future standard EXIT codes of the STAPL standard. Exit codes with negative integers are reserved for vendor-specific EXIT codes. $\textbf{Table 2} \cdot \textbf{Exit Codes for SmartFusion, IGLOO, ProASIC3 and Fusion Family Devices in Software v8.6 and Above \textbf{Model ProASIC3} and ProASIC3}$ | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------|--------------|---------------------------------|-----------------------------------------------------------------------------------------|-------------------| | | 0 | Passed (no error) | | | | | 1 | A physical chain does not match | Physical chain configuration has been altered. Something has become disconnected in the | | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |----------------------------|--------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | the expected set up from the STAPL file. Also known as Checking Chain Error. | chain. The specific IR length of non-Microsemi devices may be incorrect. The order of the specified chain may be incorrect. | | | 0x8052 | 5 | Failed to<br>enter<br>programmi<br>ng mode. | Unstable VPUMP voltage level. Unstable VCC Signal integrity issues on JTAG pins. Device is in FlashFreeze mode (ProASICL or IGLOO devices) Older software or programming file used. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. Disble the FlashFreeze pin (ProASICL or IGLOO devices) Generate STAPL file with the latest version of Designer/FlashPro. Use latest version of FlashPro software. | | 0x801D<br>0x8053 | 6 | Failed to<br>verify<br>IDCODE | Incorrect programming file Incorrect device in chain Signal integrity issues on JTAG pins | Choose the correct programming file and select the correct device in chain. Measure JTAG pins and noise or reflection. If TRST is left floating then add pull-up to pin. Reduce the length of ground connection. | | 0x8005<br>0x8009<br>0x800B | 6 | Failed to<br>verify AES<br>Sec. | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro. Use latest version of FlashPro software. Try again at a slower TCK. Contact Microsemi Technical Support. | | 0x8008 | 6 | Failed to<br>verify<br>IDCODE.<br>Target is<br>an M7<br>device | File is not for M7, but target device is M7 Signal integrity issues on JTAG pins. | Check that the target device is M7 enabled. Make sure that the programming file you generated is for an M7-enabled device. Measure JTAG pins, noise and reflection. | | 0x800A | 6 | Failed to | Files not for M1, but target device | Check that the target device is M1 | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------|--------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | verify<br>IDCODE<br>Target is<br>an M1<br>device | is M1. Signal integrity issues on JTAG pins | enabled. Make sure the programming file generated is for an M1-enabled device. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x800C | 6 | Failed to<br>verify<br>IDCODE.<br>Core<br>enabled<br>device<br>detected | File is not for target device. Signal integrity issues on JTAG pins | Check the target device; make sure the programming file generated is matches the target device. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x800D | 6 | Failed to<br>verify<br>IDCODE.<br>The target<br>is not M7<br>device | File is for M7 but target device is not M7. Signal integrity issues on JTAG pins. | Check that the target device is not M7 enabled. Make sure that the programming file generated is for non-M7 enabled device. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x800E | 6 | Failed to<br>verify<br>IDCODE.<br>Target is<br>not an M1<br>device | File is for M1, but target device is not M1. Signal integrity issues on JTAG pins | Check that the target device is not M1 enabled. Make sure that the generated programming file is for non-M1 enabled device. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8006 | 6 | Failed to<br>verify<br>IDCODE.<br>Target is<br>not a P1<br>device | File is not for P1, but target device is a P1 device. Signal integrity issues on JTAG pins | Check that the target device is P1 enabled. Make sure programming file generated is for M1 enabled device. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x801E | 6 | A3PE600<br>Engineerin<br>g Sample<br>Device<br>Detected.<br>This device | | Contact Microsemi Technical Support | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |----------------------------------------|--------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | is<br>supported<br>with pre-<br>v8.3 SP1<br>STAPL<br>files only | | | | 0x8057 | 8 | Failed<br>Erase<br>Operation. | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8058 | 10 | Failed to<br>program<br>FPGA<br>array at<br>row <row<br>number&gt;.</row<br> | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x805D<br>0x805E<br>0x807B | 10 | Failed to<br>enable<br>FPGA<br>Array. | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x80<br>95<br>0x80<br>96<br>0x80<br>97 | 10 | Failed to<br>disable<br>FPGA<br>Array. | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------------------------------------|--------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | pins. | | | 0x8061<br>0x8062 | 10 | Failed to program FlashROM. | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x801B<br>0x801C<br>0x806C<br>0x806D<br>0x806E | 10 | Error<br>programmi<br>ng<br>Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | Unstable VCC_NVM/VCC_OSC voltage level (Fusion only) Unstable VCC_ENVM/VCC_RCOSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins NVM corruption is possible when writing from your design; check the NVM status for confirmation. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. Reset signal is not properly tied off in your design. Inspect device using Device Debug. | | 0x807D<br>0x807E | 10 | Error<br>programmi<br>ng system<br>init and<br>boot clients | Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. Inspect device using Device Debug. | | 0x8069<br>0x806A<br>0x806B | 10 | Error<br>programmi<br>ng<br>Embedded<br>Flash<br>Memory<br>Block<br>(EMFB) | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the latest version of FlashPro software Try again at a slower TCK Inspect device using Device Debug. Contact Microsemi Technical Support | | 0x808E<br>0x808F | 10 | Error<br>programmi | | Try reprogramming | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |----------------------------|--------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x8090<br>0x8091 | | ng<br>Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | | Contact Microsemi Technical Support | | 0x807F<br>0x8080 | 10 | Error<br>programmi<br>ng system<br>init and<br>boot clients | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the latest version of FlashPro software Try again at a slower TCK Inspect device using Device Debug. Contact Microsemi Technical Support | | 0x8059<br>0x805B | 11 | Verify 0 failed at row <row number=""> Verify 1 failed at row <row number="">.</row></row> | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8060 | 11 | Failed to<br>verify<br>FlashROM<br>at row<br><flashro<br>M row<br/>number&gt;.</flashro<br> | Device is programmed with a different design. Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. | Run VERIFY_DEVICE_INFO to verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8075<br>0x8076<br>0x8077 | 11 | Failed to<br>verify<br>Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | Device is programmed with a different design. Unstable VCC Unstable VCC_NVM/VCC_OSC (Fusion only) Unstable VCC_ENVM/VCC_ROSC voltage level (SmartFusion only) | Verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Measure JTAG pins, and noise or | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |----------------------------|--------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Signal integrity issues on JTAG pins. The EFMB data was modified in your FPGA design after programming. This could have occurred during standalone verify. The target EFMB is locked with FlashLock when running ACTION PROGRAM_NVM_ACTIVE_ARR AY or VERIFY_NVM_ACTIVE_ARRAY. | reflection. Run DEVICE_INFO to confirm if the target EFMB block is locked with FlashLock (pass key). If the target EFMB block is locked, then you must unlock it by erasing the security and then reprogramming with the desired security settings. After unlocking the target EFMB block attempt to rerun the target ACTION. Inspect device using Device Debug. | | 0x8085<br>0x8086 | 11 | Failed to<br>verify<br>system init<br>and boot<br>clients | Device is programmed with a different design. Unstable VCC Unstable VCC_NVM/VCC_OSC (Fusion only) Unstable VCC_ENVM/VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. The EFMB data was modified in your FPGA design after programming. This could have occurred during standalone verify. The target EFMB is locked with FlashLock when running ACTION PROGRAM_NVM_ACTIVE_ARR AY or VERIFY_NVM_ACTIVE_ARRAY. | Verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Measure JTAG pins, and noise or reflection. Run DEVICE_INFO to confirm if the target EFMB block is locked with FlashLock (pass key). If the target EFMB block is locked, then you must unlock it by erasing the security and then reprogramming with the desired security settings. After unlocking the target EFMB block attempt to rerun the target ACTION. Inspect device using Device Debug. | | 0x8072<br>0x8073<br>0x8074 | 11 | Failed to<br>verify<br>Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the latest version of FlashPro software Try again at a slower TCK Inspect device using Device Debug. Contact Microsemi Technical Support | | 0x8083<br>0x8084 | 11 | Failed to verify system init and boot | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the latest version of FlashPro software | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------|--------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | clients | | Try again at a slower TCK Inspect device using Device Debug. Contact Microsemi Technical Support | | 0x8014<br>0x8015 | 11 | Failed to<br>verify<br>calibration<br>data | Unstable VCC Unstable VCC_NVM/VCC_OSC (Fusion only) Unstable VCC_ENVM/VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. Try reprogramming. Workaround: Disable optional procedure CHECK_AND_BACKUP_CALIB | | 0x805A<br>0x805C | 11 | Verify 0 failed at row <row number=""> . Verify 1 failed at row <row number=""></row></row> | Device is programmed with a different design Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins | Run VERIFY_DEVICE_INFO to verify the device is programmed with the correct data/design. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8063 | 14 | Failed to<br>program<br>Silicon<br>Signature.<br>Failed to<br>program<br>security<br>lock<br>settings. | Signal integrity issues on JTAG pins. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8068 | -18 | Failed to<br>authenticat<br>e the<br>encrypted<br>data. | Incorrect AES key. Signal integrity issues on JTAG pins. | Generate a programming file with the correct AES key. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------|--------------|------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x805F | -20 | Failed to verify FlashROM | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the latest version of FlashPro software. | | | | at row<br><flashro<br>M row</flashro<br> | Device is programmed with a different design. | Program with the correct data/design. | | | | number>. | Unstable VPUMP voltage level. | Monitor related power supplies that cause the issue during programming; check for | | | | | Unstable VCC Unstable VCC_OSC (Fusion only) | transients outside of Microsemi specifications. See your device datasheet for more information on transient | | | | | | specifications. | | | | | Unstable VCC_ROSC voltage level (SmartFusion only) | Measure JTAG pins and noise or reflection. | | | | | Signal integrity issues on JTAG pins. | | | 0x8065 | -22 | Failed to program | Unstable VPUMP voltage level. | Monitor related power supplies that cause the issue during programming; check for | | | | pass key. | Unstable VCC | transients outside of Microsemi | | | | | Unstable VCC_OSC (Fusion only) | specifications. See your device datashed for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | | | | Unstable VCC_ROSC voltage level (SmartFusion only) | | | | | | Signal integrity issues on JTAG pins. | | | 0x8066 | -23 | Failed to program | Unstable VPUMP voltage level. | Monitor related power supplies that cause the issue during programming; check for | | | | AES key. | Unstable VCC | transients outside of Microsemi specifications. See your device datasheet | | | | | Unstable VCC_OSC (Fusion only) | for more information on transient specifications. | | | | | Unstable VCC_ROSC voltage level (SmartFusion only) | Measure JTAG pins and noise or | | | | | Signal integrity issues on JTAG pins. | reflection. | | 0x8055<br>0x8056 | -24 | Failed to program | Unstable VPUMP voltage level. | Monitor related power supplies that cause the issue during programming; check for | | UX8U56 | | UROW. | Unstable VCC | transients outside of Microsemi | | | | | Unstable VCC_OSC (Fusion only) | specifications. See your <u>device datashee</u> for more information on transient specifications. | | | | | Unstable VCC_ROSC voltage level (SmartFusion only) | Monitor VJTAG during programming; | | | | | Signal integrity issues on JTAG pins. | measure JTAG signals for noise or reflection. | | | | | | Make sure you mounted <b>0.01</b> μ <b>F</b> and | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |----------------------------|--------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------| | | | | | <b>0.33</b> μ <b>F</b> caps on Vpump (close to the pin). | | 0x802A | -27 | FlashROM<br>Write/Eras<br>e is<br>protected<br>by the<br>passkey.<br>A valid<br>passkey<br>needs to<br>be<br>provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | 0x8025 | -28 | FPGA Array Write/Eras e is protected by the passkey. A valid pass key needs to be provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | 0x802B<br>0x802D | -29 | FlashROM<br>Read is<br>protected<br>by<br>passkey.<br>A valid<br>passkey<br>needs to<br>be<br>provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a pass key that matches the passkey programmed into the device | | 0x8024<br>0x8026 | -30 | FPGA Array verification is protected by a passkey. A valid passkey needs to be provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | 0x804B<br>0x8001<br>0x8007 | -31 | Failed to verify AES key. | AES key in the file does not match the device. Unstable VCC | Provide a programming file with an AES key that matches the AES key programmed into the device. | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |----------------------------|--------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Unstable JTAG/VPUMP voltage level. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x8000 | -31 | Failed to<br>verify AES<br>key. | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the latest version of FlashPro software. Try again at a slower TCK Contact Microsemi Technical Support | | 0x8020<br>0x8022<br>0x8028 | -33 | FPGA Array encryption is enforced. A programmi ng file with encrypted FPGA array data needs to be provided. | File contains unencrypted array data, but device contains AES key. | Provide a programming file with an encrypted FPGA Array data. | | 0x802C<br>0x802F | -34 | FlashROM encryption is enforced. A programmi ng file with encrypted FlashROM data needs to be provided. | File contains unencrypted FlashROM data, but the device contains an AES key. | Provide a programming file with an encrypted FlashROM data. | | 0x801F<br>0x804A | -35 | Failed to match pass key. | Pass key in file does not match pass key in device. | Provide a programming file with a pass key that matches the pass key programmed into the device. | | 0x802E<br>0x8030 | -36 | FlashROM<br>Encryption<br>is not<br>enforced. | File contains encrypted FlashROM, but device encryption is not enforced for FlashROM | Regenerate security programming file with proper AES key. Program device security. Retry programming FlashROM with | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | guarantee valid AES key present in target device. Unable to proceed with Encrypted FlashROM programmi ng. | | encrypted programming file. | | 0x8021<br>0x8023<br>0x8027<br>0x8029 | -37 | FPGA Array Encryption is not enforced. Cannot guarantee valid AES key present in target device. Unable to proceed with Encrypted FPGA Array verification. | File contains encrypted FPGA Array, but the device encryption is not enforced for FPGA Array. | Regenerate security programming file with proper AES key. Program device security. Retry programming FPGA Array with encrypted programming file. | | 0x8067 | -38 | Failed to program pass key. | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins. Bad device. | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Measure JTAG pins and noise or reflection. | | 0x806F<br>0x8070<br>0x8071<br>0x8081<br>0x8082 | -39 | ERROR: 2<br>or more<br>errors<br>found on<br>this page | Unstable VCC_NVM/VCC_OSC voltage (Fusion only) Unstable VCC_ENVM/VCC_ROSC | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------------------------------------|--------------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | 0x8089 | | | (SmartFusion only) | specifications. | | | | | NVM reset signal is floating in user design | Bias NVM reset to a logic state in user design. | | | | | 2 or more ECC errors found when reading the eNVM | Try reprogramming. | | 0x8010 | -39 | ERROR: 2<br>or more<br>errors<br>found on<br>this page. | 2 or more ECC errors found when reading the master calibration data | The master calibration data has been corrupted. Try restoring master calibration from backup, if it exists, by running RECOVER_CALIB. | | | | | | Workaround: Disable optional procedure CHECK AND BACKUP CALIB | | 0x8013 | -39 | ERROR: 2<br>or more | 2 or more ECC errors found when verifying the backup calibration | Rerun action to attempt to write backup calibration again. | | | | errors<br>found on<br>this page. | | Workaround: Disable optional procedure CHECK AND BACKUP CALIB | | 0x8078<br>0x8079<br>0x807A<br>0x8087<br>0x8088 | -40 | Embedded<br>Flash<br>Memory<br>Block MAC<br>Failure. | Data in the file is encrypted with a different AES key than the device. | Verify the programming file is generated from the latest version of Designer/FlashPro. | | 0x8002<br>0x8003 | -42 | Failed to verify security settings. | File security settings do not match device. | Provide a programming file with security setting that match the security settings programmed into the device. | | 0x8093 | -42 | Failed to<br>verify<br>eNVM/EF<br>MB client<br>JTAG<br>protection<br>settings | Device eNVM/EFMB client JTAG protection settings are not programmed or are programmed with different settings | Verify the device is programmed with the correct eNVM/EFMB client JTAG protection settings | | 0x8004 | -43 | Failed to verify design information | File checksum and design name do not match the device. | Verify the device is programmed with the correct data and design. | | 0x8049 | -44 | Failed to<br>verify AES<br>key. | The AES key in the file does not match the AES key in the device. File does not contain an AES key and the device is secured with an AES key. | Provide a programming file with an AES key that matches the AES key programmed into the device. | | 0x8054 | -45 | Device<br>package | Programming file was generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | does not<br>match the<br>programmi<br>ng file. | | latest version of FlashPro software. | | 0x8033<br>0x8038<br>0x803D<br>0x8042<br>0x8045<br>0x8046<br>0x8047<br>0x8048 | -46 | Embedded<br>Flash<br>Memory<br>Block X<br>Read is<br>protected<br>by pass<br>key. A valid<br>pass key<br>needs to<br>be<br>provided. | File contains no pass key or incorrect pass key but EFMB read is secured with a pass key. | Provide a programming file with the correct pass key. | | 0x8034<br>0x8039<br>0x803E<br>0x8043 | -46 | Embedded<br>Flash<br>Memory<br>Block<br>(EFMB)<br>block X<br>Read is not<br>protected<br>by pass<br>key. | File contains encrypted EFMB for block X but the device encryption is not enforced for EFMB block X. | Regenerate security programming file with the proper AES key. Program device security. Retry programming with EFMB block X with encrypted programming file. | | | | EFMB content is not secure after encrypted programming. | | | | | | Unable to proceed with encrypted NVM programming. | | | | 0x8032<br>0x8037<br>0x803C<br>0x8041 | -47 | Embedded<br>Flash<br>Memory<br>Block<br>(EFMB)<br>block X<br>encryption<br>is<br>enforced. A<br>programmi | The programming EFMB data is not encrypted, but the device contains an AES key with encryption enforced. | Provide a programming file with encrypted EFMB data. | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |--------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | | | ng file with<br>encrypted<br>EFMB data<br>needs to<br>be<br>provided. | | | | 0x8031<br>0x8036<br>0x803B<br>0x8040 | -48 | Embedded Flash Memory Block (EFMB) block X Write is protected by pass key. A valid pass key needs to be provided. | File contains no pass key or incorrect pass key, but device is secured with a pass key. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | 0x8035<br>0x803A<br>0x803F<br>0x8044 | -49 | Embedded Flash Memory Block (EFMB) block X Encryption is not enforced. Cannot guarantee valid AES key present in target device. Unable to proceed with Encrypted EFMB programmi ng. | File contains encrypted EFMB for block X, but the device encryption is not enforced for EFMB block X. | Regenerate security programming file with proper AES key. Program device security. Retry programming EFMB block X with encrypted programming file. | | 0x801A | -50 | No backup<br>calibration<br>data found<br>or backup<br>calibration | No backup calibration copy has been made or the backup copy has been corrupted | If master copy is still intact, rerun Action to create backup calibration copy. Workaround: Disable optional procedure CHECK_AND_BACKUP_CALIB | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------|--------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | data has<br>been<br>corrupted | | | | 8x804E | -51 | Failed to<br>access<br>Embedded<br>Flash<br>Memory.<br>(AFS600<br>only) | This version of the silicon does not support programming of the Embedded Flash Memory Block while the FPGA Array is active. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, use latest revision of silicon. | | 0x804F | -52 | Failed to<br>access<br>Embedded<br>Flash<br>Memory.<br>(AFS1500<br>only) | This version of the silicon does not support programming of the Embedded Flash Memory Block while the FPGA Array is active. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, use latest revision of silicon. | | 0x8050 | -53 | Failed to<br>access<br>Embedded<br>Flash<br>Memory.<br>(AFS1500<br>only) | This version of the silicon does not support programming block 3 of the EFMBs while the FPGA Array is active. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, use EFMB blocks 0, 1, or 2, but do not use block 3. | | 0x8051 | -54 | Failed to<br>access<br>Embedded<br>Flash<br>Memory. | FPGA Array is accessing the target EFMB block while attempting programming. NVM reset signal is stuck in design. Unstable VCC MSS Clock is disabled during programming. MSS Clock is not properly routed to the correct pin. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, check the FPGA design or use a different EFMB block that is not being accessed. Check if target EFMB block logic is tied to reset. Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Verify that the NVM reset signal in the design is not stuck. Verify the MSS clock is enabled during programming. If the MSS clock is defined as an external I/O, then verify that it is properly routed to the correct pin. | | 0x808A<br>0x8094 | -55 | Failed to read | Programming file generated with an older version of software | Generate STAPL file with the latest version of Designer/FlashPro; use the | | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------------|--------------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | | Iatest version of FlashPro software Try again at a slower TCK Inspect device using Device Debug Contact Microsemi Technical Support | | 0x808B | -55 | Failed to<br>read<br>Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | Unstable VPUMP voltage level. Unstable VCC Unstable VCC_OSC (Fusion only) Unstable VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Monitor VJTAG during programming; measure JTAG signals for noise or reflection. | | 0x808C | -55 | Failed to<br>read<br>Embedded<br>Flash<br>Memory<br>Block<br>(EFMB) | Internal errror | Contact Microsemi Technical Support | | 0x8011 | -56 | Failed to read calibration data | | Try reprogramming. Workaround: Disable optional procedure CHECK_AND_BACKUP_CALIB | | 0x8012 | -56 | Failed to read calibration data | Unstable VCC Unstable VCC_NVM/VCC_OSC (Fusion only) Unstable VCC_ENVM/VCC_ROSC voltage level (SmartFusion only) Signal integrity issues on JTAG pins | Monitor related power supplies that cause the issue during programming; check for transients outside of Microsemi specifications. See your device datasheet for more information on transient specifications. Measure JTAG voltages, noise, and reflection. Try reprogramming. Workaround: Disable optional backup procedure CHECK_BACKUP_CALIB | | 0x808D<br>0x8092 | -57 | eNVM/EF<br>MB is<br>protected<br>by a Pass<br>Key; you<br>must<br>provide a | File contains no Pass Key and device is secured with a Pass Key Pass Key in the file does not match device | Provide a programming file with a Pass<br>Key that matches the Pass Key<br>programmed into the device | SmartFusion, IGLOO, ProASIC3 and FusionDevice Exit Codes for pre-v8.6 Software | ERROR_CODE | Exit<br>Code | Exit<br>Message | Possible Cause | Possible Solution | |------------|--------------|-------------------|----------------|-------------------| | | | valid Pass<br>Key | | | # SmartFusion, IGLOO, ProASIC3 and FusionDevice Exit Codes for pre-v8.6 Software The table below lists exit codes for SmartFusion, IGLOO, ProASIC3 and Fusion devices in pre-v8.6 software only. This includes v8.5 SP2, v8.5 SP1, v8.5, etc. See the <a href="Device Exit Codes for Software v8.6">Device Exit Codes for Software v8.6</a> and Above help topic for exit codes for older versions. Note: Exit codes with positive integers are reserved for current and future standard EXIT codes of the STAPL standard. Exit codes with negative integers are reserved for vendor-specific EXIT codes. Table 3 · Exit Codes for SmartFusion, IGLOO, ProASIC3 and Fusion Family Devices in pre-v8.6 Software | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Passed (no error). | | | | 1 | A physical chain does not match the expected set up from the STAPL file. Also known as Checking Chain Error. | Physical chain configuration has been altered. Something has become disconnected in the chain. The specific IR length of non-Microsemi devices may be incorrect. The order of the specified chain may be incorrect. | | | 5 | Failed to enter programming mode. | Unstable VPUMP voltage level. Signal integrity issues on JTAG pins. Older software or programming file used. | Monitor VPUMP voltage during programming Measure JTAG voltages, noise, and reflection. Generate STAPL file with the latest version of Designer/FlashPro. Use latest version of FlashPro software. | | 6 | Failed to verify IDCODE. | Signal integrity issues on JTAG pins. | Measure JTAG pins, noise and reflection. | | 8 | Failed Erase<br>Operation. | Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG voltages, noise, and reflection. | | 10 | Failed to program<br>FPGA array at row<br>", rowNumber,"." | Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG voltages, noise, or reflection. | | 10 | Failed to enable FPGA Array. | Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Measure JTAG voltages, noise, or reflection. | | 10 | Failed to program FlashROM. | Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG voltages, noise, and reflection. | | 11 | Verify 0 failed at row",rowNumber,"." Verify 1 failed at row",rowNumber,"." Failed to verify FlashROM at row",from rowNumber-1. | Device is programmed with a different design. Signal integrity issues on JTAG pins. | Run VERIFY_DEVICE_INFO to verify the device is programmed with the correct data/design. Monitor VPUMP voltage during programming. Measure JTAG voltages, noise and reflection. | | 14 | Failed to program<br>Silicon Signature.<br>Failed to program<br>security lock<br>settings. | Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG voltages, noise, and reflection. | | -18 | Failed to authenticate the encrypted data. | Incorrect AES key. Signal integrity issues on JTAG pins. | Generate a programming file with the correct AES key. Measure JTAG voltages, noise and reflection | | -20 | Failed to verify FlashROM at row ", FRomRowNumber- 1. | Device is programmed with a different design. Signal integrity issues on JTAG pins. | Program with the correct data/design. Monitor VPUMP level during programming. Measure JTAG pins and noise or reflection. | | -22 | Failed to program pass key. | Unstable VPUMP voltage level. Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG voltages, noise, and reflection. | | -23 | Failed to program<br>AES key. | Unstable VPUMP voltage level. Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG pins and noise or reflection. | | -24 | Failed to program UROW. | Unstable VPUMP voltage level. Signal integrity issues on JTAG pins. | Monitor VPUMP voltage during programming. Measure JTAG voltages, noise, and reflection. Make sure you mounted 0.01ìF and 0.33ìF caps on Vpump (close to the pin). | | -25 | Failed to enter | Signal integrity issues on JTAG pins. | Measure JTAG voltages, noise, and | #### SmartFusion, IGLOO, ProASIC3 and FusionDevice Exit Codes for pre-v8.6 Software | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | programming mode | | reflection. | | -26 | Failed to enter programming mode | Signal integrity issues on JTAG pins. | Measure JTAG voltages, noise, and reflection. | | -27 | FlashROM Write/Erase is protected by the passkey. A valid passkey needs to be provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | -28 | FPGA Array Write/Erase is protected by the passkey. A valid pass key needs to be provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | -29 | FlashROM Read is<br>protected by<br>passkey.<br>A valid passkey<br>needs to be<br>provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a pass key that matches the passkey programmed into the device | | -30 | FPGA Array verification is protected by a passkey. A valid passkey needs to be provided. | File contains no passkey and device is secured with a passkey. Passkey in the file does not match device. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | -31 | Failed to verify<br>AES key. | AES key in the file does not match the device. Unstable JTAG/VPUMP voltage level. | Provide a programming file with an AES key that matches the AES key programmed into the device. Monitor VPUMP/VJTAG voltage during programming. Measure JTAG voltages, noise, and reflection. | | -32 | Failed to verify IDCODE. Target is an M7 device | File is not for M7, but target device is an M7. Signal integrity issues on JTAG pins. | Check that the target device is M7 enabled. Make sure programming file generated is for M7 enabled device. Measure JTAG pins , noise, and reflection. | | -32 | Failed to verify IDCODE. Target is an M1 | File is not for M1, but target device is an M1 device. | Check that the target device is M1 enabled. Make sure programming file generated is for M1 enabled device. | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | device | Signal integrity issues on JTAG pins. | Measure JTAG pins, noise, and reflection. | | -32 | Failed to verify IDCODE. Core enabled device detected | File is not for target device. Signal integrity issues on JTAG pins | Check the target device. Make sure programming file generated for target device. Measure JTAG voltages, noise, and reflection. | | -32 | Failed to verify IDCODE. The target is not an M7 device | File is for M7, but target device is not M7. Signal integrity issues on JTAG pins. | Check that the target device is not M7 enabled. Make sure programming file generated is for non M7 enabled device. Measure JTAG voltages, noise, and reflection. | | -32 | Failed to verify IDCODE. The target is not an M1 device | File is for M1, but target device is not an M1 device. Signal integrity issues on JTAG pins. | Check that the target device is not M1 enabled. Make sure programming file generated is for non M1 enabled device. Measure JTAG voltages, noise and reflection. | | -33 | FPGA Array<br>encryption is<br>enforced. A<br>programming file<br>with encrypted<br>FPGA array data<br>needs to be<br>provided. | File contains unencrypted array data, but device contains AES key. | Provide a programming file with an encrypted FPGA Array data. | | -34 | FlashROM<br>encryption is<br>enforced. A<br>programming file<br>with encrypted<br>FlashROM data<br>needs to be<br>provided. | File contains unencrypted FlashROM data, but the device contains an AES key. | Provide a programming file with an encrypted FlashROM data. | | -35 | Failed to match pass key. | Pass key in file does not match pass key in device. | Provide a programming file with a pass key that matches the pass key programmed into the device. | | -36 | FlashROM Encryption is not enforced. Cannot guarantee valid AES key present in target | File contains encrypted FlashROM, but device encryption is not enforced for FlashROM | Regenerate security programming file with proper AES key. Program device security. Retry programming FlashROM with encrypted programming file. | #### SmartFusion, IGLOO, ProASIC3 and FusionDevice Exit Codes for pre-v8.6 Software | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | device. Unable to proceed with Encrypted FlashROM programming. | | | | -37 | FPGA Array Encryption is not enforced. Cannot guarantee valid AES key present in target device. Unable to proceed with Encrypted FPGA Array verification. | File contains encrypted FPGA Array, but the device encryption is not enforced for FPGA Array. | Regenerate security programming file with proper AES key. Program device security. Retry programming FPGA Array with encrypted programming file. | | -38 | Failed to program pass key. | Unstable VPUMP voltage level. Signal integrity issues on JTAG pins. Bad device. | Monitor VPUMP voltage during programming. Measure JTAG pins and noise or reflection. | | -39 | Failed to verify Embedded Flash Memory Block (EFMB). | Device is programmed with a different design. Signal integrity issues on JTAG pins. The EFMB data was modified through user FPGA design after programming; this could occur during standalone verify. The target EFMB block is locked with FlashLock when running ACTION PROGRAM_NVM_ACTIVE_ARRAY or VERIFY_NVM_ACTIVE_ARRAY. | Verify the device is programmed with the correct data/design. Monitor VPUMP voltage during programming. Measure JTAG pins and noise or reflection. Run DEVICE_INFO to confirm if the target EFMB block is locked with FlashLock (pass key). If the target EFMB block is locked, then you must unlock it by erasing the security and then reprogramming with the desired security settings. After unlocking the target EFMB block attempt to rerun the target ACTION. | | -40 | Embedded Flash<br>Memory Block<br>MAC Failure. | Data in the file is encrypted with a different AES key than the device. | Verify the programming file is generated from the latest version of Designer/FlashPro. | | -41 | Error programming<br>Embedded Flash<br>Memory Block.<br>(EFMB) | Signal integrity issues on JTAG pins. | Measure JTAG pins and noise or reflection. | | -42 | Failed to verify security settings. | File security settings do not match device. | Provide a programming file with security setting that match the security settings programmed into the device. | | Exit Message | Possible Cause | Possible Solution | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Failed to verify design information. | File checksum and design name do not match the device. | Verify the device is programmed with the correct data and design. | | Failed to verify<br>AES key. | The AES key in the file does not match the AES key in the device. File does not contain an AES key and the device is secured with an AES key. | Provide a programming file with an AES key that matches the AES key programmed into the device. | | Device package<br>does not match the<br>programming file. | | | | Embedded Flash<br>Memory Block X<br>Read is protected<br>by pass key. A<br>valid pass key<br>needs to be<br>provided. | File contains no pass key or incorrect pass key but EFMB read is secured with a pass key. | Provide a programming file with the correct pass key. | | Embedded Flash<br>Memory Block,<br>block X encryption<br>is enforced. A<br>programming file<br>with encrypted<br>EFMB data needs<br>to be provided. | The programming EFMB data is not encrypted, but the device contains an AES key with encryption enforced. | Provide a programming file with encrypted EFMB data. | | Embedded Flash<br>Memory Block<br>(EFMB) block X<br>Write is protected<br>by pass key.<br>A valid pass key<br>needs to be | File contains no pass key or incorrect pass key, but device is secured with a pass key. | Provide a programming file with a passkey that matches the passkey programmed into the device. | | Embedded Flash Memory Block (EFMB) block X Encryption is not enforced. Cannot guarantee valid AES key present in target device. Unable to proceed with Encrypted | File contains encrypted EFMB for block X, but the device encryption is not enforced for EFMB block X. | Regenerate security programming file with proper AES key. Program device security. Retry programming EFMB block X with encrypted programming file. | | | Failed to verify design information. Failed to verify AES key. Device package does not match the programming file. Embedded Flash Memory Block X Read is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block, block X encryption is enforced. A programming file with encrypted EFMB data needs to be provided. Embedded Flash Memory Block (EFMB) block X Write is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block (EFMB) block X Write is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block (EFMB) block X Encryption is not enforced. Cannot guarantee valid AES key present in target device. Unable to proceed | Failed to verify design information. Failed to verify AES key. File checksum and design name do not match the device. Failed to verify AES key. The AES key in the file does not match the AES key in the device. File does not contain an AES key and the device is secured with an AES key. Device package does not match the programming file. Embedded Flash Memory Block X Read is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block, block X encryption is enforced. A rogramming file with encrypted EFMB data needs to be provided. Embedded Flash Memory Block (EFMB) block X Write is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block (EFMB) block X Write is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block (EFMB) block X Write is protected by pass key. A valid pass key needs to be provided. Embedded Flash Memory Block (EFMB) block X Encryption is not enforced. Cannot guarantee valid AES key present in target device. Unable to proceed with ErMB data is not enforced for EFMB block X. Unable to proceed with encrypted EFMB for block X, but the device encryption is not enforced for EFMB block X. | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -51 | Failed to access<br>Embedded Flash<br>Memory.<br>(AFS600 only) | This version of the silicon does not support programming of the Embedded Flash Memory Block while the FPGA Array is active. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, use latest revision of silicon. | | -52 | Failed to access<br>Embedded Flash<br>Memory.<br>(AFS1500 only) | This version of the silicon does not support programming of the Embedded Flash Memory Block while the FPGA Array is active. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, use latest revision of silicon. | | -53 | Failed to access<br>Embedded Flash<br>Memory.<br>(AFS1500 only) | This version of the silicon does not support programming block 3 of the EFMBs while the FPGA Array is active. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, use EFMB blocks 0, 1, or 2, but do not use block 3. | | -54 | Failed to access<br>Embedded Flash<br>Memory. | FPGA Array is accessing the target EFMB block while attempting programming. NVM reset signal is stuck in design. | If programming the EFMB while the FPGA is active is not required, then use actions PROGRAM_NVM or VERIFY_NVM. Otherwise, check the FPGA design or use a different EFMB block that is not being accessed. Check if target EFMB block logic is tied to reset. Verify that the NVM reset signal in the design is not stuck. | # ProASIC<sub>PLUS</sub> Exit Codes The table below lists the exit codes for ProASIC PLUS devices. Table 4 · ProASIC PLUS Family Devices Exit Codes | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------| | 0 | This message means passed. This does not indicate an error. | | | | 1 | A physical chain does not match the expected set up from the STAPL file. Also known as Checking Chain Error. | Physical chain configuration has been altered. Something has become disconnected in the chain. The specific IR length of non-Microsemi devices may be incorrect. The order of the specified chain may be incorrect. | | | 2 | There is a reading device ID failure. | The device either does not have a valid device ID or the data cannot be read correctly. | Check the device ID. | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | This occurs when using ProASIC devices. | Connect was set up for a ProASIC device and the device is actually ProASIC <sup>PLUS</sup> . | Set up for a ProASIC <sup>PLUS</sup> device. | | 5 | Programming set up<br>problem. Also known as<br>Entering ISP Failure. | The A500K device senses the VDDL power supply as being on. | Power the VDDL down during programming. Check the device has the correct voltages on VDDP, VDDL, VPP, and VPN. | | 6 | The IDCODE of the target device does not match the expected value in the STAPL file. This is a JEDEC standard message. | The device targeted in the STAPL file does not match the device being programmed. User selected wrong device. Device TRST pin is grounded. Noise or reflections on one or more of the JTAG pins caused by the IR Bits reading it back incorrectly. | Choose the correct STAPL file and select the correct device. Measure JTAG pins and noise or reflection. TRST should be floating or tied high. Cut down the extra length of ground connection. | | 7 | Unknown algorithm: alg=x, prev=x Invalid data read from device | This occurs with current STAPL files when the revision written into the factory row is not rev 1 for ProASICPLUS devices. The STAPL files from last year may "exit 7" with newer devices or the older revision may cause this failure if the STAPL file used is from latest version. This error can also occur if the programmer has trouble reading the factory row due to signal noise, crosstalk, or reflections on the JTAG signal and clock lines. It can occur if you program an -F ProASICPLUS device with an old STAPL file. This error occurs if you connected VPP and VPN the wrong way. It occurs if there are no bypass Caps on VPP VPN, which damaged the device. This error may occur if your power supply cannot source the correct current for programming. | Re-generate STAPL file from Designer 6.1 SP1. Double check VPP and VPN connections. Make sure VPP and VPN have correct bypass caps. Make sure that your power supply can deliver the correct current during programming. | | 8 | FPGA failed during the erase operation. | The device is secured, and the corresponding STAPL file is not loaded. The device has been permanently secured and cannot be unlocked. | Load the correct STAPL file. | | 11 | FPGA failed verify | The device is secured and the corresponding STAPL file is not loaded. You used the Libero IDE software | Load the correct STAPL file. Use later software versions —at least Libero v2.3 SP1 and Designer R1- 2003 SP1. | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | v2.3 or earlier or the Designer R1-<br>2003 software or earlier to generate<br>the STAPL file.<br>VPN caps were soldered in the<br>wrong polarity. | Double-check the VPN bypass caps polarity. | | 12 | Security is enabled. | The device is secured and the wrong key/STAPL file was entered. The device is damaged. The verification was interrupted and therefore fails, causing the software to think the device is secure. | | | 14 | Program security failure. | | | | 15 | This is a factory Calibration Data CRC error. | During program, erase, or verify, you must read back Calibration Data from the FPGA. The data contains a CRC. You use the CRC to ensure the data is not corrupted/wrong. Device is damaged. Noise on the FTAL signals causes the programmer to read back wrong data. | | | 17 | The device has been secured. Write-security is enabled. | The device is secured and the wrong key or STAPL file was entered. The device is damaged. | Load the correct STAPL file. | | -54 | Failed to access Embedded<br>Flash Memory | Analog power supplies (Vcc15A, Vcc33A, GNDAQ and GNDA) are not connected. | Connect the analog power supplies (Vcc15A, Vcc33A, GNDAQ and GNDA) | | -90 | Unexpected RCK detected. | Noise on the RCK signal. You connected a CLK source to the RCK signal. The polarized bypass capacitors on VPP or VPN are reversed-biased and are affecting the programmer's VPP or VPN output voltage. This causes programming to fail. Several FlashPros are programming at the same time and are too close to each other. Programmer not properly installed by Admin. | Disconnect the RCK and make sure TCK has a clean signal. Separate FlashPros away from each other while they are programming Internal ISP. Connect programmer as an Admin in FlashPro. | | -91 | Calibration data parity error. | Device is damaged. | Replace the device. | | | Null | Several FlashPros are programming at the same time and are too close to each other. | | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | FlashPro connects to PC parallel port through a dongle key. Data length mismatch when performing DRSCAN on STAPL file. | | | | Cable to target is not connected properly. | When the Analyze command is executed, the FlashPro looks for target devices. If the cable connection is wrong, FlashPro assumes that nothing is connected at all. | Confirm the connection between the header to the device. If the board supplies the power to the device, make sure the voltage level is correct. | | | Chain integrity test failed: xx | The connection between the FlashPro programmer and the device is broken. The programmer cable might not be securely inserted into the header. The header is not connected to the JTAG pins of the FPGA correctly. The configuration setting (ProASIC/ProASICPLUS) does not match the target device. Noise or reflections on the JTAG pins has caused communication between the programmer and the device to fail. A dongle is plugged in between the PC parallel port and the FlashPro parallel port cable. | Secure the connections. Check the JTAG pins for signal activity. Check for broken TDO, TMS, and TCK pins. After checking all type of connections if the failure exists, you may need to replace the first device (the devices closest to the TDO of the programming header) in the chain. Remove the dongle. | | | Could not connect to programmer on port lp1 or parallel port device does not support IEEE-1284 negotiation protocol | The remote device does not respond to the negotiation protocol, for a variety of reasons. | Make sure the port is connected. Make sure the connected device is a FlashPro/Lite programmer. Turn the programmer on. Check parallel port setting in BIOS. Make sure that there are no dongles in between the parallel port and the FlashPro connection. Try another parallel cable, the parallel cable might be defective. Check to see if the programmer is damaged. Make sure the FlashPro Lite has power. The FlashPro Lite is powered from the target board through the Vdd pin of the programming header. Make sure the Vdd pin is connected and the target board is powered up. Secure the connection between the cable connector and the programming header. Before you program any devices, you should run the self-diagnostic test. The diagnostic software can be found on the Microsemi web site. If the test | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | fails, please contact Microsemi<br>Customer Technical Support at<br>tech@Microsemi.com for credit and<br>replacement.<br>Note: The Self-test is only available<br>for FlashPro, not FlashPro Lite. | | | External voltage detected on<br><supply></supply> | The voltage supply for the FPGA is driven by another source (board, external power-supply), but the user forgot to turn off the supply in the Connect menu. | Set appropriate options in the Connect menu. | | | VDPP Disconnected. | There is no Vddp voltage supply to the FPGA. You accidentally turned off the Vddp supply in the Connect menu. The Vddp supply on the board is not functioning. | Check the Vddp supply on the board for appropriate voltages and correct the Connect menu. | | | More than one unidentified de | vice. | | | | If you want to perform an operation on the ProASIC device, the rest of the devices in the chain must be in bypass mode. To put devices in bypass mode, select Configuration > Chain Parameter (or click the Chain Parameter button in the Single STAPL Configuration window), then set the Pre IR, Pre DR, Post IR or Post DR. | STAPL settings of Pre IR, Pre DR, Post IR, and Post DR do not match the chain configuration. One or more of the devices in the chain is damaged and the ID CODE cannot be read back. | Make sure you have set Pre IR, Pre DR, Post IR, and Post DR to match the chain configuration. If you are still experiencing the failure, it is likely that the device's ID CODE cannot be read and you need to replace the device. | | | Cannot find the programmer with ID xxx | The programmer is removed from the PC. | Delete programmer (or reconnect programmer) and select the <b>Refresh Programmer</b> button. See Connecting Programmers for more information. | | | Fatal Error: Please check programmer set up. | Software cannot resolve the error encountered in the programmer. | Save the project file, restart the software, and power cycle the programmer. | | | External voltage xxx mV is detected on xxx. | You have specified the programmer to drive the xxx but external xxx is detected. | Deselect the xxx in the programmer setting. | | | Executing action xxx failed. | The STAPL runtime failed. | | | | Executing action xxx with serial index/action xx failed. | The STAPL runtime failed. | | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | No Vpump voltage source is detected. | | Select the Vpump in the Programmer setting. Make sure the external Vpump is properly turned on. | | | Vpump short detected. | | Use a different programmer. If the problem persists, check the board layout. | | | xxx Mhz TCK frequency in<br>this STAPL file is not<br>supported by the FlashPro<br>Lite detected. It supports<br>only 4 MHz TCK frequency. | | Check FlashPro Lite version being used. Use FlashPro Lite Rev C or modify the STAPL file to 4 MHz. | | | xxx Mhz TCK frequency in<br>this STAPL file is not<br>supported by the FlashPro<br>Lite RevC detected. It<br>supports only 1, 2 or 4 Mhz<br>TCK frequency. | | Modify STAPL file to 1, 2, or 4 MHz. | | | Cannot find the serial Index/Action xxx in STAPL file. | Mismatch between STAPL file and the Index/Action selection. | Make sure the STAPL file was not overwritten. Save the project with updated serial/action selection. | | | Duplicated serial Index/Action xxx was removed. | Mismatch between STAPL file and the Index/Action selection. | Make sure the STAPL file was not overwritten. Save the project with updated serial/action selection. | | | Using local backup copy xxx | Cannot find original copy. | Check for available space on the disk. Check that write permissions are enabled. | | | FlashPro cannot rename the programmer/device with an existing name. | Name is already in use. | Create a new name. | | | FlashPro cannot rename the programmer/device with an invalid character. | Invalid character used in programmer/device name. | Do not use invalid characters. | | | Automatic check for updates. | | FlashPro can check the Microsemi website to find if an updated version of the software is available. If you would like to have FlashPro automatically check for software updates, choose Preferences from the File menu. From the Updates tab, you can choose your automatic software update settings. You can also select Software Updates from the Help menu for updates to the FlashPro software. | | Exit<br>Code | Exit Message | Possible Cause | Possible Solution | |--------------|------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------| | | FlashPro parse error. | FlashPro software failed to parse the file. | | | | FlashPro does not support STAPL files for xxx. | STAPL file not allowed. | Use a STAPL file for your device that is supported by FlashPro. | ## **Electrical Parameters** ### DC Characteristics for FlashPro5/4/3/3X Note: The target board must provide the VCC, VCCI, VPUMP, and VJTAG during programming. However, if there is only one ProASIC3 device on the target board, the FlashPro5/4/3/3X can provide the VPUMP power supply via the USB port. Note: The VJTAG signal is driven from the target/DUT board. The VJTAG pin is sensed by the FP4 to configure the internal input and output buffers to the same IO Voltage levels. The VJTAG pin is only an input pin to the programmer. Table 5 · DC Characteristic for FlashPro5/4/3/3X | Description | Symbol | Min | Max | Unit | |------------------------------------------------|-------------|------------|------------|------| | Input low voltage, TDO | VIL | -0.5 | 0.35*VJTAG | V | | Input high voltage, TDO | VIH | 0.65*VJTAG | 3.6 | V | | Input current, TDO | IIL, IIH | -20 | +20 | mA | | Input capacitance, TDO | | | 40 | pF | | Output voltage, VPUMP, operating | VPP | +3.0 | +3.6 | V | | Output current, VPUMP | IPP | | 250 | mA | | VJTAG = 1.5V | | | | | | Output low voltage, TCK, TMS, TDI, 100µA load | VOL | 0.0 | 0.2 | V | | Output low voltage, TCK, TMS, TDI, 4mA load | VOL | 0.0 | 0.30*VJTAG | V | | Output high voltage, TCK, TMS, TDI, 100µA load | V | VJTAG-0.2 | VJTAG | V | | Output high voltage, TCK, TMS, TDI, 4mA load | VOH | 0.70*VJTAG | VJTAG | V | | Output current, TCK, TMS, TDI | IOL,<br>IOH | -4 | +4 | mA | | VJTAG = 1.8V | | | | | | Output low voltage, TCK, TMS, TDI, 100µA load | VOL | 0.0 | 0.2 | V | | Output low voltage, TCK, TMS, TDI, 6mA load | VOL | 0.0 | 0.3 | V | | Description | Symbol | Min | Max | Unit | |------------------------------------------------|-------------|-----------|-------|------| | Output high voltage, TCK, TMS, TDI, 100μA load | VOH | VJTAG-0.2 | VJTAG | V | | Output high voltage, TCK, TMS, TDI, 6mA load | VOH | 1.25 | VJTAG | V | | Output current, TCK, TMS, TDI | IOL,<br>IOH | -6 | +6 | mA | | VJTAG = 2.5V | | | | | | Output low voltage, TCK, TMS, TDI, 100μA load | VOL | 0.0 | 0.2 | V | | Output low voltage, TCK, TMS, TDI, 8mA load | VOL | 0.0 | 0.6 | V | | Output high voltage, TCK, TMS, TDI, 100μA load | VOH | VJTAG-0.2 | VJTAG | V | | Output high voltage, TCK, TMS, TDI, 8mA load | VOH | 1.8 | VJTAG | V | | Output current, TCK, TMS, TDI | IOL,<br>IOH | -8 | +8 | mA | | VJTAG = 3.3V | | | | | | Output low voltage, TCK, TMS, TDI, 100μA load | VOL | 0.0 | 0.2 | V | | Output low voltage, TCK, TMS, TDI, 8mA load | VOL | 0.6 | V | | | Output high voltage, TCK, TMS, TDI, 100μA load | VOH | VJTAG-0.2 | VJTAG | V | | Output high voltage, TCK, TMS, TDI, 8mA load | VOH | 2.4 | VJTAG | V | | Output current, TCK, TMS, TDI | IOL,<br>IOH | -8 | +8 | mA | # DC Characteristics for FlashPro Lite Table 6 · DC Characteristic for FlashPro Lite | Description | Symbol | Min | Max | Unit | |-------------------------|--------|------|-----|------| | Input low voltage, TDO | VIL | -0.5 | 0.7 | V | | Input high voltage, TDO | VIH | 1.7 | 5.0 | V | | Description | Symbol | Min | Max | Unit | |------------------------------------------------|----------|-------|-------|------| | Input current, TDO | IIL, IIH | -10 | +10 | uA | | Input capacitance, TDO | | | 40 | pF | | Input voltage, VDD, operating (see note) | | +2.3 | +3.5 | V | | Input voltage, VDD, power off | | -1.0 | +1.0 | V | | Input current, VDD | IVDD | | 500 | mA | | Output voltage, VPP, operating | VPP | +15.9 | +16.5 | ٧ | | Output voltage, VPN, operating | VPN | -13.8 | -13.4 | V | | Output current, IPP | IPP | 0 | 35 | mA | | Output current, IPN | IPN | 0 | -15 | mA | | Output low voltage, TCK, TMS, TDI, 100uA load | VOL | 0.0 | 0.2 | ٧ | | Output low voltage, TCK, TMS, TDI, 1mA load | VOL | 0.0 | 0.5 | V | | Output low voltage, TCK, TMS, TDI, 2mA load | VOL | 0.0 | 0.8 | ٧ | | Output high voltage, TCK, TMS, TDI, 100uA load | VOH | 2.1 | 2.5 | ٧ | | Output high voltage, TCK, TMS, TDI, 1mA load | VOH | 1.9 | 2.5 | V | | Output high voltage, TCK, TMS, TDI, 2mA load | VOH | 1.6 | 2.5 | ٧ | | Output current, TCK, TMS, TDI, nTRST | IOL, IOH | -2 | +2 | mA | Note: Up to 3.5 V can be supplied to the FlashPro Lite on the VDD pin. However, if the VDD supply for the FlashPro is also connected to the APA VDD supply, the voltage for the VDD pin cannot exceed 2.7 V. ## DC Characteristics for FlashPro Table 7 · DC Characteristic for FlashPro | Description | Symbol | Min | Max | Unit | |---------------------------|----------|----------------|----------------|------| | Input low voltage, TDO | VIL | -0.5 | 0.30 *<br>VDDP | ٧ | | Input high voltage, TDO | VIH | 0.70 *<br>VDDP | 5.5 | ٧ | | Input current, TDO | IIL, IIH | -10 | +10 | uA | | Input voltage, VDDP, VDDL | | 0 | 5.25 | V | | Input voltage, VPP | | 0 | 21.0 | V | | Input voltage, VPN | | -21.0 | | V | | Description | Symbol | Min | Max | Unit | |-------------------------------------------------|-------------|--------------------|-------------------|----------| | Input current, VDDP, VDDL, VPN, VP | IVCC | | 5.0 | mA | | Output voltage range, VDDP | VDDP | 1.5 | 3.3 | V | | Output voltage range, VPP | VPP | 15.0 | 18.0 | ٧ | | Output voltage range, VPN | VPN | -16.0 | -12.0 | <b>V</b> | | Output voltage resolution / Acccuracy | | | 100 / ±50 | mV | | Output current, IDDP | IDDP | -135 <sup>1</sup> | +135 | mA | | Output current, IDDL | IDDL | -135 <sup>1</sup> | +135 | mA | | Output current, IPP | IPP | -2701 <sup>1</sup> | +270 | mA | | Output current, IPN | IPN | -270 | +270 <sup>1</sup> | mA | | Output low voltage, TCK, TMS, TDI, OUT0, nTRST | VOL | 0.0 | 0.4 | ٧ | | Output high voltage, TCK, TMS, TDI, OUT0, nTRST | VOH | 0.85 *<br>VDDP | + 0.3<br>VDDP | ٧ | | Output current, TCK, TMS, TDI, OUT0, nTRST | IOL,<br>IOH | -12 | +12 | mA | Note: (1): When power supply mode is set to ABI\_GROUND. Note: \* - If you want to power-up the device from the board power supply, clear the checkboxes for VDDL and VDDP. VPP and VPN are required during programming only and are supplied by the FlashPro programmer. Note: (2) Microsemi does not have operating temperature information for the FlashPro programmer. FlashPro is intended to be used as lab or production equipment and not tested at extreme temperatures. All devices in the unit are commercial temp. FlashPro4 went through a burn-in cycle operating at 100C for 250 hours during quality testing. This involved repeatedly powering the programmers and then programming after the burn in; they are not actively programming during the burn in. # **Electrical Specifications** #### FlashPro5 The FlashPro5 is a JTAG and a SPI based programmer for flash based Microsemi devices. The FlashPro5 output is supplied via a connector to which a detachable 10-pin cable is fitted. The connector on the FlashPro5 unit is a 2x5, RA male Header connector, which is manufactured by AMP and has a manufacturer's part number of 103310-1. This is a standard 2x5, 0.1 pitch connector which is keyed. Use the 10 pin right-angle header, AMP P/N 103310-1 (DigiKey P/N A26285-ND) for FlashPro4 and use the 10 pin straight header, AMP P/N 103308-1 (DigiKey P/N A26267-ND) for the straight version. The signals on the pins of the FlashPro5 10-pin connector are shown in the figure below. Figure 17 · FlashPro5 10-Pin Connector Note: All ground pins must be connected. The rectangular shape shows connections on the programmer itself. Arrows show current flow towards or from the rectangular programmer. The table below shows a description of the signals. Table 8 · FlashPro4 Signal Description | Signal | Description | |-----------|-------------------------------------------------------------------------------| | VPUMP | 3.3V Programming voltage | | GND | Signal reference | | TCK/SCK | JTAG clock; SPI clock | | TDI/SDI | JTAG data input to device; SPI MOSI | | TDO/SDO | JTAG data output from device; SPI MISO | | TMS/SS# | JTAG mode select; SPI Chip Select | | nTRST | Programmable output pin may be set to off, toggle, low, or high level | | VJTAG | Reference voltage from the target board | | PROG_MODE | IGLOO v2 family - Used for switching from VCC 1.2V to 1.5V during programming | NOTE: Links and cross-references in this PDF file may point to external files and generate an error when clicked. View the online help included with software to enable all linked content. Some designers of high-integrity boards (military and avionic) may arrange their boards so that TRST is tied to ground via a weak pull-down resistor. The purpose of this is to hold the JTAG state-machine in a reset state by default, so that even with TCK oscillating, some sudden ion bombardment or other electrical even will not suddenly throw the JTAG state-machine into an unknown state. If your design also uses a weak pull-down resistor on TRST on your board, then enabling the "Drive TRST" flag will be required to force the JTAG state-machine out of reset to permit programming to take place. With most boards, there is no need to select this flag. # **Electrical Specifications** #### FlashPro4 The FlashPro4 output is supplied via a connector to which a detachable 10-pin cable is fitted. The connector on the FlashPro4 unit is a 2x5, RA male Header connector, which is manufactured by AMP and has a manufacturer's part number of 103310-1. This is a standard 2x5, 0.1 pitch connector which is keyed. Use the 10 pin right-angle header, AMP P/N 103310-1 (DigiKey P/N A26285-ND) for FlashPro4 and use the 10 pin straight header, AMP P/N 103308-1 (DigiKey P/N A26267-ND) for the straight version.. The signals on the pins of the FlashPro4 10-pin connector are shown in the figure below (extracted from FlashPro4 product specification): Figure 18 · FlashPro4 10-Pin Connector Note: All ground pins must be connected. The rectangular shape shows connections on the programmer itself. Arrows show current flow towards or from the rectangular programmer. The table below shows a description of the signals. Table 9 · FlashPro4 Signal Description | Signal | Description | |-----------|-------------------------------------------------------------------------------| | VPUMP | 3.3V Programming voltage | | GND | Signal reference | | тск | JTAG clock | | TDI | JTAG data input to device | | TDO | JTAG data output from device | | TMS | JTAG mode select | | nTRST | Programmable output pin may be set to off, toggle, low, or high level | | VJTAG | Reference voltage from the target board | | PROG_MODE | IGLOO v2 family - Used for switching from VCC 1.2V to 1.5V during programming | Some designers of high-integrity boards (military and avionic) may arrange their boards so that TRST is tied to ground via a weak pull-down resistor. The purpose of this is to hold the JTAG state-machine in a reset state by default, so that even with TCK oscillating, some sudden ion bombardment or other electrical even will not suddenly throw the JTAG state-machine into an unknown state. If your design also uses a weak pull-down resistor on TRST on your board, then enabling the "Drive TRST" flag will be required to force the JTAG state-machine out of reset to permit programming to take place. With most boards, there is no need to select this flag. #### FlashPro3 The FlashPro3 output is supplied via a connector to which a detachable 10-pin cable is fitted. The connector on the FlashPro3 unit is a 2x5, RA male Header connector, which is manufactured by AMP and has a manufacturer's part number of 103310-1. This is a standard 2x5, 0.1 pitch connector which is keyed. Use the 10 pin right-angle header, AMP P/N 103310-1 (DigiKey P/N A26285-ND) for FlashPro5/4/3/3X and use the 10 pin straight header, AMP P/N 103308-1 (DigiKey P/N A26267-ND) for the straight version. The signals on the pins of the FlashPro3 10-pin connector are shown in the figure below (extracted from FlashPro3 product specification): Figure 19 · FlashPro3 10-Pin Connector Note: All ground pins must be connected. The rectangular shape shows connections on the programmer itself. Arrows show current flow towards or from the rectangular programmer. The table below shows a description of the signals. Table 10 · FlashPro3 Signal Description | Signal | Description | |--------|-----------------------------------------------------------------------| | VPUMP | 3.3V Programming voltage | | GND | Signal reference | | TCK | JTAG clock | | TDI | JTAG data input to device | | TDO | JTAG data output from device | | TMS | JTAG mode select | | nTRST | Programmable output pin may be set to off, toggle, low, or high level | | VJTAG | Reference voltage from the target board | | N/C | Programmer does not connect to this pin | Some designers of high-integrity boards (military and avionic) may arrange their boards so that TRST is tied to ground via a weak pull-down resistor. The purpose of this is to hold the JTAG state-machine in a reset state by default, so that even with TCK oscillating, some sudden ion bombardment or other electrical even will not suddenly throw the JTAG state-machine into an unknown state. If your design also uses a weak pull-down resistor on TRST on your board, then enabling the "Drive TRST" flag will be required to force the JTAG state-machine out of reset to permit programming to take place. With most boards, there is no need to select this flag. ### FlashPro Lite For FlashPro Lite, the existing 26-pin connector is shown in the figure below. Figure 20 · 26-pin Connector for FlashPro Lite Note: All ground pins must be connected. The rectangular shape shows connections on the programmer itself. Arrows show current flow towards or from the rectangular programmer. The appropriate SAMTEC micro connector target cable for this is: Samtec FFSD-13-D-12.00-01-N. The 12 inch cable is specified. This is likely to be more than enough to connect to the board and reducing the inductance will help compared with 18 inches, which is supplied by the default with FlashPro Lite. See the table below for a description of the signals. Table 11 · FlashPro Lite Signal Description | Signal | Description | | |--------|------------------------------------------------------------------------|--| | VDDP | VDD supply for logic I/O pads | | | VDDL | VDD supply for core | | | VPP | Positive programming supply (+16.5V) | | | VPN | Negative programming supply(-13.8V) | | | GND | Signal reference | | | SENSE | Input from target board to programmer to indicate connection to ground | | | TCK | JTAG clock | | | TDI | JTAG data input to device | | | Signal | Description | | |--------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--| | TDO | JTAG data output from device | | | TMS | JTAG mode select | | | nTRST | nTRST Programmable output pin may be set to off, toggle, low, or high level | | | RCK/OUT0 Programmable output pin may be set to off, toggle, low, or high level | | | | N/C | Programmer does not connect to this pin | | Some designers of high-integrity boards (military and avionic) may arrange their boards so that TRST is tied to ground via a weak pull-down resistor. The purpose of this is to hold the JTAG state-machine in a reset state by default, so that even with TCK oscillating, some sudden ion bombardment or other electrical even will not suddenly throw the JTAG state-machine into an unknown state. If your design also uses a weak pull-down resistor on TRST on your board, then enabling the "Drive TRST" flag will be required to force the JTAG state-machine out of reset to permit programming to take place. With most boards, there is no need to select this flag. #### **FlashPro** For FlashPro, you can use the same 26-pin target cable you used for FlashPro Lite, but the connections are shown in the figure below. Figure 21 · 26-pin connections for FlashPro Note: All ground pins must be connected. The rectangular shape shows connections on the programmer itself. Arrows show current flow towards or from the rectangular programmer. The table below shows the signal pin descriptions for FlashPro. Table 12 · FlashPro Signal Description | Signal | Description | |--------|---------------------------------------| | VDDP | VDD supply for logic I/O pads | | VDDL | VDD supply for core | | VPP | Positive programming supply (+16.5 V) | | Signal | Description | |-------------------------|------------------------------------------------------------------------| | VPN | Negative programming supply (-13.8 V) | | GND | Signal reference | | SENSE | Input from target board to programmer to indicate connection to ground | | тск | JTAG clock | | TDI | JTAG data input to device | | TDO | JTAG data output from device | | TMS | JTAG mode select | | nTRST | Programmable output pin may be set to off, toggle, low, or high level | | RCK/OUT0 | Programmable output pin may be set to off, toggle, low, or high level | | 2.5V, 2.5V/3.3V,<br>N/C | Programmer does not connect to these pins | Some designers of high-integrity boards (military and avionic) may arrange their boards so that TRST is tied to ground via a weak pull-down resistor. The purpose of this is to hold the JTAG state-machine in a reset state by default, so that even with TCK oscillating, some sudden ion bombardment or other electrical even will not suddenly throw the JTAG state-machine into an unknown state. If your design also uses a weak pull-down resistor on TRST on your board, then enabling the "Drive TRST" flag will be required to force the JTAG state-machine out of reset to permit programming to take place. With most boards, there is no need to select this flag. ### FlashPro 5/4/3/3X Characteristics Table 13 · JTAG Switching Characteristics for FlashPro5/4/3/3X | Description | Symbol | Min | Max | Unit | |---------------------------------------------|---------|------|-------|------| | Output delay from TCK to TDI, TMS | TTCKTDI | -2 | 2 | ns | | TDO setup time before TCK rising, VJTAG=3.3 | TTDOTCK | 12 | | ns | | TDO setup time before TCK rising, VJTAG=1.5 | TTDOTCK | 14.5 | | ns | | TDO hold time after TCK rising | TTCKTDO | 0 | | ns | | TCK period | ттск | 41.7 | 10667 | ns | ## FlashPro and FlashPro Lite Characteristics The table below shows the JTAG switching characteristics for FlashPro and FlashPro Lite measured at the programmer end of the JTAG cable. Table 14 · JTAG Switching Characteristics for FlashPro and FlashPro Lite | Description | Symbol | Min | Max | Unit | |-------------------------------------------|---------|-----|-------|------| | Output delay from TCK falling to TDI, TMS | TTCKTDI | -2 | 2 | ns | | TDO setup time before TCK rising | TTDOTCK | 5.0 | | ns | | TDO hold time after TCK rising | TTCKTDO | 0 | | ns | | TCK period | ттск | 40 | 10240 | ns | ## Illustration of the JTAG Switching Characteristics The figure below is an illustration of the JTAG switching characteristics. Figure 22 · JTAG Switching Characteristics # FlashPro Express Reference ## FlashPro Express Start Page The FlashPro Express Start Page is the first page to show when the tool starts up. This page provides the interface for loading a project into the tool by either navigating to the project location, or clicking on one of the recently opened projects. Figure 23 · FlashPro Express Start Page ## FlashPro Express Project Menu | Command | Function | |-------------------------|-------------------------------------------------------| | Create Job Project from | New job project folder with programming job name will | | Command | Function | |--------------------|-------------------------------------------------------------------------------------------| | Programming Job | be created at the specified location. | | Open Job Project | Loads a job project into the tool by reading the information in user specified .pro file. | | Close Job Project | Closes the current job project | | Save Job Project | Saves the current job project | | Set Log File | Sets the location of the Log file to your specified location. | | Export Log File | Exports the Log file to your specified location. | | Execute Script | Runs your specified Tcl script. | | Export Script File | Exports all commands run in this session to your specified path as a Tcl script | | Exit | Exits FlashPro Express | # FlashPro Express Edit Menu | Command | Function | |------------------|-----------------------| | Clear Log Window | Clears the Log window | # FlashPro Express View Menu The View menu shows or hides the FlashPro Express GUI elements. | Command | Function | |------------|----------------------------| | Log Window | Shows/hides the Log window | # FlashPro Express Tools Menu | Command | Function | |------------------------|-----------------------------------------------------------------------------------------------------------------------| | Programmer<br>Settings | Opens the Programmer Settings dialog box; enables you to set options for all types of supported Microsemi programmers | | Run | Runs the current Programming Action. | ## FlashPro Express Help Menu | Command | Function | |--------------------------------|-------------------------------------------------------------------------------| | Help Topics | Opens the help | | Microsemi Technical<br>Support | Opens the Microsemi technical support site. | | Microsemi Web Site | Opens the Microsemi website in your default browser | | User Guide | Opens the FlashPro Express User Guide. | | Check for Software<br>Updates | Checks for software updates (works only if you are connected to the internet) | | About FlashPro Express | Lists the FlashPro Express release information | ## FlashPro Express Log Window and Status Bar #### FlashProExpress Log Window The FlashPro Express log window shows status messages for user activity. Click on the appropriate tab (Messages, Errors, Warning, Info) to filter messages by type. - Use the right-click menu to copy text, clear the log, and scroll the log. - Use the def variable LOG\_WINDOW\_BUFFER\_SIZE to set the buffer size. - Use the View menu to show or hide the Log window. #### FlashProExpress Status Bar The Status Bar at the bottom displays the status of the load project action. ## FlashPro Express Help Menu | Command | Function | |--------------------------------|-------------------------------------------------------------------------------| | Help Topics | Opens the help | | Microsemi Technical<br>Support | Opens the Microsemi technical support site. | | Microsemi Web Site | Opens the Microsemi website in your default browser | | User Guide | Opens the FlashPro Express User Guide. | | Check for Software<br>Updates | Checks for software updates (works only if you are connected to the internet) | | About FlashPro Express | Lists the FlashPro Express release information | # FlashPro Express Log Window and Status Bar #### FlashProExpress Log Window The FlashPro Express log window shows status messages for user activity. Click on the appropriate tab (Messages, Errors, Warning, Info) to filter messages by type. - Use the right-click menu to copy text, clear the log, and scroll the log. - Use the def variable LOG\_WINDOW\_BUFFER\_SIZE to set the buffer size. - Use the View menu to show or hide the Log window. #### FlashProExpress Status Bar The Status Bar at the bottom displays the status of the load project action. # **Product Support** Microsemi SoC Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, electronic mail, and worldwide sales offices. This appendix contains information about contacting Microsemi SoC Products Group and using these support services. ### **Customer Service** Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization. From North America, call **800.262.1060**From the rest of the world, call **650.318.4460**Fax, from anywhere in the world **650.318.8044** ## **Customer Technical Support Center** Microsemi SoC Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microsemi SoC Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions. ## **Technical Support** For Microsemi SoC Products Support, visit http://www.microsemi.com/products/fpga-soc/design-support/fpga-soc-support. ### Website You can browse a variety of technical and non-technical information on the Microsemi SoC Products Group home page, at http://www.microsemi.com/soc/. ## Contacting the Customer Technical Support Center Highly skilled engineers staff the Technical Support Center. The Technical Support Center can be contacted by email or through the Microsemi SoC Products Group website. #### **Email** You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request. The technical support email address is soc\_tech@microsemi.com. #### My Cases Microsemi SoC Products Group customers may submit and track technical cases online by going to My Cases. FlashPro Express Log Window and Status Bar #### Outside the U.S. Customers needing assistance outside the US time zones can either contact technical support via email (soc\_tech@microsemi.com) or contact a local sales office. Visit About Us for sales office listings and corporate contacts. # **ITAR Technical Support** For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), contact us via soc\_tech@microsemi.com. Alternatively, within My Cases, select **Yes** in the ITAR drop-down list. For a complete list of ITAR-regulated Microsemi FPGAs, visit the ITAR web page. Microsemi Corporate Headquarters One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996 E-mail: sales.support@microsemi.com © 2016 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners. #### **About Microsemi** Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense & security, aerospace and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; Enterprise Storage and Communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Microsemi is headquartered in Aliso Viejo, Calif., and has approximately 4,800 employees globally. Learn more at www.microsemi.com Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this