

**Report No:** 

## AN105

Title:

## In-System Programming (ISP) of Atmel AVR FLASH Microcontroller devices using the JTAG Programming Interface

| Author:       | Date:                     | Version Number: |
|---------------|---------------------------|-----------------|
| John Marriott | 7 <sup>th</sup> June 2010 | 1.23            |
|               |                           |                 |

## High-speed JTAG ISP Programmers...



## ...designed for Production Programming

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner. The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without prior notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent or other industrial or intellectual property rights





## Contents

| 1.0 Introduction                                                  | 5            |
|-------------------------------------------------------------------|--------------|
| 1.1 Features                                                      | 5            |
| General features                                                  | 5            |
| JTAG chain (JTAG daisy-chained mode)                              | 6            |
| In 'Development Mode'                                             | 6            |
| In 'Production Mode'                                              | 6            |
| Compatibility with Atmel AVR Studio software                      | 6            |
| Importing settings from Atmel FLE File supported                  | 0            |
| Compatibility with Atmel ITAG-ICE MK1 / MK2 Debugger              | 7            |
| 1.2 Programmers supported                                         | <i>i</i>     |
| 1.3 Device Support                                                | ٥            |
| 1.4 ITAG versus SPI algorithm                                     | 10           |
| 1.5 ITAG Algorithm Overview                                       | 11           |
| 1.6 SPI Algorithm Overview                                        | 12           |
| 1.7 Upgrading your Equipov Programmer to support ITAC             | 12           |
| 1.7 1 Purchasing a ITAG Liconso                                   | 12           |
| 1.7.2 How do Lonable the programmer for ITAC2                     | 12           |
| 1.7.2 How do reliable the programmer for 3TAC:                    | 12           |
| 1.7.5 Opgrading a PDM2 MK2 and PDM4 MK1 Programmer to support TAG | 11           |
| 1.7.5 Entering the License String to upgrade your programmer      | 14           |
| 1.7.5 Entering the License Stilling to upgrade your programmer    | 16           |
| 2.0 ITAG Programming Algorithm                                    | .10<br>17    |
|                                                                   | 17           |
| 2.1 Overview                                                      | . 17<br>10   |
| 2.2 JTAG PCB design / ISP cable quidelines                        | 10           |
| 2.3 JTAG FOD design / ISF cable guidelines                        | 10           |
| 2.4 JTAG single-chip in-System Flogramming (ISF) Schematic        | 20           |
| 2.5 TRO Signals - TDI, TDO, TNIO, TOR                             | 20           |
| 2.7 ITAG-in-a-chain In-System Programming (ISP) Schematic         | 21<br>22     |
| 2.8 ITAG connector compatibility with Atmol ITAG ICE MK1/MK2      | 22.          |
| 2.0 0 TAG connector compatibility with Ather 0 TAG TOE MICT/MICZ  | .20<br>21    |
| 2.9 Allier To-Way OTAG Header (OTAG Interface)                    | 26           |
| 2.10 IST hand Trogrammer - TTAG connections                       | .20<br>27    |
| 2.11 ISI hand - CONMOD Module - STAC connections                  | .21<br>20    |
| 3.1 Ovorviow                                                      | 20           |
| 3.2 Information required to create a ITAG Project                 | 29.<br>20    |
| 3.3 Creating an EDS (Development project)                         | 20           |
| 3.3.1 Launching EDS and selecting a Target Device                 | 30.<br>20    |
| 3 3 2 Target Oscillator Settings                                  | 31           |
| 3.3.3 Target System - Power Supply Settings                       | 32           |
| 3 3 4 Specifying the FLASH (Code) File                            | -02<br>      |
| 3 3 5 Specifying the FEPBOM (Data) File                           | .00<br>24    |
| 3.3.6 Launching EDS at the end of the EDS Wizard                  | 25           |
| 3.4 Testing a JTAG Project in Development (EDS) Mode              | 36           |
| 3.5. ITAG Frequency                                               | .00          |
| 3.6 ITAG Device Chain settings                                    | .07<br>.28   |
| 3 6 1 Overview                                                    | .00<br>28    |
| 3 6 2 JTAG Chain settings                                         | 30           |
| 3 6 3 JTAG Chain - Devices REFORE / AFTER parameters              | 30           |
| 3 6 4 JTAG Chain - Instruction Bits BEFORE / AFTER parameters     | <u>د</u> ور. |
| 3.6.5 Calculating the 'Bits Before' value                         | <u>⊿∩</u> .  |
| 3 6 6 Calculating the 'Bits After' value                          | . 10<br>⊿∩   |
| 3 6 7 Summary of the JTAG Chain settings                          | 41           |
|                                                                   |              |



|      | 3.7 Testing JTAG communication with the Target Chip                  | .42  |
|------|----------------------------------------------------------------------|------|
|      | 3.8 Programming the FLASH Area                                       | . 43 |
|      | 3.9 Programming the EEPROM Area                                      | . 44 |
|      | 3.10 Erasing the FLASH / EEPROM area                                 | . 45 |
|      | 3.10.1 Erasing the FLASH area                                        | . 45 |
|      | 3.10.2 Erasing the EEPROM area – special considerations              | . 45 |
|      | 3.11 Programming the Configuration Fuses                             | . 46 |
|      | 3.11.1 Overview                                                      | . 46 |
|      | 3.11.2 Reading the Fuses from a Target Device                        | . 47 |
|      | 3.11.3 Verifying the Fuses of a Target Device                        | . 47 |
|      | 3.11.4 Writing the Fuses into a Target Device                        | . 48 |
|      | 3.11.5 Using a 'Fuse File' to import Fuse settings into a project    | . 48 |
|      | 3.12 Programming the Security Fuses                                  | . 49 |
|      | 3.12.1 Overview                                                      | . 49 |
|      | 3.12.2 Reading the Security Fuses from a Target Device               | . 50 |
|      | 3.12.3 Verifying the Fuses of a Target Device                        | . 50 |
|      | 3.12.4 Writing the Security Fuses into a Target Device               | . 51 |
|      | 3.12.5 Erasing the Security Fuses                                    | . 51 |
|      | 3.13 Internal Oscillator Calibration – Factory OSCAL Byte            | . 52 |
|      | 3.13.1 Overview                                                      | . 52 |
|      | 3.13.2 Reading / writing the Oscillator Calibration Byte in EDS mode | . 52 |
|      | 3.13.3 Writing the Oscillator Galibration Byte in STANDALONE mode    | .54  |
| 4.0  | 3.14 Exporting an EDS Project to a Standalone Project                | . 34 |
| 4.0  | Exporting / Importing Fuse Settings to / from an Equinox Fuse File   | . 33 |
|      | 4.1 Overview                                                         | . 33 |
|      | 4.2 Exporting the Fuses from a Target Device                         | . 33 |
|      | 4.5 Copying the Fuse Softings from a Fuse File                       | 55   |
| 5 0  | Umporting Fuse Settings in HFX format from AVR Studio                | 57   |
| 0.0  | 5 1 Overview                                                         | 57   |
|      | 5.2 Finding the AVR Studio 'Hex Fuse Values'                         | 57   |
|      | 5.3 Importing the AVB Studio 'Hex Fuse Values' into EQTools          | 58   |
|      | 5.4 Importing the AVR Studio 'Hex Security Fuse Values' into EQTools | 61   |
| 6.0  | Creating a Standalone Programming Project                            | .65  |
| •••• | 6.1 Overview                                                         | . 65 |
|      | 6.2 Creating a Standalone Project from EDS (Development Mode)        | .65  |
|      | 6.3 Add Project File to a new Project Collection                     | .65  |
|      | 6.4 Uploading a Project to a programmer                              | .66  |
|      | 6.5 Re-testing a Project in EDS (Development mode)                   | . 67 |
|      |                                                                      |      |



## **1.0 Introduction**

This application note describes how to develop and implement *In-System Programming (ISP)* support for the Atmel AVR microcontroller family using the '*JTAG Programming Interface*'. The document details how to make a JTAG '*Programming Project*' which will operate on any Equinox ISP programmer. A full description of all connection method required to implement JTAG In-System Programming (ISP) of the Atmel AT90USB, AT90CAN and ATmega AVR FLASH Microcontroller is also discussed.

## 1.1 Features

The Equinox range of programmers includes solutions for development, low / mid / high volume production and field programming of Atmel AVR microcontrollers.

### General features

- High-speed In-System Programming (ISP) support of Atmel AVR microcontrollers using the *'JTAG programming interface'*.
- Programming solutions for development, low / mid / high volume production and field programming of Atmel AVR microcontrollers
- Programs the on-chip FLASH Memory, EEPROM Memory, Configuration Fuses and Security Fuses
- Uses the Atmel AVR standard 'JTAG Debug Interface' port as the ISP interface
- Very high-speed programming due to local data storage in on-board FLASH inside the programmer and optimised programming algorithms
- Programmers can be used in "Standalone Mode" (no PC required)
- Supports high-speed program / verify of the on-chip FLASH and EEPROM in a singe operation.
- Supports programming of the factory calibrated 'Oscillator Calibration Byte'
- Optimised Erase operations for FLASH and EEPROM
- Supports programming of non volatile 'Configuration Fuses'
- Supports programming of the 'Security Fuses' to protect code from being read out
- Supports programming of any AVR microcontroller when placed in a '*JTAG Chain*' (JTAG daisy-chain mode)
- Supports up to 256 devices in a single 'JTAG Chain'
- User-programmable '*pre-programming state machine*' allows non-standard reset circuits to be supported (both reset polarity and timing can be manually adjusted)
- User-configurable '*JTAG frequency*' allows the JTAG signals to be matched to the target hardware / wiring
- Target voltage can be measured and validated





## JTAG chain (JTAG daisy-chained mode)

All Equinox programmers supports programming of an Atmel AVR microcontroller when it is connected in a so-called *'JTAG Chain'*.

- Supports programming of any one of up to 256 devices in a single 'JTAG Chain'
- User-programmable JTAG chain settings allowing the user to set up the configuration of the target device in the chain.
- Multiple AVR devices in a chain can be programmed sequentially one-after-the-other using a single programmer by making a separate '*standalone project*' for each device in the chain.
- High-current TDI drive pin to ensure good signal integrity throughout the chain

## In 'Development Mode'

All Equinox programmers can be used in *'Development Mode'* where the programmer is controlled via our *EDS* software application running on the PC. This allows the user to control all programming operations under PC control and so is ideal for the initial set up and testing of programming projects.

- Powerful yet simple-to-use Development Suite called 'EDS'
- All aspects of programming the AVR device can be controlled from the PC using EDS
- Erase, Program, Read or Blank Check both the FLASH and EEPROM areas under PC control
- Program / Read back the 'Configuration Fuses'
- Program / Read back the 'Security Fuses'
- Program / Read back the factory calibrated 'Oscillator Calibration Byte'

### In 'Production Mode'

It is all possible to use any Equinox programmer in standalone mode. In this mode, the programmer operates without PC control and is capable of fully programming a target device.

- Programmers can be used in "Standalone Mode" (no PC required)
- A single *'Standalone Programming Project'* can Erase the device, program /verify the FLASH and EEPROM, program the *'Configuration Fuse Bits'*, program the 'Oscillator Calibration Byte' and finally program the *'Security Fuses'* all in a single operation.
- Up to 64 x AVR '*Standalone Programming Projects*' can be stored inside an FS2003, FS2009, PPM3-MK2, PPM4-MK1 or ISPnano programmer.
- Programmer can store multiple versions of firmware for different *'customer product versions'*.
- A 'Standalone Programming Project' can be created from an 'Atmel ELF File' created by e.g. AVR Studio

### Compatibility with Atmel AVR Studio software

- Supports importing of Fuse and Lock Hex byte settings from AVR Studio
- Supports importing of FLASH, EEPROM, Fuse and Security settings from an '*Atmel ELF File*' created by e.g. AVR Studio



### Importing settings from Atmel ELF File supported

- Supports importing of FLASH, EEPROM, Fuse and Security settings from an '*Atmel ELF File*' created by e.g. AVR Studio
- Allows a '*development user*' to send a single '*ELF File*' which can contain most of the data required for production.

## Compatibility with Atmel JTAG-ICE MK1 / MK2 Debugger

- All Equinox programmers can support connection to the standard Atmel 10-way AVR JTAG IDC header connector.
- If your Target Board already works with the Atmel JTAG-ICE MK1 / MK2 debugger, then it should work with any Equinox JTAG programmer.
- All Equinox programmers must be configured with the Equinox EQTools software. They will not work with Atmel's AVR Studio software.



## **1.2 Programmers supported**

All Equinox ISP Programmers are capable of supporting programming of Atmel AVR microcontrollers using the '*JTAG Programming Interface*'. Some programmers offer this support as standard but most require a '*License upgrade*' to be purchased. Please refer to the table below for full details.

| Programmer<br>Picture | Programmer<br>Order code | AVR SPI algorithms   | AVR JTAG algorithms                                                                                          |
|-----------------------|--------------------------|----------------------|--------------------------------------------------------------------------------------------------------------|
| Tieture               |                          |                      |                                                                                                              |
|                       | EPSILON5(UN)             | Included as standard | UPGRADE:<br>EPSILON5-UPG3                                                                                    |
|                       | EPSILON5(AVR-<br>JTAG)   | EPSILON5-UPG17       | Included as standard                                                                                         |
|                       | FS2003(UN)               | Included as standard | UPGRADE:<br>FS2003-UPG7                                                                                      |
|                       | FS2009(UN)               | Included as standard | UPGRADE:<br>FS2009-UPG7                                                                                      |
|                       | FS2009(AVRJTAG)          | FS2009-UPG17         | Included as standard                                                                                         |
|                       | PPM3 MK2(UN)             | Included as standard | UPGRADE:<br>PPM3A1-UPG7<br>+ IO-CON-3 JTAG<br>Connector Module +<br>SFM-MAX-V1.3 Special<br>Function Module  |
|                       | PPM4 MK1(UN)             | Included as standard | UPGRADE:<br>PPM4MK1-UPG7<br>+ IO-CON-3 JTAG<br>Connector Module +<br>SFM-MAX-V1.3 Special<br>Function Module |
|                       |                          |                      |                                                                                                              |

Fig. 1.2 Equinox Programmer – SPI and JTAG ISP Support



|                                         | ISPnano                                      | UPGRADE                  | UPGRADE                 |
|-----------------------------------------|----------------------------------------------|--------------------------|-------------------------|
|                                         | Series I / II / III                          | ISPnano-UPG17            | ISPnano-UPG7            |
| Series III - ATE                        | ISPnano                                      | UPGRADE                  | UPGRADE                 |
| DC DC V V V V V V V V V V V V V V V V V | Series III ATE                               | ISPnano-UPG17            | ISPnano-UPG7            |
|                                         | ISPnano-MUX2<br>ISPnano-MUX4<br>ISPnano-MUX8 | UPGRADE<br>ISPnano-UPG17 | UPGRADE<br>ISPnano-UPG7 |

Key:

• UPGRADE – Chargeable license upgrade required

## **1.3 Device Support**

Please refer to the latest *Device Support List* for the devices which are currently supported by the Equinox range of programmers.

This can be found:

- 1. As a **Download** available on the website:
  - Click on the *Downloads* tab.
    - Under 'Download Type' choose Device Support Lists / Release notes then click Search.
- 2. Browsing on the **Device Support** tab under each product.
- 3. In the latest version of **EQTools:** 
  - Select EQTools. Go to <Programmer><Create a Device Report>.
  - All programmers and devices supported are listed in this document.
  - You will need the most recent EQ-Tools build version please refer to the website for further details.

#### Please note:

- As a rule of thumb, only Atmel Atmega AVR devices with 16k bytes of FLASH or greater will feature the JTAG Programming Interface.
- Some ATmega devices such as the ATmega8(L) and ATmega161(L) do not have a JTAG port and so cannot support JTAG programming.
- Devices with greater than 128kb of FLASH memory require a firmware upgrade to version 3.01 or above in order to support programming of the upper 128kb.
- It is possible to program devices connected in a 'JTAG Chain' using firmware 3.05 or above.
- Please see *Application Note AN112* for instructions on updating your programmer firmware.



