2010 Microchip Technology Inc.
DS39774D-page 129
PIC18F85J11 FAMILY
11.0 I/O PORTS
Depending on the device selected and features
enabled, there are up to nine 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
FIGURE 11-1:
GENERIC I/O PORT
OPERATION
11.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 VDD input levels.
11.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 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. The digital pins that cannot exceed VDD are
RE0, RE1, RE2, RG0, RG2 and RG3.
In contrast, pins that also have analog input functions of
any kind can only tolerate voltages up to VDD. Voltage
excursions beyond VDD on these pins should be avoided.
Table 11-1 summarizes the input voltage capabilities.
more details.
TABLE 11-1:
INPUT VOLTAGE TOLERANCE
11.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 are capable of driving
digital circuits associated with external memory
devices. They 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.
Data
Bus
WR LAT
WR TRIS
RD PORT
Data Latch
TRIS Latch
RD TRIS
Input
Buffer
I/O pin(1)
Q
D
CK
Q
D
CK
EN
Q
D
EN
RD LAT
or PORT
Port or Pin
Tolerated
Input
Description
PORTA<7:5>
VDD
Only VDD input levels
tolerated.
PORTA<3:0>
PORTC<1:0>
PORTE<2:0>
PORTF<7:1>
PORTG<3:2,0>
PORTA<4>
5.5V
Tolerates input levels
above VDD, useful for
most standard logic.
PORTB<7:0>
PORTC<7:2>
PORTD<7:0>
PORTE<7:3>
PORTG<4,1>
PORTH<7:0>(1)
PORTJ<7:0>(1)
Note 1: Not available on 64-pin devices.