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 - Microcontrollers</u>" | Details | | |----------------------------|--------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 4MHz | | Connectivity | - | | Peripherals | POR, WDT | | Number of I/O | 12 | | Program Memory Size | 1.5KB (1K x 12) | | Program Memory Type | OTP | | EEPROM Size | - | | RAM Size | 25 x 8 | | Voltage - Supply (Vcc/Vdd) | 3V ~ 6.25V | | Data Converters | - | | Oscillator Type | External | | Operating Temperature | 0°C ~ 70°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | 20-SSOP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16c56-rc-ss | | | | ### **Pin Diagrams** #### **Device Differences** | Device Differences | | | | | | | | | | |--------------------|------------------|--------------------------------------|------------|------------------------------------|-------------------|----------------|--|--|--| | Device | Voltage<br>Range | Oscillator<br>Selection<br>(Program) | Oscillator | Process<br>Technology<br>(Microns) | ROM<br>Equivalent | MCLR<br>Filter | | | | | PIC16C54 | 2.5-6.25 | Factory | See Note 1 | 1.2 | PIC16CR54A | No | | | | | PIC16C54A | 2.0-6.25 | User | See Note 1 | 0.9 | _ | No | | | | | PIC16C54C | 2.5-5.5 | User | See Note 1 | 0.7 | PIC16CR54C | Yes | | | | | PIC16C55 | 2.5-6.25 | Factory | See Note 1 | 1.7 | _ | No | | | | | PIC16C55A | 2.5-5.5 | User | See Note 1 | 0.7 | _ | Yes | | | | | PIC16C56 | 2.5-6.25 | Factory | See Note 1 | 1.7 | _ | No | | | | | PIC16C56A | 2.5-5.5 | User | See Note 1 | 0.7 | PIC16CR56A | Yes | | | | | PIC16C57 | 2.5-6.25 | Factory | See Note 1 | 1.2 | _ | No | | | | | PIC16C57C | 2.5-5.5 | User | See Note 1 | 0.7 | PIC16CR57C | Yes | | | | | PIC16C58B | 2.5-5.5 | User | See Note 1 | 0.7 | PIC16CR58B | Yes | | | | | PIC16CR54A | 2.5-6.25 | Factory | See Note 1 | 1.2 | N/A | Yes | | | | | PIC16CR54C | 2.5-5.5 | Factory | See Note 1 | 0.7 | N/A | Yes | | | | | PIC16CR56A | 2.5-5.5 | Factory | See Note 1 | 0.7 | N/A | Yes | | | | | PIC16CR57C | 2.5-5.5 | Factory | See Note 1 | 0.7 | N/A | Yes | | | | | PIC16CR58B | 2.5-5.5 | Factory | See Note 1 | 0.7 | N/A | Yes | | | | Note 1: If you change from this device to another device, please verify oscillator characteristics in your application. **Note:** The table shown above shows the generic names of the PIC16C5X devices. For device varieties, please refer to Section 2.0. # PIC16C5X NOTES: ### 5.1 Power-On Reset (POR) The PIC16C5X family incorporates on-chip Power-On Reset (POR) circuitry which provides an internal chip RESET for most power-up situations. To use this feature, the user merely ties the $\overline{\text{MCLR}}/\text{VPP}$ pin to VDD. A simplified block diagram of the on-chip Power-On Reset circuit is shown in Figure 5-1. The Power-On Reset circuit and the Device Reset Timer (Section 5.2) circuit are closely related. On power-up, the RESET latch is set and the DRT is RESET. The DRT timer begins counting once it detects MCLR to be high. After the time-out period, which is typically 18 ms, it will RESET the reset latch and thus end the on-chip RESET signal. A power-up example where $\overline{MCLR}$ is not tied to VDD is shown in Figure 5-3. VDD is allowed to rise and stabilize before bringing $\overline{MCLR}$ high. The chip will actually come out of reset TDRT msec after $\overline{MCLR}$ goes high. In Figure 5-4, the on-chip Power-On Reset feature is being used (MCLR and VDD are tied together). The VDD is stable before the start-up timer times out and there is no problem in getting a proper RESET. However, Figure 5-5 depicts a problem situation where VDD rises too slowly. The time between when the DRT senses a high on the MCLR/VPP pin, and when the MCLR/VPP pin (and VDD) actually reach their full value, is too long. In this situation, when the start-up timer times out, VDD has not reached the VDD (min) value and the chip is, therefore, not guaranteed to function correctly. For such situations, we recommend that external RC circuits be used to achieve longer POR delay times (Figure 5-2). **Note:** When the device starts normal operation (exits the RESET condition), device oper- ating parameters (voltage, frequency, temperature, etc.) must be met to ensure operation. If these conditions are not met, the device must be held in RESET until the operating conditions are met. For more information on PIC16C5X POR, see *Power-Up Considerations* - AN522 in the <u>Embedded Control Handbook</u>. The POR circuit does not produce an internal RESET when VDD declines. # FIGURE 5-2: EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP) - External Power-On Reset circuit is required only if VDD power-up is too slow. The diode D helps discharge the capacitor quickly when VDD powers down. - R < 40 kΩ is recommended to make sure that voltage drop across R does not violate the device electrical specification. - R1 = $100\Omega$ to 1 k $\Omega$ will limit any current flowing into $\overline{\text{MCLR}}$ from external capacitor C in the event of $\overline{\text{MCLR}}$ pin breakdown due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). ### 6.3 STATUS Register This register contains the arithmetic status of the ALU, the RESET status and the page preselect bits for program memories larger than 512 words. The STATUS Register can be the destination for any instruction, as with any other register. If the STATUS Register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the $\overline{\text{TO}}$ and $\overline{\text{PD}}$ bits are not writable. Therefore, the result of an instruction with the STATUS Register as destination may be different than intended. For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS Register as 000u uluu (where u = unchanged). It is recommended, therefore, that only BCF, BSF and MOVWF instructions be used to alter the STATUS Register because these instructions do not affect the Z, DC or C bits from the STATUS Register. For other instructions which do affect STATUS Bits, see Section 10.0, Instruction Set Summary. ### REGISTER 6-1: STATUS REGISTER (ADDRESS: 03h) | R/W-0 | R/W-0 | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x | | |-------|-------|-------|-----|-----|-------|-------|-------|--| | PA2 | PA1 | PA0 | TO | PD | Z | DC | С | | | bit 7 | | | | | | | bit 0 | | bit 7: **PA2**: This bit unused at this time. Use of the PA2 bit as a general purpose read/write bit is not recommended, since this may affect upward compatibility with future products. bit 6-5: PA<1:0>: Program page preselect bits (PIC16C56/CR56)(PIC16C57/CR57)(PIC16C58/CR58) 00 = Page 0 (000h - 1FFh) - PIC16C56/CR56, PIC16C57/CR57, PIC16C58/CR58 01 = Page 1 (200h - 3FFh) - PIC16C56/CR56, PIC16C57/CR57, PIC16C58/CR58 10 = Page 2 (400h - 5FFh) - PIC16C57/CR57, PIC16C58/CR58 11 = Page 3 (600h - 7FFh) - PIC16C57/CR57, PIC16C58/CR58 Each page is 512 words. Using the PA<1:0> bits as general purpose read/write bits in devices which do not use them for program page preselect is not recommended since this may affect upward compatibility with future products. bit 4: **TO**: Time-out bit 1 = After power-up, CLRWDT instruction, or SLEEP instruction 0 = A WDT time-out occurred bit 3: **PD**: Power-down bit 1 = After power-up or by the CLRWDT instruction 0 = By execution of the SLEEP instruction bit 2: Z: Zero bit 1 = The result of an arithmetic or logic operation is zero 0 = The result of an arithmetic or logic operation is not zero bit 1: **DC**: Digit carry/borrow bit (for ADDWF and SUBWF instructions) ### ADDWF 1 = A carry from the 4th low order bit of the result occurred 0 = A carry from the 4th low order bit of the result did not occur #### **SUBWF** 1 = A borrow from the 4th low order bit of the result did not occur 0 = A borrow from the 4th low order bit of the result occurred bit 0: C: Carry/borrow bit (for ADDWF, SUBWF and RRF, RLF instructions) ADDWF SUBWF RRF or RLF 1 = A carry occurred 1 = A borrow did not occur 0 = A carry did not occur 0 = A borrow occurred 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 Loaded with LSb or MSb, respectively ### 6.4 OPTION Register The OPTION Register is a 6-bit wide, write-only register which contains various control bits to configure the Timer0/WDT prescaler and Timer0. By executing the OPTION instruction, the contents of the W Register will be transferred to the OPTION Register. A RESET sets the OPTION<5:0> bits. ### **REGISTER 6-2: OPTION REGISTER** | U-0 | U-0 | W-1 | W-1 | W-1 | W-1 | W-1 | W-1 | |-------|-----|------|------|-----|-----|-----|-------| | _ | _ | T0CS | TOSE | PSA | PS2 | PS1 | PS0 | | bit 7 | | | | | | | bit 0 | bit 7-6: Unimplemented: Read as '0' bit 5: Tocs: Timer0 clock source select bit 1 = Transition on T0CKI pin 0 = Internal instruction cycle clock (CLKOUT) bit 4: **T0SE**: Timer0 source edge select bit 1 = Increment on high-to-low transition on T0CKI pin0 = Increment on low-to-high transition on T0CKI pin bit 3: **PSA**: Prescaler assignment bit 1 = Prescaler assigned to the WDT0 = Prescaler assigned to Timer0 bit 2-0: **PS<2:0>**: Prescaler rate select bits | Bit Value | Timer0 Rate | WDT Rate | |-----------|-------------|----------| | 000 | 1:2 | 1:1 | | 001 | 1:4 | 1:2 | | 010 | 1:8 | 1:4 | | 011 | 1:16 | 1:8 | | 100 | 1:32 | 1:16 | | 101 | 1:64 | 1:32 | | 110 | 1 : 128 | 1:64 | | 111 | 1:256 | 1:128 | 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 # 6.7 Indirect Data Addressing; INDF and FSR Registers The INDF Register is not a physical register. Addressing INDF actually addresses the register whose address is contained in the FSR Register (FSR is a *pointer*). This is indirect addressing. #### **EXAMPLE 6-1: INDIRECT ADDRESSING** - Register file 08 contains the value 10h - Register file 09 contains the value 0Ah - · Load the value 08 into the FSR Register - A read of the INDF Register will return the value of 10h - Increment the value of the FSR Register by one (FSR = 09h) - A read of the INDF register now will return the value of 0Ah. Reading INDF itself indirectly (FSR = 0) will produce 00h. Writing to the INDF Register indirectly results in a no-operation (although STATUS bits may be affected). A simple program to clear RAM locations 10h-1Fh using indirect addressing is shown in Example 6-2. # EXAMPLE 6-2: HOW TO CLEAR RAM USING INDIRECT ADDRESSING | | MOVLW | H'10' | ;initialize pointer | |----------|-------|-------|----------------------| | | MOVWF | FSR | ; to RAM | | NEXT | CLRF | INDF | ;clear INDF Register | | | INCF | FSR,F | ;inc pointer | | | BTFSC | FSR,4 | ;all done? | | | GOTO | NEXT | ;NO, clear next | | CONTINUE | | | | | | : | | ;YES, continue | The FSR is either a 5-bit (PIC16C54, PIC16CR54, PIC16C55, PIC16C56, PIC16CR56) or 7-bit (PIC16C57, PIC16CR57, PIC16CR58, PIC16CR58) wide register. It is used in conjunction with the INDF Register to indirectly address the data memory area. The FSR<4:0> bits are used to select data memory addresses 00h to 1Fh. **PIC16C54, PIC16CR54, PIC16C55, PIC16C56, PIC16CR56:** These do not use banking. FSR<6:5> bits are unimplemented and read as '1's. **PIC16C57, PIC16CR57, PIC16C58, PIC16CR58:** FSR<6:5> are the bank select bits and are used to select the bank to be addressed (00 = bank 0, 01 = bank 1, 10 = bank 2, 11 = bank 3). #### FIGURE 6-10: DIRECT/INDIRECT ADDRESSING # 8.1 Using Timer0 with an External Clock When an external clock input is used for Timer0, it must meet certain requirements. The external clock requirement is due to internal phase clock (Tosc) synchronization. Also, there is a delay in the actual incrementing of Timer0 after synchronization. # 8.1.1 EXTERNAL CLOCK SYNCHRONIZATION When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks (Figure 8-5). Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device. When a prescaler is used, the external clock input is divided by the asynchronous ripple counter-type prescaler so that the prescaler output is symmetrical. For the external clock to meet the sampling requirement, the ripple counter must be taken into account. Therefore, it is necessary for TOCKI to have a period of at least 4Tosc (and a small RC delay of 40 ns) divided by the prescaler value. The only requirement on TOCKI high and low time is that they do not violate the minimum pulse width requirement of 10 ns. Refer to parameters 40, 41 and 42 in the electrical specification of the desired device. #### 8.1.2 TIMERO INCREMENT DELAY Since the prescaler output is synchronized with the internal clocks, there is a small delay from the time the external clock edge occurs to the time the Timer0 module is actually incremented. Figure 8-5 shows the delay from the external clock edge to the timer incrementing. FIGURE 8-5: TIMERO TIMING WITH EXTERNAL CLOCK - **Note 1:** External clock if no prescaler selected, prescaler output otherwise. - 2: The arrows indicate the points in time where sampling occurs. - 3: Delay from clock input change to Timer0 increment is 3Tosc to 7Tosc (duration of Q = Tosc). Therefore, the error in measuring the interval between two edges on Timer0 input = $\pm$ 4Tosc max. # 9.0 SPECIAL FEATURES OF THE CPU What sets a microcontroller apart from other processors are special circuits that deal with the needs of real-time applications. The PIC16C5X family of microcontrollers have a host of such features intended to maximize system reliability, minimize cost through elimination of external components, provide power saving operating modes and offer code protection. These features are: - Oscillator Selection (Section 4.0) - RESET (Section 5.0) - Power-On Reset (Section 5.1) - Device Reset Timer (Section 5.2) - Watchdog Timer (WDT) (Section 9.2) - SLEEP (Section 9.3) - Code protection (Section 9.4) - ID locations (Section 9.5) The PIC16C5X Family has a Watchdog Timer which can be shut off only through configuration bit WDTE. It runs off of its own RC oscillator for added reliability. There is an 18 ms delay provided by the Device Reset Timer (DRT), intended to keep the chip in RESET until the crystal oscillator is stable. With this timer on-chip, most applications need no external RESET circuitry. The SLEEP mode is designed to offer a very low current Power-down mode. The user can wake up from SLEEP through external RESET or through a Watchdog Timer time-out. Several oscillator options are also made available to allow the part to fit the application. The RC oscillator option saves system cost while the LP crystal option saves power. A set of configuration bits are used to select various options. ### 9.3 Power-Down Mode (SLEEP) A device may be powered down (SLEEP) and later powered up (Wake-up from SLEEP). #### 9.3.1 SLEEP The Power-down mode is entered by executing a SLEEP instruction. If enabled, the Watchdog Timer will be cleared but keeps running, the $\overline{10}$ bit (STATUS<4>) is set, the $\overline{PD}$ bit (STATUS<3>) is cleared and the oscillator driver is turned off. The I/O ports maintain the status they had before the SLEEP instruction was executed (driving high, driving low, or hi-impedance). It should be noted that a RESET generated by a WDT time-out does not drive the MCLR/VPP pin low. For lowest current consumption while powered down, the T0CKI input should be at VDD or Vss and the $\overline{\text{MCLR}}/\text{VPP}$ pin must be at a logic high level $\overline{\text{(MCLR}} = \text{VIH)}$ . #### 9.3.2 WAKE-UP FROM SLEEP The device can wake up from SLEEP through one of the following events: - 1. An external RESET input on MCLR/VPP pin. - 2. A Watchdog Timer Time-out Reset (if WDT was enabled). Both of these events cause a device RESET. The $\overline{\text{TO}}$ and $\overline{\text{PD}}$ bits can be used to determine the cause of device RESET. The $\overline{\text{TO}}$ bit is cleared if a WDT timeout occurred (and caused wake-up). The $\overline{\text{PD}}$ bit, which is set on power-up, is cleared when SLEEP is invoked. The WDT is cleared when the device wakes from SLEEP, regardless of the wake-up source. # 9.4 Program Verification/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 windowed devices. #### 9.5 ID Locations Four memory locations 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. Use only the lower 4 bits of the ID locations and always program the upper 8 bits as '1's. Note: Microchip will assign a unique pattern number for QTP and SQTP requests and for ROM devices. This pattern number will be unique and traceable to the submitted code. | ADDWF | Add | W | and f | | | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------|-----|----|--| | Syntax: | [ lab | el] | ADDWF | f,d | | | | Operands: | 0 ≤ 1<br>d ∈ | | - | | | | | Operation: | (W) | + (f) | $\rightarrow$ (dest) | | | | | Status Affected: | C, D | )C, Z | <u> </u> | | | | | Encoding: | 00 | 01 | 11df | ff | ff | | | Description: | Add the contents of the W registe and register 'f'. If 'd' is 0 the result is stored in the W register. If 'd' is '1' the result is stored back in register 'f'. | | | | | | | Words: | 1 | | | | | | | Cycles: | 1 | | | | | | | Example: | ADD | WF | TEMP_RE | EG, | 0 | | | Before Instr | uctio | n | | | | | | W | | = | 0x17 | | | | | TEMP_I | | = | 0xC2 | | | | | After Instruc | ction | | | | | | | W | | = | 0xD9 | | | | | TEMP_I | REG | = | 0xC2 | | | | | ANDWF | AND W with f | | | | | | |---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Syntax: | [ label ] ANDWF f,d | | | | | | | Operands: | $0 \le f \le 31$<br>$d \in [0,1]$ | | | | | | | Operation: | (W) .AND. (f) $\rightarrow$ (dest) | | | | | | | Status Affected: | Z | | | | | | | Encoding: | 0001 01df ffff | | | | | | | Description: | The contents of the W register are AND'ed with register 'f'. If 'd' is 0 the result is stored in the W register. If 'd' is '1' the result is stored back in register 'f'. | | | | | | | Words: | 1 | | | | | | | Cycles: | 1 | | | | | | | Example: | ANDWF TEMP_REG, 1 | | | | | | | Before Instruction W = 0x17 TEMP_REG = 0xC2 After Instruction W = 0x17 TEMP_REG = 0x02 | | | | | | | | ANDLW | AND literal with W | | | | | | | |-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Syntax: | [ label ] ANDLW k | | | | | | | | Operands: | $0 \leq k \leq 255$ | | | | | | | | Operation: | (W).AND. (k) $\rightarrow$ (W) | | | | | | | | Status Affected: | Z | | | | | | | | Encoding: | 1110 kkkk kkkk | | | | | | | | Description: | The contents of the W register are AND'ed with the eight-bit literal 'k'. The result is placed in the W register. | | | | | | | | Words: | 1 | | | | | | | | Cycles: | 1 | | | | | | | | Example: | ANDLW H'5F' | | | | | | | | Before Instruction W = 0xA3 After Instruction W = 0x03 | | | | | | | | | BCF | Bit Clea | r f | | | | | | |-----------------------------------|----------------------------------|--------------|-------------|--|--|--|--| | Syntax: | [ label ] | BCF f,t | ) | | | | | | Operands: | $0 \le f \le 31$ $0 \le b \le 7$ | | | | | | | | Operation: | $0 \rightarrow (f < b)$ | >) | | | | | | | Status Affected: | None | | | | | | | | Encoding: | 0100 | bbbf | ffff | | | | | | Description: | Bit 'b' in | register 'f' | is cleared. | | | | | | Words: | 1 | | | | | | | | Cycles: | 1 | | | | | | | | Example: | BCF | FLAG_RE | EG, 7 | | | | | | Before Instruction | | | | | | | | | FLAG_REG = 0xC7 After Instruction | | | | | | | | | FLAG_R | | 0x47 | | | | | | ### 12.5 DC Characteristics: PIC16C54/55/56/57-RCE, XTE, 10E, HSE, LPE (Extended) | | | | Standard Operating Conditions (unless otherwise specified) Operating Temperature $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for extended | | | | | | |--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Param<br>No. | Symbol | Characteristic | Min | Typ† | Max | Units | Conditions | | | D030 | VIL | Input Low Voltage I/O ports MCLR (Schmitt Trigger) TOCKI (Schmitt Trigger) OSC1 (Schmitt Trigger) OSC1 (Schmitt Trigger) | Vss<br>Vss<br>Vss<br>Vss<br>Vss | 11111 | 0.15 VDD<br>0.15 VDD<br>0.15 VDD<br>0.15 VDD<br>0.3 VDD | V<br>V<br>V<br>V | Pin at hi-impedance PIC16C5X-RC only <sup>(3)</sup> PIC16C5X-XT, 10, HS, LP | | | D040 | VHYS | Input High Voltage I/O ports I/O ports I/O ports MCLR (Schmitt Trigger) TOCKI (Schmitt Trigger) OSC1 (Schmitt Trigger) OSC1 (Schmitt Trigger) Hysteresis of Schmitt | 0.45 VDD<br>2.0<br>0.36 VDD<br>0.85 VDD<br>0.85 VDD<br>0.85 VDD<br>0.7 VDD | | VDD VDD VDD VDD VDD VDD VDD VDD | V<br>V<br>V<br>V<br>V | For all $VDD^{(4)}$<br>$4.0V < VDD \le 5.5V^{(4)}$<br>VDD > 5.5 V<br>PIC16C5X-RC only <sup>(3)</sup><br>PIC16C5X-XT, 10, HS, LP | | | D060 | lι∟ | Trigger inputs Input Leakage Current (1,2) I/O ports MCLR MCLR TOCKI OSC1 | -1<br>-5<br>-3<br>-3 | 0.5<br><br>0.5<br>0.5<br>0.5 | +1<br><br>+5<br>+3<br>+3 | μΑ<br>μΑ<br>μΑ<br>μΑ<br>μΑ | For VDD $\leq$ 5.5 V:<br>VSS $\leq$ VPIN $\leq$ VDD,<br>pin at hi-impedance<br>VPIN = VSS + 0.25V<br>VPIN = VDD<br>VSS $\leq$ VPIN $\leq$ VDD<br>VSS $\leq$ VPIN $\leq$ VDD,<br>PIC16C5X-XT, 10, HS, LP | | | D080 | Vol | Output Low Voltage I/O ports OSC2/CLKOUT | | _ | 0.6<br>0.6 | V<br>V | IOL = 8.7 mA, VDD = 4.5V<br>IOL = 1.6 mA, VDD = 4.5V,<br>PIC16C5X-RC | | | D090 | Voн | Output High Voltage <sup>(2)</sup> I/O ports OSC2/CLKOUT | VDD - 0.7<br>VDD - 0.7 | _ | | V<br>V | IOH = -5.4 mA, VDD = 4.5V<br>IOH = -1.0 mA, VDD = 4.5V,<br>PIC16C5X-RC | | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested. Note 1: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltage. <sup>2:</sup> Negative current is defined as coming out of the pin. **<sup>3:</sup>** For PIC16C5X-RC devices, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC16C5X be driven with external clock in RC mode. **<sup>4:</sup>** The user may use the better of the two specifications. ## 12.7 Timing Diagrams and Specifications FIGURE 12-2: EXTERNAL CLOCK TIMING - PIC16C54/55/56/57 TABLE 12-1: EXTERNAL CLOCK TIMING REQUIREMENTS - PIC16C54/55/56/57 | AC Chara | cteristics | Standard Operating Conditions (unless otherwise specified) Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended | | | | | | | |---------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|-----|-------|------------------------|--| | Param<br>No. Symbol | | Characteristic | Min | Typ† | Max | Units | Conditions | | | 1A | Fosc | External CLKIN Frequency <sup>(1)</sup> | DC | _ | 4.0 | MHz | XT osc mode | | | | | | DC | _ | 10 | MHz | 10 MHz mode | | | | | | DC | _ | 20 | MHz | HS osc mode (Comm/Ind) | | | | | | DC | _ | 16 | MHz | HS osc mode (Ext) | | | | | | DC | _ | 40 | kHz | LP osc mode | | | | | Oscillator Frequency <sup>(1)</sup> | DC | _ | 4.0 | MHz | RC osc mode | | | | | | 0.1 | _ | 4.0 | MHz | XT osc mode | | | | | | 4.0 | _ | 10 | MHz | 10 MHz mode | | | | | | 4.0 | _ | 20 | MHz | HS osc mode (Comm/Ind) | | | | | | 4.0 | _ | 16 | MHz | HS osc mode (Ext) | | | | | | DC | _ | 40 | kHz | LP osc mode | | <sup>\*</sup> These parameters are characterized but not tested. - Note 1: 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. When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices. - 2: Instruction cycle period (Tcy) equals four times the input oscillator time base period. <sup>†</sup> Data in the Typical ("Typ") column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. FIGURE 12-4: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER TIMING - PIC16C54/55/56/57 TABLE 12-3: RESET, WATCHDOG TIMER, AND DEVICE RESET TIMER - PIC16C54/55/56/57 | AC Characteristics | | Standard Operating Conditions (unless otherwise specified) Operating Temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial $-40^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial $-40^{\circ}C \leq TA \leq +125^{\circ}C$ for extended | | | | | | | | |--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|-------|-------------------|--|--| | Param<br>No. | Symbol | Characteristic | Min | Тур† | Max | Units | Conditions | | | | 30 | TmcL | MCLR Pulse Width (low) | | _ | _ | ns | VDD = 5.0V | | | | 31 | Twdt | Watchdog Timer Time-out Period (No Prescaler) | 9.0* | 18* | 30* | ms | VDD = 5.0V (Comm) | | | | 32 | TDRT | Device Reset Timer Period | 9.0* | 18* | 30* | ms | VDD = 5.0V (Comm) | | | | 34 | Tioz | I/O Hi-impedance from MCLR Low | _ | _ | 100* | ns | | | | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in the Typical ("Typ") column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Q1 Q3 Q4 Q2 OSC1 CLKOUT <del><-</del>18→ 19 14 I/O Pin (input) I/O Pin (output) New Value Old Value 20, 21 Note: Please refer to Figure 13.1 for load conditions. FIGURE 13-3: CLKOUT AND I/O TIMING - PIC16CR54A TABLE 13-2: CLKOUT AND I/O TIMING REQUIREMENTS - PIC16CR54A | AC Characteristics | | Standard Operating Conditions (unless otherwise specified) Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended | | | | | | | |--------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------|------|-------|--|--| | Param<br>No. | Symbol | Characteristic | Min | Тур† | Max | Units | | | | 10 | TosH2ckL | OSC1 <sup>↑</sup> to CLKOUT↓ <sup>(1)</sup> | _ | 15 | 30** | ns | | | | 11 | TosH2ckH | OSC1 <sup>†</sup> to CLKOUT <sup>†(1)</sup> | _ | 15 | 30** | ns | | | | 12 | TckR | CLKOUT rise time <sup>(1)</sup> | _ | 5.0 | 15** | ns | | | | 13 | TckF | CLKOUT fall time <sup>(1)</sup> | _ | 5.0 | 15** | ns | | | | 14 | TckL2ioV | CLKOUT↓ to Port out valid <sup>(1)</sup> | _ | _ | 40** | ns | | | | 15 | TioV2ckH | Port in valid before CLKOUT <sup>(1)</sup> | 0.25 TCY+30* | | _ | ns | | | | 16 | TckH2ioI | Port in hold after CLKOUT <sup>(1)</sup> | 0* | | _ | ns | | | | 17 | TosH2ioV | OSC1 <sup>↑</sup> (Q1 cycle) to Port out valid <sup>(2)</sup> | _ | _ | 100* | ns | | | | 18 | TosH2ioI | OSC1 <sup>†</sup> (Q2 cycle) to Port input invalid (I/O in hold time) | TBD | | _ | ns | | | | 19 | TioV2osH | Port input valid to OSC1↑ (I/O in setup time) | TBD | | _ | ns | | | | 20 | TioR | Port output rise time <sup>(2)</sup> | _ | 10 | 25** | ns | | | | 21 | TioF | Port output fall time <sup>(2)</sup> | _ | 10 | 25** | ns | | | <sup>\*</sup> These parameters are characterized but not tested. <sup>\*\*</sup> These parameters are design targets and are not tested. No characterization data available at this time. <sup>†</sup> Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested. Note 1: Measurements are taken in RC Mode where CLKOUT output is 4 x Tosc. <sup>2:</sup> Please refer to Figure 13.1 for load conditions. # PIC16C5X NOTES: 17.3 DC Characteristics: PIC16C54C/C55A/C56A/C57C/C58B-04, 20 (Commercial, Industrial, Extended) PIC16LC54C/LC55A/LC56A/LC57C/LC58B-04 (Commercial, Industrial) PIC16CR54C/CR56A/CR57C/CR58B-04, 20 (Commercial, Industrial, Extended) PIC16LCR54C/LCR56A/LCR57C/LCR58B-04 (Commercial, Industrial) | DC CHARACTERISTICS | | | Standard Operating Conditions (unless otherwise specified) Operating Temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial $-40^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial $-40^{\circ}C \leq TA \leq +125^{\circ}C$ for extended | | | | | | |--------------------|--------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------------------------------------------------|----------------------|-------------------------------------------------------------------------------------------------|--| | Param<br>No. | Symbol | Characteristic | Min | Тур† | Max | Units | Conditions | | | D030 | VIL | Input Low Voltage I/O Ports I/O Ports MCLR (Schmitt Trigger) T0CKI (Schmitt Trigger) OSC1 (Schmitt Trigger) OSC1 | Vss<br>Vss<br>Vss<br>Vss<br>Vss | _<br>_<br>_<br>_ | 0.8 V<br>0.15 VDD<br>0.15 VDD<br>0.15 VDD<br>0.15 VDD<br>0.3 VDD | V<br>V<br>V<br>V | 4.5V <vdd 5.5v="" mode="" only<sup="" otherwise="" rc="" ≤="">(3) XT, HS and LP modes</vdd> | | | D040 | ViH | Input High Voltage I/O ports I/O ports MCLR (Schmitt Trigger) T0CKI (Schmitt Trigger) OSC1 (Schmitt Trigger) OSC1 | 2.0<br>0.25 Vdd+0.8<br>0.85 Vdd<br>0.85 Vdd<br>0.85 Vdd<br>0.7 Vdd | _<br>_<br>_<br>_ | VDD<br>VDD<br>VDD<br>VDD<br>VDD<br>VDD | V<br>V<br>V<br>V | 4.5V < VDD ≤ 5.5V Otherwise RC mode only <sup>(3)</sup> XT, HS and LP modes | | | D050 | VHYS | Hysteresis of Schmitt<br>Trigger inputs | 0.15 VDD* | _ | _ | V | | | | D060 | lı∟ | Input Leakage Current <sup>(1,2)</sup> I/O ports | -1.0 | 0.5 | +1.0 | μА | For VDD ≤ 5.5V:<br>VSS ≤ VPIN ≤ VDD,<br>pin at hi-impedance | | | | | MCLR<br>MCLR<br>TOCKI<br>OSC1 | -5.0<br>-3.0<br>-3.0 | 0.5<br>0.5<br>0.5 | +5.0<br>+3.0<br>+3.0<br>— | μΑ<br>μΑ<br>μΑ<br>μΑ | VPIN = VSS +0.25V<br>VPIN = VDD<br>VSS ≤ VPIN ≤ VDD<br>VSS ≤ VPIN ≤ VDD,<br>XT, HS and LP modes | | | D080 | Vol | Output Low Voltage I/O ports OSC2/CLKOUT | | _ | 0.6<br>0.6 | V<br>V | IOL = 8.7 mA, VDD = 4.5V<br>IOL = 1.6 mA, VDD = 4.5V,<br>RC mode only | | | D090 | Voн | Output High Voltage <sup>(2)</sup> I/O ports OSC2/CLKOUT | VDD - 0.7<br>VDD - 0.7 | _ | | V<br>V | IOH = -5.4 mA, VDD = 4.5V<br>IOH = -1.0 mA, VDD = 4.5V,<br>RC mode only | | These parameters are characterized but not tested. <sup>†</sup> Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested. Note 1: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltage. <sup>2:</sup> Negative current is defined as coming out of the pin. **<sup>3:</sup>** For the RC mode, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC16C5X be driven with external clock in RC mode. # FIGURE 20-7: WDT TIMER TIME-OUT PERIOD vs. VDD<sup>(1)</sup> #### TABLE 20-1: INPUT CAPACITANCE | Pin | Typical Capacitance (pF) | | | | | |-------------|--------------------------|----------|--|--|--| | Pin | 18L PDIP | 18L SOIC | | | | | RA port | 5.0 | 4.3 | | | | | RB port | 5.0 | 4.3 | | | | | MCLR | 17.0 | 17.0 | | | | | OSC1 | 4.0 | 3.5 | | | | | OSC2/CLKOUT | 4.3 | 3.5 | | | | | T0CKI | 3.2 | 2.8 | | | | All capacitance values are typical at 25°C. A part-to-part variation of $\pm 25\%$ (three standard deviations) should be taken into account. FIGURE 20-8: IOH vs. VOH, VDD = 5 V ## 18-Lead Plastic Dual In-line (P) - 300 mil (PDIP) Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | INCHES* | | | MILLIMETERS | | | | |----------------------------|---------|------|------|-------------|-------|-------|-------| | Dimension | MIN | NOM | MAX | MIN | NOM | MAX | | | Number of Pins | n | | 18 | | | 18 | | | Pitch | р | | .100 | | | 2.54 | | | Top to Seating Plane | Α | .140 | .155 | .170 | 3.56 | 3.94 | 4.32 | | Molded Package Thickness | A2 | .115 | .130 | .145 | 2.92 | 3.30 | 3.68 | | Base to Seating Plane | A1 | .015 | | | 0.38 | | | | Shoulder to Shoulder Width | Е | .300 | .313 | .325 | 7.62 | 7.94 | 8.26 | | Molded Package Width | E1 | .240 | .250 | .260 | 6.10 | 6.35 | 6.60 | | Overall Length | D | .890 | .898 | .905 | 22.61 | 22.80 | 22.99 | | Tip to Seating Plane | L | .125 | .130 | .135 | 3.18 | 3.30 | 3.43 | | Lead Thickness | С | .008 | .012 | .015 | 0.20 | 0.29 | 0.38 | | Upper Lead Width | B1 | .045 | .058 | .070 | 1.14 | 1.46 | 1.78 | | Lower Lead Width | В | .014 | .018 | .022 | 0.36 | 0.46 | 0.56 | | Overall Row Spacing § | eВ | .310 | .370 | .430 | 7.87 | 9.40 | 10.92 | | Mold Draft Angle Top | 5 | 10 | 15 | 5 | 10 | 15 | | | Mold Draft Angle Bottom | 5 | 10 | 15 | 5 | 10 | 15 | | Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side. JEDEC Equivalent: MS-001 Drawing No. C04-007 <sup>\*</sup> Controlling Parameter § Significant Characteristic | INDEX | Extended | 82, 84 | |---------------------------------------------|-----------------------------------------|----------| | | Industrial | 80, 83 | | A | PIC16LV54A | | | Absolute Maximum Ratings | Commercial | 108, 109 | | PIC16C54/55/56/5767 | Industrial | 108, 109 | | PIC16C54A103 | DECF | 54 | | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | DECFSZ | 54 | | C58B/CR58B131 | Development Support | 61 | | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | Device Characterization | | | C58B/CR58B-40 | PIC16C54/55/56/57/CR54A | 91 | | PIC16CR54A | PIC16C54A | | | ADDWF | PIC16C54C/C55A/C56A/C57C/C58B-40 | | | | Device Reset Timer (DRT) | | | ALU9 | Device Varieties | | | ANDLW | Digit Carry (DC) bit | | | ANDWF51 | DRT | | | Applications5 | DIX1 | 20 | | Architectural Overview9 | E | | | Assembler | | | | MPASM Assembler61 | Electrical Specifications | 07 | | В | PIC16C54/55/56/57 | | | В | PIC16C54A | | | Block Diagram | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/ | | | On-Chip Reset Circuit20 | C58B/CR58B | | | PIC16C5X Series10 | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/ | | | Timer037 | C58B/CR58B-40 | | | TMR0/WDT Prescaler41 | PIC16CR54A | 79 | | Watchdog Timer46 | Errata | 3 | | Brown-Out Protection Circuit | External Power-On Reset Circuit | 21 | | BSF | _ | | | BTFSC | F | | | BTFSS | Family of Devices | | | 511 00 | PIC16C5X | 6 | | C | FSR Register | 33 | | CALL31, 53 | Value on reset | | | · | 14.45 | | | Carry (C) bit | G | | | Clocking Scheme | General Purpose Registers | | | CLRF53 | Value on reset | 20 | | CLRW | GOTO | | | CLRWDT53 | GO10 | 51, 55 | | CMOS Technology1 | Н | | | Code Protection43, 47 | | | | COMF54 | High-Performance RISC CPU | 1 | | Compatibility182 | I | | | Configuration Bits44 | • | | | _ | I/O Interfacing | | | D | I/O Ports | | | Data Memory Organization | I/O Programming Considerations | 36 | | DC Characteristics | ICEPIC In-Circuit Emulator | 62 | | PIC16C54/55/56/57 | ID Locations | 43, 47 | | Commercial | INCF | 55 | | Extended | INCFSZ | 55 | | Industrial | INDF Register | 33 | | PIC16C54A | Value on reset | 20 | | Commercial104, 109 | Indirect Data Addressing | | | • | Instruction Cycle | | | Extended | Instruction Flow/Pipelining | | | · | Instruction Set Summary | | | PIC16C54C/C55A/C56A/C57C/C58B-40 | IORLW | | | Commercial | IORUWIORWF | | | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | IOIXWF | 56 | | C58B/CR58B | K | | | Commercial134, 138 | | ٠. | | Extended137, 138 | KeeLoq Evaluation and Programming Tools | 64 | | Industrial134, 138 | L | | | PIC16CR54A | | | | Commercial 80, 83 | Loading of PC | 31 | # PIC16C5X | M | Q | |----------------------------------------------------------|---------------------------------------------------------| | MCLR Reset | Q cycles13 | | Register values on20 | Quick-Turnaround-Production (QTP) Devices | | Memory Map | <u> </u> | | PIC16C54/CR54/C5525 | R | | PIC16C56/CR5625 | RC Oscillator17 | | PIC16C57/CR57/C58/CR5825 | Read Only Memory (ROM) Devices7 | | Memory Organization25 | Read-Modify-Write36 | | MOVF56 | Register File Map | | MOVLW56 | PIC16C54, PIC16CR54, PIC16C55, PIC16C56, | | MOVWF57 | PIC16CR56 | | MPLAB C17 and MPLAB C18 C Compilers61 | PIC16C57/CR57 27 | | MPLAB ICD In-Circuit Debugger63 | PIC16C58/CR5827 | | MPLAB ICE High Performance Universal In-Circuit Emulator | Registers | | with MPLAB IDE62 | Special Function28 | | MPLAB Integrated Development Environment Software 61 | Value on reset20 | | MPLINK Object Linker/MPLIB Object Librarian62 | Reset 19 | | •• | Reset on Brown-Out23 | | N | RETLW 57 | | NOP57 | RLF58 | | | RRF 58 | | 0 | | | One-Time-Programmable (OTP) Devices7 | S | | OPTION57 | Serialized Quick-Turnaround-Production (SQTP) Devices 7 | | OPTION Register30 | SLEEP 43, 47, 58 | | Value on reset20 | Software Simulator (MPLAB SIM)62 | | Oscillator Configurations15 | Special Features of the CPU43 | | Oscillator Types | Special Function Registers | | HS15 | Stack32 | | LP15 | STATUS Register | | RC15 | Value on reset20 | | XT15 | SUBWF59 | | n | SWAPF59 | | Р | <b>T</b> | | PA0 bit29 | Т | | PA1 bit29 | Timer0 | | Paging31 | Switching Prescaler Assignment | | PC31 | Timer0 (TMR0) Module37 | | Value on reset20 | TMR0 register - Value on reset | | PD bit | TMR0 with External Clock | | Peripheral Features1 | Timing Diagrams and Specifications | | PICDEM 1 Low Cost PIC MCU Demonstration Board63 | PIC16C54/55/56/57 | | PICDEM 17 Demonstration Board64 | PIC16C54A111 | | PICDEM 2 Low Cost PIC16CXX Demonstration Board63 | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | | PICDEM 3 Low Cost PIC16CXXX Demonstration Board 64 | C58B/CR58B 140 | | PICSTART Plus Entry Level Development Programmer 63 | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | | Pin Configurations2 | C58B/CR58B-40160 | | Pinout Description - PIC16C54, PIC16CR54, PIC16C56, | PIC16CR54A 86 | | PIC16CR56, PIC16C58, PIC16CR5811 | Timing Parameter Symbology and Load Conditions | | Pinout Description - PIC16C55, PIC16C57, PIC16CR57 12 | PIC16C54/55/56/57 | | PORTA35 | PIC16C54A110 | | Value on reset20 | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | | PORTB35 | C58B/CR58B 139 | | Value on reset | PIC16C54C/CR54C/C55A/C56A/CR56A/C57C/CR57C/ | | PORTC | C58B/CR58B-40 | | Value on reset | PIC16CR54A | | Power-Down Mode47 | TO bit | | Power-On Reset (POR)21 | TRIS | | Register values on | TRIS Registers | | Prescaler | Value on reset | | PRO MATE II Universal Device Programmer | U | | Program Counter | _ | | Program Memory Organization | UV Erasable Devices | | Frogram venucation/Code Projection 47 | |