Professional Documents
Culture Documents
Pic18 (L) F2X/45K50
Pic18 (L) F2X/45K50
6.6.3.1 FSR Registers and the INDF 6.6.3.2 FSR Registers and POSTINC,
Operand POSTDEC, PREINC and PLUSW
At the core of indirect addressing are three sets of reg- In addition to the INDF operand, each FSR register pair
isters: FSR0, FSR1 and FSR2. Each represents a pair also has four additional indirect operands. Like INDF,
of 8-bit registers, FSRnH and FSRnL. Each FSR pair these are “virtual” registers which cannot be directly
holds a 12-bit value, therefore, the four upper bits of the read or written. Accessing these registers actually
FSRnH register are not used. The 12-bit FSR value can accesses the location to which the associated FSR
address the entire range of the data memory in a linear register pair points, and also performs a specific action
fashion. The FSR register pairs, then, serve as pointers on the FSR value. They are:
to data memory locations. • POSTDEC: accesses the location to which the
Indirect addressing is accomplished with a set of FSR points, then automatically decrements the
Indirect File Operands, INDF0 through INDF2. These FSR by 1 afterwards
can be thought of as “virtual” registers: they are • POSTINC: accesses the location to which the
mapped in the SFR space but are not physically FSR points, then automatically increments the
implemented. Reading or writing to a particular INDF FSR by 1 afterwards
register actually accesses its corresponding FSR • PREINC: automatically increments the FSR by 1,
register pair. A read from INDF1, for example, reads then uses the location to which the FSR points in
the data at the address indicated by FSR1H:FSR1L. the operation
Instructions that use the INDF registers as operands
• PLUSW: adds the signed value of the W register
actually use the contents of their corresponding FSR as
(range of -128 to +127) to that of the FSR and
a pointer to the instruction’s target. The INDF operand
uses the location to which the result points in the
is just a convenient way of using the pointer.
operation.
Because indirect addressing uses a full 12-bit address,
In this context, accessing an INDF register uses the
data RAM banking is not necessary. Thus, the current
value in the associated FSR register without changing
contents of the BSR and the Access RAM bit have no
it. Similarly, accessing a PLUSW register gives the
effect on determining the target address.
FSR value an offset by that in the W register; however,
neither W nor the FSR is actually changed in the
operation. Accessing the other virtual registers
changes the value of the FSR register.
000h
When ‘a’ = 0 and f 60h:
060h
The instruction executes in
Direct Forced mode. ‘f’ is inter- Bank 0
BSR
When ‘a’ = 1 (all values of f): 000h 00000000
FIGURE 6-9: REMAPPING THE ACCESS BANK WITH INDEXED LITERAL OFFSET
ADDRESSING
Example Situation:
ADDWF f, d, a 000h
FSR2H:FSR2L = 120h
Bank 0
Locations in the region
from the FSR2 pointer 100h
(120h) to the pointer plus Bank 1
120h
05Fh (17Fh) are mapped Window
17Fh 00h
to the bottom of the
Bank 1
Access RAM (000h-05Fh). 200h Bank 1 “Window”
Special File Registers at 5Fh
60h
F60h through FFFh are
mapped to 60h through Bank 2
FFh, as usual. SFRs
through
Bank 0 addresses below Bank 14
5Fh can still be addressed FFh
by using the BSR. Access Bank
F00h
Bank 15
F60h
SFRs
FFFh
Data Memory
Instruction: TBLRD*
Program Memory
Table Pointer(1)
Table Latch (8-bit)
TBLPTRU TBLPTRH TBLPTRL
TABLAT
Program Memory
(TBLPTR)
Instruction: TBLWT*
Program Memory
(TBLPTR<MSBs>)
Note 1: During table writes the Table Pointer does not point directly to Program Memory. The LSBs of TBLPRTL
actually point to an address within the write block holding registers. The MSBs of the Table Pointer deter-
mine where the write block will eventually be written. The process for writing the holding registers to the
program memory array is discussed in Section 7.6 “Writing to Flash Program Memory”.
7.2 Control Registers The FREE bit allows the program memory erase
operation. When FREE is set, an erase operation is
Several control registers are used in conjunction with initiated on the next WR command. When FREE is
the TBLRD and TBLWT instructions. These include the: clear, only writes are enabled.
• EECON1 register The WREN bit, when set, will allow a write operation.
• EECON2 register The WREN bit is clear on power-up.
• TABLAT register The WRERR bit is set by hardware when the WR bit is
• TBLPTR registers set and cleared when the internal programming timer
expires and the write operation is complete.
7.2.1 EECON1 AND EECON2 REGISTERS
Note: During normal operation, the WRERR is
The EECON1 register (Register 7-1) is the control read as ‘1’. This can indicate that a write
register for memory accesses. The EECON2 register is operation was prematurely terminated by
not a physical register; it is used exclusively in the a Reset, or a write operation was
memory write and erase sequences. Reading attempted improperly.
EECON2 will read all ‘0’s.
The EEPGD control bit determines if the access will be The WR control bit initiates write operations. The WR
a program or data EEPROM memory access. When bit cannot be cleared, only set, by firmware. The WR bit
EEPGD is clear, any subsequent operations will is cleared by hardware at the completion of the write
operate on the data EEPROM memory. When EEPGD operation.
is set, any subsequent operations will operate on the
Note: The EEIF interrupt flag bit of the PIR2
program memory.
register is set when the write is complete.
The CFGS control bit determines if the access will be The EEIF flag stays set until cleared by
to the Configuration/Calibration registers or to program firmware.
memory/data EEPROM memory. When CFGS is set,
subsequent operations will operate on Configuration
registers regardless of EEPGD (see Section 26.0
“Special Features of the CPU”). When CFGS is clear,
memory selection access is determined by EEPGD.
Legend:
R = Readable bit W = Writable bit
S = Bit can be set by software, but not cleared U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Note 1: When a WRERR occurs, the EEPGD and CFGS bits are not cleared. This allows tracing of the
error condition.
TABLE 7-1: TABLE POINTER OPERATIONS WITH TBLRD AND TBLWT INSTRUCTIONS
Example Operation on Table Pointer
TBLRD*
TBLPTR is not modified
TBLWT*
TBLRD*+
TBLPTR is incremented after the read/write
TBLWT*+
TBLRD*-
TBLPTR is decremented after the read/write
TBLWT*-
TBLRD+*
TBLPTR is incremented before the read/write
TBLWT+*
Program Memory
TABLAT
Write Register
8 8 8 8
Program Memory
Legend:
R = Readable bit W = Writable bit
S = Bit can be set by software, but not cleared U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Note 1: When a WRERR occurs, the EEPGD and CFGS bits are not cleared. This allows tracing of the
error condition.
9.2 Operation
Example 9-1 shows the instruction sequence for an 8 x 8
unsigned multiplication. Only one instruction is required
when one of the arguments is already loaded in the
WREG register.
Example 9-2 shows the sequence to do an 8 x 8 signed
multiplication. To account for the sign bits of the
arguments, each argument’s Most Significant bit (MSb)
is tested and the appropriate subtractions are done.
CONT_CODE
:
Wake-up if in
INT0IF Idle or Sleep modes
INT0IE
TMR0IF
TMR0IE
TMR0IP
(1)
IOCIF
IOCIE
IOCIP
INT1IF Interrupt to CPU
PIR1<7:0> INT1IE Vector to Location
PIE1<7:0> INT1IP 0008h
IPR1<7:0> INT2IF
PIR2<7:0> INT2IE
PIE2<7:0> INT2IP
IPR2<7:0>
GIEH/GIE
PIR3<7:0>
PIE3<7:0>
IPR3<7:0> IPEN
IPEN
GIEL/PEIE
IPEN
PIR1<7:0>
PIE1<7:0>
IPR1<7:0>
PIR2<7:0>
PIE2<7:0>
IPR2<7:0>
PIR3<7:0>
PIE3<7:0>
IPR3<7:0> Interrupt to CPU
TMR0IF Vector to Location
TMR0IE 0018h
TMR0IP
(1)
IOCIF
IOCIE
IOCIP GIEH/GIE
GIEL/PEIE
INT1IF
INT1IE
INT1IP
INT2IF
INT2IE
INT2IP
Note 1: The IOCIF interrupt also requires the individual pin IOCB enables.
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Note 1: A mismatch condition will continue to set the IOCIF bit. Reading PORTB/PORTC will end the
mismatch condition and allow the bit to be cleared.
2: Port change interrupts also require the individual pins IOCBx/IOCCx enables.
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
-n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown