



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Obsolete                                                                   |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 4MHz                                                                       |
| Connectivity               | -                                                                          |
| Peripherals                | POR, WDT                                                                   |
| Number of I/O              | 13                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                |
| Data Converters            | -                                                                          |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Through Hole                                                               |
| Package / Case             | 18-DIP (0.300", 7.62mm)                                                    |
| Supplier Device Package    | 18-PDIP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc558-04e-p |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

### 2.0 PIC16C55X DEVICE VARIETIES

A variety of frequency ranges and packaging options are available. Depending on application and production requirements, the proper device option can be selected using the information in the PIC16C55X Product Identification System section at the end of this data sheet. When placing orders, please use this page of the data sheet to specify the correct part number.

#### 2.1 UV Erasable Devices

The UV erasable version, offered in CERDIP package, is optimal for prototype development and pilot programs. This version can be erased and reprogrammed to any of the oscillator modes.

Microchip's PICSTART<sup>®</sup> and PROMATE<sup>®</sup> programmers both support programming of the PIC16C55X.

#### 2.2 One-Time Programmable (OTP) Devices

The availability of OTP devices is especially useful for customers who need the flexibility for frequent code updates and small volume applications. In addition to the program memory, the configuration bits must also be programmed.

#### 2.3 Quick-Turnaround Production (QTP) Devices

Microchip offers a QTP Programming Service for factory production orders. This service is made available for users who choose not to program a medium-to-high quantity of units and whose code patterns have stabilized. The devices are identical to the OTP devices, but with all EPROM locations and configuration options already programmed by the factory. Certain code and prototype verification procedures apply before production shipments are available. Please contact your Microchip Technology sales office for more details.

#### 2.4 Serialized Quick-Turnaround Production (SQTP<sup>™</sup>) Devices

Microchip offers a unique programming service where a few user-defined locations in each device are programmed with different serial numbers. The serial numbers may be random, pseudo-random or sequential.

Serial programming allows each device to have a unique number which can serve as an entry code, password or ID number.

## 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16C55X family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16C55X uses a Harvard architecture in which program and data are accessed from separate memories using separate busses. This improves bandwidth over traditional von Neumann architecture where program and data are fetched from the same memory. Separating program and data memory further allows instructions to be sized differently from 8-bit wide data words. Instruction opcodes are 14-bit wide making it possible to have all single word instructions. A 14-bit wide program memory access bus fetches a 14-bit instruction in a single cycle. A two-stage pipeline overlaps fetch and execution of instructions. Consequently, all instructions (35) execute in a singlecycle (200 ns @ 20 MHz) except for program branches. The table below lists the memory (EPROM and RAM).

| Device    | Program<br>Memory<br>(EPROM) | Data<br>Memor<br>(RAM) |
|-----------|------------------------------|------------------------|
| PIC16C554 | 512                          | 80                     |
| PIC16C557 | 2 K                          | 128                    |
| PIC16C558 | 2 K                          | 128                    |

The PIC16C554 addresses 512 x 14 on-chip program memory. The PIC16C557 and PIC16C558 addresses 2 K x 14 program memory. All program memory is internal.

The PIC16C55X can directly or indirectly address its register files or data memory. All special function registers, including the program counter, are mapped into the data memory. The PIC16C55X has an orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any Addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC16C55X simple yet efficient. In addition, the learning curve is reduced significantly.

The PIC16C55X devices contain an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between data in the working register and any register file.

The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the working register (W register). The other operand is a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register.

The W register is an 8-bit working register used for ALU operations. It is not an addressable register.

Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a Borrow and Digit Borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

A simplified block diagram is shown in Figure 3-1, with a description of the device pins in Table 3-1.

#### 4.3 PCL and PCLATH

The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The high bits (PC<12:8>) are not directly readable or writable and come from PCLATH. On any RESET, the PC is cleared. Figure 4-6 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in Figure 4-6 shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 4-6: LOADING OF PC IN DIFFERENT SITUATIONS



#### 4.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note *"Implementing a Table Read"* (AN556).

#### 4.3.2 STACK

The PIC16C55X family has an 8-level deep x 13-bit wide hardware stack (Figure 4-1 and Figure 4-2). The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RET-FIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

Note 1: There are no status bits to indicate stack overflow or stack underflow conditions.

2: There are no instructions mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or vectoring to an interrupt address.

#### 4.4 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses data pointed to by the file select register (FSR). Reading INDF itself indirectly will produce 00h. Writing to the INDF register indirectly results in a nooperation (although status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 4-7. However, IRP is not used in the PIC16C55X.

A simple program to clear RAM locations 20h-2Fh using indirect addressing is shown in Example 4-1.

| EXAMP | LE 4-1:                                         | INDIR                                       | ECT ADDRESSING                                                                                                   |
|-------|-------------------------------------------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| NEXT  | movlw<br>movwf<br>clrf<br>incf<br>btfss<br>goto | 0x20<br>FSR<br>INDF<br>FSR<br>FSR,4<br>NEXT | <pre>;initialize pointer ;to RAM ;clear INDF register ;inc pointer ;all done? ;no clear next ;yes continue</pre> |

CONTINUE:

#### 5.4 I/O Programming Considerations

#### 5.4.1 BI-DIRECTIONAL I/O PORTS

Any instruction which writes, operates internally as a read followed by a write operation. The BCF and BSF instructions, for example, read the register into the CPU, execute the bit operation and write the result back to the register. Caution must be used when these instructions are applied to a port with both inputs and outputs defined. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU. Then the BSF operation takes place on bit5 and PORTB is written to the output latches. If another bit of PORTB is used as a bi-directional I/O pin (e.g., bit 0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and re-written to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the Input mode, no problem occurs. However, if bit 0 is switched into Output mode later on, the content of the data latch may now be unknown.

Reading the port register, reads the values of the port pins. Writing to the port register writes the value to the port latch. When using read-modify-write instructions (ex. BCF, BSF, etc.) on a port, the value of the port pins is read, the desired operation is done to this value, and this value is then written to the port latch.

Example 5-1 shows the effect of two sequential read-modify-write instructions (ex.,  ${\tt BCF}$ ,  ${\tt BSF}$ , etc.) on an I/O port.

A pin actively outputting a low or high should not be driven from external devices at the same time in order to change the level on this pin ("wired-or", "wired-and"). The resulting high output currents may damage the chip.

#### EXAMPLE 5-1: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT

| ; | Initial PORT settin | ng | s: PORTB<7:4> Inputs |
|---|---------------------|----|----------------------|
| ; |                     |    |                      |
| ; |                     |    | PORTB<3:0> Outputs   |
| ; | PORTB<7:6> have ext | te | rnal pull-up and are |
| ; | not connected to of | th | er circuitry         |
| ; |                     |    |                      |
| ; |                     |    | PORT latch PORT pins |
| ; |                     |    |                      |
| ; |                     |    |                      |
|   |                     |    |                      |
|   | BCF PORTB, 7        | ;  | 01pp pppp 11pp pppp  |
|   | BCF PORTB, 6        | ;  | 10pp pppp 11pp pppp  |
|   | BSF STATUS, RPO     | ;  |                      |
|   | BCF TRISB, 7        | ;  | 10pp pppp 11pp pppp  |
|   | BCF TRISB, 6        | ;  | 10pp pppp 10pp pppp  |
|   |                     |    |                      |

## 5.4.2 SUCCESSIVE OPERATIONS ON I/O PORTS

The actual write to an I/O port happens at the end of an instruction cycle, whereas for reading, the data must be valid at the beginning of the instruction cycle, as shown in Figure 5-6. Therefore, care must be exercised if a write followed by a read operation is carried out on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with an NOP or another instruction not accessing this I/O port.

| GURE 5-6:              | SUCCESSIVE I/O C                                                                     | <b>DPERATION</b>            |                                       |                             |                               |             |
|------------------------|--------------------------------------------------------------------------------------|-----------------------------|---------------------------------------|-----------------------------|-------------------------------|-------------|
|                        | $Q_1   Q_2   Q_3   Q_4$                                                              | $Q_1   Q_2   Q_3   Q_4$     | Q1                                    | Q2   Q3   Q4                | $Q_1  _{Q_2}  _{Q_3}  _{Q_3}$ | Q4          |
| PC                     | PC                                                                                   | PC + 1                      | X                                     | PC + 2                      | PC + 3                        |             |
| Instruction<br>fetched | MOVWF PORTB<br>Write to<br>PORTB                                                     | MOVF PORTB, W<br>Read PORTB | 1<br>1<br>1                           | NOP<br>I I<br>I I           | NOP                           | 1<br>1<br>1 |
| RB <7:0>               |                                                                                      |                             | XXX                                   |                             |                               | <u> </u>    |
|                        |                                                                                      | TPD 🗕                       | , , , , , , , , , , , , , , , , , , , | Port pin<br>sampled here    |                               |             |
|                        | i i                                                                                  | Execute<br>MOVWF<br>PORTB   | I<br>I                                | Execute<br>MOVF<br>PORTB, W | Execute<br>NOP                | :           |
| 2: Data se             | ample shows write to PO<br>etup time = (0.25 Tcy - Tp<br>valid. Therefore, at higher | D) where TCY = instruct     | ion cy                                | cle and TPD = prop          | • •                           | 1 cycle to  |

© 1996-2013 Microchip Technology Inc.

#### **REGISTER 6-1: CONFIGURATION WORD**

|          | CP1                | CP0                              | CP1        | CP0                                 | CP1       | CP0      | —        | Reserved     | CP1       | CP0      | PWRTE        | WDTE        | F0SC1 | F0SC0 |
|----------|--------------------|----------------------------------|------------|-------------------------------------|-----------|----------|----------|--------------|-----------|----------|--------------|-------------|-------|-------|
|          | bit 13             |                                  |            |                                     |           |          |          |              |           |          |              |             |       | bit 0 |
|          |                    |                                  |            | (4)                                 |           |          |          |              |           |          |              |             |       |       |
| bit 13-8 |                    |                                  | protection | bits <sup>(1)</sup><br>de protect   | ion off   |          |          |              |           |          |              |             |       |       |
| bit 5-4  | 10 = 04<br>01 = 02 | 00h - 07f<br>200h - 07f          | Fh code    | protected<br>protected<br>protected |           |          |          |              |           |          |              |             |       |       |
| bit 7    | Unimpl             | emented                          | I: Read as | s '1'                               |           |          |          |              |           |          |              |             |       |       |
| bit 6    | Reserv             | ed: Do no                        | ot use     |                                     |           |          |          |              |           |          |              |             |       |       |
| bit 3    | 1 = PW             | : Power-<br>RT disab<br>RT enabl | led        | Enable bi                           | t         |          |          |              |           |          |              |             |       |       |
| bit 2    | WDTE:              | Watchdo                          | g Timer E  | nable bit                           |           |          |          |              |           |          |              |             |       |       |
|          |                    | T enable<br>T disable            | -          |                                     |           |          |          |              |           |          |              |             |       |       |
| bit 1-0  | FOSC1              | :FOSC0:                          | Oscillator | r Selectior                         | n bits    |          |          |              |           |          |              |             |       |       |
|          |                    | C oscillato                      |            |                                     |           |          |          |              |           |          |              |             |       |       |
|          |                    | S oscillato<br>F oscillato       |            |                                     |           |          |          |              |           |          |              |             |       |       |
|          | 00 = LF            | oscillato                        | or         |                                     |           |          |          |              |           |          |              |             |       |       |
|          | Note               | <b>1:</b> All c                  | of the CP1 | I:CP0 pair                          | s have to | be given | the same | value to ena | ble the o | code pro | tection sche | eme listed. |       |       |
|          |                    |                                  |            |                                     |           |          |          |              |           |          |              |             |       |       |
|          | Legend             | 1:                               |            |                                     |           |          |          |              |           |          |              |             |       |       |

| Legend:                  |                  |                               |                    |
|--------------------------|------------------|-------------------------------|--------------------|
| R = Readable bit         | W = Writable bit | U = Unimplemented bit, read a | s '0'              |
| - n = Value at POR reset | '1' = Bit is set | '0' = Bit is cleared          | x = Bit is unknown |

#### 6.2.3 EXTERNAL CRYSTAL OSCILLATOR CIRCUIT

Either a pre-packaged oscillator can be used or a simple oscillator circuit with TTL gates can be built. Prepackaged oscillators provide a wide operating range and better stability. A well-designed crystal oscillator will provide good performance with TTL gates. Two types of crystal oscillator circuits can be used: one with series resonance, or one with parallel resonance.

Figure 6-3 shows implementation of a parallel resonant oscillator circuit. The circuit is designed to use the fundamental frequency of the crystal. The 74AS04 inverter performs the 180° phase shift that a parallel oscillator requires. The 4.7 k $\Omega$  resistor provides the negative feedback for stability. The 10 k $\Omega$  potentiometers bias the 74AS04 in the linear region. This could be used for external oscillator designs.

#### FIGURE 6-3: EXTERNAL PARALLEL RESONANT CRYSTAL OSCILLATOR CIRCUIT



Figure 6-4 shows a series resonant oscillator circuit. This circuit is also designed to use the fundamental frequency of the crystal. The inverter performs a  $180^{\circ}$  phase shift in a series resonant oscillator circuit. The  $330\Omega$  resistors provide the negative feedback to bias the inverters in their linear region.

#### FIGURE 6-4: EXTERNAL SERIES RESONANT CRYSTAL OSCILLATOR CIRCUIT



#### 6.2.4 RC OSCILLATOR

For timing insensitive applications the "RC" device option offers additional cost savings. The RC oscillator frequency is a function of the supply voltage, the resistor (REXT) and capacitor (CEXT) values, and the operating temperature. In addition to this, the oscillator frequency will vary from unit to unit due to normal process parameter variation. Furthermore, the difference in lead frame capacitance between package types will also affect the oscillation frequency, especially for low CEXT values. The user also needs to take into account variation due to tolerance of external R and C components used. Figure 6-5 shows how the R/C combination is connected to the PIC16C55X. For REXT values below 2.2 k $\Omega$ , the oscillator operation may become unstable, or stop completely. For very high REXT values (e.g., 1 M $\Omega$ ), the oscillator becomes sensitive to noise, humidity and leakage. Thus, we recommend to keep REXT between 3 k $\Omega$  and 100 k $\Omega$ .

Although the oscillator will operate with no external capacitor (CEXT = 0 pF), we recommend using values above 20 pF for noise and stability reasons. With no or small external capacitance, the oscillation frequency can vary dramatically due to changes in external capacitances, such as PCB trace capacitance or package lead frame capacitance.

The oscillator frequency, divided by 4, is available on the OSC2/CLKOUT pin, and can be used for test purposes or to synchronize other logic (Figure 3-2 for waveform).



#### FIGURE 6-5: RC OSCILLATOR MODE

#### 6.5 Interrupts

The PIC16C55X has 3 sources of interrupt:

- External interrupt RB0/INT
- TMR0 overflow interrupt
- PORTB change interrupts (pins RB7:RB4)

The interrupt control register (INTCON) records individual interrupt requests in flag bits. It also has individual and global interrupt enable bits.

A global interrupt enable bit, GIE (INTCON<7>) enables (if set) all un-masked interrupts or disables (if cleared) all interrupts. Individual interrupts can be disabled through their corresponding enable bits in INTCON register. GIE is cleared on RESET.

The "Return from Interrupt" instruction, RETFIE, exits the interrupt routine as well as sets the GIE bit, which re-enables RB0/INT interrupts.

The INT pin interrupt, the RB port change interrupt and the TMR0 overflow interrupt flags are contained in the INTCON register.

When an interrupt is responded to, the GIE is cleared to disable any further interrupt, the return address is pushed into the stack and the PC is loaded with 0004h. Once in the interrupt service routine the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid RB0/INT recursive interrupts. For external interrupt events, such as the INT pin or PORTB change interrupt, the interrupt latency will be three or four instruction cycles. The exact latency depends when the interrupt event occurs (Figure 6-12). The latency is the same for one or two cycle instructions. Once in the interrupt service routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid multiple interrupt requests. Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit.

- Note 1: Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit.
  - 2: When an instruction that clears the GIE bit is executed, any interrupts that were pending for execution in the next cycle are ignored. The CPU will execute a NOP in the cycle immediately following the instruction which clears the GIE bit. The interrupts which were ignored are still pending to be serviced when the GIE bit is set again.



© 1996-2013 Microchip Technology Inc.

#### 6.9 Code Protection

If the code protection bit(s) have not been programmed, the on-chip program memory can be read out for verification purposes.

| Note: | Microchip  | does   | not   | recommend | code |
|-------|------------|--------|-------|-----------|------|
|       | protecting | windov | ved d | evices.   |      |

#### 6.10 ID Locations

Four memory locations (2000h-2003h) are designated as ID locations where the user can store checksum or other code-identification numbers. These locations are not accessible during normal execution but are readable and writable during program/verify.

#### 6.11 In-Circuit Serial Programming™

The PIC16C55X microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground, and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

The device is placed into a Program/Verify mode by holding the RB6 and RB7 pins low while raising the MCLR (VPP) pin from VIL to VIHH (see programming specification). RB6 becomes the programming clock and RB7 becomes the programming data. Both RB6 and RB7 are Schmitt Trigger inputs in this mode.

After RESET, to place the device into Programming/ Verify mode, the program counter (PC) is at location 00h. A 6-bit command is then supplied to the device. Depending on the command, 14 bits of program data are then supplied to or from the device, depending if the command was a load or a read. For complete details of serial programming, please refer to the PIC16C6X/7X Programming Specifications (Literature #DS30228).

A typical in-circuit serial programming connection is shown in Figure 6-15.

#### FIGURE 6-15: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



#### 7.0 TIMER0 MODULE

The Timer0 module timer/counter has the following features:

- 8-bit timer/counter
- Readable and writable
- 8-bit software programmable prescaler
- · Internal or external clock select
- Interrupt on overflow from FFh to 00h
- Edge select for external clock

Figure 7-1 is a simplified block diagram of the Timer0 module.

Timer mode is selected by clearing the T0CS bit (OPTION<5>). In Timer mode, the TMR0 will increment every instruction cycle (without prescaler). If Timer0 is written, the increment is inhibited for the following two cycles (Figure 7-2 and Figure 7-3). The user can work around this by writing an adjusted value to TMR0.

Counter mode is selected by setting the T0CS bit. In this mode Timer0 will increment either on every rising or falling edge of pin RA4/T0CKI. The incrementing edge is determined by the source edge (T0SE) control bit (OPTION<4>). Clearing the TOSE bit selects the rising edge. Restrictions on the external clock input are discussed in detail in Section 7.2.

The prescaler is shared between the Timer0 module and the Watchdog Timer. The prescaler assignment is controlled in software by the control bit PSA (OPTION<3>). Clearing the PSA bit will assign the prescaler to Timer0. The prescaler is not readable or writable. When the prescaler is assigned to the Timer0 module, prescale value of 1:2, 1:4, ..., 1:256 are selectable. Section 7.3 details the operation of the prescaler.

#### 7.1 TIMER0 Interrupt

Timer0 interrupt is generated when the TMR0 register timer/counter overflows from FFh to 00h. This overflow sets the T0IF bit. The interrupt can be masked by clearing the T0IE bit (INTCON<5>). The T0IF bit (INTCON<2>) must be cleared in software by the Timer0 module interrupt service routine before reenabling this interrupt. The Timer0 interrupt cannot wake the processor from SLEEP since the timer is shut off during SLEEP. See Figure 7-4 for Timer0 interrupt timing.



#### FIGURE 7-2: TIMER0 (TMR0) TIMING: INTERNAL CLOCK/NO PRESCALER



NOTES:

#### 9.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK object linker combines relocatable objects created by the MPASM assembler and the MPLAB C17 and MPLAB C18 C compilers. It can also link relocatable objects from pre-compiled libraries, using directives from a linker script.

The MPLIB object librarian is a librarian for precompiled code to be used with the MPLINK object linker. When a routine from a library is called from another source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications. The MPLIB object librarian manages the creation and modification of library files.

The MPLINK object linker features include:

- Integration with MPASM assembler and MPLAB C17 and MPLAB C18 C compilers.
- Allows all memory areas to be defined as sections to provide link-time flexibility.

The MPLIB object librarian features include:

- Easier linking because single libraries can be included instead of many smaller files.
- Helps keep code maintainable by grouping related modules together.
- Allows libraries to be created and modules to be added, listed, replaced, deleted or extracted.

#### 9.5 MPLAB SIM Software Simulator

The MPLAB SIM software simulator allows code development in a PC-hosted environment by simulating the PIC series microcontrollers on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a file, or user-defined key press, to any of the pins. The execution can be performed in single step, execute until break, or Trace mode.

The MPLAB SIM simulator fully supports symbolic debugging using the MPLAB C17 and the MPLAB C18 C compilers and the MPASM assembler. The software simulator offers the flexibility to develop and debug code outside of the laboratory environment, making it an excellent multi-project software development tool.

#### 9.6 MPLAB ICE High Performance Universal In-Circuit Emulator with MPLAB IDE

The MPLAB ICE universal in-circuit emulator is intended to provide the product development engineer with a complete microcontroller design tool set for PIC microcontrollers (MCUs). Software control of the MPLAB ICE in-circuit emulator is provided by the MPLAB Integrated Development Environment (IDE), which allows editing, building, downloading and source debugging from a single environment.

The MPLAB ICE 2000 is a full-featured emulator system with enhanced trace, trigger and data monitoring features. Interchangeable processor modules allow the system to be easily re configured for emulation of different processors. The universal architecture of the MPLAB ICE in-circuit emulator allows expansion to support new PIC microcontrollers.

The MPLAB ICE in-circuit emulator system has been designed as a real-time emulation system, with advanced features that are generally found on more expensive development tools. The PC platform and Microsoft<sup>®</sup> Windows environment were chosen to best make these features available to you, the end user.

#### 9.7 ICEPIC In-Circuit Emulator

The ICEPIC low cost, in-circuit emulator is a solution for the Microchip Technology PIC16C5X, PIC16C6X, PIC16C7X and PIC16CXXX families of 8-bit One-Time-Programmable (OTP) microcontrollers. The modular system can support different subsets of PIC16C5X or PIC16CXXX products through the use of interchangeable personality modules, or daughter boards. The emulator is capable of emulating without target application circuitry being present.

#### TABLE 9-1: DEVELOPMENT TOOLS FROM MICROCHIP

|                                                                  |      | PIC14000 | PIC16C5X | PIC16C6X | PIC16CXX | PIC16F62) | X7381319   | (X7OðfOld | 78281519 | PIC16F8X | VX6D81DI9 | X4JTrJI9 | (X70710I9 | PIC18CXX | PIC18FXXX | 83CXX<br>52CXX\<br>54CXX\ | ХХХЗЭН | МСКЕХХХ | MCP2510 |
|------------------------------------------------------------------|------|----------|----------|----------|----------|-----------|------------|-----------|----------|----------|-----------|----------|-----------|----------|-----------|---------------------------|--------|---------|---------|
| MPLAB <sup>®</sup> Integrated<br>Development Environment         | -    | ><br>>   | >        | >        | >        | >         | >          | >         | >        | >        | >         | >        | >         | >        | >         |                           |        |         |         |
| MPLAB <sup>®</sup> C17 C Compiler                                |      |          |          |          |          |           |            |           |          |          |           | >        | ~         |          |           |                           |        |         |         |
| MPLAB <sup>®</sup> C18 C Compiler                                |      |          |          |          |          |           |            |           |          |          |           |          |           | >        | ~         |                           |        |         |         |
| MPASM™ Assembler/<br>MPLINK™ Object Linker                       |      | `````    | >        | >        | >        | >         | >          | >         | >        | >        | >         | >        | >         | >        | >         | >                         | >      |         |         |
| MPLAB® ICE In-Circuit Emulator                                   | ator | >        | >        | >        | >        | **`       | >          | >         | >        | >        | >         | >        | >         | >        | >         |                           |        |         |         |
| International Internation ICEPIC™ Internation                    |      | >        | >        | >        | >        |           | >          | >         | >        |          | >         |          |           |          |           |                           |        |         |         |
| eb<br>MPLAB® ICD In-Circuit<br>Debugger                          |      |          |          | *>       |          |           | *>         |           |          | >        |           |          |           |          | >         |                           |        |         |         |
| PICSTART <sup>®</sup> Plus Entry Level<br>Development Programmer |      | ` `      | >        | >        | >        | **^       | >          | >         | `        | `        | >         | >        | >         | >        | >         |                           |        |         |         |
| PRO MATE® II<br>Universal Device Programmer                      |      | ><br>>   | >        | >        | >        | **/       | >          | >         | >        | >        | >         | >        | >         | >        | >         | >                         | >      |         |         |
| PICDEM <sup>TM</sup> 1 Demonstration<br>Board                    |      |          | >        |          | >        |           | ÷,         |           | >        |          |           | >        |           |          |           |                           |        |         |         |
| PICDEM <sup>TM</sup> 2 Demonstration<br>Board                    |      |          |          | ≁        |          |           | <b>^</b> + |           |          |          |           |          |           | >        | >         |                           |        |         |         |
| PICDEM <sup>TM</sup> 3 Demonstration<br>Board                    |      |          |          |          |          |           |            |           |          |          | >         |          |           |          |           |                           |        |         |         |
| PICDEM <sup>TM</sup> 14A Demonstration<br>Board                  | 5    | >        |          |          |          |           |            |           |          |          |           |          |           |          |           |                           |        |         |         |
| PICDEM <sup>TM</sup> 17 Demonstration<br>Board                   |      |          |          |          |          |           |            |           |          |          |           |          | >         |          |           |                           |        |         |         |
| KEELoq <sup>®</sup> Evaluation Kit                               |      |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           | >      |         |         |
| KEELoq <sup>®</sup> Transponder Kit                              |      |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           | >      |         |         |
| microlD <sup>TM</sup> Programmer's Kit                           |      |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           |        | ~       |         |
| 125 kHz microlD™<br>Developer's Kit                              |      |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           |        | >       |         |
| 125 kHz Anticollision microlD™<br>Developer's Kit                | MTO  |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           |        | >       |         |
| 13.56 MHz Anticollision<br>microlD™ Developer's Kit              |      |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           |        | >       |         |
| MCP2510 CAN Developer's Kit                                      | Cit  |          |          |          |          |           |            |           |          |          |           |          |           |          |           |                           |        |         | ~       |

 $\ensuremath{\textcircled{}^{\circ}}$  1996-2013 Microchip Technology Inc.

# PIC16C55X





**2**: The maximum rated speed of the part limits the permissible combinations of voltage and frequency. Please reference the Product Identification System section for the maximum rated speed of the parts.







**2:** The maximum rated speed of the part limits the permissible combinations of voltage and frequency. Please reference the Product Identification System section for the maximum rated speed of the parts.

#### 10.2 DC Characteristics: PIC16C55X (Commercial, Industrial, Extended) PIC16LC55X(Commercial, Industrial, Extended) (Continued)

|               |           |                                | •              | -       | •              |         | otherwise stated)                                                    |
|---------------|-----------|--------------------------------|----------------|---------|----------------|---------|----------------------------------------------------------------------|
|               |           |                                | Operating tem  | peratur |                |         | 5°C for industrial and                                               |
| DC Cha        | racteris  | tics                           |                |         |                |         | 70°C for commercial and                                              |
|               |           |                                |                |         |                |         | 25°C for automotive                                                  |
|               | 1         |                                | Operating volt | age VD  | D range as des | scribed | t in DC spec Table 10-1                                              |
| Param.<br>No. | Sym       | Characteristic                 | Min            | Тур†    | Мах            | Unit    | Conditions                                                           |
|               |           |                                | Vdd-0.7        | -       | —              | V       | Iон=-2.5 mA,<br>Vdd=4.5V, +125°С                                     |
| D092          |           | OSC2/CLKOUT                    | Vdd-0.7        | -       |                | V       | lон=-1.3 mA, VDD=4.5V, -40° to<br>+85°С                              |
|               |           | (RC only)                      | Vdd-0.7        | _       | _              | V       | ІОн=-1.0 mA,<br>VDD=4.5V, +125°С                                     |
| *             | Vod       | Open-Drain High Voltage        |                |         | 10*            | V       | RA4 pin                                                              |
|               |           | Capacitive Loading Specs on    | Output Pins    |         |                | •       |                                                                      |
| D100          | COSC<br>2 | OSC2 pin                       |                |         | 15             | pF      | In XT, HS and LP modes when<br>external clock used to drive<br>OSC1. |
| D101          | Сю        | All I/O pins/OSC2 (in RC mode) |                |         | 50             | pF      |                                                                      |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note** 1: In RC oscillator configuration, the OSC1 pin is a Schmitt Trigger input. It is not recommended that the PIC16C55X be driven with external clock in RC mode.

2: The leakage current on the MCLR pin is strongly dependent on applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

3: Negative current is defined as coming out of the pin.

© 1996-2013 Microchip Technology Inc.

#### **10.4** Timing Diagrams and Specifications



#### FIGURE 10-6: EXTERNAL CLOCK TIMING

#### TABLE 10-1: EXTERNAL CLOCK TIMING REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic                          | Min  | Тур†  | Max    | Units | Conditions                   |
|------------------|-------|-----------------------------------------|------|-------|--------|-------|------------------------------|
|                  | Fos   | External CLKIN Frequency <sup>(1)</sup> | DC   | —     | 4      | MHz   | XT and RC osc mode, VDD=5.0V |
|                  |       |                                         | DC   | —     | 20     | MHz   | HS osc mode                  |
|                  |       |                                         | DC   | —     | 200    | kHz   | LP osc mode                  |
|                  |       | Oscillator Frequency <sup>(1)</sup>     | DC   | _     | 4      | MHz   | RC osc mode, VDD=5.0V        |
|                  |       |                                         | 0.1  | —     | 4      | MHz   | XT osc mode                  |
|                  |       |                                         | 1    | —     | 20     | MHz   | HS osc mode                  |
|                  |       |                                         | DC   | -     | 200    | kHz   | LP osc mode                  |
| 1                | Tosc  | External CLKIN Period <sup>(1)</sup>    | 250  | _     | _      | ns    | XT and RC osc mode           |
|                  |       |                                         | 50   | —     | —      | ns    | HS osc mode                  |
|                  |       |                                         | 5    | —     | _      | μs    | LP osc mode                  |
|                  |       | Oscillator Period <sup>(1)</sup>        | 250  | _     | _      | ns    | RC osc mode                  |
|                  |       |                                         | 250  | —     | 10,000 | ns    | XT osc mode                  |
|                  |       |                                         | 50   | —     | 1,000  | ns    | HS osc mode                  |
|                  |       |                                         | 5    | —     | —      | μs    | LP osc mode                  |
| 2                | Тсу   | Instruction Cycle Time <sup>(1)</sup>   | 1.0  | Fos/4 | DC     | μs    | Tcy=Fos/4                    |
| 3*               | TosL, | External Clock in (OSC1) High or        | 100* | —     | —      | ns    | XT osc mode                  |
|                  | TosH  | Low Time                                | 2*   | —     | —      | μs    | LP osc mode                  |
|                  |       |                                         | 20*  | —     | —      | ns    | HS osc mode                  |
| 4*               | TosR, | External Clock in (OSC1) Rise or        | 25*  | —     | —      | ns    | XT osc mode                  |
|                  | TosF  | Fall Time                               | 50*  | —     | —      | ns    | LP osc mode                  |
|                  |       |                                         | 15*  | —     | —      | ns    | HS osc mode                  |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0 V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note** 1: Instruction cycle period (TCY) equals four times the input oscillator time-base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1 pin. When an external clock input is used, the "Max." cycle time limit is "DC" (no clock) for all devices.



#### **FIGURE 10-8:** RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING

#### **TABLE 10-3**: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER REQUIREMENTS

| Param<br>No. | Sym      | Characteristic                                  | Min    | Тур†         | Max  | Units | Conditions                |
|--------------|----------|-------------------------------------------------|--------|--------------|------|-------|---------------------------|
| 30           | TmcL     | MCLR Pulse Width (low)                          | 2000   |              | —    | ns    | -40° to +85°C             |
| 31           | Twdt     | Watchdog Timer Timeout Period<br>(No Prescaler) | 7*     | 18           | 33*  | ms    | VDD = 5.0V, -40° to +85°C |
| 32           | Tost     | Oscillation Start-up Timer Period               | —      | 1024<br>Tosc | —    | —     | Tosc = OSC1 period        |
| 33           | Tpwrt    | Power-up Timer Period                           | 28*    | 72           | 132* | ms    | VDD = 5.0V, -40° to +85°C |
| 34           | Tioz     | I/O hi-impedance from MCLR low                  |        | —            | 2.0* | μS    |                           |
| *            | These na | arameters are characterized but not             | tested |              |      |       |                           |

These parameters are characterized but not tested.

Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance † only and are not tested.

## 28-Lead Skinny Plastic Dual In-line (SP) – 300 mil (PDIP)

Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



| ision L | n  | MIN                                                                                                              | NOM                                                    | MAX                                                     | MIN                                                    | NOM                                                    | MAX                                                     |
|---------|----|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|
|         |    |                                                                                                                  |                                                        |                                                         |                                                        |                                                        | IVIAA                                                   |
|         | -  |                                                                                                                  | 28                                                     |                                                         |                                                        | 28                                                     |                                                         |
|         | р  |                                                                                                                  | .100                                                   |                                                         |                                                        | 2.54                                                   |                                                         |
|         | А  | .140                                                                                                             | .150                                                   | .160                                                    | 3.56                                                   | 3.81                                                   | 4.06                                                    |
|         | A2 | .125                                                                                                             | .130                                                   | .135                                                    | 3.18                                                   | 3.30                                                   | 3.43                                                    |
|         | A1 | .015                                                                                                             |                                                        |                                                         | 0.38                                                   |                                                        |                                                         |
|         | E  | .300                                                                                                             | .310                                                   | .325                                                    | 7.62                                                   | 7.87                                                   | 8.26                                                    |
|         | E1 | .275                                                                                                             | .285                                                   | .295                                                    | 6.99                                                   | 7.24                                                   | 7.49                                                    |
|         | D  | 1.345                                                                                                            | 1.365                                                  | 1.385                                                   | 34.16                                                  | 34.67                                                  | 35.18                                                   |
|         | L  | .125                                                                                                             | .130                                                   | .135                                                    | 3.18                                                   | 3.30                                                   | 3.43                                                    |
|         | С  | .008                                                                                                             | .012                                                   | .015                                                    | 0.20                                                   | 0.29                                                   | 0.38                                                    |
|         | B1 | .040                                                                                                             | .053                                                   | .065                                                    | 1.02                                                   | 1.33                                                   | 1.65                                                    |
|         | В  | .016                                                                                                             | .019                                                   | .022                                                    | 0.41                                                   | 0.48                                                   | 0.56                                                    |
| §       | eB | .320                                                                                                             | .350                                                   | .430                                                    | 8.13                                                   | 8.89                                                   | 10.92                                                   |
|         | α  | 5                                                                                                                | 10                                                     | 15                                                      | 5                                                      | 10                                                     | 15                                                      |
|         | β  | 5                                                                                                                | 10                                                     | 15                                                      | 5                                                      | 10                                                     | 15                                                      |
|         | Ş  | A           A2           A1           E           D           L           C           B1           §           α | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ |

\* Controlling Parameter § Significant Characteristic

Notes:

Dimension D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed

.010" (0.254mm) per side. JEDEC Equivalent: MO-095

Drawing No. C04-070

NOTES:

NOTES: