33.8 Serial Downloading

Both the Flash and EEPROM memory arrays can be programmed using the serial SPI bus while RESET is pulled to GND. The serial interface consists of pins SCK, MOSI (input) and MISO (output). After RESET is set low, the Programming Enable instruction needs to be executed first before program/erase operations can be executed.

Figure 33-6. Serial Programming and Verify
Note:
  1. If the device is clocked by the internal Oscillator, it is no need to connect a clock source to the XTAL1 pin.
  2. VCC - 0.3V < AVCC < VCC + 0.3V, however, AVCC should always be within 1.8–5.5V .

When programming the EEPROM, an auto-erase cycle is built into the self-timed programming operation (in the Serial mode ONLY) and there is no need to first execute the Chip Erase instruction. The Chip Erase operation turns the content of every memory location in both the Program and EEPROM arrays into 0xFF.

Depending on CKSEL Fuses, a valid clock must be present. The minimum low and high periods for the serial clock (SCK) input are defined as follows:

  • Low: > 2 CPU clock cycles for fck < 12MHz, , 3 CPU clock cycles for fck ≥ 12MHz
  • High: > 2 CPU clock cycles for fck < 12MHz, 3 CPU clock cycles for fck ≥ 12MHz