Microchip Technology ARD00330 データシート

ページ / 480
 2010 Microchip Technology Inc.
Preliminary
DS39979A-page 105
PIC18F87J72 FAMILY
10.0 I/O PORTS
Depending on the features enabled, there are up to
seven ports available. Some pins of the I/O ports are
multiplexed with an alternate function from the
peripheral features on the device. In general, when a
peripheral is enabled, that pin may not be used as a
general purpose I/O pin.
Each port has three memory mapped registers for its
operation:
• TRIS register (Data Direction register)
• PORT register (reads the levels on the pins of the 
device)
• LAT register (Output Latch register)
Reading the PORT register reads the current status of
the pins, whereas writing to the PORT register, writes
to the Output Latch (LAT) register. 
Setting a TRIS bit (= 1) makes the corresponding
PORT pin an input (i.e., put the corresponding output
driver in a high-impedance mode). Clearing a TRIS bit
(=  0) makes the corresponding PORT pin an output
(i.e., put the contents of the corresponding LAT bit on
the selected pin). 
The Output Latch (LAT register) is useful for
read-modify-write operations on the value that the I/O
pins are driving. Read-modify-write operations on the
LAT register read and write the latched output value for
the PORT register.
A simplified model of a generic I/O port, without the
interfaces to other peripherals, is shown in Figure 10-1.
FIGURE 10-1:
GENERIC I/O PORT 
OPERATION   
10.1
I/O Port Pin Capabilities
When developing an application, the capabilities of the
port pins must be considered. Outputs on some pins
have higher output drive strength than others. Similarly,
some pins can tolerate higher than V
DD
 input levels. 
10.1.1
INPUT PINS AND VOLTAGE 
CONSIDERATIONS
The voltage tolerance of pins used as device inputs is
dependent on the pin’s input function. Most of the pins
that are used as digital only inputs are able to handle DC
voltages up to 5.5V, a level typical for digital logic circuits.
In contrast, pins that also have analog input functions of
any kind can only tolerate voltages up to V
DD
summarizes the input voltage capabilities of the I/O pins. 
Refer to Section 29.0 “Electrical Characteristics” for
more details. Voltage excursions beyond V
DD
 on these
pins should be avoided. 
TABLE 10-1:
INPUT VOLTAGE TOLERANCE
10.1.2
PIN OUTPUT DRIVE
When used as digital I/O, the output pin drive strengths
vary for groups of pins intended to meet the needs for
a variety of applications. In general, there are three
classes of output pins in terms of drive capability.
PORTB and PORTC, as well as PORTA<7:6>, are
designed to drive higher current loads, such as LEDs.
PORTD, PORTE and PORTJ can also drive LEDs but
only those with smaller current requirements. PORTF,
PORTG and PORTH, along with PORTA<5:0>, have
the lowest drive level but are capable of driving normal
digital circuit loads with a high input impedance.
Regardless of which port it is located on, all output pins
in LCD Segment or common-mode have sufficient
output to directly drive a display.
Table 10-2 summarizes the output capabilities of the
ports. Refer to the “Absolute Maximum Ratings” in
Section 29.0 “Electrical Characteristics” for more
details.
Data
Bus
WR LAT
WR TRIS
RD PORT
Data Latch
TRIS Latch
RD TRIS
Input
Buffer
I/O Pin
Q
D
CKx
Q
D
CKx
EN
Q
D
EN
RD LAT
or PORT
PORT or Pin
Tolerated 
Input
Description
PORTA<7:0>
V
DD
Only V
DD
 input levels 
tolerated.
PORTC<1:0>
PORTF<1,0>
PORTF<7:1>
PORTG<3:2, 0>
PORTB<7:0>
5.5V
Tolerates input 
levels above V
DD
useful for most 
standard logic.
PORTC<7:2>
PORTD<7:0>
PORTE<7:2>
PORTG<4,1>