Vault 7: Projects
This publication series is about specific projects related to the Vault 7 main publication.
PIC24F Family Reference Manual
DS39715A-page 4-4 Advance Information © 2007 Microchip Technology Inc.
4.2 PROGRAM COUNTER
The PC increments by 2 with the LSb set to ‘0’ to provide compatibility with data space
addressing. Sequential instruction words are addressed in the 4M program memory space by
PC<22:1>. Each instruction word is 24 bits wide.
The LSb of the program memory address (PC<0>) is reserved as a byte select bit for program
memory accesses from data space that use Program Space Visibility (PSV) or table instructions.
For instruction fetches via the PC, the byte select bit is not required. Therefore, PC<0> is always
set to ‘0’.
An instruction fetch example is shown in Figure 4-3. Note that incrementing PC<22:1> by one is
equivalent to adding 2 to PC<22:0>.
Figure 4-3: Instruction Fetch Example
4.3 DATA ACCESS FROM PROGRAM MEMORY
There are two methods by which data can be transferred between the program memory and data
memory spaces: via special table instructions or through remapping of a 32-Kbyte program
space page into the upper half of data space. The TBLRDL and TBLWTL instructions offer a direct
method of reading or writing the least significant word (lsw) of any address within program space
without going through the data space, which is preferable for some applications. The TBLRDH
and TBLWTH instructions are the only method whereby the upper 8 bits of a program word can
be accessed as data.
4.3.1 Table Instruction Summary
A set of table instructions is provided to move byte or word-sized data between program space
and data space. The table read instructions are used to read from the program memory space
into data memory space. The table write instructions allow data memory to be written into the
program memory space.
The four available table instructions are listed below:
• TBLRDL: Table Read Low
• TBLWTL: Table Write Low
• TBLRDH: Table Read High
• TBLWTH: Table Write High
22
0
Program Counter
0
0x000000
0x7FFFFE
24 bits
Instruction
Instruction
23
+1
(1)
Note 1: Increment of PC<22:1> is equivalent to PC<22:0> + 2.
24
23
User
Space
Latch
Note: Detailed code examples using table instructions can be found in Section 5. “Flash
Memory Operation”.
Protego_Release_01_05-Related-OEM-Documentation-PIC24FJ32MC10X-Reference_Manual-Section4-Program_Memory.pdf