## 1.4 JTAG versus SPI algorithm

The table below compares the JTAG and SPI programming algorithms for the Atmel AVR family of microcontrollers.

| Parameter                                           | SPI algorithm                                                                     | JTAG algorithm                                                                                              | Comments                                                                                                              |
|-----------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| Programming speed                                   | Much clowor than                                                                  | x3 or x4 timos fastor                                                                                       | Doponds on SPL / ITAG                                                                                                 |
| Frogramming speed                                   | JTAG                                                                              | than SPI                                                                                                    | clock frequencies                                                                                                     |
| Programming reliability                             | Depends on AVR<br>clock frequency                                                 | Very good                                                                                                   | '                                                                                                                     |
| In-System Debugging                                 | Not possible                                                                      | Yes – use Atmel JTAG-<br>ICE debugger                                                                       | JTAG port normally<br>used during<br>development phase                                                                |
| Boundary Scan Testing                               | Not possible                                                                      | Yes – requires external<br>JTAG tester                                                                      | Very useful for production testing.                                                                                   |
| Multiple AVR<br>programming on same<br>Target Board | Very difficult in SPI<br>mode                                                     | Possible to daisy-chain multiple AVR devices in a JTAG chain.                                               | Only one device can be programmed at a time.                                                                          |
| EEPROM programming speed                            | Slow on most<br>devices as 1 byte<br>per page                                     | x4 or x8 times faster as<br>programmed in 4 or 8<br>byte pages                                              | Some newer AVR<br>devices do have 'Page<br>Mode' programming.                                                         |
| EEPROM Erase cycle                                  | Each EEPROM byte<br>can be individually<br>erased                                 | A Chip Erase is<br>required to erase any<br>non 0xFF location                                               | Cannot use JTAG mode<br>to re-program EEPROM<br>without erasing FLASH.                                                |
| Programming pins<br>required                        | 3 + RESET<br>MOSI, MISO, SCK                                                      | 4 + RESET<br>TDI, TDO, TCK, TMS                                                                             | RESET pin is required<br>for both SPI and JTAG                                                                        |
| Programming pins can<br>be used for user I/O?       | Yes                                                                               | Not recommended                                                                                             | Try not to put other components on pins.                                                                              |
| RESET pin control required?                         | Yes                                                                               | Yes                                                                                                         | The RESET pin is essential for SPI and JTAG operation.                                                                |
| Programming<br>dependent on AVR<br>clock settings?  | Programming will<br>fail if a valid clock is<br>not applied to the<br>AVR device. | Programming should<br>always work in JTAG<br>mode even if the AVR<br>does not have a valid<br>clock source. | In SPI mode, an AVR<br>device can be rendered<br>no longer programmable<br>by selecting an incorrect<br>clock source. |
| Possible to lock out SPI<br>/ JTAG port             | Yes – but only from JTAG mode                                                     | Yes – from SPI and JTAG mode                                                                                | Need to unset the SPIEN or JTAGEN fuses                                                                               |
| Scramble AVR fuses by accident?                     | Very easy to do by mistake!!!                                                     | Most fuse issues can<br>be recovered in JTAG<br>mode.                                                       | Use JTAG mode to<br>recover a device with<br>scrambled fuses.                                                         |



## **1.5 JTAG Algorithm Overview**

The JTAG algorithm provides a method of performing high-speed programming of an Atmel Atmega AVR microcontroller. The same JTAG port can also be used for on-chip debugging of code using the Atmel JTAG-ICE Debugger. The advantages and disadvantages of the JTAG algorithm are detailed below.

#### Advantages

- The JTAG algorithm is approximately **3-4 times faster** at programming compared to the SPI algorithm.
- The programming time using JTAG for the EEPROM is significantly faster than the SPI algorithm because in JTAG mode a 'Page' of EEPROM is programmed at a time rather than a single byte. Each byte may take e.g. 9ms to program in SPI mode, where as a whole page of e.g. 4 bytes may take 9ms to program in JTAG mode.
- The JTAG algorithm uses the same '*JTAG Port*' as the Atmel JTAG-ICE Debugger. This means that the same port can be used for both debugging during the development phase and also programming during the production phase of the product.
- With the JTAG algorithm, the programming clock is supplied by the programmer and JTAG logic inside the Target AVR device does not require any other clocking. This means that the chip is not dependent on the settings of the *'Clock Selection Fuses'* in JTAG Mode.
- In JTAG mode is it possible to change the '*Clock Selection Fuses*' to any value and still program the chip. (with the exception of the '*JTAGEN*' Fuse)
- It is possible to use the JTAG port of the Target Microcontroller to perform in-circuit testing of the microcontroller and surrounding circuitry. This testing is performed by shifting Test Data through the JTAG port of the Target Microcontroller. A JTAG Test System is required to perform this testing. It is not supported by any Equinox Programmer or the Atmel JTAG ICE.
- It is possible to daisy-chain multiple JTAG devices on the JTAG bus in a so-called 'JTAG Chain' and then select to program a particular device in the chain. This functionality is now supported by Equinox programmers running firmware 3.05 and above.

#### Disadvantages

- The JTAG Programming Interface uses **5 pins**: TCK, TDI, TDO, TMS and RESET.
- The JTAG pins of the microcontroller are not designed for off-board use and should not be shared with any other circuitry on Target Board. This means that the JTAG port pins must be dedicated for programming / debugging.
- In JTAG mode the EEPROM is divided into '*Pages*' rather than '*Single Bytes*'. It is therefore more complicated to program a single byte in the EEPROM as the entire page (usually 4 or 8 bytes) must be read back and then the single byte overlaid on top of this data and finally the entire page is then re-programmed back into the EEPROM.
- In JTAG Mode, it is not possible to re-program any location in the EEPROM which is not\_0xFF without first performing a Chip Erase operation. This means that if the EEPROM already contains any data, it is not possible to re-program this data without erasing the entire chip first.



## **1.6 SPI Algorithm Overview**

The SPI algorithm is a simple 3-wire interface which can be used to program most AVR Microcontrollers. The advantages and disadvantages of this algorithm are detailed below.

#### Advantages

- The SPI algorithm is supported by almost all Atmel AVR microcontrollers including AT90S, AT90CANxxx, ATtiny and ATmega devices. This means that the same Programming Interface can be used on any products containing any AVR microcontroller.
- The SPI Programming Interface uses only 3 SPI pins (MOSI, MISO, SCK) and the RESET pin.
- The SPI pins can be used to drive other circuitry such as LED's and switches on the Target Board as well as being used for ISP purposes. However, this will require careful design on the Target Board to ensure that the programming signals are not compromised.
- In SPI Mode, it is possible to reprogram a single byte of the EEPROM area without having to perform a Chip Erase first.
- The SPI algorithms are supported as standard on all Equinox ISP Programmers.

#### Disadvantages

- In general terms, the SPI algorithm is 3-4 times slower than the JTAG algorithm.
- When using the SPI algorithm, the clock used during programming is supplied from either the AVR Internal RC Oscillator or from an external crystal / resonator. The programming SPI speed is completely dependent on the speed of this oscillator.
- If the oscillator speed is slow, then the maximum SPI speed is seriously limited and the overall programming will be very slow.
- If the AVR '*Clock Selection Fuses*' are incorrectly programmed in SPI mode, then the chip may no longer have a valid oscillator and so will not respond to the programmer. This can render the chip non-programmable except by physically removing it from the Target Board and using either a JTAG or Parallel programmer to resurrect the correct fuse settings.



## **1.7 Upgrading your Equinox Programmer to support JTAG**

The *AVR JTAG* algorithms are <u>not</u> supported as standard on any Equinox programmers (for exceptions – see below\*). It is necessary to purchase a *'License Upgrade'* for *AVR JTAG* support from Equinox. Equinox will then send you a *'JTAG Upgrade License String'* which will upgrade your programmer to support JTAG programming.

#### Please note

The following '*Standalone programmer*' and '*Bundle*' options have the *AVR JTAG* license preinstalled, therefore these instructions are not necessary:

- Epsilon5(AVR-JTAG)
- EPS-AVRJTAG-BUNDLE
- FS2009(AVR-JTAG)

### 1.7.1 Purchasing a JTAG License

All Equinox ISP programmers require the purchase of a 'License Upgrade' to enable JTAG support. Please see the table in section 1.1 for the relevant upgrade for your programmer.

#### 1.7.2 How do I enable the programmer for JTAG?

To enable your programmer to support JTAG ISP programming, please purchase the relevant JTAG Upgrade from Equinox or an Equinox distributor:

#### 1. If you purchase the upgrade directly from Equinox

- Equinox will email you a 'JTAG License String'.
- This string can be entered directly into the <Enter License> screen in EQTools.

#### 2. If you purchase the upgrade from a distributor

- The distributor will send you the Upgrade Pack by courier.
- Within the Upgrade Pack you will find an Upgrade Form with a Code String on it.
- Email this Code String plus your programmer Serial Number to <a href="mailto:support@equinox-tech.com">support@equinox-tech.com</a>
- Equinox will then send you a 'JTAG License String' which is keyed to your programmer Serial Number.
- This string can be entered directly into the *<Enter License>* screen in EQTools.

### 1.7.3 Upgrading an Epsilon5, FS2003 and FS2009 to support JTAG

To upgrade an Epsilon5, FS2003 or FS2009 programmer to support JTAG, please follow the steps below:

- Order An **AVR JTAG** License from Equinox
- Enter the 'JTAG Upgrade License String' given to you by Equinox into EQTools see section 2.9.5 below.
- Make sure you have the required version of Programmer Firmware to support the device you wish to program.
- Plug the 10-way ISP cable supplied with the programmer into the '**J8 JTAG-10**' ISP Header on the programmer.
- Connect the other end of the 10-way ISP cable to the JTAG port on your Target Board
- You are now ready to program a Target AVR Chip via JTAG.



## *1.7.4 Upgrading a PPM3-MK2 and PPM4-MK1 Programmer to support JTAG*

To upgrade a PPM3-MK2 or PPM4-MK1 programmer to support JTAG, please follow the steps below:

- Order a 'PPM3-MK2 / PPM4-MK1 JTAG upgrade' from Equinox Technologies
- Enter the 'JTAG Upgrade License String' given to you by Equinox into EQTools see section 2.9.5 below.
- The JTAG upgrade also includes a new 'I/O Connector Module' for the PPM3-MK2 and PPM4-MK1 called the 'I/O-CON-3'. This module has a JTAG 10-way header which has the same pinout as the JTAG-ICE.
- It also includes the High Speed / High Current Special Function Module 'EQ-SFM-MAX-V1.3'. This significantly reduces the overall programming times for many high capacity devices. For full instructions on fitting this module please refer to *Application Note AN115* provided with your upgrade
- Make sure you have the required version of Programmer Firmware to support the device you wish to program.
- Plug the 'I/O-CON-3' module into the programmer.
- Plug the 10-way ISP cable supplied with the programmer into the '**JTAG**' ISP Header on the '**I/O-CON-3**' module.
- Connect the other end of the 10-way ISP cable to the JTAG port on your Target Board
- You are now ready to program a Target Chip via JTAG





### 1.7.5 Entering the License String to upgrade your programmer

Once you have received the License String from Equinox, please follow the steps below to apply the upgrade to your programmer:

- Launch EQTools  $\rightarrow$  The EQTools 'Welcome Screen' is displayed.
- Close down the EQTools 'Welcome Screen'
- From the top menu bar, select <Programmer><Programmer Info>
- $\rightarrow$  the Programmer Information screen is displayed
- Click the *<Enter License>* button
- → The <*Enter License Key*> screen is displayed.

