beautypg.com

Serial programming algorithm, Serial programming instruction set, At89s52 – Rainbow Electronics AT89S52 User Manual

Page 17

background image

AT89S52

17

frequency should be less than 1/16 of the crystal fre-
quency. With a 33 MHz oscillator clock, the maximum SCK
frequency is 2 MHz.

Serial Programming Algorithm

To program and verify the AT89S52 in the serial program-
ming mode, the following sequence is recommended:

1.

Power-up sequence:

Apply power between VCC and GND pins.

Set RST pin to “H”.

If a crystal is not connected across pins XTAL1 and
XTAL2, apply a 3 MHz to 33 MHz clock to XTAL1 pin
and wait for at least 10 milliseconds.

2.

Enable serial programming by sending the Pro-
gramming Enable serial instruction to pin
MOSI/P1.5. The frequency of the shift clock sup-
plied at pin SCK/P1.7 needs to be less than the
CPU clock at XTAL1 divided by 16.

3.

The Code array is programmed one byte at a time
by supplying the address and data together with the

appropriate Write instruction. The write cycle is self-
timed and typically takes less than 1 ms at 5V.

4.

Any memory location can be verified by using the
Read instruction which returns the content at the
selected address at serial output MISO/P1.6.

5.

At the end of a programming session, RST can be
set low to commence normal device operation.

Power-off sequence (if needed):

Set XTAL1 to “L” (if a crystal is not used).

Set RST to “L”.

Turn V

CC

power off.

Data Polling: The Data Polling feature is also available in
the serial mode. In this mode, during a write cycle an
attempted read of the last byte written will result in the com-
plement of the MSB of the serial output byte on MISO.

Serial Programming Instruction Set

The Instruction Set for Serial Programming follows a 4-byte
protocol and is shown in Table 10.