Micro-Controller 1. Pic Controller Pin Diagram
Micro-Controller 1. Pic Controller Pin Diagram
• Most instructions are single cycle execution (2 clock cycles), with one delay cycle on
branches and skips
• One accumulator (W0), the use of which (as source operand) is implied (i.e. is not
encoded in the opcode)
• All RAM locations function as registers as both source and/or destination of math and
other functions.
• A fairly small amount of addressable data space (typically 256 bytes), extended through
banking
• The program counter is also mapped into the data space and writable (this is used to
implement indirect jumps).
There is no distinction between memory space and register space because the RAM
serves the job of both memory and registers, and the RAM is usually just referred to as the
register file or simply as the registers.
PICs have a set of registers that function as general purpose RAM. Special purpose
control registers for on-chip hardware resources are also mapped into the data space. The
addressability of memory varies depending on device series, and all PIC devices have
some banking mechanism to extend addressing to additional memory. Later series of devices
feature move instructions which can cover the whole addressable space, independent of the
selected bank. In earlier devices, any register move had to be achieved via the accumulator.
To implement indirect addressing, a "file select register" (FSR) and "indirect register"
(INDF) are used. A register number is written to the FSR, after which reads from or
writes to INDF will actually be to or from the register pointed to by FSR. Later devices
extended this concept with post- and pre- increment/decrement for greater efficiency in
accessing sequentially stored data. This also allows FSR to be treated almost like a stack
pointer (SP).
External data memory is not directly addressable except in some high pin count
PIC18 devices.
Code space
Word size
All PICs handle (and address) data in 8-bit chunks. However, the unit of
addressability of the code space is not generally the same as the data space. For example,
PICs in the baseline and mid-range families have program memory addressable in the same
word size as the instruction width, i.e. 12 or 14 bits respectively. In contrast, in the PIC18
series, the program memory is addressed in 8-bit increments (bytes), which differs from the
instruction width of 16 bits.
PICs have a hardware call stack, which is used to save return addresses. The hardware
stack is not software accessible on earlier devices, but this changed with the 18 series
devices.
Hardware support for a general purpose parameter stack was lacking in early series,
but this greatly improved in the 18 series, making the 18 series architecture more friendly to
high level language compilers.
Instruction set
A PIC's instructions vary from about 35 instructions for the low-end PICs to over 80
instructions for the high-end PICs. The instruction set includes instructions to perform a
variety of operations on registers directly, the accumulator and a literal constant or the
accumulator and a register, as well as for conditional execution, and program branching.
Some operations, such as bit setting and testing, can be performed on any numbered
register, but bi-operand arithmetic operations always involve W (the accumulator), writing
the result back to either W or the other operand register. To load a constant, it is necessary to
load it into W before it can be moved into another register. On the older cores, all register
moves needed to pass through W, but this changed on the "high end" cores.
PIC cores have skip instructions which are used for conditional execution and
branching. The skip instructions are 'skip if bit set' and 'skip if bit not set'. Because cores
before PIC18 had only unconditional branch instructions, conditional jumps are implemented
by a conditional skip (with the opposite condition) followed by an unconditional branch.
Skips are also of utility for conditional execution of any immediate single following
instruction.
The 18 series implemented shadow registers which save several important registers
during an interrupt, providing hardware support for automatically saving processor state
when servicing interrupts.
In general, PIC instructions fall into 5 classes:
2. Operation with WREG and indexed register. The result can be written to either
the Working register (e.g. addwf reg,w). or the selected register (e.g. addwf reg,f).
3. Bit operations. These take a register number and a bit number, and perform one of
4 actions: set or clear a bit, and test and skip on set/clear. The latter are used to
perform conditional branches. The usual ALU status flags are available in a
numbered register so operations such as "branch on carry clear" are possible.
4. Control transfers. Other than the skip instructions previously mentioned, there are
only two: goto and call.
Performance
The PIC instruction set is suited to implementation of fast lookup tables in the
program space. Such lookups take one instruction and two instruction cycles. Many functions
can be modeled in this way. Optimization is facilitated by the relatively large program space
of the PIC (e.g. 4096 x 14-bit words on the 16F690) and by the design of the instruction set,
which allows for embedded constants. For example, a branch instruction's target may be
indexed by W, and execute a "RETLW" which does as it is named - return with literal in W.
Advantages
RISC architecture
Easy entry level, in circuit programming plus in circuit debugging PIC Kit units
available from Microchip.com for less than $50
Inexpensive microcontrollers
Wide range of interfaces including I2C, SPI, USB, USART, A/D, programmable
Comparators, PWM, LIN, CAN, PSP, and Ethernet[6]
Limitations
Operations and registers are not orthogonal; some instructions can address RAM
and/or immediate constants, while others can only use the accumulator
The following limitations have been addressed in the PIC18 series, but still apply to earlier cores:
Stack:
1. The hardware call stack is not addressable, so preemptive task switching cannot
be implemented
With paged program memory, there are two page sizes to worry about: one for CALL
and GOTO and another for computed GOTO (typically used for table lookups). For example,
on PIC16, CALL and GOTO have 11 bits of addressing, so the page size is 2048 instruction
words. For computed GOTOs, where you add to PCL, the page size is 256 instruction words.
In both cases, the upper address bits are provided by the PCLATH register. This register
must be changed every time control transfers between pages. PCLATH must also be
preserved by any interrupt handler.
Compiler development
While several commercial compilers are available, in 2008, Microchip released their
own C compilers, C18 and C30, for the line of 18f 24f and 30/33f processors. By
contrast, Atmel's AVR microcontrollers which are competitive with PIC in terms of hardware
capabilities and price, but feature a more traditional instruction set have long been supported
by the GNU C Compiler.
The easy to learn RISC instruction set of the PIC assembly language code can make
the overall flow difficult to comprehend. Judicious use of simple macros can increase the
readability of PIC assembly language. For example, the original Parallax PIC assembler
("SPASM") has macros which hide W and make the PIC look like a two-address machine. It
has macro instructions like "mov b, a" (move the data from address a to address b) and "add
b, a" (add data from address a to data in address b). It also hides the skip instructions by
providing three operand branch macro instructions such as "cjne a, b, dest" (compare a
with b and jump to dest if they are not equal).