2010 Microchip Technology Inc.
DS39905E-page 133
PIC24FJ256GA110 FAMILY
10.4.3.4
Mapping Limitations
The control schema of the Peripheral Pin Select is
extremely flexible. Other than systematic blocks that
prevent signal contention caused by two physical pins
being configured as the same functional input or two
functional outputs configured as the same pin, there
are no hardware enforced lock outs. The flexibility
extends to the point of allowing a single input to drive
multiple peripherals or a single functional output to
drive multiple output pins.
10.4.3.5
Mapping Exceptions for
PIC24FJ256GA110 Family Devices
Although the PPS registers theoretically allow for up to
64 remappable I/O pins, not all of these are implemented
in all devices. For PIC24FJ256GA110 family devices,
the maximum number of remappable pins available are
46, which includes 14 input only pins. In addition, some
pins in the RPn and RPIn sequences are unimple-
mented in lower pin count devices. The differences in
available
remappable
pins
are
summarized
in
When developing applications that use remappable
pins, users should also keep these things in mind:
For the RPINRx registers, bit combinations
corresponding to an unimplemented pin for a
particular device are treated as invalid; the
corresponding module will not have an input
mapped to it. For all PIC24FJ256GA110 family
devices, this includes all values greater than
45 (‘101101’).
For RPORx registers, the bit fields corresponding
to an unimplemented pin will also be
unimplemented. Writing to these fields will have
no effect.
10.4.4
CONTROLLING CONFIGURATION
CHANGES
Because peripheral remapping can be changed during
run time, some restrictions on peripheral remapping
are needed to prevent accidental configuration
changes. PIC24F devices include three features to
prevent alterations to the peripheral map:
Control register lock sequence
Continuous state monitoring
Configuration bit remapping lock
10.4.4.1
Control Register Lock
Under normal operation, writes to the RPINRx and
RPORx registers are not allowed. Attempted writes will
appear to execute normally, but the contents of the
registers will remain unchanged. To change these reg-
isters, they must be unlocked in hardware. The register
lock is controlled by the IOLOCK bit (OSCCON<6>).
Setting IOLOCK prevents writes to the control
registers; clearing IOLOCK allows writes.
To set or clear IOLOCK, a specific command sequence
must be executed:
1.
Write 46h to OSCCON<7:0>.
2.
Write 57h to OSCCON<7:0>.
3.
Clear (or set) IOLOCK as a single operation.
Unlike the similar sequence with the oscillator’s LOCK
bit, IOLOCK remains in one state until changed. This
allows all of the Peripheral Pin Selects to be configured
with a single unlock sequence, followed by an update
to all control registers, then locked with a second lock
sequence.
10.4.4.2
Continuous State Monitoring
In addition to being protected from direct writes, the
contents of the RPINRx and RPORx registers are
constantly monitored in hardware by shadow registers.
If an unexpected change in any of the registers occurs
(such as cell disturbances caused by ESD or other
external events), a Configuration Mismatch Reset will
be triggered.
10.4.4.3
Configuration Bit Pin Select Lock
As an additional level of safety, the device can be con-
figured to prevent more than one write session to the
RPINRx and RPORx registers. The IOL1WAY
(CW2<4>) Configuration bit blocks the IOLOCK bit
from being cleared after it has been set once. If
IOLOCK remains set, the register unlock procedure will
not execute and the Peripheral Pin Select Control
registers cannot be written to. The only way to clear the
bit and re-enable peripheral remapping is to perform a
device Reset.
In the default (unprogrammed) state, IOL1WAY is set,
restricting users to one write session. Programming
IOL1WAY allows users unlimited access (with the
proper use of the unlock sequence) to the Peripheral
Pin Select registers.
TABLE 10-4:
REMAPPABLE PIN EXCEPTIONS FOR PIC24FJ256GA110 FAMILY DEVICES
Device Pin Count
RP Pins (I/O)
RPI Pins
Total
Unimplemented
Total
Unimplemented
64-pin
29
RP5, RP15, RP31
2
RPI32-36, RPI38-44
80-pin
31
RP31
11
RPI32, RPI39, RPI41
100-pin
32
—
14
—