beautypg.com

Programming the eeprom, Reading the eeprom, Programming the fuses – Rainbow Electronics ATmega3290P_V User Manual

Page 311

background image

311

ATmega329/3290/649/6490

2552H–AVR–11/06

ending with the MSB of the last instruction in the page (Flash). The Capture-DR
state both captures the data from the Flash, and also auto-increments the pro-
gram counter after each word is read. Note that Capture-DR comes before the
shift-DR state. Hence, the first byte which is shifted out contains valid data.

6.

Enter JTAG instruction PROG_COMMANDS.

7.

Repeat steps 3 to 6 until all data have been read.

Programming the EEPROM

Before programming the EEPROM a Chip Erase must be performed, see “Performing
Chip Erase” on page 309.

1.

Enter JTAG instruction PROG_COMMANDS.

2.

Enable EEPROM write using programming instruction 4a.

3.

Load address High byte using programming instruction 4b.

4.

Load address Low byte using programming instruction 4c.

5.

Load data using programming instructions 4d and 4e.

6.

Repeat steps 4 and 5 for all data bytes in the page.

7.

Write the data using programming instruction 4f.

8.

Poll for EEPROM write complete using programming instruction 4g, or wait for
t

WLRH

(refer to Table 134 on page 295).

9.

Repeat steps 3 to 8 until all data have been programmed.

Note that the PROG_PAGELOAD instruction can not be used when programming the
EEPROM.

Reading the EEPROM

1.

Enter JTAG instruction PROG_COMMANDS.

2.

Enable EEPROM read using programming instruction 5a.

3.

Load address using programming instructions 5b and 5c.

4.

Read data using programming instruction 5d.

5.

Repeat steps 3 and 4 until all data have been read.

Note that the PROG_PAGEREAD instruction can not be used when reading the
EEPROM.

Programming the Fuses

1.

Enter JTAG instruction PROG_COMMANDS.

2.

Enable Fuse write using programming instruction 6a.

3.

Load data high byte using programming instructions 6b. A bit value of “0” will pro-
gram the corresponding fuse, a “1” will unprogram the fuse.

4.

Write Fuse High byte using programming instruction 6c.

5.

Poll for Fuse write complete using programming instruction 6d, or wait for t

WLRH

(refer to Table 134 on page 295).

6.

Load data low byte using programming instructions 6e. A “0” will program the
fuse, a “1” will unprogram the fuse.

7.

Write Fuse low byte using programming instruction 6f.

8.

Poll for Fuse write complete using programming instruction 6g, or wait for t

WLRH

(refer to Table 134 on page 295).