Atmega32(l) – Rainbow Electronics ATmega32L User Manual

Page 271

Advertising
background image

271

ATmega32(L)

2503C–AVR–10/02

Note:

a = address high bits
b = address low bits
H = 0 – Low byte, 1 – High Byte
o = data out
i = data in
x = don’t care

Table 116. SPI Serial Programming Instruction Set

Instruction

Instruction Format

Operation

Byte 1

Byte 2

Byte 3

Byte4

Programming Enable

1010 1100

0101 0011

xxxx xxxx

xxxx xxxx

Enable SPI Serial Programming after
RESET goes low.

Chip Erase

1010 1100

100x xxxx

xxxx xxxx

xxxx xxxx

Chip Erase EEPROM and Flash.

Read Program Memory

0010 H000

00aa aaaa

bbbb bbbb

oooo oooo

Read H (high or low) data o from
Program memory at word address a:b.

Load Program Memory Page

0100 H000

00xx xxxx

xxbb bbbb

iiii iiii

Write H (high or low) data i to Program
Memory page at word address b. Data
low byte must be loaded before Data
high byte is applied within the same
address.

Write Program Memory Page

0100 1100

00aa aaaa

bb

xx xxxx

xxxx xxxx

Write Program Memory Page at
address a:b.

Read EEPROM Memory

1010 0000

00xx xxaa

bbbb bbbb

oooo oooo

Read data o from EEPROM memory at
address a:b.

Write EEPROM Memory

1100 0000

00xx xxaa

bbbb bbbb

iiii iiii

Write data i to EEPROM memory at
address a:b.

Read Lock Bits

0101 1000

0000 0000

xxxx xxxx

xxoo oooo

Read Lock bits. “0” = programmed, “1”
= unprogrammed. See

Table 103 on

page 254

for details.

Write Lock Bits

1010 1100

111x xxxx

xxxx xxxx

11ii iiii

Write Lock bits. Set bits = “0” to
program Lock bits. See

Table 103 on

page 254

for details.

Read Signature Byte

0011 0000

00xx xxxx

xxxx xxbb

oooo oooo

Read Signature Byte o at address b.

Write Fuse Bits

1010 1100

1010 0000

xxxx xxxx

iiii iiii

Set bits = “0” to program, “1” to
unprogram. See

Table 106 on page

256

for details.

Write Fuse High Bits

1010 1100

1010 1000

xxxx xxxx

iiii iiii

Set bits = “0” to program, “1” to
unprogram. See

Table 105 on page

255

for details.

Read Fuse Bits

0101 0000

0000 0000

xxxx xxxx

oooo oooo

Read Fuse bits. “0” = programmed, “1”
= unprogrammed. See

Table 106 on

page 256

for details.

Read Fuse High Bits

0101 1000

0000 1000

xxxx xxxx

oooo oooo

Read Fuse high bits. “0” = pro-
grammed, “1” = unprogrammed. See

Table 105 on page 255

for details.

Read Calibration Byte

0011 1000

00xx xxxx

0000 0000

oooo oooo

Read Calibration Byte

Advertising