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>" | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic12ce673-10-p | |----------------------------|---------------------------------------------------------------------------| | Supplier Device Package | 8-PDIP | | Package / Case | 8-DIP (0.300", 7.62mm) | | Mounting Type | Through Hole | | Operating Temperature | 0°C ~ 70°C (TA) | | Oscillator Type | Internal | | Data Converters | A/D 4x8b | | Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V | | RAM Size | 128 x 8 | | EEPROM Size | 16 x 8 | | Program Memory Type | OTP | | Program Memory Size | 1.75KB (1K x 14) | | Number of I/O | 5 | | Peripherals | POR, WDT | | Connectivity | - | | Speed | 10MHz | | Core Size | 8-Bit | | Core Processor | PIC | | Product Status | Active | | Details | | #### **Table of Contents** | 1.0 | General Description | 3 | |-------|----------------------------------------------------------------------------------------------------|-----| | 2.0 | General Description | 5 | | 3.0 | Architectural Overview | 7 | | 4.0 | Memory Organization | 11 | | 5.0 | Memory Organization | 25 | | 6.0 | EEPROM Peripheral Operation | 33 | | 7.0 | Timer0 Module | 39 | | 8.0 | Analog-to-Digital Converter (A/D) Module | 45 | | 9.0 | Special Features of the CPU | 53 | | 10.0 | Instruction Set Summary | 69 | | 11.0 | Development Support | 83 | | 12.0 | Electrical Specifications | 89 | | 13.0 | Electrical Specifications DC and AC Characteristics Packaging Information Indix A:Compatibility | 109 | | 14.0 | Packaging Information | 115 | | Appe | endix A:Compatibility | 119 | | Appe | endix B:Code for Accessing EEPROM Data Memory | 119 | | Index | ( | 121 | | On-L | ine Support | 125 | | Read | ler Response | 126 | | PIC1 | 2C67X Product Identification System | 127 | #### To Our Valued Customers #### **Most Current Data Sheet** To automatically obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at: http://www.microchip.com You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number. e.g., DS30000A is version A of document DS30000. #### **New Customer Notification System** Register on our web site (www.microchip.com/cn) to receive the most current information on our products. #### **Errata** An errata sheet may exist for current devices, describing minor operational differences (from the data sheet) and recommended workarounds. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - Microchip's Worldwide Web site; http://www.microchip.com - Your local Microchip sales office (see last page) - The Microchip Corporate Literature Center; U.S. FAX: (480) 786-7277 When contacting a sales office or the literature center, please specify which device, revision of silicon and data sheet (include literature number) you are using. #### **Corrections to this Data Sheet** We constantly strive to improve the quality of all our products and documentation. We have spent a great deal of time to ensure that this document is correct. However, we realize that we may have missed a few things. If you find any information that is missing or appears in error, please: - Fill out and mail in the reader response form in the back of this data sheet. - E-mail us at webmaster@microchip.com. We appreciate your assistance in making this a better document. TABLE 1-1: PIC12C67X & PIC12CE67X FAMILY OF DEVICES | | | PIC12C671 | PIC12LC671 | PIC12C672 | PIC12LC672 | PIC12CE673 | PIC12LCE673 | PIC12CE674 | PIC12LCE674 | |-------------|-----------------------------------------------|------------------------|------------------------|------------------------|------------------------|------------------|------------------|------------------|------------------| | Clock | Maximum<br>Frequency<br>of Operation<br>(MHz) | 10 | 10 | 10 | 10 | 10 | 10 | 10 | 10 | | Manager | EPROM<br>Program<br>Memory | 1024 x 14 | 1024 x 14 | 2048 x 14 | 2048 x 14 | 1024 x 14 | 1024 x 14 | 2048 x 14 | 2048 x 14 | | Memory | RAM Data<br>Memory<br>(bytes) | 128 | 128 | 128 | 128 | 128 | 128 | 128 | 128 | | | EEPROM<br>Data Memory<br>(bytes) | _ | _ | _ | _ | 16 | 16 | 16 | 16 | | Peripherals | Timer<br>Module(s) | TMR0 | | A/D Con-<br>verter (8-bit)<br>Channels | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | | | Wake-up<br>from SLEEP<br>on pin<br>change | Yes | | Interrupt<br>Sources | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | | Features | I/O Pins | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | | | Input Pins | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Internal<br>Pull-ups | Yes | | In-Circuit<br>Serial<br>Programming | Yes | | Number of<br>Instructions | 35 | 35 | 35 | 35 | 35 | 35 | 35 | 35 | | | Voltage<br>Range (Volts) | 3.0V - 5.5V | 2.5V - 5.5V | 3.0V - 5.5V | 2.5V - 5.5V | 3.0V - 5.5V | 2.5V - 5.5V | 3.0V - 5.5V | 2.5V - 5.5V | | | Packages | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW, SOIC | 8-pin DIP,<br>JW | 8-pin DIP,<br>JW | 8-pin DIP,<br>JW | 8-pin DIP,<br>JW | All PIC12C67X devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC12C67X devices use serial programming with data pin GP0 and clock pin GP1. #### 3.1 **Clocking Scheme/Instruction Cycle** The clock input (from OSC1) is internally divided by four to generate four non-overlapping quadrature clocks, namely Q1, Q2, Q3 and Q4. Internally, the program counter (PC) is incremented every Q1, and the instruction is fetched from the program memory and latched into the instruction register in Q4. The instruction is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow is shown in Figure 3-2. #### 3.2 **Instruction Flow/Pipelining** An "Instruction Cycle" consists of four Q cycles (Q1, Q2, Q3 and Q4). The instruction fetch and execute are pipelined such that fetch takes one instruction cycle, while decode and execute takes another instruction cycle. However, due to the pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (i.e., GOTO), then two cycles are required to complete the instruction (Example 3-1). A fetch cycle begins with the program counter (PC) incrementing in Q1. In the execution cycle, the fetched instruction is latched into the "Instruction Register" (IR) in cycle Q1. This instruction is then decoded and executed during the Q2, Q3, and Q4 cycles. Data memory is read during Q2 (operand read) and written during Q4 (destination write). FIGURE 3-2: **CLOCK/INSTRUCTION CYCLE** #### **EXAMPLE 3-1: INSTRUCTION PIPELINE FLOW** All instructions are single cycle, except for any program branches. These take two cycles since the fetched instruction is "flushed" from the pipeline while the new instruction is being fetched and then executed. FIGURE 4-2: PIC12C67X REGISTER FILE MAP | | IVIZAI | | | | | | |-------------------------------------------|-------------------------------------------|--------------------------------|-----------------|--|--|--| | File<br>Address | <b>;</b> | | File<br>Address | | | | | 00h | INDF <sup>(1)</sup> | INDF <sup>(1)</sup> | 80h | | | | | 01h | TMR0 | OPTION | 81h | | | | | 02h | PCL | PCL | 82h | | | | | 03h | STATUS | STATUS | 83h | | | | | 04h | FSR | FSR | 84h | | | | | 05h | GPIO | TRIS | 85h | | | | | 06h | GI 10 | 11110 | 86h | | | | | 07h | | | 87h | | | | | 08h | | | 88h | | | | | 09h | | | 89h | | | | | 0911<br>0Ah | PCLATH | PCLATH | 8Ah | | | | | 0An<br>0Bh | INTCON | INTCON | 8Bh | | | | | 0Ch | PIR1 | PIE1 | 8Ch | | | | | 0Dh | FINI | FIET | 8Dh | | | | | I | | DCON | | | | | | 0Eh<br>0Fh | | PCON | 8Eh | | | | | · - | | OSCCAL | 8Fh | | | | | 10h | | | 90h | | | | | 11h | | | 91h | | | | | 12h | | | 92h | | | | | 13h | | | 93h | | | | | 14h | | | 94h | | | | | 15h | | | 95h | | | | | 16h | | | 96h | | | | | 17h | | | 97h | | | | | 18h | | | 98h | | | | | 19h | | | 99h | | | | | 1Ah | | | 9Ah | | | | | 1Bh | | | 9Bh | | | | | 1Ch | | | 9Ch | | | | | 1Dh | | | 9Dh | | | | | 1Eh | ADRES | | 9Eh | | | | | 1Fh | ADCON0 | ADCON1 | 9Fh | | | | | 20h | | General<br>Purpose<br>Register | A0h | | | | | | General | ricgister | BFh | | | | | | Purpose | | C0h | | | | | | Register | | | | | | | | | | EFh | | | | | 70h | | Mapped | F0h | | | | | | | in Bank 0 | | | | | | 7Fh <sup>[</sup> | Bank 0 | Bank 1 | J FFh │ | | | | | | Danie | Dank i | | | | | | | Unimplemented data memory locations, read | | | | | | | as '0'. Note 1: Not a physical register. | | | | | | | | | | | | | | | #### 4.2.2 SPECIAL FUNCTION REGISTERS The Special Function Registers are registers used by the CPU and Peripheral Modules for controlling the desired operation of the device. These registers are implemented as static RAM. The Special Function Registers can be classified into two sets (core and peripheral). Those registers associated with the "core" functions are described in this section, and those related to the operation of the peripheral features are described in the section of that peripheral feature. #### 4.2.2.6 PCON REGISTER The Power Control (PCON) Register contains a flag bit to allow differentiation between a Power-on Reset (POR), an external MCLR Reset and a WDT Reset. ### REGISTER 4-6: PCON REGISTER (ADDRESS 8Eh) **NOTES:** | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>Power-on<br>Reset | Value on<br>all other<br>Resets | |---------|--------|--------------------|--------------------|---------|-------------|---------|-------|-------|-------|-------------------------------|---------------------------------| | 85h | TRIS | _ | _ | GPIO Da | ata Directi | on Regi | ster | | | 11 1111 | 11 1111 | | 81h | OPTION | GPPU | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 1111 1111 | | 03h | STATUS | IRP <sup>(1)</sup> | RP1 <sup>(1)</sup> | RP0 | TO | PD | Z | DC | С | 0001 1xxx | 000q quuu | | 05h | GPIO | SCL <sup>(2)</sup> | SDA <sup>(2)</sup> | GP5 | GP4 | GP3 | GP2 | GP1 | GP0 | 11xx xxxx | 11uu uuuu | Legend: Shaded cells not used by Port Registers, read as '0', — = unimplemented, read as '0', x = unknown, u = unchanged, q = see tables in Section 9.4 for possible values. Note 1: The IRP and RP1 bits are reserved on the PIC12C67X; always maintain these bits clear. 2: The SCL and SDA bits are unimplemented on the PIC12C671 and PIC12C672. ### 5.4 <u>I/O Programming Considerations</u> #### 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 GPIO will cause all eight bits of GPIO to be read into the CPU. Then the BSF operation takes place on bit5 and GPIO is written to the output latches. If another bit of GPIO is used as a bi-directional I/O pin (i.e., bit0) 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 rewritten 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 bit0 is switched to an output, 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 (i.e., 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 readmodify-write instructions on an I/O port. # EXAMPLE 5-1: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT ``` ; Initial GPIO Settings ; GPIO<5:3> Inputs ; GPIO<2:0> Outputs GPIO latch GPIO pins GPIO, 5 ;--01 -ppp --11 pppp ;--10 -ppp BCF GPIO, 4 --11 pppp MOVLW 007h TRIS GPIO ;--10 -ppp --10 pppp ; Note that the user may have expected the pin ; values to be --00 pppp. The 2nd BCF caused ``` 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. ;GP5 to be latched as the pin value (High). #### 6.5 Read Operations Read operations are initiated in the same way as write operations with the exception that the $R/\overline{W}$ bit of the EEPROM address is set to one. There are three basic types of read operations; current address read, random read and sequential read. #### 6.5.1 CURRENT ADDRESS READ The EEPROM contains an address counter that maintains the address of the last word accessed, internally incremented by one. Therefore, if the previous read access was to address n, the next current address read operation would access data from address n+1. Upon receipt of the EEPROM address with the $R/\overline{W}$ bit set to one, the EEPROM issues an acknowledge and transmits the 8-bit data word. The processor will not acknowledge the transfer, but does generate a stop condition and the EEPROM discontinues transmission (Figure 6-8). #### 6.5.2 RANDOM READ Random read operations allow the processor to access any memory location in a random manner. To perform this type of read operation, first the word address must be set. This is done by sending the word address to the EEPROM as part of a write operation. After the word address is sent, the processor generates a start condition following the acknowledge. This terminates the write operation, but not before the internal address pointer is set. Then the processor issues the control byte again, but with the $R/\overline{W}$ bit set to a one. The EEPROM will then issue an acknowledge and transmits the 8-bit data word. The processor will not acknowledge the transfer, but does generate a stop condition and the EEPROM discontinues transmission (Figure 6-9). After this command, the internal address counter will point to the address location following the one that was just read. #### 6.5.3 SEQUENTIAL READ Sequential reads are initiated in the same way as a random read, except that after the device transmits the first data byte, the processor issues an acknowledge as opposed to a stop condition in a random read. This directs the EEPROM to transmit the next sequentially addressed 8-bit word (Figure 6-10). To provide sequential reads, the EEPROM contains an internal address pointer, which is incremented by one at the completion of each read operation. This address pointer allows the entire memory contents to be serially read during one operation. FIGURE 6-8: CURRENT ADDRESS READ FIGURE 6-9: RANDOM READ FIGURE 6-10: SEQUENTIAL READ #### 7.3.1 SWITCHING PRESCALER ASSIGNMENT The prescaler assignment is fully under software control, (i.e., it can be changed "on-the-fly" during program execution). Note: To avoid an unintended device RESET, the following instruction sequence (shown in Example 7-1) must be executed when changing the prescaler assignment from Timer0 to the WDT. This sequence must be followed even if the WDT is disabled. ### EXAMPLE 7-1: CHANGING PRESCALER (TIMER0→WDT) BCF STATUS, RPO ;Bank 0 CLRF TMR0 ;Clear TMR0 & Prescaler BSF STATUS, RPO ;Bank 1 CLRWDT ;Clears CLRWDT ;Clears WDT MOVLW b'xxxx1xxx' ;Select new prescale MOVWF OPTION\_REG ;value & WDT BCF STATUS, RPO ; Bank 0 To change prescaler from the WDT to the Timer0 module, use the sequence shown in Example 7-2. # EXAMPLE 7-2: CHANGING PRESCALER (WDT→TIMER0) CLRWDT ;Clear WDT and ;prescaler BSF STATUS, RPO; Bank 1 MOVLW b'xxxx0xxx'; Select TMR0, new ;prescale value and MOVWF OPTION\_REG ; clock source BCF STATUS, RPO ; Bank 0 #### TABLE 7-1: REGISTERS ASSOCIATED WITH TIMERO | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR | Value on<br>all other<br>Resets | |---------|--------|--------|--------------------------|-------|-------|-------|-------|-------|-------|-----------------|---------------------------------| | 01h | TMR0 | Timer0 | Timer0 module's register | | | | | | | xxxx xxxx | uuuu uuuu | | 0Bh/8Bh | INTCON | GIE | PEIE | TOIE | INTE | GPIE | TOIF | INTF | GPIF | 0000 000x | 0000 000u | | 81h | OPTION | GPPU | INTEDG | TOCS | T0SE | PSA | PS2 | PS1 | PS0 | 1111 1111 | 1111 1111 | | 85h | TRIS | _ | _ | TRIS5 | TRIS4 | TRIS3 | TRIS2 | TRIS1 | TRIS0 | 11 1111 | 11 1111 | Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by Timer0. TABLE 9-6: RESET CONDITION FOR SPECIAL REGISTERS | Condition | Program<br>Counter | STATUS<br>Register | PCON<br>Register | |------------------------------------|-----------------------|--------------------|------------------| | Power-on Reset | 000h | 0001 1xxx | 0- | | MCLR Reset during normal operation | 000h | 000u uuuu | u- | | MCLR Reset during SLEEP | 000h | 0001 0uuu | u- | | WDT Reset during normal operation | 000h | 0000 uuuu | u- | | WDT Wake-up from SLEEP | PC + 1 | uuu0 0uuu | u- | | Interrupt wake-up from SLEEP | PC + 1 <sup>(1)</sup> | uuu1 0uuu | u- | Legend: u = unchanged, x = unknown, - = unimplemented bit read as '0'. Note 1: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h). TABLE 9-7: INITIALIZATION CON\DITIONS FOR ALL REGISTERS | Register | Power-on Reset | MCLR Resets<br>WDT Reset | Wake-up via<br>WDT or Interrupt | |--------------------|----------------|--------------------------|---------------------------------| | W | xxxx xxxx | uuuu uuuu | uuuu uuuu | | INDF | 0000 0000 | 0000 0000 | 0000 0000 | | TMR0 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | PCL | 0000 0000 | 0000 0000 | PC + 1 <sup>(2)</sup> | | STATUS | 0001 1xxx | 000q quuu <sup>(3)</sup> | uuuq quuu(3) | | FSR | xxxx xxxx | uuuu uuuu | uuuu uuuu | | GPIO<br>PIC12CE67X | 11xx xxxx | 11uu uuuu | 11uu uuuu | | GPIO<br>PIC12C67X | xx xxxx | uu uuuu | uu uuuu | | PCLATH | 0 0000 | 0 0000 | u uuuu | | INTCON | 0000 000x | 0000 000u | uuuu uqqq(1) | | PIR1 | -0 | -0 | -q <b>(4)</b> | | ADCON0 | 0000 0000 | 0000 0000 | uuuu uquu <sup>(5)</sup> | | OPTION | 1111 1111 | 1111 1111 | uuuu uuuu | | TRIS | 11 1111 | 11 1111 | uu uuuu | | PIE1 | -0 | -0 | -u | | PCON | 0- | u- | u- | | OSCCAL | 0111 00 | uuuu uu | uuuu uu | | ADCON1 | 000 | 000 | uuu | $\label{eq:local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_$ - Note 1: One or more bits in INTCON and PIR1 will be affected (to cause wake-up). - 2: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h). - 3: See Table 9-5 for reset value for specific condition. - 4: If wake-up was due to A/D completing then bit 6 = 1, all other interrupts generating a wake-up will cause bit 6 = u. - 5: If wake-up was due to A/D completing then bit 3 = 0, all other interrupts generating a wake-up will cause bit 3 = u. FIGURE 9-10: EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP) - Note 1: External Power-on Reset circuit is required only if VDD power-up slope is too slow. The diode D helps discharge the capacitor quickly when VDD powers down. - 2: $R < 40 \text{ k}\Omega$ is recommended to make sure that voltage drop across R does not violate the device's electrical specification. - 3: R1 = $100\Omega$ to 1 k $\Omega$ will limit any current flowing into $\overline{MCLR}$ from external capacitor C, in the event of $\overline{MCLR}$ /VPP pin breakdown due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). # FIGURE 9-11: EXTERNAL BROWN-OUT PROTECTION CIRCUIT 1 - **Note 1:** This circuit will activate reset when VDD goes below (Vz + 0.7V), where Vz = Zener voltage. - 2: Resistors should be adjusted for the characteristics of the transistor. ### FIGURE 9-12: EXTERNAL BROWN-OUT PROTECTION CIRCUIT 2 Note 1: This brown-out circuit is less expensive, albeit less accurate. Transistor Q1 turns off when VDD is below a certain level such that: $$V_{DD} \bullet \frac{R1}{R1 + R2} = 0.7V$$ **2:** Resistors should be adjusted for the characteristics of the transistor. TABLE 10-2: INSTRUCTION SET SUMMARY | Mnemonic, | | Description | Cycles | | 14-Bit | Opcode | ) | Status | Notes | |------------|--------|-----------------------------------------------------------|----------|-----|--------|--------|------|------------|-------| | Operands | | | | MSb | | | LSb | Affected | | | BYTE-ORIE | NTED I | FILE REGISTER OPERATIONS | I | I | | | | | | | ADDWF | f, d | Add W and f | 1 | 00 | 0111 | dfff | ffff | C,DC,Z | 1,2 | | ANDWF | f, d | AND W with f | 1 | 0.0 | 0101 | dfff | ffff | Z | 1,2 | | CLRF | f | Clear f | 1 | 0.0 | 0001 | lfff | ffff | Z | 2 | | CLRW | - | Clear W | 1 | 00 | 0001 | 0000 | 0011 | Z | | | COMF | f, d | Complement f | 1 | 0.0 | 1001 | dfff | ffff | Z | 1,2 | | DECF | f, d | Decrement f | 1 | 0.0 | 0011 | dfff | ffff | Z | 1,2 | | DECFSZ | f, d | Decrement f, Skip if 0 | 1(2) | 0.0 | 1011 | dfff | ffff | | 1,2,3 | | INCF | f, d | Increment f | 1 | 0.0 | 1010 | dfff | ffff | Z | 1,2 | | INCFSZ | f, d | Increment f, Skip if 0 | 1(2) | 0.0 | 1111 | dfff | ffff | | 1,2,3 | | IORWF | f, d | Inclusive OR W with f | 1 | 0.0 | 0100 | dfff | ffff | Z | 1,2 | | MOVF | f, d | Move f | 1 | 00 | 1000 | dfff | ffff | Z | 1,2 | | MOVWF | f | Move W to f | 1 | 0.0 | 0000 | lfff | ffff | | | | NOP | - | No Operation | 1 | 0.0 | 0000 | 0xx0 | 0000 | | | | RLF | f, d | Rotate Left f through Carry | 1 | 00 | 1101 | dfff | ffff | С | 1,2 | | RRF | f, d | Rotate Right f through Carry | 1 | 0.0 | 1100 | dfff | ffff | С | 1,2 | | SUBWF | f, d | Subtract W from f | 1 | 0.0 | 0010 | dfff | ffff | C,DC,Z | 1,2 | | SWAPF | f, d | Swap nibbles in f | 1 | 0.0 | 1110 | dfff | ffff | | 1,2 | | XORWF | f, d | Exclusive OR W with f | 1 | 00 | 0110 | dfff | ffff | Z | 1,2 | | BIT-ORIENT | ED FIL | E REGISTER OPERATIONS | I | I | | | | | | | BCF | f, b | Bit Clear f | 1 | 01 | 00bb | bfff | ffff | | 1,2 | | BSF | f, b | Bit Set f | 1 | 01 | 01bb | bfff | ffff | | 1,2 | | BTFSC | f, b | Bit Test f, Skip if Clear | 1 (2) | 01 | 10bb | bfff | ffff | | 3 | | BTFSS | f, b | Bit Test f, Skip if Set | 1 (2) | 01 | 11bb | bfff | ffff | | 3 | | LITERAL A | ND CO | NTROL OPERATIONS | ı | I | | | | | | | ADDLW | k | Add literal and W | 1 | 11 | 111x | kkkk | kkkk | C,DC,Z | | | ANDLW | k | AND literal with W | 1 | 11 | | kkkk | | Z | | | CALL | k | Call subroutine | 2 | 10 | 0kkk | kkkk | kkkk | | | | CLRWDT | - | Clear Watchdog Timer | 1 | 0.0 | 0000 | 0110 | 0100 | TO,PD | | | GOTO | k | Go to address | 2 | 10 | 1kkk | kkkk | kkkk | | | | IORLW | k | Inclusive OR literal with W | 1 | 11 | 1000 | kkkk | kkkk | Z | | | MOVLW | k | Move literal to W | 1 | 11 | 00xx | kkkk | kkkk | | | | RETFIE | - | Return from interrupt | 2 | 00 | 0000 | 0000 | 1001 | | | | RETLW | k | Return with literal in W | 2 | 11 | 01xx | kkkk | kkkk | | | | RETURN | - | Return from Subroutine | 2 | 00 | 0000 | 0000 | 1000 | | | | SLEEP | - | Go into standby mode | 1 | 00 | 0000 | 0110 | 0011 | TO,PD | | | SUBLW | k | Subtract W from literal | 1 | 11 | 110x | kkkk | kkkk | C,DC,Z | | | XORLW | k | Exclusive OR literal with W | 1 | 11 | 1010 | kkkk | kkkk | Z | | | | | I/O register is modified as a function of itself ( i.e. M | <u> </u> | L | | | | that value | | Note 1: When an I/O register is modified as a function of itself (i.e., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'. <sup>2:</sup> If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 Module. <sup>3:</sup> If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP. #### 10.2 **Instruction Descriptions** | ADDLW | Add Literal and W | ANDLW | |------------------|-------------------------------------------------------------------------------------------------------------------|-------------| | Syntax: | [ label ] ADDLW k | Syntax: | | Operands: | $0 \leq k \leq 255$ | Operands: | | Operation: | $(W) + k \rightarrow (W)$ | Operation: | | Status Affected: | C, DC, Z | Status Affe | | Encoding: | 11 111x kkkk kkkk | Encoding: | | Description: | The contents of the W register are added to the eight bit literal 'k' and the result is placed in the W register. | Description | | Words: | 1 | Words: | | Cycles: | 1 | Cycles: | | Example | ADDLW 0x15 | Example | | | Before Instruction W = 0x10 After Instruction W = 0x25 | · | | Syntax: | [ label ] ANDLW k | |------------------|---------------------------------------------------------------------------------------------------------------| | Operands: | $0 \leq k \leq 255$ | | Operation: | (W) .AND. (k) $\rightarrow$ (W) | | Status Affected: | Z | | Encoding: | 11 1001 kkkk kkkk | | Description: | The contents of 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 0x5F | | | Before Instruction W = 0xA3 After Instruction W = 0x03 | And Literal with W | ADDWF | Add W and f | | | | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Syntax: | [ label ] ADDWF f,d | | | | | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | | | | | Operation: | $(W) + (f) \to (dest)$ | | | | | | | Status Affected: | C, DC, Z | | | | | | | Encoding: | 00 0111 dfff ffff | | | | | | | Description: | Add the contents of the W register 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 | ADDWF FSR, <b>0</b> | | | | | | | | Before Instruction $W = 0x17$ $FSR = 0xC2$ After Instruction $W = 0xD9$ $FSD = 0xD9$ | | | | | | 0xC2 FSR = | ANDWF | AND W with f | | | | | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Syntax: | [ label ] ANDWF f,d | | | | | | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | | | | | | Operation: | (W) .AND. (f) $\rightarrow$ (dest) | | | | | | | | Status Affected: | Z | | | | | | | | Encoding: | 00 0101 dfff ffff | | | | | | | | Description: | AND the W register 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 FSR, 1 | | | | | | | | | Before Instruction | | | | | | | | RETURN | Return from Subroutine | | | | | | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------|------|--|--|--| | Syntax: | [ label ] | [ label ] RETURN | | | | | | | Operands: | None | | | | | | | | Operation: | $TOS \rightarrow P$ | C | | | | | | | Status Affected: | None | | | | | | | | Encoding: | 0 0 | 0000 | 0000 | 1000 | | | | | Description: | Return from subroutine. The stack is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two cycle instruction. | | | | | | | | Words: | 1 | | | | | | | | Cycles: | 2 | | | | | | | | Example | RETURN | | | | | | | | | After Inte | rrupt<br>PC = | TOS | | | | | | RRF | Rotate Right f through Carry | | | | | | | |-------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Syntax: | [label] RRF | f,d | | | | | | | Operands: | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$ | | | | | | | | Operation: | See description below | | | | | | | | Status Affected: | С | | | | | | | | Encoding: | 00 110 | 0 dfff ffff | | | | | | | Description: | rotated one bit<br>the Carry Flag<br>is placed in the | of register 'f' are to the right through . If 'd' is 0, the result by W register. If 'd' is placed back in reg- | | | | | | | | <del></del> | Redister i 🕳 | | | | | | | | | Register f | | | | | | | Words: | 1 | Register 1 | | | | | | | Words:<br>Cycles: | 1 | Hegister 1 | | | | | | | | • | REG1, | | | | | | | Cycles: | 1 RRF Before Instruc | REG1,<br>0<br>tion<br>= 1110 0110 | | | | | | | Cycles: | 1 RRF Before Instruc REG1 C After Instruction | REG1,<br>0<br>tion<br>= 1110 0110<br>= 0 | | | | | | | Cycles: | 1 RRF Before Instruc REG1 C | REG1,<br>0<br>tion<br>= 1110 0110<br>= 0 | | | | | | #### **RLF Rotate Left f through Carry** Syntax: RLF [ label ] Operands: $0 \le f \le 127$ $d \in \left[0,1\right]$ Operation: See description below Status Affected: С ffff Encoding: 00 1101 dfff The contents of register 'f' are rotated one bit to the left through the Carry Flag. If 'd' is 0, the result is placed in the very least to the register. If 'd' is 1, the result is a three least to register. Description: 1, the result is stored back in register 'f'. Register f Words: 1 Cycles: 1 Example RLF REG1,0 Before Instruction REG1 1110 0110 С 0 After Instruction REG1 1110 0110 W 1100 1100 С | SLEEP | | | | | | | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---------------------------------------------|--------------------------|--|--|--| | Syntax: | [ label ] | SLEEF | ) | | | | | | Operands: | None | | | | | | | | Operation: | $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow \underline{W}DT \text{ prescaler,} \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$ | | | | | | | | Status Affected: | $\overline{TO}, \overline{PD}$ | | | | | | | | Encoding: | 00 | 0000 | 0110 | 0011 | | | | | Description: | The power cleared. is set. Was prescaled The procumode with | Time-out<br>atchdog<br>are clea<br>essor is | status b<br>Timer an<br>ared.<br>put into S | it, TO<br>d its<br>SLEEP | | | | | Words: | 1 | | | | | | | | Cycles: | 1 | | | | | | | | Example: | SLEEP | | | | | | | | | | | | | | | | ### 12.0 ELECTRICAL SPECIFICATIONS FOR PIC12C67X ### **Absolute Maximum Ratings †** | Ambient temperature under bias | 40° to +125°C | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------| | Storage temperature | 65°C to +150°C | | Voltage on any pin with respect to Vss (except VDD and MCLR) | 0.3V to (VDD + 0.3V) | | Voltage on VDD with respect to Vss | 0 to +7.0V | | Voltage on MCLR with respect to Vss (Note 2) | 0 to +14V | | Total power dissipation (Note 1) | 700 mW | | Maximum current out of Vss pin | 200 mA | | Maximum current into VDD pin | 150 mA | | Input clamp current, IiK (VI < 0 or VI > VDD) | ± 20 mA | | Output clamp current, lok (Vo < 0 or Vo > VDD) | ± 20 mA | | Maximum output current sunk by any I/O pin | 25 mA | | Maximum output current sourced by any I/O pin | 25 mA | | Maximum current sunk by GPIO pins combined | 100 mA | | Maximum current sourced by GPIO pins combined | 100 mA | | <b>Note 1:</b> Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IDD - $\sum$ IOH} + $\sum$ {(VDD - VOH) = VDD x {IDD - $\sum$ IDD | $x IOH$ + $\sum (VOI x IOL)$ . | † NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. | DC CHARACTERISTICS Standar Operatin | | | | | _ | ire (<br>-4 | tions (unless otherwise specified) $0^{\circ}C \leq TA \leq +70^{\circ}C$ (commercial) $0^{\circ}C \leq TA \leq +85^{\circ}C$ (industrial) $0^{\circ}C \leq TA \leq +125^{\circ}C$ (extended) | |-------------------------------------|----------------------------------------------------------------------------------------------------------------|------|-------------|--------------------|-------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Parm<br>No. | Characteristic | Sym | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | | LP Oscillator Operating Frequency INTRC/EXTRC Oscillator Operating Frequency XT Oscillator Operating Frequency | Fosc | 0<br>_<br>0 | | 200<br>4 <sup>(6)</sup> | kHz<br>MHz<br>MHz | All temperatures All temperatures All temperatures | | | HS Oscillator Operating Frequency | | 0 | | 10 | MHz | All temperatures | - \* These parameters are characterized but not tested. - Note 1: Data in Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested - 2: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data. - 3: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern, and temperature also have an impact on the current consumption. - a) The test conditions for all IDD measurements in active operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tristated, pulled to Vss, TOCKI = VDD, MCLR = VDD; WDT disabled. - b) For standby current measurements, the conditions are the same, except that the device is in SLEEP mode. - **4:** For EXTRC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: - Ir = VDD/2REXT (mA) with REXT in kOhm. - 5: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSs. - **6:** INTRC calibration value is for 4MHz nominal at 5V, 25°C. TABLE 12-2: CALIBRATED INTERNAL RC FREQUENCIES -PIC12C671, PIC12C672, PIC12CE673, PIC12CE674, PIC12LC671, PIC12LC672, PIC12LCE673, PIC12LCE674 | AC Characteristics Standard Operating Conditions (ur Operating Temperature 0°C ≤ T -40°C ≤ T -40°C ≤ T Operating Voltage VDD range is desc | | | | 70°C (co<br>·85°C (ind<br>·125°C (e | mmerci<br>dustrial)<br>extended | al),<br>, | | |-------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------------------------|------|-------------------------------------|---------------------------------|------------|------------| | Parameter<br>No. | Sym | Characteristic | Min* | Typ <sup>(1)</sup> | Max* | Units | Conditions | | | | Internal Calibrated RC Frequency | 3.65 | 4.00 | 4.28 | MHz | VDD = 5.0V | | Internal Calibrated RC Frequency | | 3.55 | 4.00 | 4.31 | MHz | VDD = 2.5V | | <sup>\*</sup> These parameters are characterized but not tested. Note 1: Data in the Typical ("Typ") column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. TABLE 12-9: EEPROM MEMORY BUS TIMING REQUIREMENTS - PIC12CE673/674 ONLY. AC Characteristics Standard Operating Conditions (unless otherwise specified) Operating Temperature $0^{\circ}C \le TA \le +70^{\circ}C$ , Vcc = 3.0V to 5.5V (commercial) $-40^{\circ}C \leq \text{TA} \leq +85^{\circ}C, \ \text{Vcc} = 3.0 \text{V to } 5.5 \text{V} \ \text{(industrial)}$ $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ , Vcc = 4.5V to 5.5V (extended) Operating Voltage VDD range is described in Section 12.1 | | Operating voltage VDD range is described in Section 12.1 | | | | | | | | |--------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------|---------------------|--------|----------------------------------------------------------------------------|--|--|--| | Parameter | Symbol | Min | Max | Units | Conditions | | | | | Clock frequency | FCLK | _<br>_<br>_ | 100<br>100<br>400 | kHz | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | Clock high time | THIGH | 4000<br>4000<br>600 | _<br>_<br>_ | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | Clock low time | TLOW | 4700<br>4700<br>1300 | _<br> | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | SDA and SCL rise time (Note 1) | TR | _<br>_<br>_ | 1000<br>1000<br>300 | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | SDA and SCL fall time | TF | _ | 300 | ns | (Note 1) | | | | | START condition hold time | THD:STA | 4000<br>4000<br>600 | _<br>_<br>_ | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | START condition setup time | TSU:STA | 4700<br>4700<br>600 | _<br> | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | Data input hold time | THD:DAT | 0 | _ | ns | (Note 2) | | | | | Data input setup time | Tsu:DAT | 250<br>250<br>100 | _<br>_<br>_ | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | STOP condition setup time | Tsu:sto | 4000<br>4000<br>600 | _<br>_<br>_ | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | Output valid from clock (Note 2) | Таа | _<br>_<br>_ | 3500<br>3500<br>900 | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | Bus free time: Time the bus must<br>be free before a new transmis-<br>sion can start | TBUF | 4700<br>4700<br>1300 | _<br>_<br>_ | ns | 4.5V ≤ Vcc ≤ 5.5V (E Temp range)<br>3.0V ≤ Vcc ≤ 4.5V<br>4.5V ≤ Vcc ≤ 5.5V | | | | | Output fall time from VIH minimum to VIL maximum | Tof | 20+0.1<br>CB | 250 | ns | (Note 1), CB ≤ 100 pF | | | | | Input filter spike suppression (SDA and SCL pins) | Tsp | _ | 50 | ns | (Notes 1, 3) | | | | | Write cycle time | Twc | _ | 4 | ms | | | | | | Endurance | | 1M | _ | cycles | 25°C, VCC = 5.0V, Block Mode (Note 4) | | | | **Note 1:** Not 100% tested. CB = total capacitance of one bus line in pF. - 2: As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL and avoid unintended generation of START or STOP conditions. - **3:** The combined TSP and VHYS specifications are due to new Schmitt Trigger inputs which provide improved noise spike suppression. This eliminates the need for a TI specification for standard operation. - **4:** This parameter is not tested but ensured by characterization. For endurance estimates in a specific application, please consult the Total Endurance Model which can be obtained on Microchip's website. **NOTES:** | 1 | | K | | |---------------------------------------------|--------|---------------------------------------------------|------| | I/O Interfacing | 25 | KeeLoq® Evaluation and Programming Tools | . 86 | | I/O Ports | | L | | | I/O Programming Considerations | 31 | Loading of PC | 22 | | ID Locations | | | . 22 | | INCF Instruction | | M | | | INCFSZ Instruction | - | MCLR56 | , 59 | | In-Circuit Serial Programming | | Memory | | | INDF Register | 14, 23 | Data Memory | | | Indirect Addressing | | Program Memory | | | Initialization Conditions for All Registers | | Register File Map - PIC12CE67X | | | Instruction Cycle | | MOVF Instruction | | | Instruction Flow/Pipelining | | MOVLW Instruction | | | Instruction Format | 69 | MOVWF Instruction | | | Instruction Set | | MPLAB Integrated Development Environment Software | . 83 | | ADDLW | | N | | | ADDWF | | NOP Instruction | . 78 | | ANDLW | | 0 | | | ANDWF | | _ | | | BCF | _ | Opcode | | | BSF | | OPTION Instruction | | | BTFSC | | OPTION Register | | | BTFSS | | Orthogonal | | | CALL | | OSC selection | | | CLRF | | OSCCAL Register | . 21 | | CLRW | | Oscillator | | | CLRWDT | _ | EXTRC | | | COMF | | HS | | | DECF | _ | INTRC | | | DECFSZ | _ | LP | | | GOTO | | XT | | | INCF | - | Oscillator Configurations | . 54 | | INCFSZ | | Oscillator Types | - 4 | | IORLW | | EXTRC | | | IORWF | | HS | | | MOVF | | INTRC | - | | MOVLW | | LP | | | MOVWF | | XT | . 54 | | NOP | - | Р | | | OPTION | _ | Package Marking Information | 115 | | RETFIE | _ | Packaging Information | 115 | | RETLW | _ | Paging, Program Memory | . 22 | | RETURN | | PCL | . 70 | | RLF<br>RRF | 79 | PCL Register 13, 14 | , 22 | | | 79 | PCLATH | . 59 | | SLEEP<br>SUBLW | | PCLATH Register 13, 14 | , 22 | | SUBWF | | PCON Register20 | , 58 | | SWAPF | | PD bit15 | , 56 | | TRIS | | PICDEM-1 Low-Cost PIC MCU Demo Board | . 85 | | XORLW | | PICDEM-2 Low-Cost PIC16CXX Demo Board | . 85 | | XORWF | | PICDEM-3 Low-Cost PIC16CXXX Demo Board | . 85 | | Section | | PICSTART® Plus Entry Level Development System | . 85 | | INTCON Register | | PIE1 Register | | | INTEDG bit | | Pinout Description - PIC12CE67X | 9 | | Internal Sampling Switch (Rss) Impedence | | PIR1 Register | . 19 | | Interrupts | | POP | . 22 | | A/D | | POR | . 58 | | GP2/INT | | Oscillator Start-up Timer (OST)53 | | | GPIO Port | | Power Control Register (PCON) | | | Section | | Power-on Reset (POR) 53, 58 | | | TMR0 | | Power-up Timer (PWRT)53 | | | TMR0 Overflow | | Power-Up-Timer (PWRT) | | | IORLW Instruction | | Time-out Sequence | | | IORWF Instruction | | Time-out Sequence on Power-up | | | IRP bit | | TO | | | | | Power | . 56 |