background image

the use of ASCII, which requires each program data byte
to be expressed as two hex characters. This demands
that nearly twice as many bytes be transferred as might
otherwise be required. This is not a severe limitation, how-
ever, since typical file transfer times are less than one
minute. Overall, the simplicity of the custom FTP/hex
packet format implementation outweighs the drawbacks.

Remote Station

The remote station in the test configuration consists of the
display application and programmer circuits, described
previously, connected to a Hayes-compatible,
Prometheus 1200 baud modem. During normal operation,
the application executes its internal program while the mo-
dem and programmer monitor the phone line for incoming
calls.

After a call has been detected and a connection estab-
lished, the programmer forces the application to suspend
execution of its program. The new program is then down-
loaded and programmed into the AT89C51 embedded in
the application. When programming is complete, the ap-
plication is allowed to begin execution of its new program,
and the programmer returns to monitoring the phone line
for the next call.

The programmer powers up with its programming control
outputs inactive, allowing the application to run normally.
After configuring the modem to answer incoming calls, the
programmer puts itself to sleep. The programmer will not
disturb the application until a new program is to be down-
loaded.

The programmer controls the modem by sending ASCII
command strings over the serial interface, to which the
modem responds with Hayes-style ASCII numeric codes.
The software is designed for use with Hayes-compatible
modems, which includes the Prometheus ProModem
1200 used here.

The serial interface, through which the programmer con-
nects to the modem, supports two handshaking signals,
DTR and DSR. On power up, the programmer asserts
DTR, to which the modem responds by asserting DSR. If
the modem should fail to respond to any command, in-
cluding the command to hang up, the programmer deas-
serts DTR, which forces the modem to drop the line.

The modem monitors the phone line while the program-
mer sleeps, waiting for an incoming call. When a call is
detected, the modem answers and attempts to establish
communication with the caller. If a connection is estab-
lished, the modem sends a code to the programmer, wak-
ing it up. The programmer verifies the connect code and
begins polling for a valid packet header.

Incoming packets must arrive fewer than thirty seconds
apart, or the modem drops the line (hangs up) and the
programmer returns to sleep, waiting for the next call. If

the caller hangs up, the thirty second period must expire
before another call will be answered. Calls incoming dur-
ing the reset delay period are ignored.

If a valid packet header is received prior to the expiration
of the reset delay period, the programmer will attempt to
read and validate the incoming packet. At any time during
packet reception, an invalid character, parity error or time-
out during character reception will cause the partial
packet to be declared invalid and discarded.

Two packet types are defined: data and end-of-file. A data
packet contains five fields in addition to the packet
header, one of which is a variable length data field. The
data field contains program data to be written into the
AT89C51 controller in the application. The load address
field contains the address at which the data is to be writ-
ten. The end-of-file packet contains the same fields as the
data packet, except that the data field is empty. This
packet type has special meaning to the programmer, as
explained below.

Any packet which contains an invalid record type, record
length or checksum is invalid. Program data accumulated
during the processing of an invalid packet is discarded.
The programmer sends a NAK to the transmitter to signal
reception of an invalid packet and resumes polling for a
valid packet header.

Receipt of the first valid data packet causes the program-
mer to interrupt the application controller. The controller
responds to the interrupt by abandoning execution of its
usual program and displaying a message indicating that
programming is taking place. If this is the first valid data
packet since power was applied or an end-of-file packet
was received, the programmer asserts the control signals
necessary to erase the program memory in the applica-
tion controller. The programmer then places the controller
in programming mode.

The first and subsequent valid data packets are dissected
as they are received and the data which they contain is
programmed into the application controller at the address
indicated in the packet load address field. After program-
ming, the data is read back from the controller and verified
against the received packet data. Successful verification
indicates that programming was successful, causing the
programmer to send ACK to the transmitter. The program-
mer then resumes polling for a valid packet header, sub-
ject to the thirty second reset delay.

If programming fails, the programmer sends CAN to sig-
nal the transmitter to abort the file transfer. The modem
drops the line and the programmer returns to sleep, wait-
ing for the next call. The application controller is left in pro-
gramming mode, preventing it from executing the incom-
plete or invalid program which it contains.

4-12

Microcontroller

Summary of Contents for AT89C51

Page 1: ...not be driven during normal operation ALE PROG is pulsed low during pro gramming but must not be driven during normal operation During programming AT89C51 I O ports are used for the application of mode select addresses and data pos sibly requiring that the controller be iso lated from the application circuitry How this is done is application dependent and will be addressed here only in gen eral te...

Page 2: ... and pro gram verification the programmer asserts control of port zero and part of port two The programmer is connected to ports zero and two without buffering since when inac tive its presence does not affect the normal operation of the application A transparent latch has been added between port two of the controller and the display control inputs The latch holds the display control signals inact...

Page 3: ...rammer might respond to a packet by sending a CAN which indicates that a non recoverable error has oc curred and that the transmitter should immediately abort the file transfer If the programmer fails to respond to a packet within a limited period of time the transmitter will resend the same packet The transmitter will continue to resend the same packet until a valid response is received or until ...

Page 4: ...ng for the next call If the caller hangs up the thirty second period must expire before another call will be answered Calls incoming dur ing the reset delay period are ignored If a valid packet header is received prior to the expiration of the reset delay period the programmer will attempt to read and validate the incoming packet At any time during packet reception an invalid character parity erro...

Page 5: ...em to an analog telephone line and set the modem switches as indicated below Turn the modem on and apply power to the display appli cation programmer The application will begin executing its program if it contains one The programmer will initial ize the modem as shown by the activity on the modem status indicators Switch settings 1 ON 2 ON 3 ON 4 OFF 5 ON 6 ON 7 ON 8 OFF 9 OFF 10 OFF Installing an...

Page 6: ... A1 WR DL1414T U2 8 9 10 11 2 1 12 5 4 D0 D1 D2 D3 D4 D5 D6 A0 A1 WR DL1414T U3 8 9 10 11 2 1 12 5 4 P2 0 P2 1 P2 2 P2 3 P2 4 P2 5 P2 6 P2 7 D0 D1 D2 D3 D4 D5 D6 A0 A1 WR DL1414T U4 8 9 10 11 2 1 12 5 4 D0 D1 D2 D3 D4 D5 D6 A0 A1 WR DL1414T U5 8 9 10 11 2 1 12 5 4 21 22 23 24 25 26 27 28 P0 0 P0 1 P0 2 P0 3 P0 4 P0 5 P0 6 P0 7 39 38 37 36 35 34 33 32 PSEN ALE PROG P3 6 WR P3 7 RD 29 30 16 17 AT89C...

Page 7: ...Figure 2 AT89C51 Moving Display Application Modified for In Circuit Programming Microcontroller 4 15 ...

Page 8: ...Figure 3 AT89C51 Programmer 4 16 Microcontroller ...

Page 9: ...Figure 4 FTP Transmit Mode Microcontroller 4 17 ...

Page 10: ...Figure 5 FTP Receive Mode 4 18 Microcontroller ...

Page 11: ...eld consists of four hex digits and in dicates the absolute address at which the data in the data field is to be loaded The record type field consists of two hex digits which are always zero in data records The data field contains from one to 16 pairs of hex digits The last two hex digits are a checksum on the record length load address record type and data fields The sum of the binary equivalents...

Reviews: