
AT89C52
4-63
The AT89 C52 provi des the fo llowi ng stan dard feat ures : 8K
bytes of Fl as h, 2 56 by tes o f RA M, 32 I/O lin es , th ree 1 6-bi t
timer/cou nters, a six -vector two -level inter rupt architec ture,
a full dup lex serial p ort, on-chip oscillator, a nd clock cir -
cuitry. In addition, the AT89C52 is designed with static logic
for operation down to zero frequency and supports two
software selectable power saving modes. The Idle Mode
stops the CPU while allowing the RA M, timer/counters,
serial port, and interrupt system to continue fun ctioning .
The Power Down Mode saves the RAM contents but
freezes th e o sc illa tor , d isabl in g a ll ot her chi p fu nc tio ns un til
the next hardware reset.
Pin Description
VCC
Supply voltage.
GND
Ground.
Port 0
Port 0 is an 8-bi t open drain bidirectional I/O port. As an
output port, each pin can sink eight TTL inputs. When 1s
are written to port 0 pins, the pins can be used as high-
impedance inputs.
Port 0 can also be configured to be the multiplexed l ow-
order address/data bus during accesses to external pr o-
gram and data memory. In this mode, P0 has internal pul-
lups.
Port 0 a lso rec eives th e code bytes d uring Fla sh prog ram-
ming and outputs the code bytes during program veri fica-
tion. E xternal pullu ps are re quired during program verifi ca-
tion.
Port 1
Port 1 is a n 8- bit bi dire ction al I/O por t with inter nal pullu ps.
The Port 1 output buffers can sink/source four TTL inputs.
When 1s are writte n to Port 1 pi ns, they ar e pulled hi gh by
the internal pullups and can be us ed as inputs. As i nputs,
Port 1 pins that are externally being pulled low will source
current (IIL) because of the internal pullups.
In addition, P1.0 and P1.1 can be configured to be the
timer/counter 2 external count input (P1.0/T2) and the
timer/counter 2 trigger input (P1.1/T2EX), respectivel y, as
shown in the following table.
Port 1 also receives the low-order address bytes during
Flash programming and verification.
Port 2
Port 2 is an 8-bit bi directiona l I/O port with interna l pullups.
The Port 2 output buffers can sink/source four TTL inputs.
When 1s a re writte n to Po rt 2 pi ns, th ey a re pulle d hi gh b y
the internal pullups and can be used as inputs. As inputs,
Port 2 pins that are externally being pulled low will source
current (IIL) be cause of the internal pullups.
Port 2 emits the high-order address byte during fetches
from external program memory and during accesses to
external da ta m emory that u se 16 -bit address es ( MO VX @
DPTR). In this application, Port 2 uses strong internal pul-
lups when emitting 1s. During accesses to external data
memory that use 8-bit addresses (MOVX @ RI), Port 2
emits the contents of the P2 Special Function Register.
Port 2 also receives the high-order address bits and some
control signals during Flash programming and verification.
Port 3
Port 3 is an 8-bit bi directiona l I/O port with interna l pullups.
The Port 3 output buffers can sink/source four TTL inputs.
When 1s a re writte n to Po rt 3 pi ns, th ey a re pulle d hi gh b y
the internal pullups and can be used as inputs. As inputs,
Port 3 pins that are externally being pulled low will source
current (IIL) because of the pullups.
Port 3 also s erves the funct ions of var ious s peci al featu res
of the AT89C51, as shown in the following table.
Port 3 also receives some control signals for Flash pro-
gramming and verification.
RST
Reset input. A high on this pin for two machine cycles while
the oscillator is running resets the device.
ALE/PROG
Address Latch Enabl e is an output pulse for latching the
low byte of the address during accesses to external mem-
ory . Thi s pi n is also t h e pr og ra m pu l se in p ut (PROG) during
Flash programming.
In normal operation, ALE is emitted at a constant rate of 1/6
the oscillator frequency and may be used for external tim-
ing or clocking purposes. Note, however, that one ALE
Port Pin Alternate Functions
P1.0 T2 (external count input to Timer/Counter 2),
clock-out
P1.1 T2EX (Timer/Counter 2 capture/reload trigger
and direction control)
Port Pin Alternate Functions
P3.0 RXD (serial input port)
P3.1 TXD (serial output port)
P3.2 INT0 (external interrupt 0)
P3.3 INT1 (external interrupt 1)
P3.4 T0 (timer 0 external input)
P3.5 T1 (timer 1 external input)
P3.6 WR (external data memory write strobe)
P3.7 RD (external data memory read strobe)