| Enter Licen | ce key 🔀                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| <b>?</b> *  | It is possible to purchase License Upgrades from Equinox for this product which<br>will enable certain utilities or Device Libraries. Please refer to the Equinox<br>Website (http://www.equinox-tech.com) for a full list of upgrades for this product<br>or e-mail support@equinox-tech.com. |  |  |  |  |  |
|             | Please enter the 24 character Hexadecimal licence key provided by Equinox to<br>enable certain options.                                                                                                                                                                                        |  |  |  |  |  |
|             | <u>D</u> K <u>C</u> ancel                                                                                                                                                                                                                                                                      |  |  |  |  |  |

Enter the License String you were sent by Equinox

- Click <OK>
- $\rightarrow$  EQTools should acknowledge that the attached programmer has been upgraded.

| Informa | tion                  |                                               | × |
|---------|-----------------------|-----------------------------------------------|---|
| •       | Operation:<br>Result: | Update Programmer Licence information<br>Pass |   |
|         | Press <ok> to</ok>    | view the updated programmer information.      |   |
|         |                       | OK                                            |   |

- Click <OK>
- If you now check the Programmer Info screen, you should find that the entry for 'ATmega JTAG ISP' is now ENABLED.
- Your programmer is now upgraded to support JTAG programming of Atmel AVR Microcontrollers.



## 1.8 Other related application notes

The table below lists the Application Notes available for all Atmel microcontroller, serial EEPROM, Serial FLASH and Serial DataFLASH devices.

| Application<br>Note | Device Family                                                         | Programming<br>Interface |
|---------------------|-----------------------------------------------------------------------|--------------------------|
| AN100               | Atmel - AT89Sxxxx FLASH microcontrollers                              | SPI                      |
| AN101               | Atmel - AVR FLASH microcontrollers via the SPI Interface              | SPI                      |
| AN105               | Atmel - AVR FLASH microcontrollers via the JTAG Interface             | JTAG                     |
| AN118               | Generic I2C 24xxx Serial EEPROM memories                              | 12C                      |
| AN122               | Atmel - AT91SAM7 ARM7 FLASH microcontrollers                          | JTAG                     |
| AN127               | Atmel – XMEGA AVR FLASH microcontrollers via the 2-wire PDI interface | PDI                      |
| AN132               | Atmel ATtiny AVR microcontrollers via the TPI interface               | ТРІ                      |
| AN133               | Atmel AT45D Serial DataFlash programming                              | SPI                      |

These application notes can be found in PDF format on the CD-ROM which was supplied with the programmer. You can also find the very latest versions on the *"ISPnano Download Page"* on the Equinox website.



## **2.0 JTAG Programming Algorithm**

## 2.1 Overview

The 'JTAG Programming Interface' provides a method for both In-System Debugging (ISD) and In-System Programming (ISP) of Atmel ATmega AVR Microcontrollers. It uses an industry-standard set of signals to provide the connection between the programmer / debugger and the AVR microcontroller. However, the actual JTAG Header (connector) used by Atmel and Equinox is specific to Atmel AVR JTAG programming and will not match JTAG connectors for JTAG devices from other manufacturers.



#### In the development environment......

.....The JTAG Interface can be used for *In-System Debugging* of the code running on the actual Target System. This method of operation requires the use of the Atmel '*JTAG-ICE MK1*' or '*JTAG-ICE MK2*' debugger to program firmware into the FLASH of the target AVR microcontroller. Once the code is downloaded into FLASH, it is then possible to execute and debug this code under PC control. The debugger Software (AVR Studio) allows you to set breakpoints in the code, read / write memory locations, look at register contents etc.

#### In the production environment.....

.....The JTAG Interface can be use for high-speed *In-System Programming (ISP)* of the Target AVR Microcontroller. This method of operation requires the use of any Equinox ISP Programmer which has been enabled to support the '*AVR JTAG*' algorithms.

The Equinox ISP Programmer range supports high-speed *In-System Programming (ISP)* of a single or multiple Atmel AVR microcontrollers on a Target Board using the 4-wire JTAG inerface. Support has now been added for programming of any Atmel AVR microcontroller when connected as part of a *'JTAG Chain'*. This mode allows multiple JTAG devices to be in-system programmed using a single JTAG bus.



## 2.2 JTAG Features

- Fast Programming speeds
- Simple 4-wire JTAG bus connection + RESET signal
- JTAG programming does not depend on the AVR oscillator frequency so JTAG programming will always work
- JTAG interface is compatible with the Atmel *JTAG-ICE MK2 In-System Debugger* so same interface can be used for development and production.
- Both single microcontroller and 'JTAG-in-a-chain' implementations are supported

## 2.3 JTAG PCB design / ISP cable guidelines

The following guidelines are provided for designing an '*AVR based Target Board*' which is to be programmed via the JTAG interface.

- **Proper decoupling** Make sure the AVR microcontroller is well decoupled.
- **No JTAG in-line resistors** Avoid placing any resistors in the JTAG lines TDO, TDI, TCK, TMS as this can skew the waveforms so the JTAG clock is not sampled correctly.
- **No JTAG capacitors** Avoid placing any capacitors from any of the JTAG lines to 0V as this will slug the waveforms and probably stop JTAG working reliably.
- **JTAG pull-up resistors** It is recommended that either the Target Board or the Test Fixture has pull-ups e.g. 47k ohm on the JTAG signal lines. (The programmer does not have any pull-ups)
- **RESET pin connection** Make sure that the RESET pin of the target AVR microcontroller is brought out to the programming header. It is essential that the programmer can control the RESET pin of the AVR device !!!
- **Cable length** Keep the cable length between the Target Board and the programmer as short as possible. e.g. no more than 15cm in length.
- **JTAG relays etc** Do not use any relays or electronics analogue switches in the JTAG signal lines if at all possible.



## 2.4 JTAG single-chip In-System Programming (ISP) Schematic

The diagram below details the connections required to implement JTAG In-System Programming of a single Atmel ATmega AVR Microcontroller using an Equinox ISP programmer.

Fig 2.4 – ATmega AVR – JTAG Programming Interface connections



ATmega AVR – JTAG Programming Interface - signal names and directions

#### Please note:

- The *RESET* connection is essential in JTAG mode. This allows the programmer to reset the Target Microcontroller and release the JTAG port for programming.
- It is recommended that either the Target Board or the Test Fixture has pull-up resistors e.g. 47k ohm on the JTAG signal lines.



## 2.5 JTAG signals – TDI, TDO, TMS, TCK

The JTAG programming interface for AVR devices uses four data lines: TDI, TDO, TMS and TCK. The table below shows the relevant direction of each JTAG signal line.

| Programmer<br>Signal Name | Signal description | Signal<br>direction<br>(from<br>Programmer) | Connect to<br>AVR<br>Microcontroller<br>Pin | Signal direction<br>(from<br>Microcontroller) |
|---------------------------|--------------------|---------------------------------------------|---------------------------------------------|-----------------------------------------------|
| PROG_TCK                  | Test Clock Pin     | Output                                      | TCK                                         | Input                                         |
| PROG_TDI                  | Test Data Input    | Output                                      | TDI                                         | Input                                         |
| PROG_TDO                  | Test Data Output   | Input                                       | TDO                                         | Output                                        |
| PROG_TMS                  | Test Mode Select   | Output                                      | TMS                                         | Input                                         |
| PROG_RESET                | RESET              | Output                                      | RESET                                       | Input                                         |

When programming in JTAG mode, the programmer provides the clock to the "JTAG TAP **Controller**" inside the target AVR device. The programmer clocks data out of the '**TDI**' pin on the programmer into the '**TDI**' pin on the AVR device.



This data is then shifted through a shift-register inside the AVR device and appears out of the '**TDO**' pin on the AVR device. This bit-stream is then fed back into the programmer '**TDO**' pin.

#### Please note:

- It is recommended that either the Target Board or the Test Fixture has pull-ups e.g. 47k ohm on the JTAG signal lines.
- The target AVR device must drive the '**TDO**' pin back via the ISP cable to the programmer. This pin is susceptible to noise and skew as the AVR only drives the pin for part of the dutycycle of the waveform. It may be necessary to use a stronger pull-up or some sort of buffering on this pin if long ISP cables are being used.
- No in-line resistors or capacitors to 0V should be placed in any of the JTAG signal lines as they could skew / slug the waveforms leading to erratic programming operation.



## 2.6 AVR RESET signal

When programming Atmel AVR devices using the JTAG Interface, it is imperative that the programmer can control the *RESET* pin of the target AVR microcontroller. It does not matter if the *RESET* signal from the programmer goes through other logic on the Target Board, as long as the programmer is capable of forcing the *RESET* pin <u>LOW</u> when commencing a JTAG programming operation.

The reasons for requiring control of the *RESET* pin are as follows:

- If any user firmware which is programmed into the target AVR device writes to any of the JTAG pins or sets up the '*Data Direction Registers*' of the JTAG port incorrectly, then the JTAG port will no longer operate correctly and entering JTAG programming mode will fail.
- If any user firmware which is programmed into the target AVR device happens to execute the AVR instruction to disable the JTAG port (usually for power consumption reasons), then the programmer will not be able to enter JTAG programming mode.
- The programmer must assert the *RESET* pin of the target AVR microcontroller <u>LOW</u> when commencing a JTAG programming operation. This forces the AVR device to stop running firmware and releases / resets the JTAG port so the programmer can communicate with it.

#### Warning!

- Any AVR Target System which does not allow control of the *RESET* pin may be programmable once only via JTAG and then all subsequent attempts to enter JTAG programming mode may fail.
- Once the target AVR device is in JTAG mode, the *RESET* pin will have no effect until JTAG mode has been exited. This will hold the AVR device in reset so it cannot execute code.



## 2.7 JTAG-in-a-chain In-System Programming (ISP) Schematic

The diagram below details the connections required to implement JTAG In-System Programming of either a single or multiple Atmel ATmega AVR Microcontrollers which are connected in a *'JTAG Chain'* arrangement.



Fig 2.7 – ATmega AVR – JTAG Programming Interface connections

The TDI signal is fed into the TDI input on the first JTAG Device in the chain. The data path then goes through the first device and comes out on the TDO pin. The TDO pin is connected to the TDI pin of the next JTAG Device in the chain.

| ATmaga |       | $TTA \cap D$ | roarommin | a Intarfaca | aianal   | nomoo | and | diractiona |
|--------|-------|--------------|-----------|-------------|----------|-------|-----|------------|
| Armeda | AVH - | 11 A(3 PI    | oorannin  | о ппепасе   | - Sionai | names | ana | onecnons   |
|        |       |              | eg        | ginneria    | e.ga.    |       |     |            |

| Programmer<br>Signal Name | Signal description | Signal<br>direction<br>(from<br>Programmer) | Connect to<br>AVR<br>Microcontroller<br>Pin | Signal direction<br>(from<br>Microcontroller) |
|---------------------------|--------------------|---------------------------------------------|---------------------------------------------|-----------------------------------------------|
| PROG_TCK                  | Test Clock Pin     | Output                                      | TCK                                         | Input                                         |
| PROG_TDI                  | Test Data Input    | Output                                      | TDI                                         | Input                                         |
| PROG_TDO                  | Test Data Output   | Input                                       | TDO                                         | Output                                        |
| PROG_TMS                  | Test Mode Select   | Output                                      | TMS                                         | Input                                         |
| PROG_RESET                | RESET              | Output                                      | RESET                                       | Input                                         |

#### Please note:

The RESET connection is essential in JTAG mode. This allows the programmer to reset the Target Microcontroller and release the JTAG port for programming.



## 2.8 JTAG connector compatibility with Atmel JTAG ICE MK1/MK2

The JTAG port of an ATmega AVR Microcontroller can be used for both debugging and programming purposes. The Equinox '*JTAG ISP Header*' pin-out found on all Equinox ISP Programmers uses the same pins as the Atmel '*JTAG ICE MK1 / MK2 Debugger*' so it is possible to use the same connector / cabling for both programming and debugging.

#### Fig. 2.8 JTAG ISP 10-way IDC Header

| Atmel 10-way JTAG IDC Header                                                             | Atmel JTAG ICE MK1 or<br>MK2 | Equinox ISP Programmer |
|------------------------------------------------------------------------------------------|------------------------------|------------------------|
| PROG_TCK12PROG_GNDPROG_TDO34PROG_VCCPROG_TMS56PROG_RESETPROG_VCC78N/CPROG_TDI910PROG_GND |                              |                        |

#### Important notes:

#### 1. RESET pin connection

The RESET pin of the AVR Microcontroller must be brought out to the ISP Header. It is not actually required for the JTAG algorithm as the control of programming initiated via a JTAG command. However, the Equinox programmer / Atmel JTAG-ICE can use the RESET pin to RESET the Target AVR microcontroller to ensure that the AVR JTAG port is not driving any I/O pins which could cause contention during programming. The JTAG-ICE also needs control of the RESET pin to force the AVR microcontroller to execute code when in debugging mode.





## 2.9 Atmel 10-way JTAG Header (JTAG Interface)

This connection method is suitable for interfacing any Equinox ISP Programmer to a Target System which features the following:

- An Atmel device which features a JTAG ISP port e.g. ATmega128 / 64 / 32 / 16 etc.
- Atmel 10-way IDC JTAG Header
- The pin-out is the same as the "JTAG connector" used on the Atmel JTAG-ICE MK1 / MK2 debuggers., STK500, STK600 and all associated Atmel STK plug-in boards.

To implement this connection, simply plug the 10-way ISP cable into the *JTAG ISP Header* and plug the other end of the cable into the matching header on the Target System.

| PROG_TCK | 1 | -••   | 2  | PROG_GND   |
|----------|---|-------|----|------------|
| PROG_TDO | 3 | -••   | 4  | PROG_VCC   |
| PROG_TMS | 5 | ┣• •─ | 6  | PROG_RESET |
| PROG_VCC | 7 | ┍     | 8  | N/C        |
| PROG_TDI | 9 | -• •  | 10 | PROG_GND   |

Figure 2.9 - Atmel 10-way JTAG IDC Header viewed from above

#### Warning!

Connecting to the wrong ISP Header may cause catastrophic damage to the Programmer & Target System

| Pin<br>No | Programmer<br>Pin name | Programmer<br>Input /<br>Output | Connect to<br>pin on<br>Target Device | Description                                                                                                                                                       |
|-----------|------------------------|---------------------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         | PROG_TCK               | 0                               | тск                                   | <b>JTAG TCK – Test Clock Signal pin</b><br>Clock signal from programmer to Target<br>Device JTAG port.                                                            |
| 2         | PROG_GND               | Р                               | GROUND                                | <b>Ground Connection</b><br>Common ground connection between<br>Programmer and Target System.                                                                     |
| 3         | PROG_TDO               | l                               | TDO                                   | <b>JTAG TDO – Test Data Output pin</b><br>Data signal from Target device JTAG port<br>to programmer.                                                              |
| 4         | PROG_VCC               | P                               | TARGET_VCC                            | Target Vcc Connection- Pins 4 + 7 are physically connectedinside the programmer Connects to Vcc rail of Target System Pin referred to as VTref on Atmel JTAG-ICE. |
| 5         | PROG_TMS               | 0                               | TMS                                   | <b>JTAG TMS – Test Mode Select pin</b><br>Mode Select Signal from programmer to<br>Target Device JTAG port.                                                       |
| 6         | PROG_RESET             | 0                               | RESET                                 | <b>Microcontroller RESET control signal</b><br>This pin connects to the main RESET pin<br>of the Target Microcontroller.                                          |



| 7  | PROG_VCC | Р | TARGET_VCC | <b>Target Vcc Connection</b><br>- See pin 4<br>- Pins 4 + 7 are physically connected<br>inside the programmer. |
|----|----------|---|------------|----------------------------------------------------------------------------------------------------------------|
| 8  | N/C      | 0 | N/C        | Not Connected                                                                                                  |
| 9  | PROG_TDI | 0 | TDI        | <b>JTAG TDI – Test Data Input pin</b><br>Data signal from programmer to Target<br>Device JTAG port.            |
| 10 | PROG_GND | Р | GROUND     | Ground Connection<br>Common ground connection between<br>PROGRAMMER and Target System.                         |

#### Key

O - Output from programmer to Target Device

I - Input to programmer from Target Device

P - Passive e.g. GROUND and power rails

N/C - Not connected



.

## 2.10 ISPnano Programmer – JTAG connections

The illustration below shows the location of the '*Target ISP Connector*' port on the rear panel of the ISPnano Series I / II and III programmers.



The table below details the connections for programming Atmel AVR microcontrollers via the JTAG Interface using the ISPnano programmer '*Target ISP Connector*' port

| Pin<br>No | Programmer<br>Pin name | Programmer<br>Input /<br>Output | Connect to<br>pin on<br>Target System | Notes                    |
|-----------|------------------------|---------------------------------|---------------------------------------|--------------------------|
| 1 + 2     | TARGET_VCC             | Ρ                               | TARGET_VCC                            | Target VCC               |
| 3 + 4     | TARGET_EXT_VCC         | Ρ                               | See notes.                            | Target External VCC      |
| 5 + 6     | PROG_GND               | Ρ                               | Signal GROUND<br>(0V)                 | Signal Ground Connection |
| 10        | Programmer I/O5        | I/O                             | Spare I/O                             |                          |
| 11        | Programmer I/O4        | I/O                             | JTAG – TMS                            | JTAG – Test Mode Select  |
| 12        | Programmer I/O3        | I/O                             | JTAG - TCK                            | JTAG – Clock             |
| 13        | Programmer I/O2        | I/O                             | JTAG - TDO                            | JTAG – Data Out          |
| 14        | Programmer I/O1        | I/O                             | JTAG - TDI                            | JTAG – Data In           |
| 16        | PROG_RESET             | 0                               | RESET                                 | Target RESET control pin |



## 2.11 ISPnano - CONMOD Module - JTAG connections

This section describes how to use the '**ISPnano CONMOD Module**' to connect an ISPnano programmer to an '**Atmel AVR microcontroller**' using the 4-wire JTAG interface. The programmer connects to the 16-way IDC port labelled (3) and the '**Atmel AVR microcontroller**' connects to the 10-way IDC connector labelled (1) in the picture below.



#### Please note:

- The 'Atmel JTAG' 10-way IDC connector marked (1) in the above picture has the same pinout as the standard 'JTAG' found on the Atmel JTAG-ICE MK1/MK2 debugger and also the STK500 / STK600 evaluation kits.
- All relevant connections for JTAG are already made on the CONMOD board so there is no need to add any other connections to get JTAG to work.

#### Instructions

- Referring to the annotated picture above
- Plug the 16-way IDC cable supplied with the programmer between the programmer '*Target ISP Port*' (16-way IDC connector) and the CONMOD Module 16-way header (J7) see arrow (3).
- The 'JTAG Port' is the 10-way IDC connector labelled 'Atmel JTAG' see arrow (1)
- Set up the '*Target Vcc Select*' jumper so that the programmer powers the Target Board see red box marked (2) in the picture.





## **3.0 Creating a JTAG Programming Project**

## 3.1 Overview

A Programming Project for an '*AVR JTAG Device*' can be created in exactly the same as you would for an '*SPI Device*' except that the device must now be selected from the JTAG Device Library. All the settings are the same except for the *<Pre-Programming State Machine>* and the *<JTAG Settings>*.

## 3.2 Information required to create a JTAG Project

The following information is required about the Target Board in order to create a JTAG Programming Project:

| #  | Information / data required                     | Example                                          |
|----|-------------------------------------------------|--------------------------------------------------|
| 1  | AVR Device part number                          | ATmega2561                                       |
| 2  | JTAG connections / connector on Target board    | Atmel 10-way IDC connector                       |
| 3  | JTAG configuration                              | i. Single JTAG device                            |
|    |                                                 | or                                               |
|    |                                                 | ii. JTAG device is part of a 'JTAG chain'        |
| 4  | JTAG chain configuration parameters             | <ul> <li>Devices before: 0</li> </ul>            |
|    |                                                 | <ul> <li>Devices after: 0</li> </ul>             |
|    | I hese parameters are required if the device to | Bits before: 0                                   |
|    | be programmed is part of a JIAG chain. If a     | Bits after: 0                                    |
|    | single device is to be programmed via JTAG,     |                                                  |
|    | then simply set all the "JIAG Chain"            |                                                  |
|    | parameters to 0.                                |                                                  |
| 5  | Target device oscillator frequency              | eg 12 MHz                                        |
| 6  | Target System Vcc voltage                       | eg 3.3V                                          |
| 7  | Target System maximum current consumption       | e.g. 100mA                                       |
| 8  | FLASH area 'Program File'                       | Binary (*.bin) or Intel Hex (*.hex)              |
| 9  | EEPROM area 'Data File'                         | Binary (*.bin) or Intel Hex (*.hex)              |
| 10 | Configuration Fuse values                       | i. Boolean fuse values:                          |
|    |                                                 | e.g. SPIEN=0, CKSEL=1, CKSEL2=0 etc              |
|    | These fuse values describe how the              |                                                  |
|    | 'Configuration Fuses' in the ATmega device are  | or                                               |
|    | to be programmed.                               | ii. Fuse Hex values from 'AVR Studio'            |
|    |                                                 | e.g. 0x22 0x45 0x34                              |
| 11 | Reset circuit parameters                        | e.g.                                             |
|    |                                                 | <ul> <li>Capacitor / Resistor circuit</li> </ul> |
|    |                                                 | <ul> <li>Watchdog supervisor circuit</li> </ul>  |
|    |                                                 | <ul> <li>Voltage monitoring circuit</li> </ul>   |



## 3.3 Creating an EDS (Development project)

The simplest way to create a Programming Project for a JTAG device is to use the EDS (Development Mode) Wizard as follows:

### 3.3.1 Launching EDS and selecting a Target Device

- Launch EQTools
- Select < Create a new Development (EDS) Project> → the EDS (Development) Wizard will launch
- Click <Next> → the <Select Target Device> screen will be displayed.

| Select Target Device                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Search for Device<br>ATmega256<br>Atmel<br>Atmel<br>ATMega (JTAG)<br>ATmega2560 (JTAG)<br>ATmega2560 (JTAG)<br>ATmega2560V (JTAG)<br>ATmega2561V (JTAG)<br>ATmega2561V (JTAG)<br>ATmega2561V (JTAG)<br>ATmega2560-16<br>ATmega2560V-8<br>ATmega2561V-8 | Micro Details Notes<br>Manufacturer:<br>Atmel<br>Family:<br>ATMega (JTAG)<br>Device Code:<br>ATmega2560 (JTAG)<br>Flash Size:<br>262144 (0x40000)<br>EEPROM Size:<br>4096 (0x1000)<br>Signature:<br>0x1E 9801<br>Version:<br>1.05R |
| Library: ATmega.LIB Description: ATmega(AVR) Libra                                                                                                                                                                                                     | ry (SPI/JTAG) Version: 1.65R<br>OK Cancel                                                                                                                                                                                          |

- Type in the 'Device Part Number' eg. ATmega2560 into the 'Search for Device' field
   → a list of all matching devices will be displayed in the box underneath.
- Select the required device from the list and then click <OK>
   → the device is now selected.
- On the next screen, check that the device selection and all other device parameters are correct
- The project is set to automatically read and validate the '*JTAG ID*' of the Target Device by default. The 'JTAG Revision' is not validated if the first digit of the 'JTAG ID' is '0'.

| 🗹 Check Signature | 🗹 Read JTAG ID: |
|-------------------|-----------------|
| 0x1E9801          | 0x0980103F      |

• If you do not want to validate the 'JTAG ID', untick the 'Read JTAG ID' tick box.



• Click <Next> to advance to the next screen

### 3.3.2 Target Oscillator Settings

This screen allows you to set up the 'Target Oscillator frequency'.

The '*Target Oscillator frequency*' is the frequency which the Target Device is being clocked at during the In-System Programming Process.

| External Oscillator Frequency<br>1.00 MHz<br>Dscillator Frequency:<br>Min<br>0.0 Hz<br>Max<br>8.0 Hz | Internal Oscillator Frequency 1.000000 MHz Write Calibration Byte to: Flash Eeprom Address 0: Address 1: Ox3FFFE Ox3FFFE Ox3FFFF | OP4 Clock Frequency     1.8432 MHz     ✓     To enable OP4 Clock, select     'SCK2_IN' followed by 'SCK2_EN'     in Pre-Program State Machine     Set Defa |
|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ies:                                                                                                 |                                                                                                                                  | Set                                                                                                                                                        |

#### **INTERNAL RC Oscillator**

- Many Atmel AVR devices feature both an '*INTERNAL RC*' on-chip oscillator and also the ability to run from an *EXTERNAL* crystal or Ceramic Resonator.
- When a virgin device from Atmel is programmed for the first time, it will usually be running from an *INTERNAL* Oscillator.
- The frequency of the oscillator is usually set at the factory to be approximately 1MHz.
- This *INTERNAL* Oscillator is '*factory calibrated*' by Atmel see section 3.13 for further details on how to use the factory calibrated OSCAL value.
- If the Target Device is running from an *INTERNAL* oscillator e.g. 1MHz internal, select *'Internal Oscillator'* and select the internal oscillator frequency from the drop-down list.

#### **EXTERNAL Oscillator:**

- If the Target Device is running from an *EXTERNAL* oscillator e.g. crystal or ceramic resonator, select '*External Oscillator*' and enter the oscillator frequency. This frequency should be written on the oscillator component itself or on the circuit schematic.
- The '*Programmer OP4 Clock*' can be used to clock a device which has no oscillator. This is not required for JTAG programming.



#### Please note:

The Target Oscillator speed is not technically required for JTAG programming as the programmer provides the clock during programming. If you do not know the *Oscillator Frequency*, simply leave all settings as the default values.

### 3.3.3 Target System – Power Supply Settings

This screen allows you to set up the Power Supply characteristics of your Target System.

| Target System Power Supp<br>Select Target System Voltage and C | Dily Settings<br>Current Consumption                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Target Voltage Settings                                        | Programmer Controlled Power Supply                                                                                                                                                                                                                                                                                                                                                  |
| Voltage<br>5.0                                                 | Programmer controlled Target Power Supply: ON       ►         Maximum Current (mA)       Powerdown Time (ms)         200 ◆       1000 ◆         Current Settle Time (ms)       PSU Qut OK Delay (ms)         100 ◆       500 ◆         Voltage Settle Time (ms)       100 ◆         100 ◆       500 ◆         Power Status at end of project:       Power Status at end of project: |

#### i. Select the Target Voltage

- This should be the voltage at which the Target System is being powered during the programming operation.
- Set the '*Voltage Tolerance*' to be as wide as possible e.g. 500mV to allow for power supply variations. If the programmer is powering the Target System, this will also give a faster power-up time.
- It may be possible to power just the Target Microcontroller rather than the entire Target System.

#### ii. Set up the Target Powering and current parameters

- This option is only available for the PPM3-MK2 programmer.
- If the programmer is to power the Target System, select < Programmer controlled Target Power Supply: ON>
- Set the '*Maximum Current*' to the maximum possible current which the Target System could draw from the programmer.
- Leave all other settings as default.



## 3.3.4 Specifying the FLASH (Code) File

This screen allows you to specify the Code (firmware) file which is to be programmed into the FLASH area of the Target Device. This is an optional step – you can also specify the file once you are in the Development Suite (EDS).

| 🔛 Equinox Development Suite(EDS) Wizard Untitled                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FLASH Area Programming Options         Select the required programming options for the FLASH memory area                                                                                                                                                                                                                                                                              |
| Blank Check Flash V Entire Device                                                                                                                                                                                                                                                                                                                                                     |
| Operation: O None O Program/Verify O Verify Only<br>Flash File Timings                                                                                                                                                                                                                                                                                                                |
| Elash File:       C:\temp\JTAG_Testing\FLASH.hex       Browse       6d <sup>1</sup> Status:       Loaded OK       Type:       Intel Hex (Generic)         Min Add.       0x0000       Max Add.       0x3FFF       Bytes:       16384 (0x4000)       CRC       0x6205         Buffer:       ✓       Discard leading 0xFF       ✓       Discard trailing 0xFF       0.0000       0.0000 |
| Notes:                                                                                                                                                                                                                                                                                                                                                                                |
| <pre></pre>                                                                                                                                                                                                                                                                                                                                                                           |

#### i. Blank Check the FLASH

- If the chip has been erased at the start of the programming cycle, then the FLASH should already be blank (i.e. all locations contain the value 0xFF).
- If you want to be absolutely sure the FLASH is blank, you can enable the 'Blank Check Flash' option. This will perform a full Blank Check of the FLASH area to check that all locations are set to 0xFF.
- Warning this check can be time-consuming and will increase the overall programming time!

#### ii. Selecting the FLASH File

- Click the <Browse> button
- Browse to and select the file you wish to load and then select <OK>
- If the input file is a BINARY file then the wizard will load the data in from file starting at address 0x0000 and continuing contiguously to the end of the file.
- If the input file is an INTEL HEX file then the wizard will load in from file from the start address specified in the file to end address specified in the file.



## 3.3.5 Specifying the EEPROM (Data) File

This screen allows you to specify the EEPROM (data) file which is to be programmed into the EEPROM area of the Target Device. This is an optional step – you can also specify the file once you are in the Development Suite (EDS).

| 🔛 Equinox D                 | evelopment Suite(EDS) Wizard Untitled                                                    |
|-----------------------------|------------------------------------------------------------------------------------------|
| EEPRON<br>Select th         | A Area Programming Options<br>te required programming options for the EEPROM memory area |
| 🔲 Blank Che                 | eck Eeprom 🛛 🔽 Entire Device                                                             |
| Operation: (<br>Eeprom File | None  Program./Verify Overify Only Timings                                               |
| <u>E</u> eprom File         | e: C:\temp\JTAG_Testing\EE.hex                                                           |
| Status:                     | Warning: File is too large for device Type: Intel Hex (Generic)                          |
| Min Add.                    | 0x0000 Max Add. 0x0FFF Bytes: 4096 (0x1000) CRC: 0x80DF                                  |
| Buffer:                     | Discard leading 0xFF     Discard trailing 0xFF                                           |
| Write:                      | Auto Range Custom: Write From 0x0000 Io 0x0FFF Bytes: 4096                               |
| Notes:                      |                                                                                          |
| <u>in</u> oles.             |                                                                                          |
|                             |                                                                                          |
|                             | <u>×</u>                                                                                 |
|                             |                                                                                          |
|                             | < Back Next > Close                                                                      |

#### i. Blank Check the EEPROM

- If the chip has been erased at the start of the programming cycle, then the EEPROM should already be blank (i.e. all locations contain the value 0xFF).
- However, if the Target Device has an 'EESAVE' fuse and this fuse is ENABLED (EESAVE=0), then the EEPROM will not be erased during the Chip Erase operation.
- If you want to be absolutely sure the EEPROM is blank, you can enable the 'Blank Check EEPROM' option. This will perform a full Blank Check of the EEPROM area to check that all locations are set to 0xFF.
- Warning this check can be time-consuming and will increase the overall programming time!

#### ii. Selecting the EEPROM File

- Click the *<Browse>* button
- Browse to and select the file you wish to load and then select <OK>
- If the input file is a BINARY file then the wizard will load the data in from file starting at address 0x0000 and continuing contiguously to the end of the file.
- If the input file is an INTEL HEX file then the wizard will load in from file from the start address specified in the file to end address specified in the file.
- In JTAG Mode, the granularity of the EEPROM Memory is either 4 or 8 bytes. This means that the programmer will always program in blocks of 4 or 8 bytes. Your input file will therefore be rounded up to the nearest block of 4 or 8 bytes.



## 3.3.6 Launching EDS at the end of the EDS Wizard

Once you reach the end of the EDS Wizard, click the <Test> button to launch the project in the Equinox Development Suite (EDS).

| Congratulations!         You have now created a Development (EDS) project. This can be fully tested under PC control with the EDS Development Environment. The Project can then be uploaded to a programmer and executed in 'Standalone Mode'. To test this project in Development Mode:         • Click the <test> button below         • Save your project with a suitable name eg. myproject.pm         • Your project will launch in the Equinox Development Suite (EDS).         • You can now interactively program the Target Chip under PC control.         Please note:         Your project will be saved in the EQTools installation directory by default.         Please select an alternative directory to save your projects when you save the EDS project.         To program:         • AASH area of the Target Chip, select the <flash> tab.         • Configuration Fuses of the Target Chip, select the <eeprom> tab.         • Security Fuses of the Target Chip, select the <security> tab.         • Security Fuses of the Target Chip, select the <security> tab.         • Dupload this project to a programmer.         • Once in EDS mode, test all aspects of the Programming Project.         • Select the <overview> tab         • Click the <add a="" collection="" new="" project="" to=""> button         • Use Project Manager to upload the Programming Project to the attached programmer.</add></overview></security></security></eeprom></flash></test> |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| < Back Next > Test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Enter a name for the EDS project e.g. ATmega256 and click the *<Test>* button

 $\rightarrow$  your project will now launch in EDS (Development) Mode.



## 3.4 Testing a JTAG Project in Development (EDS) Mode

If you have clicked the **<Test>** button at the end of the EDS Wizard, then an EDS (Development Mode) session will now launch.

| Sequinox Development Suite                                                        | (EDS) C:\temp\JTAG_Testing\ATmega2561V.EDS                                                                  |  |  |  |  |  |
|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Overview Programmer and Device 1                                                  | arget Oscillator JTAG Settings Target Power Supply Flash Eeprom Fuses Security                              |  |  |  |  |  |
| Project Information:                                                              |                                                                                                             |  |  |  |  |  |
| 🖆 Open / Modify Base Programming Project                                          |                                                                                                             |  |  |  |  |  |
| 🔛 Add Project file to a new Projec                                                | t Collection                                                                                                |  |  |  |  |  |
| Determine the project in an existing                                              | ng Project Collection                                                                                       |  |  |  |  |  |
| C:\temp\JTAG_Testing\ATmega25                                                     | 61V.PPM                                                                                                     |  |  |  |  |  |
| Project Name:                                                                     | Author:                                                                                                     |  |  |  |  |  |
| Project Version: <u>C</u> reation                                                 | Date                                                                                                        |  |  |  |  |  |
| 1.0.0.0 25/10/2                                                                   | 2007 💌                                                                                                      |  |  |  |  |  |
| Please note: To upload this p<br>an existing Project Collection<br>Main Settings: | roject to a programmer, please either add the project to<br>or create a ne <del>w</del> Project Collection. |  |  |  |  |  |
| Option:                                                                           | Value                                                                                                       |  |  |  |  |  |
| Target Device                                                                     | ATmega2561V (JTAG)                                                                                          |  |  |  |  |  |
| Programming Interface                                                             | JTAG (Atmel)                                                                                                |  |  |  |  |  |
| Target Voltage                                                                    | 5V +/- 500mV                                                                                                |  |  |  |  |  |
| Programmer Powers Target                                                          | Yes                                                                                                         |  |  |  |  |  |
| Pre-Programming State Machine                                                     | 8 - Atmel ATmega AVR Microcontroller - JTAG ISP                                                             |  |  |  |  |  |
| Flash file                                                                        | C:\temp\JTAG Testing\FLASH.hex                                                                              |  |  |  |  |  |
| Eeprom file                                                                       | Eeprom file C:\temp\JTAG_Testing\EE.hex                                                                     |  |  |  |  |  |
| JTAG Settings:                                                                    |                                                                                                             |  |  |  |  |  |
| Speed Setting:                                                                    | Speed Setting: SLOW                                                                                         |  |  |  |  |  |
| JTAG Frequency:                                                                   | 833 kHz                                                                                                     |  |  |  |  |  |
| <                                                                                 |                                                                                                             |  |  |  |  |  |

The following default settings will be used:

- **SLOW JTAG** speed at maximum SLOW frequency
- Single JTAG device (no JTAG Chain)
- Target System not powered by programmer (unless enabled during the EDS Wizard)
- The default JTAG pre-programming state machine will be used.
- The *Configuration Fuse Write* is disabled (can be enabled in EDS)
- The *Security Fuse Write* is disabled (can be enabled in EDS)

At this stage there are still a few parameters which may need to be set up / checked before the programmer will communicate with the Target Device on the Target Board.

Please follow the instructions in the next sections which explain how to set up the:

- JTAG Frequency
- JTAG chain settings



## 3.5 JTAG Frequency

The JTAG Frequency must be set up before any programming operation can take place.

To set up the JTAG Frequency, select the <JTAG Settings> tab.

| Overview Programmer                                                         | Target Device Target Oscillator                                                    | JTAG Settings                                                   | Target Power Supply | Flash | Eeprom | Fuses | Security |
|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------|---------------------|-------|--------|-------|----------|
| JTAG Frequency<br>Fast Frequency:<br>1,266 kHz                              | <ul> <li>Slow Frequency:</li> <li>833 kHz</li> </ul>                               | Maximum Sk<br>833 kHz                                           | ow Frequency        |       |        |       |          |
| JTAG Daisy Chain M<br>Target Device is<br>Devices Before:<br>Devices After: | Hode - supported by ATmega<br>part of a JTAG chain<br>Instruction bits before<br>0 | JTAG Misce<br>Read ID <u>O</u> P<br>0x0001<br>IR Length<br>0x04 | Ilaneous Settings   |       |        |       |          |

There are two choices of JTAG frequency setting:

#### i. Slow JTAG (default setting)

- Selecting the *SLOW JTAG* option allows you to specify a JTAG frequency from 30 kHz up the maximum SLOW JTAG frequency.
- This option should be used if there are reliability problems with JTAG programming using the '**FAST JTAG**' option. If the JTAG frequency is slowed down, the reliability of programming often increases.

#### ii. FAST JTAG

- This option is now available on most Equinox ISP programmers.
- If the programmer is a PPM3-MK2 or PPM4-MK1, then the programmer must be fitted with either the *EQ-SFM-MAX-V1.2* or *EQ-SFM-MAX-V1.3* Special Function Module.
- Selecting the '**FAST JTAG**' option selects a single high-speed JTAG frequency which is fixed for the selected programmer.
- This option should be tried to see if reliable programming of the Target System is possible. If programming proves to be unreliable, then try using the *'SLOW JTAG'* instead.



## 3.6 JTAG Device Chain settings

### 3.6.1 Overview

It is possible to set up a Programming Project so that the programmer is able to program an Atmel ATmega microcontroller when the device is part of a so-called '*JTAG Chain*'. This is where the Target AVR Device is connected on a shared JTAG Bus in a '*JTAG Chain*' configuration. The AVR microcontroller can be in any position in the '*JTAG Chain*' and the chain can also contain other JTAG devices which are not AVR microcontrollers. The data is shifted into the first device in the chain via the *TDI* pin and is then output on the *TDO* pin which connects to the *TDI* pin of the next device in the chain until it comes out of the *TDO* pin of the last device in the chain which connects back to the *TDO* pin of the programmer.





## 3.6.2 JTAG Chain settings

To set up the position of the Target AVR Device in a JTAG Chain, select the **<JTAG Settings>** tab.

| JTAG Daisy Chain M                    | ode - supported by ATmega2561V (JTAG) |  |  |
|---------------------------------------|---------------------------------------|--|--|
| Target Device is                      | part of a JTAG chain                  |  |  |
| Devices Before:                       | Instruction bits before               |  |  |
| Devices After: Instruction bits after |                                       |  |  |
|                                       |                                       |  |  |

#### i. Single JTAG Device

If the programmer is only connected to ONE JTAG device, then you can leave all the settings as their default value of '0'. This means the Target Device is the first and only device in the JTAG Chain.

#### ii. Device is part of a JTAG Chain

If the Target Device to be programmed is connected so it is part of a JTAG chain, then it is necessary to specify the number of '*JTAG devices*' and '*Instruction Bits*' both BEFORE and AFTER the Target Device in the Chain – see example JTAG Chain below.

#### 3.6.3 JTAG Chain – Devices BEFORE / AFTER parameters

In order to program the Target JTAG Device, the programmer needs to know the physical position of the Target Device in the JTAG Chain.

- In the *'Devices BEFORE'* field, enter the number of JTAG devices **BEFORE** the Target Device in the JTAG Chain. If the Target device is the first device in the chain, enter '0'.
- In the 'Devices AFTER' field, enter the number of JTAG devices AFTER the Target Device in the JTAG Chain. If the Target device is the last device in the chain, enter '0'.

#### Example:

If you are trying to program '*JTAG Device 2*' in the JTAG Chain of 3 devices, then there is 1 device before and 1 device after the Target Device.



## 3.6.4 JTAG Chain – Instruction Bits BEFORE / AFTER parameters

In order to program the Target Device, the programmer needs to know the total number of JTAG *'Instruction Register'* bits contained in the JTAG devices BEFORE and AFTER the Target Device. The programmer then pads all outgoing bit streams with the relevant numbers of dummy bits so only the Target Device is actually accessed / programmed.

- You can find *the 'JTAG Instruction Register'* width (number of bits) in the manufacturer's datasheet for each JTAG device you are looking to program in the chain.
- All Atmel ATmega AVR microcontrollers have a 'JTAG Instruction Register' width of 4 bits.
- All Atmel ATFxxxx CPLD's have an instruction width of 8 bits.

### 3.6.5 Calculating the 'Bits Before' value

To calculate the 'Bits Before' value:

- Find out the '*JTAG Instruction Register*' width (number of bits) in the manufacturers datasheet for each JTAG device you are looking to program in the chain.
- Add together all the '*JTAG Instruction Register*' widths for JTAG devices BEFORE the Target Device
- Enter this value in the 'Bits BEFORE' field

#### Example:

- In our example JTAG Chain with 3 AVR devices, each AVR device will have a '*JTAG Instruction Register*' width of 4 bits.
- If you are trying to program 'JTAG Device 2' in the JTAG Chain of 3 devices, then there is 1 AVR device before Device 2 so the 'Bits BEFORE' field should be set to 4.

### 3.6.6 Calculating the 'Bits After' value

To calculate the 'Bits After' value:

- Find out the '*JTAG Instruction Register*' width (number of bits) in the manufacturers datasheet for each JTAG device you are looking to program in the chain.
- Add together all the 'JTAG Instruction Register' widths for JTAG devices **AFTER** the Target Device
- Enter this value in the 'Bits AFTER' field

#### Example:

- In our example JTAG Chain with 3 AVR devices, each AVR device will have a 'JTAG Instruction Register' width of 4 bits.
- If you are trying to program '*JTAG Device 2*' in the JTAG Chain of 3 devices, then there is 1 AVR device after Device 2 so the '*Bits After*' field should be set to 4.



## 3.6.7 Summary of the JTAG Chain settings

Here are the settings to program 'Device 2' in the 3 device JTAG chain:

| -JTAG Daisy Chain M | lode - supported by ATmega2561V (JTAG) |
|---------------------|----------------------------------------|
| Target Device is    | part of a JTAG chain                   |
| Devices Before:     | Instruction bits before                |
| Devices After:      | Instruction bits after                 |

- There is one AVR device BEFORE 'Device 2' and one AFTER it.
- Every AVR device has an 'JTAG Instruction Register width' of 4 bits, so there are '4 bits before' and '4 bits after' the target device 'Device 2'.





## 3.7 Testing JTAG communication with the Target Chip

To make sure that the programmer can communicate to the Target JTAG device, try reading back the Device Signature as follows:

- Select the <FLASH> tab
- Locate the <**Check Sig>** button on the right-hand side of the screen and click it.
- $\rightarrow$  The programmer will now try to communicate with the Target Chip via the JTAG Interface
- → If the Target Chip responds correctly, then EDS will report 'Signature Read: Pass'.

| Information |                                                                         |  |
|-------------|-------------------------------------------------------------------------|--|
| ¢           | Operation: Signature Check<br>Result: PASS<br>Signature Read = 0x1E9802 |  |
|             | ок                                                                      |  |

 $\rightarrow$  If the Target Chip does not respond, then EDS will report either:

#### i. Cannot enter programming mode

If you receive this error, please check the following:

- The JTAG connections between the programmer and the Target System are correct.
- There is definitely power applied to the Target System and to all the JTAG devices if the Target Device is part of a JTAG chain.
- The 'JTAG Chain' settings are correct for the Target Device being programmed.
- Try slowing down the 'JTAG Frequency' and then try to check the Device Signature again.

#### ii. 'Signature Read: Fail'.



If you receive this error, please check the following:

- Make sure there are no series resistors in-line with any of the JTAG signal lines
- Make sure there are no capacitors on any of the JTAG signal lines
- Make sure the total length of the JTAG ISP cabling is no more than 200 cm
- The 'JTAG Chain' settings are correct for the Target Device being programmed.
- Try slowing down the 'JTAG Frequency' and then try to check the Device Signature again.
- If the Signature looks like a valid signature, make sure that you have selected the correct JTAG Device in the chain. It is possible that the programmer is actually communicating with a different device by mistake and hence reading the wrong signature.



## 3.8 Programming the FLASH Area

These instructions describe how to program the contents of a file into the FLASH area of the Target Device:

- Select the <FLASH> tab
- If you have not already selected a data file to program, click the 'Edit buffer' check box and then click the **<Load>** button to select a suitable Binary of Intel Hex file.
- The contents of the specified file should now be displayed in the Buffer Window.
- Click the **<Write>** button

| Write Block to Flash          | $\overline{\mathbf{X}}$  |
|-------------------------------|--------------------------|
| 🗹 Electronic Chip Erase       |                          |
| 🕑 Use file start and end addr | esses                    |
| <u>S</u> tart Address         |                          |
| 0x000000                      | Entire Device            |
| <u>N</u> o of bytes           | Remove preceeding '0xFF' |
| 16384                         | Bemove trailing '0vFF'   |
| End Address                   |                          |
| 0x003FFF                      |                          |
|                               |                          |
|                               |                          |
|                               |                          |
| (                             | OK Cancel                |

- EDS will automatically perform a Chip Erase by default which will erase the entire FLASH before programming any data into it.
- Select the address range you wish to program.
- EDS will automatically use the '*Start*' and '*End*' address of the FLASH input file unless otherwise specified. This reduces the total data actually programmed to the number of bytes in the input file rounded to the end of the nearest FLASH Page.
- If you want to program the entire FLASH range, click the **<Entire Device>** button.
- Click **<OK>** to program the FLASH of the Target Chip.
- The programmer should now start to program the chip.
- The BUSY LED will illuminate on the programmer.
- The programmer will program the contents of the Buffer Window into the FLASH area of the Target Device.
- Each block of data is programmed and then verified so if a failure occurs it will be notified immediately.
- To verify that the data has been programmed correctly, click the **<Verify>** button.



## 3.9 Programming the EEPROM Area

These instructions describe how to program the contents of a file into the EEPROM area of the Target Device.

#### Important note:

In JTAG ISP mode, <u>an EEPROM location must contain 0xFF</u> before it can be programmed to any other value. This requires a '*Chip Erase*' operation to clear all locations to the value 0xFF.

#### To program the EEPROM area:

- Select the <EEPROM> tab
- If you have not already selected a data file to program, click the 'Edit buffer' check box and then click the **<Load>** button to select a suitable Binary of Intel Hex file.
- The contents of the specified file should now be displayed in the Buffer Window.
- Click the **<Write>** button

| Write Block to EEPROM         | $\mathbf{X}$             |
|-------------------------------|--------------------------|
| 🗹 Use file start and end addr | esses                    |
| <u>S</u> tart Address         |                          |
| 0x000000                      | Entire Device            |
| <u>N</u> o of bytes           | Remove preceeding '0xFF' |
| 512                           | Remove trailing '0xFF'   |
| End Address                   |                          |
| 0x0001FF                      |                          |
|                               |                          |
|                               |                          |
|                               |                          |
|                               |                          |
| (                             | OK Cancel                |

- Select the address range you wish to program
- EDS will automatically use the 'Start' and 'End' address of the EEPROM input file unless otherwise specified. This reduces the total data actually programmed to the number of bytes in the input file rounded to the end of the nearest EEPROM Page.
- If you want to program the entire EEPROM range, click the **<Entire Device>** button.
- The EEPROM address range which you are trying to program must contain 0xFF otherwise the programmer will be unable to program the bytes.
- Click **<OK>** to program the EEPROM of the Target Chip.
- The programmer should now start to program the chip.
- The BUSY LED will illuminate on the programmer.
- The programmer will program the contents of the Buffer Window into the EEPROM area of the Target Device.
- The EEPROM data is programmed in pages of either 4 or 8 bytes and then verified so if a failure occurs it will be notified immediately.

#### If EDS reports an 'EEPROM programming error', please check the following:

• Make sure that address range in the EEPROM which is being programmed contains the value 0xFF before the programming operation is started.



- This may require a Chip Erase operation to be performed because in JTAG Mode an EEPROM Page does NOT get automatically erased during a program operation.
- To Erase the EEPROM area to value 0xFF, you may need to set the 'EESAVE' fuse to a '1' and then perform a Chip Erase operation.

## 3.10 Erasing the FLASH / EEPROM area

It is possible to erase the FLASH and / or EEPROM area of a Target Device by clicking the *<Erase>* button. This will also erase the Security Lock Bits changing all the Lock Bit values from '0' to '1'. The Configuration Fuses are not affected by a Chip Erase operation.

## 3.10.1 Erasing the FLASH area

The only way to erase the FLASH area of the Target Device is to use the 'Chip Erase' command:

- Select the <FLASH> tab
- Click the <Erase> button
- This will send the 'Chip Erase' command to the Target Device.
- The Target Device will then erase the FLASH (and EEPROM as long as the EESAVE flag is not set to 0)
- To confirm that the FLASH / EEPROM is definitely blank, you can choose to perform a Blank Check operation.

## 3.10.2 Erasing the EEPROM area – special considerations

The only way to erase the EEPROM area of the Target Device in JTAG mode is to use the '*Chip Erase*' command:

- Select the <EEPROM> tab
- Click the <Erase> button
- This will send the 'Chip Erase' command to the Target Device.
- The Target Device will then automatically erase the FLASH followed by the EEPROM areas.
- The EEPROM area will only be erased if the EESAVE flag is set to '1'.
- To confirm that the FLASH / EEPROM is definitely blank, you can choose to perform a Blank Check operation.
- If the EEPROM is still not blank after the Erase Operation, check that the EESAVE fuse is definitely set to '1'.

#### Important note:

**In JTAG ISP mode only**, it is not possible for the programmer to write any bit of EEPROM from a '1' to a '0'. This means that each EEPROM location must contain 0xFF before it can be programmed to any other value. This requires a Chip Erase operation to clear all locations to the value 0xFF.



## **3.11 Programming the Configuration Fuses**

### 3.11.1 Overview

The Configuration Fuses of an Atmel AVR device can be programmed / read using the *<Fuses>* tab.

#### Instructions:

- Select the <Fuses> tab
- If this is a new EDS project, then the Fuses will be disabled.
- Check the 'Program Post-Erase Fuse Bits' box → the Fuses can now be programmed

| Overview                 | view Programmer and Device Target Oscillator JTAG Settings Target Power Supply Flash Eeprom Fuses Security |               |         |               |           |                   |                          |        | Security        |                 |
|--------------------------|------------------------------------------------------------------------------------------------------------|---------------|---------|---------------|-----------|-------------------|--------------------------|--------|-----------------|-----------------|
| PC Fuses:                |                                                                                                            |               |         |               |           |                   |                          |        |                 |                 |
| Fuse Programming Action: |                                                                                                            |               |         |               |           |                   |                          |        |                 |                 |
| Program                  | n/Verify                                                                                                   |               |         |               |           | ~                 |                          |        | <u><u> </u></u> | et Default      |
|                          |                                                                                                            |               |         |               |           |                   |                          |        | F               | dit Value       |
| Read                     | d from Fuse                                                                                                | file.         |         |               |           |                   |                          |        | <u></u>         |                 |
|                          |                                                                                                            |               |         |               |           | Bro               | owse                     |        |                 | Import          |
|                          |                                                                                                            |               |         |               |           |                   |                          |        | <u> </u>        | 2004-0000       |
| Fuses                    |                                                                                                            | PC Fuse State |         | Target Fuse 9 | State Des | cription          |                          |        |                 | Export          |
| CKS                      | ELO                                                                                                        | 0 - PROGRA    | MMED    | ?             | Clock     | k Select 0        |                          |        |                 |                 |
| CKS                      | EL1                                                                                                        | 1 - UNPROG    | RAMMED  | ?             | Clock     | k Select 1        |                          |        | Target          | Fuses:          |
| CKS                      | EL2                                                                                                        | 0 - PROGRA    | MMED    | ?             | Clock     | k Select 2        |                          |        |                 | <b>n</b> 1      |
| CKS                      | EL3                                                                                                        | 0 - PROGRA    | MMED    | ?             | Clock     | k Select 3        |                          |        |                 | <u>H</u> ead    |
| SUT                      | 0                                                                                                          | 0 - PROGRA    | MMED    | ?             | Selec     | ct Oscillator Sta | rt Up Tim                | e0     | -               | Write           |
| SUT                      | 1                                                                                                          | 1 - UNPROG    | RAMMED  | ?             | Sele      | ct Oscillator Sta | rt Up Tim                | e1     |                 | wine            |
| СКО                      | UT                                                                                                         | 1 - UNPROG    | RAMMED  | ?             | Clock     | k Output Enable   | •                        |        |                 | Verifu          |
| CKD                      | IV8                                                                                                        | 0 - PROGRA    | MMED    | ?             | Divid     | le Clock by 8     |                          |        |                 | <u></u>         |
| BOO                      | TRST                                                                                                       | 1 - UNPROG    | RAMMED  | ?             | RES       | ET Vector         |                          |        |                 | << <u>C</u> opy |
| BOO                      | TSZ0                                                                                                       | 0 - PROGRA    | MMED    | ?             | Boot      | Size 0            |                          |        |                 |                 |
| BOO                      | ITSZ1                                                                                                      | 0 - PROGRA    | MMED    | ?             | Boot      | Size 1            |                          |        |                 |                 |
| EES.                     | AVE                                                                                                        | 1 - UNPROG    | RAMMED  | ?             | Prese     | erve EEPROM (     | during EF                | RASE - |                 |                 |
| WD                       | TON                                                                                                        | 1 - UNPROG    | RAMMED  | ?             | Wato      | chdog Timer alw   | vays ON                  |        |                 |                 |
| SPIE                     | N N                                                                                                        | U - PRUGRA    | MMED    | ?             | SPLE      | Programming EN    | ABLE (O                  | =ENAE  |                 |                 |
| JIAL                     | aEN<br>EN                                                                                                  | U - PRUGRA    | MMED    | <i>′</i>      | JIAU      | a Programming b   | ENABLE                   | (U=EN/ |                 |                 |
| UCD                      |                                                                                                            | 1 - UNPRUU    | HAMMED  | 2             | Un-U      | hip Debug (UCI    | UJ-ENAI<br>Tileni        | BLE    |                 |                 |
| BOD                      |                                                                                                            | 1 - UNPRUC    |         | 2             | BLOM      | n-out Detector    | i rigger Li<br>Trianna I | evel U |                 |                 |
| BOD                      |                                                                                                            | 1 - UNPRUC    |         | (<br>)        | D         | n-out Detector    | Trigger Li               | evel 0 |                 |                 |
| BOD                      | LEVEL2                                                                                                     | T - UNPRUG    | INAMMED | ſ             | RIOM      | n-out Detector    | i ligger L               | evel 2 |                 |                 |
|                          |                                                                                                            |               |         |               |           |                   |                          |        |                 |                 |
| <                        |                                                                                                            |               |         |               |           |                   |                          | >      |                 |                 |
| Fuse Va                  | alues: 0x62,1                                                                                              | 0x99,0x07     |         |               |           |                   |                          |        |                 |                 |

- The values of the Fuses which could be programmed into the Target Chip are shown in the 'PC Fuse State' column. The initial Fuse values are the default Fuse values for a virgin chip.
- The '*Target Fuse State*' column displays the current value of the Fuses of the actual Target Device. They are initially set to '?' until the first read or write operation is performed.
- The Fuse Hex values are shown for the 'PC Fuse State' at the bottom of the screen.
- A red 'x' next to a fuse indicates a 'Dangerous Fuse'. Programming one of these fuses incorrectly could result in the chip no longer responding to the programmer.



### 3.11.2 Reading the Fuses from a Target Device

To read the Fuse Values from a Target Device:

- Click the <Read> button
- The Hex values of the 'Fuse Bytes' which are read back are displayed as follows:

| Informa | ation 🛛 🔀                                                                   |
|---------|-----------------------------------------------------------------------------|
| (į)     | Operation: FUSE Read<br>Result: PASS<br>Fuses Values Read: 0xED, 0x98, 0xFD |
|         | ОК                                                                          |

• The Fuse values from the Target Device are now displayed in the 'Target Fuse State' column.



### 3.11.3 Verifying the Fuses of a Target Device

To verify the Fuse Values in a Target Device with the Fuse Values in the 'PC Fuse State' column:

- Click the **<Verify>** button
- Any differences in the Fuse Values between the PC settings and the Target Device setting will now be displayed.



### 3.11.4 Writing the Fuses into a Target Device

- To program the Fuses values in the 'PC Fuse State' column into the Target Device, click the <Write> button
- If there are any 'Dangerous Fuses' in the list, then the following warning will be displayed:

| Confirm | n 🛛 🔀                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ?       | The Fuse 'JTAGEN' is a dangerous fuse.<br>Setting this fuse to the wrong value could make the device so it cannot be programmed again in ISP mode.<br>Please double-check that the value of the fuse is correct before programming it.<br>To go ahead and skip all 'dangerous fuse' messages and program the fuses, press the [ALL] button.<br>Are you sure you want to program this fuse? |
|         | Yes No All                                                                                                                                                                                                                                                                                                                                                                                 |

- **!!! WARNING !!!** If you choose to program e.g. the **JTAGEN** Fuse to a **'1'** (*unprogrammed*), then the chip will no longer respond the JTAG ISP programming.
- Click <Yes> to allow programming of the selected Fuse
- Click <All> to skip all fuse warning messages and program all the fuses
- The programmer will now program all the fuses at the same time and then read them back and verify them with the values in the *'PC Fuse State'* column.
- The programmer will then report a PASS or FAIL for programming the Fuses.

| Inform | ation 🔀                                                                                                                         |
|--------|---------------------------------------------------------------------------------------------------------------------------------|
| (į)    | Operation: FUSE Write<br>Result: PASS<br>Fuse Bits have been programmed/verified OK<br>Fuses Values Read Back: 0x62, 0x99, 0xFF |
|        | ОК                                                                                                                              |

#### 3.11.5 Using a 'Fuse File' to import Fuse settings into a project

It is possible to export the '*Fuse Values*' for a particular device to a so-called '*Fuse File*' so that a single copy of the fuses is stored in one place. This '*Fuse File*' can then be shared amongst many projects if required. See section 4 for further details about using '*Fuse Files*'.



## 3.12 Programming the Security Fuses

### 3.12.1 Overview

The Security Fuses of an Atmel AVR device can be programmed / read using the **<Security Fuses>** tab.

#### Instructions:

- Select the <Security Fuses> tab
- If this is a new EDS project, then the Security Fuses will be disabled.
- Check the 'Program Device Security Fuses' box → the Security Fuses can now be programmed

| Overview Programmer and Device Target Oscillator JTAG Se | ttings Target Power Supply Flash Eeprom Fuses Security |  |  |  |  |  |
|----------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--|
| Program Device Security Fuses / Security Level           |                                                        |  |  |  |  |  |
| Fuse Programming Action:                                 | Set Default                                            |  |  |  |  |  |
| Program/Verify                                           | ✓                                                      |  |  |  |  |  |
| Read from Fuse file.                                     | <u>E</u> dit Value                                     |  |  |  |  |  |
|                                                          | Browse                                                 |  |  |  |  |  |
|                                                          |                                                        |  |  |  |  |  |
| Fuses PC Fuse State Target Fuse State                    | Description <u>Export</u>                              |  |  |  |  |  |
| LBT T - UNPROGRAMMED                                     | Lock Bit 1                                             |  |  |  |  |  |
| BLB01 1 - UNPROGRAMMED                                   | Boot Lock Bit 01                                       |  |  |  |  |  |
| BLB02 1 - UNPROGRAMMED                                   | Boot Lock Bit 02                                       |  |  |  |  |  |
| BLB11 1 - UNPROGRAMMED<br>BLB12 1 - UNPROGRAMMED         | Boot Lock Bit 11<br>Boot Lock Bit 12<br>₩ Write        |  |  |  |  |  |
|                                                          | verify                                                 |  |  |  |  |  |
|                                                          | 😵 Er <u>a</u> se                                       |  |  |  |  |  |
|                                                          | << <u>С</u> ору                                        |  |  |  |  |  |
|                                                          |                                                        |  |  |  |  |  |
|                                                          |                                                        |  |  |  |  |  |
|                                                          |                                                        |  |  |  |  |  |
|                                                          |                                                        |  |  |  |  |  |
| Fuse Values: 0x00                                        |                                                        |  |  |  |  |  |

- The values of the Security Fuse values which could be programmed into the Target Chip are shown in the '*PC Fuse State*' column. The initial Fuse values are the default Fuse values for a virgin chip which usually represents an 'unlocked' chip.
- The '*Target Fuse State*' column displays the current value of the Fuses of the actual Target Device. They are initially set to '?' until the first read or write operation is performed.
- The Fuse Hex values are shown for the 'PC Fuse State' at the bottom of the screen.



### 3.12.2 Reading the Security Fuses from a Target Device

To read the Security Fuse Values from a Target Device:

- Click the <**Read**> button
- The Hex values of the 'Fuse Bytes' which are read back are displayed as follows:



• The Security Fuse values from the Target Device are now displayed in the 'Target Fuse State' column.

| Overview Programmer and Device Target Oscillator JTAG Settings Target Power Supply Flash Eepror                                                                             | Fuses Security     |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|--|--|--|--|
| PC Fuses: PC Fuses:                                                                                                                                                         |                    |  |  |  |  |  |
| Fuse Programming Action:                                                                                                                                                    | Set Default        |  |  |  |  |  |
| Program/Verify                                                                                                                                                              |                    |  |  |  |  |  |
| Read from Fuse file.                                                                                                                                                        | <u>E</u> dit Value |  |  |  |  |  |
| Browse                                                                                                                                                                      | Import             |  |  |  |  |  |
| Fuses         PC Fuse State         Target Fuse State         Description                                                                                                   | Export             |  |  |  |  |  |
| LB1         1 - UNPROGRAMMED         1 - UNPROGRAMMED         Lock Bit 1           LB2         1 - UNPROGRAMMED         1 - UNPROGRAMMED         Lock Bit 2                 | Target Fuses:      |  |  |  |  |  |
| BLB01         1 - UNPROGRAMMED         1 - UNPROGRAMMED         Boot Lock Bit 01           BLB02         1 - UNPROGRAMMED         1 - UNPROGRAMMED         Boot Lock Bit 02 | 🏼 🖗 <u>R</u> ead   |  |  |  |  |  |
| BLB11         1 - UNPROGRAMMED         1 - UNPROGRAMMED         Boot Lock Bit 11           BLB12         1 - UNPROGRAMMED         1 - UNPROGRAMMED         Boot Lock Bit 12 | 🔖 🔟rite            |  |  |  |  |  |
|                                                                                                                                                                             | 💸 Verify           |  |  |  |  |  |
|                                                                                                                                                                             | 🎽 Er <u>a</u> se   |  |  |  |  |  |
|                                                                                                                                                                             | << <u>С</u> ору    |  |  |  |  |  |
|                                                                                                                                                                             |                    |  |  |  |  |  |
|                                                                                                                                                                             |                    |  |  |  |  |  |
|                                                                                                                                                                             |                    |  |  |  |  |  |
| Fuse Values: 0x3F                                                                                                                                                           |                    |  |  |  |  |  |

#### 3.12.3 Verifying the Fuses of a Target Device

To verify the Security Fuse Values in a Target Device with the Fuse Values in the 'PC Fuse State' column:

- Click the <Verify> button
- Any differences in the Fuse Values between the PC settings and the Target Device setting will now be displayed.



## 3.12.4 Writing the Security Fuses into a Target Device

- To stop anyone from reading / copying the contents of an AVR device, it is usual practice to 'Lock' the device at the end of the programming sequence.
- To lock the FLASH and EEPROM from being read back, set the 'LB1' and 'LB2' Lock Bits to '0'.
- To program the Fuses values in the 'PC Fuse State' column into the Target Device, click the <**Write>** button

| Fuses | PC Fuse State    | Target Fuse State | Description      |
|-------|------------------|-------------------|------------------|
| LB1   | 0 - PROGRAMMED   | ?                 | Lock Bit 1       |
| LB2   | 0 - PROGRAMMED   | ?                 | Lock Bit 2       |
| BLB01 | 1 - UNPROGRAMMED | ?                 | Boot Lock Bit 01 |
| BLB02 | 1 - UNPROGRAMMED | ?                 | Boot Lock Bit 02 |
| BLB11 | 1 - UNPROGRAMMED | ?                 | Boot Lock Bit 11 |
| BLB12 | 1 - UNPROGRAMMED | ?                 | Boot Lock Bit 12 |

- The programmer will now program all the Security Fuses at the same time and then read them back and verify them with the values in the 'PC Fuse State' column.
- The programmer will then report a PASS or FAIL for programming of the Security Fuses.
- The Target Device is now locked

#### Please note:

- Once the Lock Bits have been programmed on an AVR Device, it is then no longer possible to read or re-program the FLASH or EEPROM memory areas.
- The Configuration Fuses and Security Fuses can usually still be read from a Target Device even if the device is locked.

### 3.12.5 Erasing the Security Fuses

The only way to change a Security Fuse from a '0' to a '1' is to perform a '**Chip Erase**' operation. This will erase the FLASH / EEPROM and then finally erase the Security Fuses and set them back to a value of '1'.



## 3.13 Internal Oscillator Calibration – Factory OSCAL Byte

### 3.13.1 Overview

Every Atmel AVR microcontroller features an 'Internal RC Oscillator' which provides a clock source for the device when no external clock is present. This oscillator has been 'factory calibrated' by Atmel and the so-called 'OSCAL Factory Calibration Byte' can be found in the 'Signature Row' of the AVR device. With older AVR devices, the external programmer must read this OSCAL byte from the 'Signature Row' and then write it into either the FLASH or EEPROM of the target device. It is then the responsibility of the customer's firmware application to transfer the byte from FLASH / EEPROM into the AVR OSCAL register when the firmware runs. This forces the 'Internal RC Oscillator' to run at the factory calibrated frequency.

### 3.13.2 Reading / writing the Oscillator Calibration Byte in EDS mode

It is possible to read back the value of the 'OSCAL Factory Calibration Byte' for each of the available internal oscillators using EDS – Development Mode.

#### Instructions:

- Launch your project in EDS
- Select the <Target Oscillator> tab
- Click the 'Internal RC Oscillator' radio button see screenshot below

| Overview Programmer Target Device                                                                                             | Target Oscillator JTAG Settings                                                                                                                                                                                                                                 | Target Power Supply Flash Eeprom Fuse                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External Oscillator<br>External Oscillator Frequency<br>1.00 MHz<br>Oscillator Frequency:<br>Min<br>0.0 Hz<br>Max<br>16.0 MHz | <ul> <li>● Internal RC Oscillator<br/>Internal Oscillator Frequency</li> <li>1.000000 MH2</li> <li>✓ Write Calibration Byte to:</li> <li>● Flash ● Eeprom<br/>Address 0: Address 1:</li> <li>0x1FFFE</li> <li>0x1FFFF</li> <li>Read Calibration Byte</li> </ul> | Programmer OP4 Clock<br><u>OP4 Clock Frequency</u><br>1.8432 MHz<br>To enable OP4 Clock, select<br>'SCK2_IN' followed by 'SCK2_EN'<br>in Pre-Program State Machine |

- To read the 'OSCAL Factory Calibration Byte' for the selected 'Internal Oscillator', click the <Read Calibration Byte> button.
- → The 'OSCAL Factory Calibration Byte' is displayed.

| Inform | ation                                                                |                    |
|--------|----------------------------------------------------------------------|--------------------|
| ٩      | Operation: Read Oscillator Calibration<br>Result: PASS<br>Read: 0x59 | Diagnostic Info >> |
|        | ОК                                                                   |                    |





- To set the project up to program the 'OSCAL Factory Calibration Byte' into the FLASH or EEPROM
- Tick the 'Write Calibration Byte to:'

| Vrite Calibration Byte to: |            |  |  |  |
|----------------------------|------------|--|--|--|
| 💿 Flash                    | O Eeprom   |  |  |  |
| Address 0:                 | Address 1: |  |  |  |
| 0x1FFFE                    | 0x1FFFF    |  |  |  |
| Read Calibration Byte      |            |  |  |  |

- Select the FLASH or EEPROM area as required
- Enter the address to program the byte into
- When programming the byte into FLASH, the programmer will actually program the byte twice into a WORD.
- Click the <Read Calibration Byte> button.
- → The read 'OSCAL Factory Calibration Byte' is displayed.

| Inform | ation                                                                                                                                                                 |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ¢,     | Operation: Read Oscillator Calibration<br>Result: PASS<br>Read: 0x59<br>Would you like to write this Calibration byte back to Flash location 0x1FFFE and 0x1FFFF now? |
|        | Yes No                                                                                                                                                                |

• You can now choose <**Yes**> to program the 'OSCAL Factory Calibration Byte' back into the specified address in FLASH or EEPROM.



- Click <OK>
- The 'OSCAL Factory Calibration Byte' is now programmed into addresses 0x1FFFE and 0x1FFFF of the FLASH area.
- This can be confirmed by reading back the FLASH area and it shows the two copies of the byte in the top two bytes.



## 3.13.3 Writing the Oscillator Calibration Byte in STANDALONE mode

It is possible to get the programmer to automatically read the '**OSCAL Factory Calibration Byte**' and program it into a specified location in FLASH or EEPROM using a Standalone Project. This is ideal for production environments where the programmer is used without a PC.

#### Instructions:

- Follow the instructions in the previous section to set up the address into which the 'OSCAL Factory Calibration Byte' is to be programmed.
- Make sure that your FLASH or EEPROM data files to not also write data to the same location where the '**OSCAL Factory Calibration Byte**' is to be programmed
- Compile the project and upload it to the programmer.
- When the project is executed, it will perform the other actions specified in the project and then automatically read the 'OSCAL Factory Calibration Byte' and write it into the specified address in FLASH or EEPROM.

## 3.14 Exporting an EDS Project to a Standalone Project

Once you have fully tested your EDS Development Project, it is possible to add the project to a *Project Collection* and then upload it to a programmer as a so-called *'Standalone Project'*. The project can then be executed on a programmer without requiring any form of PC control.

Please follow the instructions detailed in Section 6 to upload your EDS project to a programmer.



# 4.0 Exporting / Importing Fuse Settings to / from an Equinox Fuse File

## 4.1 Overview

One of the new powerful features of EQTools is the ability to export the '*Fuse Settings*' for a Programming Project to a *Fuse File (\*.eff)*. This allows the settings for all the fuses to be contained in one Fuse File which can then be imported into any of the Fuse tabs in Project Manager or in the *<Fuses>* tab in EDS. In this way, the values of all the Fuses for a particular project can be shared with other projects. This helps to ensure that the correct fuse values are specified in all projects.

## 4.2 Exporting the Fuse Settings to a Fuse File

To export the settings of the 'Local Fuses' column to a fuse File:

- Select the EDS <Fuses> Tab
- Set up the 'Local Fuses' to the correct values for your Target Device.
- Click the *<Export>* button  $\rightarrow$  a file browser is displayed.
- Enter a suitable name for your Fuse File eg. project\_fuses.eff
- Click <Save> → The 'Local Fuses' column is transferred to your specified Fuse File (\*.eff).

## 4.3 Copying the Fuses from a Target Device

To copy the Fuses from the Target Device to a Fuse File:

- Select the EDS *<Fuses>* Tab
- Click the <Read> button

→ the Fuses are read from the Target Device and are then displayed in the 'Target State' column.

- Click the *<<Copy* button
   → the Fuse settings read from the Target Device are copied into the *'Local State'* fuse column.
- Click the *<Export>* button  $\rightarrow$  a file browser is displayed.
- Enter a suitable name for your Fuse File eg. project\_fuses.eff
- Click <Save> → The 'Local Fuses' column is transferred to your specified Fuse File (\*.eff).

## 4.4 Importing the Fuse Settings from a Fuse File

To import the settings of the 'Local Fuses' column from a Fuse File:

- Select the EDS <**Fuses**> Tab
- Click the *<Import>* button  $\rightarrow$  a file browser appears
- Browse to and select your *Fuse File (\*.eff)* 
  - → The Fuse settings are then automatically copied from the *Fuse File* to the '*Local Fuses*' column.
- To program these settings into a Target Device, click < Write>.





## **5.0 Importing Fuse Settings in HEX format from AVR Studio**

## 5.1 Overview

If the original firmware for your project has been developed using the Atmel 'AVR Studio' software, then it is likely that both the AVR 'Configuration Fuse settings' and the 'Security Fuse Settings' are defined as so-called 'Hex Fuse Bytes'. This is the raw version of the fuses where each 'Hex Fuse Byte' can represent up to 8 individual 'Boolean Fuses'. It is possible to import the 'Hex Fuse Bytes' from AVR Studio into an EQTools project by following the instructions in the next section.

## 5.2 Finding the AVR Studio 'Hex Fuse Values'

In the Atmel 'AVR Studio' software, the '*Configuration Fuse settings*' for your project are displayed on the *<Fuses>* tab – see screenshot below.

| TAGICE mkll in .                                                                                                         | JTAG mode with ATmega169                                                       |
|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| Main Program                                                                                                             | Fuses LockBits Advanced HW Settings HW Info Auto                               |
| BODLEVEL                                                                                                                 | Brown-out Detection Disabled 🔹 💌                                               |
| RSTDISBL                                                                                                                 |                                                                                |
| OCDEN                                                                                                                    |                                                                                |
| JTAGEN                                                                                                                   |                                                                                |
| SPIEN                                                                                                                    |                                                                                |
| WDTON                                                                                                                    | ✓                                                                              |
| EESAVE                                                                                                                   |                                                                                |
| BOOTSZ                                                                                                                   | Boot Flash size=1024 words start address=\$1C00                                |
| BOOTRST                                                                                                                  |                                                                                |
| CKDIV8                                                                                                                   | ✓                                                                              |
| CKOUT                                                                                                                    |                                                                                |
| SUT_CKSEL                                                                                                                | Int. RC Osc.; Start-up time: 6 CK + 0 ms                                       |
| EXTENDED                                                                                                                 | 0xFF                                                                           |
| HIGH                                                                                                                     | 0x49                                                                           |
| LOW                                                                                                                      | 0x42                                                                           |
| Auto read                                                                                                                |                                                                                |
| Smart warnings                                                                                                           |                                                                                |
| Verify after pro                                                                                                         | gramming Program Verify Read                                                   |
| Entering programming<br>Writing fuses (low to<br>Reading fuses (low to<br>Fuse bits verification,<br>Leaving programming | g mode OKI<br>high) 0x42, 0xA9, 0xFF OKI<br>5 high) 0x42, 0xA9, 0xFF OKI<br>OK |

The '*AVR Studio*' software displays a high-level overview of the fuses, grouping similar fuses together with more meaningful group names eg. '*BODELEVEL*' is made up of two fuses: BODLEVEL0 and BODLEV1 and the fuse '*SUT\_CKSEL*' actually represents the following six Boolean fuses: SUT0, SUT1, CKSEL0, CKSEL1, CKSEL2, CKSEL3.



These Fuse values are then converted by AVR Studio into '*Hex Fuse Bytes*'. For AVR microcontrollers, the '*Hex Fuse Bytes*' are called '*LOW*', '*HIGH*' and '*EXTENDED*' – see screenshot from AVR Studio above.

In this example, the '*Hex Fuse Bytes*' are as follows: EXTENDED: 0xFF HIGH: 0xA9

## LOW: 0x42

## 5.3 Importing the AVR Studio 'Hex Fuse Values' into EQTools

It is possible to import the AVR *'Hex Fuse Bytes'* from AVR Studio into EQTools. This functionality requires that EQTools build 927 or above is installed.

#### Instructions:

#### 1. Launch your project in EDS (Development Mode)

 $\rightarrow$  Launch your project in EDS (Development Mode) and then select the *<Fuses>* tab.

| Overview | Programmer                     | Target Device | Target Oscillator | SPI Settings | Target Power Supply | Flash                                 | Eeprom    | Fuses | Security |                     |
|----------|--------------------------------|---------------|-------------------|--------------|---------------------|---------------------------------------|-----------|-------|----------|---------------------|
| 🔽 Prog   | ✓ Program Post-Erase Fuse Bits |               |                   |              |                     |                                       | PC Fuses: |       |          |                     |
| Fuse P   | Euse Programming Action:       |               |                   |              |                     | · · · · · · · · · · · · · · · · · · · |           |       |          |                     |
| Progra   | am/Verify> Bf                  | ESET          |                   |              | *                   |                                       |           |       |          | <u>S</u> et Default |
|          |                                |               |                   |              |                     |                                       |           |       |          | <b>E 1 1</b>        |
| 📃 Rea    | ad from Fuse file              | э.            |                   |              |                     |                                       |           |       |          | Enter Hex           |
|          |                                |               |                   |              | Brows               | se                                    |           |       |          | Import              |
|          |                                |               |                   |              |                     |                                       |           |       |          |                     |
| Fuses    | F                              | PC Fuse State | Target f          | Fuse State   | Description         |                                       |           |       |          | Export              |
| 🛛 🥴 CKS  | GELO O                         | - PROGRAMM    | ED ?              |              | Clock Select 0      |                                       |           |       |          |                     |
| 🔜 🕴 CKS  | GEL1 1                         | - UNPROGRAM   | MMED ?            |              | Clock Select 1      |                                       |           |       |          | arget Fuses:        |
| 🔜 🕴 CKS  | GEL2 0                         | - PROGRAMM    | ED ?              |              | Clock Select 2      |                                       |           |       |          |                     |
| 🔜 🥴 CKS  | GEL3 O                         | - PROGRAMM    | ED ?              |              | Clock Select 3      |                                       |           |       |          | Read                |
| SU       | TO <b>O</b>                    | - PROGRAMM    | ED ?              |              | Select Oscillator 9 | Start Up 1                            | Fime O    |       |          | Ma Aufrika          |
| SU       | T1 1                           | - UNPROGRAM   | MMED ?            |              | Select Oscillator S | Start Up 1                            | Fime 1    |       |          | A. Mure             |
| CKI      | DUT <b>1</b>                   | - UNPROGRAM   | MMED ?            |              | Clock Output        |                                       |           |       |          | 🏞 Verifu            |
| CKI      | DIV8 0                         | - PROGRAMM    | ED ?              |              | Divide Clock by 8   | 3                                     |           |       |          | A. Tourk            |
| BO       | OTRST 1                        | - UNPROGRAM   | MMED ?            |              | RESET Vector        |                                       |           |       |          | << Cody             |
| BO       | OTSZO O                        | - PROGRAMM    | ED ?              |              | Boot Size 0         |                                       |           |       |          |                     |
| BO       | OTSZ1 0                        | - PROGRAMM    | ED ?              |              | Boot Size 1         |                                       |           |       |          |                     |
| EES      | SAVE 1                         | - UNPROGRAM   | MMED ?            |              | Preserve EEPRO      | M during                              | ERASE -   | ENA   |          |                     |
| WD       | TON 1                          | - UNPROGRAM   | MMED ?            |              | Watchdog Timer      | <ul> <li>Always</li> </ul>            | ON        |       |          |                     |
| 🛛 🥴 SPI  | EN O                           | - PROGRAMM    | ED ?              |              | SPI Programming     | ENABLE                                |           |       |          |                     |
| 🔜 🕴 JTA  | AGEN 0                         | - PROGRAMM    | ED ?              |              | JTAG Port - ENA     | BLE                                   |           |       |          |                     |
| 00       | DEN 1                          | - UNPROGRAM   | MMED ?            |              | On-Chip Debug ((    | OCD) - El                             | VABLE     |       |          |                     |
| BO       | DLEVELO 1                      | - UNPROGRAM   | MMED ?            |              | Brown-out Detect    | tor Trigge                            | r Level 0 |       |          |                     |
| BO       | DLEVEL1 1                      | - UNPROGRAM   | MMED ?            |              | Brown-out Detect    | tor Trigge                            | r Level 1 |       |          |                     |
| BO       | DLEVEL2 1                      | - UNPROGRAM   | MMED ?            |              | Brown-out Detect    | tor Trigge                            | r Level 2 |       |          |                     |
| Local    | Juca Valuas: As                | 52 No99 NoEE  |                   |              |                     |                                       |           |       |          |                     |

- The default 'library' settings for the Fuses are displayed in the 'PC Fuse State' column. These fuse values represent a virgin AVR device which has never been programmed before.
- The 'Local Fuse Values' in Hex format are displayed at the bottom of the window. These values represent the current settings of the fuses in the 'PC Fuse State' column.
- The 'Local Fuse Values' are displayed in the following order: LOW, HIGH, EXTENDED



#### 2. Click the <Enter Hex> button

• The 'Enter Fuse Values' dialog box is displayed:

| Enter Fuse Values                                                           |  |  |  |
|-----------------------------------------------------------------------------|--|--|--|
| Enter the Hex value for each Fuse Byte                                      |  |  |  |
| Fuse Byte <u>L</u> OW:                                                      |  |  |  |
| 0x62                                                                        |  |  |  |
| Fuse Byte <u>H</u> IGH:                                                     |  |  |  |
| 0x99                                                                        |  |  |  |
| Fuse Byte <u>E</u> xtended:                                                 |  |  |  |
| 0xFF                                                                        |  |  |  |
|                                                                             |  |  |  |
| Click <ok> to convert these Fuse Hex values to<br/>Boolean Fuse Values</ok> |  |  |  |
| OK Cancel                                                                   |  |  |  |

- The Hex values displayed as default are the values corresponding to the default Fuse Settings already specified in EQTools.
- Enter the 'Hex Fuse Bytes' from AVR Studio in the relevant Fuse Value fields: LOW, HIGH, EXTENDED. These fields correspond to the same fuse field values in AVR Studio – see example below.

| From AVR                                                                                                                 | Studio – Fuses tab:                                                                   | Enter into EQTools – Enter Hex values                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Main Program                                                                                                             | Fuses LockBits Advanced HW Settings HW Info Auto                                      | Enter Fuse Values                                                                                                                                                                                         |
| BODLEVEL<br>RSTDISBL<br>OCDEN<br>JTAGEN<br>SPIEN<br>WDTON<br>EESAVE<br>BOOTSZ<br>BOOTRST<br>CKDIV8<br>CKOUT<br>SUT_CKSEL | Brown-out Detection Disabled    Brown-out Detection Disabled                          | Enter the Hex value for each Fuse Byte<br>Fuse Byte LOW:<br>0x42<br>Fuse Byte HIGH:<br>0xA9<br>Fuse Byte Extended:<br>0xFF<br>Click <ok> to convert these Fuse Hex values to<br/>Boolean Fuse Values</ok> |
| HIGH                                                                                                                     |                                                                                       | OK Cancel                                                                                                                                                                                                 |
| In this exam<br>follows:<br>EXTENDED<br>HIGH:<br>LOW:                                                                    | 0x42<br>nple, <i>'<b>Hex Fuse Bytes'</b></i> are as<br><b>D:</b> 0xFF<br>0xA9<br>0x42 | <ul> <li>Click the <i><ok></ok></i> button to accept the Fuse values</li> <li>EQTools will then convert these bytes into the Individual Boolean Fuse values.</li> </ul>                                   |





 $\rightarrow$  The Hex values which you entered are now converted to the corresponding individual Boolean fuses for each Fuse Byte.

| Fuses     | PC Fuse State    | Target Fuse State | Description                           |
|-----------|------------------|-------------------|---------------------------------------|
| CKSELO    | 0 - PROGRAMMED   |                   | Clock Select 0                        |
| CKSEL1    | 1 - UNPROGRAMMED |                   | Clock Select 1                        |
| CKSEL2    | 0 - PROGRAMMED   |                   | Clock Select 2                        |
| CKSEL3    | 0 - PROGRAMMED   |                   | Clock Select 3                        |
| SUTO      | 0 - PROGRAMMED   |                   | Select Oscillator Start Up Time 0     |
| SUT1      | 0 - PROGRAMMED   |                   | Select Oscillator Start Up Time 1     |
| CKOUT     | 1 - UNPROGRAMMED |                   | Clock Output                          |
| CKDIV8    | 0 - PROGRAMMED   |                   | Divide Clock by 8                     |
| BOOTRST   | 1 - UNPROGRAMMED |                   | RESET Vector                          |
| BOOTSZO   | 0 - PROGRAMMED   |                   | Boot Size 0                           |
| BOOTSZ1   | 0 - PROGRAMMED   |                   | Boot Size 1                           |
| EESAVE    | 1 - UNPROGRAMMED |                   | Preserve EEPROM during ERASE - ENABLE |
| WDTON     | 0 - PROGRAMMED   |                   | Watchdog Timer - Always ON            |
| 😣 SPIEN   | 1 - UNPROGRAMMED |                   | SPI Programming ENABLE                |
| 😣 JTAGEN  | 0 - PROGRAMMED   |                   | JTAG Port - ENABLE                    |
| OCDEN     | 1 - UNPROGRAMMED |                   | On-Chip Debug (OCD) - ENABLE          |
| BODLEVELO | 1 - UNPROGRAMMED |                   | Brown-out Detector Trigger Level 0    |
| BODLEVEL1 | 1 - UNPROGRAMMED |                   | Brown-out Detector Trigger Level 1    |
| BODLEVEL2 | 1 - UNPROGRAMMED |                   | Brown-out Detector Trigger Level 2    |

Local Fuse Values: 0x42,0xA9,0xFF

• The 'Local Fuse Values' represent the 'Hex Fuse Values' and they should have the same values as the Fuse Bytes specified in the 'AVR Studio' project.

#### 3. Export the 'PC State Fuses' to a Fuse File

It is possible to export these Fuse Settings to a 'Fuse File' as follows:

- Click the <**Export>** button
- Save the fuse settings with a suitable name e.g. ATmega169\_JTAG\_Fuses.eff

#### 4. Read the fuses from the Fuse file

- Once you have exported the Fuse Settings to a *Fuse File*, you can then include these Fuse Settings in any project.
- In EDS, on the <Fuses> tab, tick the '*Read from Fuse File*' check box and then browse to and select your Fuse File.

| Read from Fuse file.                          |        |
|-----------------------------------------------|--------|
| C:\temp\EDS_Documentation\ATmega169_Fuses.EFF | Browse |
|                                               |        |

- The project will then automatically use the Fuse Settings in the specified Fuse File.
- The *Fuse File* can also be used by any other project allowing the fuse values to be shared between many projects if required.



# 5.4 Importing the AVR Studio 'Hex Security Fuse Values' into EQTools

In AVR Studio, the 'Security Fuse settings' for your project are displayed on the <Lock Bits> tab and will be defined as one or more 'Hex Security / Lock Bytes'. This is the raw version of the fuses where each 'Hex Security Fuse Byte' can represent up to 8 individual 'Boolean Fuses'.

It is possible to import the AVR '*Hex Security Fuse Bytes*' from AVR Studio into EQTools. This functionality requires that EQTools build 927 or above is installed.

#### 1. Launch your project in EDS (Development Mode)

• Launch your project in EDS (Development Mode) and then select the *<Security>* tab.

| Program Device Security Fuses / Security Level     PC Fuse     Fuse                                                                                                                                                                            | 38:                                                                                               |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Euro Programming Action:                                                                                                                                                                                                                       |                                                                                                   |  |  |  |  |  |  |  |  |
| Fuse Programming Action:                                                                                                                                                                                                                       |                                                                                                   |  |  |  |  |  |  |  |  |
| Program/Verify                                                                                                                                                                                                                                 |                                                                                                   |  |  |  |  |  |  |  |  |
| Read from Fuse file.                                                                                                                                                                                                                           | iter <u>H</u> ex                                                                                  |  |  |  |  |  |  |  |  |
| Browse                                                                                                                                                                                                                                         | moort                                                                                             |  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                |                                                                                                   |  |  |  |  |  |  |  |  |
| Fuses PC Fuse State Target Fuse State Description                                                                                                                                                                                              | xport                                                                                             |  |  |  |  |  |  |  |  |
| LB1 1 - UNPROGRAMMED Lock Bit 1<br>LB2 1 - UNPROGRAMMED Lock Bit 2<br>BLB01 1 - UNPROGRAMMED Boot Lock Bit 01<br>BLB02 1 - UNPROGRAMMED Boot Lock Bit 10<br>BLB11 1 - UNPROGRAMMED Boot Lock Bit 11<br>BLB12 1 - UNPROGRAMMED Boot Lock Bit 12 | <sup>r</sup> uses:<br><u>R</u> ead<br><u>W</u> rite<br>⊻erify<br>Er <u>a</u> se<br>< <u>C</u> opy |  |  |  |  |  |  |  |  |
| Local Fuse Values: 0xFF Target Fuses : ?????                                                                                                                                                                                                   |                                                                                                   |  |  |  |  |  |  |  |  |

- The default 'library' settings for the Fuses are displayed in the 'PC Fuse State' column.
- These fuse values represent a virgin AVR device which has never been programmed before which should be "unlocked" ie all Lock Bits are set to '1'.



#### 2. Click the <Enter Hex> button

• The 'Enter Fuse Values' dialog box is displayed:

| Enter Fuse Values                                                     |
|-----------------------------------------------------------------------|
| Enter the Hex value for each Fuse Byte                                |
| Security Byte <u>0</u><br>0xFF                                        |
|                                                                       |
|                                                                       |
|                                                                       |
| Click <0K> to convert these Fuse Hex values to<br>Boolean Fuse Values |
| OK Cancel                                                             |

- The value(s) displayed as default are the values corresponding to the individual Boolean Fuse Settings already specified in EQTools.
- Enter the 'Security Hex Fuse Byte(s)' from AVR Studio in the relevant Fuse Value field(s).
- Click *<OK>* to convert the Hex value(s) to Boolean fuses.

| Informa  | ation                                                                                                                             |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| <b>(</b> | Action: Convert Hex Fuse Values<br>Result: PASS                                                                                   |
|          | The Hex Fuse values entered have been converted to show the Boolean Fuse Values (individual Fuses Bits) - see the 'Fuses' column. |
|          | OK                                                                                                                                |

• Click  $\langle OK \rangle \rightarrow$  the individual Boolean Security fuses are now displayed:





#### 3. Export Security Fuses to a Fuse File

- Click <*Export*> and then save the Security Fuses to a Fuse File called eg. *ATmega169\_Security.eff*.
- This file can then be automatically read back into your programming project by selecting *'Read from Fuse File'* and then specifying the relevant *Fuse File*.

#### 4. Reading the Security Fuses from a Fuse file

- Once you have exported the Security Fuse Settings to a *Fuse File*, you can then include these Fuse Settings in any project.
- In EDS, on the <Security> tab, tick the 'Read from Fuse File' check box and then browse to and select your Fuse File.

| <b>V</b> | Read from Fuse file.                           |        |
|----------|------------------------------------------------|--------|
|          | C:\temp\ATmega169\ATmega169_Security_Fuses.EFF | Browse |
|          |                                                |        |

- The project will then automatically use the Fuse Settings in the specified Fuse File.
- The '*Security Fuse File*' can also be used by any other project allowing the fuse values to be shared between many projects if required.





## 6.0 Creating a Standalone Programming Project

## 6.1 Overview

Once you have tested your project fully in *EDS* (Development Mode), it is possible to then make this project into a *'Standalone Project'* which can be uploaded to a programmer. This single standalone project file (\*.prj) will contain all the information required to program the Target Device including FLASH file, EEPROM file, Fuse settings, Security Settings etc.

## 6.2 Creating a Standalone Project from EDS (Development Mode)

| Overview         | Programmer                                                                                                                                                  | Target Device       | Target Oscillator | JTAG Settings | Target Power Supply | Flash          | Eeprom | Fuses | Security |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------|---------------|---------------------|----------------|--------|-------|----------|--|
| Project I        | nformation:                                                                                                                                                 |                     |                   |               |                     |                |        |       |          |  |
| 😅 Op             | oen / Modify B                                                                                                                                              | ase Programming     | Project           |               |                     | <b>1010F</b> · |        |       |          |  |
| 🔛 <u>A</u> c     | ld Project file to                                                                                                                                          | o a new Project C   | ollection         |               |                     |                |        |       |          |  |
|                  | Deputate this project in an existing Project Collection                                                                                                     |                     |                   |               |                     |                |        |       |          |  |
| C:\tem           | ip\ATmega256                                                                                                                                                | SVATmega2560-J      | FAG.PPM           |               |                     |                |        |       |          |  |
| <u>P</u> roject  | Name:                                                                                                                                                       |                     | <u>A</u> uthor:   |               |                     |                |        |       |          |  |
| Project          | <u>V</u> ersion:                                                                                                                                            | <u>C</u> reation Da | te                |               |                     |                |        |       |          |  |
| 1.0.0.0          | )                                                                                                                                                           | 19/05/200           | 8 🔽               |               |                     |                |        |       |          |  |
| Please<br>an exi | Please note: To upload this project to a programmer, please either add the project to<br>an existing Project Collection or create a new Project Collection. |                     |                   |               |                     |                |        |       |          |  |

In EDS (Development Mode), select the <Overview> tab

- If this is the first time the EDS Project has been uploaded to a programmer, click the <Add Project File to a new Project Collection> button.
- If the EDS Project has already been uploaded to a programmer before, click the <**Update this project in an existing Project Collection>** button.

## 6.3 Add Project File to a new Project Collection

When the *Add Project File to a new Project Collection>* button is pressed, the EDS project will be automatically added to a new *'Project Collection'*.

- The EDS Project will appear in a 'Project Manager' window.
- You will then be prompted to save the *'Project Collection'*. Choose a suitable name eg. *Test.ppc* and click the *<Save>* button.



| EC Pr        |      | t Ma        | nager - Untitl                                                  | ed.PPC                                      |                                                                                |                                                                          |                                        |                   |
|--------------|------|-------------|-----------------------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------|-------------------|
| Nun<br>Datio | nber | Unio<br>ATM | que Id<br>IEGA2560JTAG                                          | Version<br>1.0.0.0                          | Build Date<br>19/05/2008 at 15:5                                               | Target Device<br>ATmega2560 (J                                           | Min Firmware 3.07                      | Size (pages)<br>3 |
|              |      | orma<br>D   | Operation:<br>You now need to<br>The name can co<br>characters. | Project has<br>o Save the P<br>ontain up to | been added to a new<br>roject Collection file w<br>128 characters and ca<br>OK | Project Collection.<br>th a suitable name e.g<br>n be a mix of upper, lo | . myprojectcollect<br>wer and alphanun | ion.ppc.<br>heric |

The Project Manager window is now displayed - see section 6.4.

## 6.4 Uploading a Project to a programmer

The *Project Manager* window displays all the projects in your *Project Collection*.

| 🔛 Projec  | t Manager - C:\ter   | np\ATmeg   | a256\Test.PPC             |                         |              |                   |      |                            |               |              |
|-----------|----------------------|------------|---------------------------|-------------------------|--------------|-------------------|------|----------------------------|---------------|--------------|
| Number    | Unique Id            | Version    | Build Date                | Target Device           | Min Firmware | Size (pages)      | Name | Author                     | Relative Path |              |
| <b>0</b>  | ATMEGA2560-JTAG      | 1.0.0.0    | 20/05/2008 at 11:21       | ATmega2560 (JTAG)       | 3.07         | 3                 |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           |                         |              |                   |      |                            |               |              |
|           |                      |            |                           | D. Edit Project         |              | est Proiect in El | DS   | "" Upload selected project | 🚆 Upload a    | all projects |
|           |                      |            |                           | 10101 2011101201        | * =          |                   |      | f                          |               |              |
| Programme | r Type: PPM3 MK2   1 | otal FLASH | usage - Used: 1.0 KB (0.0 | )%), Free: 4.0 MB bytes | (100.0%)     |                   |      |                            |               |              |

In this example we have only one project called 'ATMEGA2560-JTAG'. The 'Unique ID' is the 'Project Name' which is also the file name you saved the project with in EDS.

#### To upload the project to the programmer:

- Click the <Upload all projects> button
  - $\rightarrow$  uploads all the projects in the collection to the programmer.

or

- Click once on the project you wish to upload in the *Project Manager* window and then click the *<Upload selected project>* button
  - $\rightarrow$  uploads only the selected project in the collection to the programmer.

Follow the on-screen **Upload Wizard** instructions to complete the uploading of the project(s) to the programmer(s).



## 6.5 Re-testing a Project in EDS (Development mode)

If you want to re-test a Programming Project in EDS (Development Mode), the simplest method to do this is as follows:

- Use Project Manager to open your Project Collection (\*.ppc file)
- Click once on the project which you wish to test in EDS mode. This will select the project.

|   | R Projec   | t Manager - C:\ter | np\ATme     | ga256\Test.PPC           |                         |              |                           |      |                               |               |              |
|---|------------|--------------------|-------------|--------------------------|-------------------------|--------------|---------------------------|------|-------------------------------|---------------|--------------|
|   | Number     | Unique Id          | Version     | Build Date               | Target Device           | Min Firmware | Size (pages)              | Name | Author                        | Relative Path |              |
| I | <b>0</b>   | ATMEGA2560-JTAG    | 1.0.0.0     | 20/05/2008 at 11:21      | ATmega2560 (JTAG)       | 3.07         | 3                         |      |                               |               |              |
| I |            |                    |             |                          |                         |              |                           |      |                               |               |              |
| I |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
| I |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
| I |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
|   |            |                    |             |                          |                         |              |                           |      |                               |               |              |
| I | L          |                    |             |                          | <b>e</b>                | 1            |                           |      | 14141 · · · · · · · · · · · · | 1             |              |
|   |            |                    |             |                          | Edit Project            | <b>%</b> :   | <u>T</u> est Project in E | DS   | Upload selected project       | tion Upload   | all projects |
|   | Programmer | Type: PPM3 MK2     | Total FLASH | usage - Used: 1.0 KB (0. | 0%), Free: 4.0 MB bytes | (100.0%)     |                           |      |                               |               |              |

• Click the <Test in EDS> button

→ The selected project will now be opened in *EDS (Development Mode)*.

| Equinox Developme                             | nt Suite (EDS) C:\temp\ATmega256\Test_ATMEGA2560-JTAG.EDS                                                         |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| Overview Programmer Ta                        | arget Device Target Oscillator JTAG Settings Target Power Supply Flash Eeprom Fuses Secu                          |
| Project Information:                          |                                                                                                                   |
| 😅 Open / Modify Base                          | Programming Project                                                                                               |
| 😭 Add Project file to a                       | new Project Collection                                                                                            |
| Dpdate this project                           | in an existing Project Collection                                                                                 |
| C:\temp\ATmega256\A                           | TMEGA2560-JTAG.PPM                                                                                                |
| Project Name:                                 | <u>A</u> uthor:                                                                                                   |
| Project Version:                              | Creation Date                                                                                                     |
| 1.0.0.0                                       | 20/05/2008                                                                                                        |
| Please note: To uple<br>an existing Project C | ad this project to a programmer, please either add the project to<br>ollection or create a new Project Collection |
| an emeting i fojoot e                         |                                                                                                                   |

• You can now test your project in EDS (Development Mode).