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 | Obsolete | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 8MHz | | Connectivity | UART/USART | | Peripherals | POR, PWM, WDT | | Number of I/O | 33 | | Program Memory Size | 8KB (4K x 16) | | Program Memory Type | ОТР | | EEPROM Size | - | | RAM Size | 454 x 8 | | Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V | | Data Converters | - | | Oscillator Type | External | | Operating Temperature | 0°C ~ 70°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 44-TQFP | | Supplier Device Package | 44-TQFP (10x10) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic17lc43-08-pt | | | | ### 5.3 <u>Peripheral Interrupt Request Register</u> (PIR) This register contains the individual flag bits for the peripheral interrupts. These bits will be set by the specified condition, even if the corresponding interrupt enable bit is cleared (interrupt disabled), or the GLINTD bit is set (all interrupts disabled). Before enabling an interrupt, the user may wish to clear the interrupt flag to ensure that the program does not immediately branch to the peripheral interrupt service routine. ### FIGURE 5-4: PIR REGISTER (ADDRESS: 16h, BANK 1) | R/W - ( | 0 R/W - 0 R/W - 0 R/W - 0 R/W - 0 R/W - 0 R - 1 R - 0 TMR3IF TMR2IF TMR1IF CA2IF CA1IF TXIF RCIF R = Readable bit | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | N/ N/ 11 12 | | bit7 | bit0 W = Writable bit<br>-n = Value at POR reset | | bit 7: | RBIF: PORTB Interrupt on Change Flag bit 1 = One of the PORTB inputs changed (Software must end the mismatch condition) 0 = None of the PORTB inputs have changed | | bit 6: | TMR3IF: Timer3 Interrupt Flag bit If Capture1 is enabled (CA1/PR3 = 1) 1 = Timer3 overflowed 0 = Timer3 did not overflow | | | If Capture1 is disabled (CA1/ $\overline{PR3}$ = 0)<br>1 = Timer3 value has rolled over to 0000h from equalling the period register (PR3H:PR3L) value<br>0 = Timer3 value has not rolled over to 0000h from equalling the period register (PR3H:PR3L) value | | bit 5: | <b>TMR2IF</b> : Timer2 Interrupt Flag bit<br>1 = Timer2 value has rolled over to 0000h from equalling the period register (PR2) value<br>0 = Timer2 value has not rolled over to 0000h from equalling the period register (PR2) value | | bit 4: | TMR1IF: Timer1 Interrupt Flag bit If Timer1 is in 8-bit mode (T16 = 0) 1 = Timer1 value has rolled over to 0000h from equalling the period register (PR) value 0 = Timer1 value has not rolled over to 0000h from equalling the period register (PR2) value | | | If Timer1 is in 16-bit mode (T16 = 1) 1 = TMR1:TMR2 value has rolled over to 0000h from equalling the period register (PR1:PR2) value 0 = TMR1:TMR2 value has not rolled over to 0000h from equalling the period register (PR1:PR2) value | | bit 3: | CA2IF: Capture2 Interrupt Flag bit 1 = Capture event occurred on RB1/CAP2 pin 0 = Capture event did not occur on RB1/CAP2 pin | | bit 2: | CA1IF: Capture1 Interrupt Flag bit 1 = Capture event occurred on RB0/CAP1 pin 0 = Capture event did not occur on RB0/CAP1 pin | | bit 1: | TXIF: USART Transmit Interrupt Flag bit 1 = Transmit buffer is empty 0 = Transmit buffer is full | | bit 0: | RCIF: USART Receive Interrupt Flag bit 1 = Receive buffer is full 0 = Receive buffer is empty | Note: NOTES: #### **TABLE 6-3: SPECIAL FUNCTION REGISTERS (Cont.'d)** | 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 all<br>other<br>resets (3) | |--------------------|-----------|----------------------------------------|--------------------------------------|----------------|--------------|----------------|--------|-----------|-----------|-------------------------------|-------------------------------------| | Bank 2 | | | | | | | | | | | | | 10h | TMR1 | Timer1 | | | | | | | | xxxx xxxx | uuuu uuuu | | 11h | TMR2 | Timer2 | | | | | | | | xxxx xxxx | uuuu uuuu | | 12h | TMR3L | TMR3 reg | ister; low b | yte | | | | | | xxxx xxxx | uuuu uuuu | | 13h | TMR3H | TMR3 reg | ister; high l | oyte | | | | | | xxxx xxxx | uuuu uuuu | | 14h | PR1 | Timer1 pe | riod registe | er | | | | | | xxxx xxxx | uuuu uuuu | | 15h | PR2 | Timer2 pe | riod registe | er | | | | | | xxxx xxxx | uuuu uuuu | | 16h | PR3L/CA1L | Timer3 pe | riod registe | er, low byte/c | apture1 regi | ister; low by | te | | | xxxx xxxx | uuuu uuuu | | 17h | PR3H/CA1H | Timer3 pe | riod registe | er, high byte/ | capture1 rec | gister; high l | oyte | | | xxxx xxxx | uuuu uuuu | | Bank 3 | | | | | | | | | | | | | 10h | PW1DCL | DC1 | DC0 | _ | _ | _ | _ | _ | _ | xx | uu | | 11h | PW2DCL | DC1 | DC1 DC0 TM2PW2 — — — — — xx0 uu0 | | | | | | | | uu0 | | 12h | PW1DCH | DC9 | DC8 | DC7 | DC6 | DC5 | DC4 | DC3 | DC2 | xxxx xxxx | uuuu uuuu | | 13h | PW2DCH | DC9 | DC8 | DC7 | DC6 | DC5 | DC4 | DC3 | DC2 | xxxx xxxx | uuuu uuuu | | 14h | CA2L | Capture2 | Capture2 low byte xxxx xxxx uuuu uuu | | | | | | uuuu uuuu | | | | 15h | CA2H | Capture2 high byte xxxx xxxx uuuu uuuu | | | | | | uuuu uuuu | | | | | 16h | TCON1 | CA2ED1 | CA2ED0 | CA1ED1 | CA1ED0 | T16 | TMR3CS | TMR2CS | TMR1CS | 0000 0000 | 0000 0000 | | 17h | TCON2 | CA2OVF | CA10VF | PWM2ON | PWM10N | CA1/PR3 | TMR3ON | TMR2ON | TMR10N | 0000 0000 | 0000 0000 | | Unbanke | ed | | | | | | | | | | | | 18h <sup>(5)</sup> | PRODL | Low Byte | of 16-bit Pr | oduct (8 x 8 | Hardware M | fultiply) | | | | xxxx xxxx | uuuu uuuu | | 19h <sup>(5)</sup> | PRODH | High Byte | of 16-bit P | roduct (8 x 8 | Hardware N | Multiply) | | | | xxxx xxxx | uuuu uuuu | x = unknown, u = unchanged, - = unimplemented read as '0', q - value depends on condition. Shaded cells are unimplemented, read as '0'. The upper byte of the program counter is not directly accessible. PCLATH is a holding register for PC<15:8> whose contents are updated Legend: Note 1: from or transferred to the upper byte of the program counter. The TO and PD status bits in CPUSTA are not affected by a MCLR reset. Other (non power-up) resets include: external reset through MCLR and the Watchdog Timer Reset. The following values are for both TBLPTRL and TBLPTRH: <sup>3:</sup> 4: All PIC17C4X devices (Power-on Reset 0000 0000) and (All other resets 0000 0000) except the PIC17C42 (Power-on Reset xxxx xxxx) and (All other resets uuuu uuuu) The PRODL and PRODH registers are not implemented on the PIC17C42. #### 6.3 Stack Operation The PIC17C4X devices have a 16 x 16-bit wide hardware stack (Figure 6-1). The stack is not part of either the program or data memory space, and the stack pointer is neither readable nor writable. The PC is "PUSHed" onto the stack when a CALL instruction is executed or an interrupt is acknowledged. The stack is "POPed" in the event of a RETURN, RETLW, or a RETFIE instruction execution. PCLATH is not affected by a "PUSH" or a "POP" operation. The stack operates as a circular buffer, with the stack pointer initialized to '0' after all resets. There is a stack available bit (STKAV) to allow software to ensure that the stack has not overflowed. The STKAV bit is set after a device reset. When the stack pointer equals Fh, STKAV is cleared. When the stack pointer rolls over from Fh to 0h, the STKAV bit will be held clear until a device reset. - Note 1: There is not a status bit for stack underflow. The STKAV bit can be used to detect the underflow which results in the stack pointer being at the top of stack. - Note 2: There are no instruction mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW, and RETFIE instructions, or the vectoring to an interrupt vector. - Note 3: After a reset, if a "POP" operation occurs before a "PUSH" operation, the STKAV bit will be cleared. This will appear as if the stack is full (underflow has occurred). If a "PUSH" operation occurs next (before another "POP"), the STKAV bit will be locked clear. Only a device reset will cause this bit to set. After the device is "PUSHed" sixteen times (without a "POP"), the seventeenth push overwrites the value from the first push. The eighteenth push overwrites the second push (and so on). #### 6.4 Indirect Addressing Indirect addressing is a mode of addressing data memory where the data memory address in the instruction is not fixed. That is, the register that is to be read or written can be modified by the program. This can be useful for data tables in the data memory. Figure 6-10 shows the operation of indirect addressing. This shows the moving of the value to the data memory address specified by the value of the FSR register. Example 6-1 shows the use of indirect addressing to clear RAM in a minimum number of instructions. A similar concept could be used to move a defined number of bytes (block) of data to the USART transmit register (TXREG). The starting address of the block of data to be transmitted could easily be modified by the program. FIGURE 6-10: INDIRECT ADDRESSING #### 7.2 <u>Table Writes to External Memory</u> Table writes to external memory are always two-cycle instructions. The second cycle writes the data to the external memory location. The sequence of events for an external memory write are the same for an internal write. Note: If an interrupt is pending or occurs during the TABLWT, the two cycle table write completes. The RAO/INT, TMR0, or TOCKI interrupt flag is automatically cleared or the pending peripheral interrupt is acknowledged. #### 7.2.2 TABLE WRITE CODE The "i" operand of the TABLWT instruction can specify that the value in the 16-bit TBLPTR register is automatically incremented for the next write. In Example 7-1, the TBLPTR register is not automatically incremented. #### **EXAMPLE 7-1: TABLE WRITE** ``` CLRWDT ; Clear WDT MOVLW HIGH (TBL_ADDR) ; Load the Table MOVWF TBLPTRH ; address MOVLW LOW (TBL_ADDR) ; MOVWF TBLPTRL MOVLW HIGH (DATA) ; Load HI byte TLWT 1, WREG ; in TABLATCH MOVLW LOW (DATA) ; Load LO byte ; in TABLATCH TABLWT 0,0,WREG and write to program memory (Ext. SRAM) ``` Note: If external write GLINTD = '1', Enable bit = '1', '1' → Flag bit, Do table write. The highest pending interrupt is cleared. #### 12.2.3 EXTERNAL CLOCK INPUT FOR TIMER3 When TMR3CS is set, the 16-bit TMR3 increments on the falling edge of clock input TCLK3. The input on the RB5/TCLK3 pin is sampled and synchronized by the internal phase clocks twice every instruction cycle. This causes a delay from the time a falling edge appears on TCLK3 to the time TMR3 is actually incremented. For the external clock input timing requirements, see the Electrical Specification section. Figure 12-9 shows the timing diagram when operating from an external clock. #### 12.2.4 READING/WRITING TIMER3 Since Timer3 is a 16-bit timer and only 8-bits at a time can be read or written, care should be taken when reading or writing while the timer is running. The best method to read or write the timer is to stop the timer, perform any read or write operation, and then restart Timer3 (using the TMR3ON bit). However, if it is necessary to keep Timer3 free-running, care must be taken. For writing to the 16-bit TMR3, Example 12-2 may be used. For reading the 16-bit TMR3, Example 12-3 may be used. Interrupts must be disabled during this routine. #### **EXAMPLE 12-2: WRITING TO TMR3** BSF CPUSTA, GLINTD ;Disable interrupt MOVFP RAM\_L, TMR3L ; MOVFP RAM\_H, TMR3H ; BCF CPUSTA, GLINTD ;Done,enable interrupt #### **EXAMPLE 12-3: READING FROM TMR3** | MOVPF | TMR3L, | TMPLO | <pre>;read low tmr0</pre> | |--------|--------|-------|------------------------------| | MOVPF | TMR3H, | TMPHI | <pre>;read high tmr0</pre> | | MOVFP | TMPLO, | WREG | <pre>;tmplo -&gt; wreg</pre> | | CPFSLT | TMR3L, | WREG | <pre>;tmr01 &lt; wreg?</pre> | | RETURN | | | ;no then return | | MOVPF | TMR3L, | TMPLO | <pre>;read low tmr0</pre> | | MOVPF | TMR3H, | TMPHI | <pre>;read high tmr0</pre> | | RETURN | | | ;return | FIGURE 12-9: TMR1, TMR2, AND TMR3 OPERATION IN EXTERNAL CLOCK MODE FIGURE 13-3: USART TRANSMIT #### FIGURE 13-4: USART RECEIVE | SUBWF | | WREG from | ı f | SUB | WFB | Subtrac<br>Borrow | t WREG from | f with | |-------------------------|--------------------------------|-------------------------------------------------------------------|----------------------|-------------|-----------------|----------------------------------|-----------------------------------------------------|-------------------------------------------------| | Syntax: | | SUBWF f,d | | Synta | ıx. | | SUBWFB f, | 1 | | Operands: | $0 \le f \le 25$ $d \in [0,1]$ | - | | | ands: | 0 ≤ f ≤ 2 | | - | | Operation: | (f) - (W) | | | | | d ∈ [0,1 | | | | Status Affected: | OV, C, D | | | Oper | ation: | (f) - (W) | $-\overline{C} \rightarrow (dest)$ | | | Encoding: | 0000 | 010d fff | f ffff | Statu | s Affected: | OV, C, E | OC, Z | | | Description: | Subtract V | VREG from reg | | Enco | ding: | 0000 | 001d ff | f ffff | | Words: | result is st | ent method). If <sup>t</sup><br>tored in WREG<br>tored back in re | . If 'd' is 1 the | Desc | ription: | (borrow)<br>ment me<br>stored in | WREG and the from register 'f' thod). If 'd' is 0 t | (2's comple-<br>he result is<br>1 the result is | | Cycles: | 1 | | | Word | 0. | | ck in register 'f' | | | Q Cycle Activity: | | | | Cycle | _ | 1<br>1 | | | | Q1 | Q2 | Q3 | Q4 | - | cle Activity: | ı | | | | Decode | Read<br>register 'f' | Execute | Write to destination | Q Cy | Q1 | Q2 | Q3 | Q4 | | Evenne 1 | | DEG1 1 | destination | | Decode | Read | Execute | Write to | | Example 1: | SUBWF | REG1, 1 | | L | | register 'f' | | destination | | Before Instru | = 3 | | | <u>Exam</u> | <u>nple 1</u> : | SUBWFB | REG1, 1 | | | | = 2 | | | E | Before Instru | uction | | | | · · | = ? | | | | REG1<br>WREG | = 0x19<br>= 0x0D | (0001 100<br>(0000 110 | , | | After Instructi<br>REG1 | on<br>= 1 | | | | C | = 1 | (0000 110 | ± <i>)</i> | | | = 2 | | | , | After Instruc | tion | | | | C<br>Z | = 1 ; | result is positiv | re | | REG1<br>WREG | = 0x0C<br>= 0x0D | (0000 101<br>(0000 110 | , | | Example 2: | _ 0 | | | | C | = 0000 | ; result is po | , | | Before Instru | otion | | | | Z | = 0 | | | | | = 2 | | | Exam | nple2: | SUBWFB | REG1,0 | | | | = 2 | | | E | Before Instru | | | | | C | = ? | | | | REG1<br>WREG | = 0x1B<br>= 0x1A | (0001 101<br>(0001 101 | , | | After Instructi<br>REG1 | on<br>= 0 | | | | C | = 0 | (0001 101 | 0) | | _ | = 2 | | | ļ | After Instruc | tion | | | | _ | = 1 ;<br>= 1 | result is zero | | | REG1 | | (0001 101 | 1) | | | = ' | | | | WREG<br>C | = 0x00<br>= 1 | ; result is ze | ro | | Example 3: | -4: - ·- | | | | Z | = 1 | | | | Before Instru | ction<br>= 1 | | | Exam | nple3: | SUBWFB | REG1,1 | | | | = 2 | | | E | Before Instru | uction | | | | _ | = ? | | | | REG1<br>WREG | = 0x03<br>= 0x0E | (0000 001)<br>(0000 110 | | | After Instructi<br>REG1 | on<br>= FF | | | | C | = 0000 | (0000 110 | ⊥ <i>)</i> | | | = rr<br>= 2 | | | , | After Instruc | tion | | | | | | result is negati | ve | | REG1 | = 0xF5 | | 0) [2's comp] | | Z | = 0 | | | | WREG<br>C | = 0x0E<br>= 0 | (0000 110<br>; result is ne | | | | | | | | Z | = 0 | , result is fie | 941110 | Applicable Devices 42 R42 42A 43 R43 44 #### 17.1 DC CHARACTERISTICS: PIC17C42-16 (Commercial, Industrial) PIC17C42-25 (Commercial, Industrial) | | | | Standard | d Opera | ating C | ondition | ns (unless otherwise stated) | |-----------|---------|------------------------------------------------------------------|-----------|---------|---------|----------|-------------------------------------------| | DC CHARA | CTEDIS | STICS | Operating | g tempe | erature | | | | DC CHARA | CILINIC | 31103 | | | | -40°C | ≤ TA ≤ +85°C for industrial and | | | | | | | | 0°C | ≤ Ta ≤ +70°C for commercial | | Parameter | | | | | | | | | No. | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | | D001 | VDD | Supply Voltage | 4.5 | _ | 5.5 | V | | | D002 | VDR | RAM Data Retention<br>Voltage (Note 1) | 1.5 * | _ | _ | V | Device in SLEEP mode | | D003 | VPOR | VDD start voltage to<br>ensure internal<br>Power-on Reset signal | _ | Vss | _ | V | See section on Power-on Reset for details | | D004 | SVDD | VDD rise rate to<br>ensure internal<br>Power-on Reset signal | 0.060* | _ | _ | mV/ms | See section on Power-on Reset for details | | D010 | IDD | Supply Current | _ | 3 | 6 | mA | Fosc = 4 MHz (Note 4) | | D011 | | (Note 2) | _ | 6 | 12 * | mA | Fosc = 8 MHz | | D012 | | | _ | 11 | 24 * | mA | Fosc = 16 MHz | | D013 | | | _ | 19 | 38 | mA | Fosc = 25 MHz | | D014 | | | _ | 95 | 150 | μΑ | Fosc = 32 kHz | | | | | | | | | WDT enabled (EC osc configuration) | | D020 | IPD | Power-down Current | _ | 10 | 40 | μΑ | VDD = 5.5V, WDT enabled | | D021 | | (Note 3) | _ | < 1 | 5 | μΑ | VDD = 5.5V, WDT disabled | - \* These parameters are characterized but not tested. - † Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - Note 1: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data. - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption. 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 VDD or Vss, T0CKI = VDD, MCLR = VDD; WDT enabled/disabled as specified. Current consumed from the oscillator and I/O's driving external capacitive or resistive loads need to be considered. For the RC oscillator, the current through the external pull-up resistor (R) can be estimated as: VDD / (2 • R). For capacitive loads, The current can be estimated (for an individual I/O pin) as (CL • VDD) • f CL = Total capacitive load on the I/O pin; f = average frequency on the I/O pin switches. The capacitive currents are most significant when the device is configured for external execution (includes extended microcontroller mode). - 3: 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, all I/O pins in hi-impedance state and tied to VDD or Vss. - 4: For RC 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. Applicable Devices | 42 | R42 | 42A | 43 | R43 | 44 FIGURE 18-13: WDT TIMER TIME-OUT PERIOD vs. VDD FIGURE 18-14: IOH vs. VOH, VDD = 3V Applicable Devices | 42 | R42 | 42A | 43 | R43 | 44 FIGURE 18-15: IOH vs. VOH, VDD = 5V FIGURE 18-16: IOL vs. VOL, VDD = 3V Applicable Devices | 42 | R42 | 42A | 43 | R43 | 44 FIGURE 18-19: VTH, VIL of I/O PINS (SCHMITT TRIGGER) vs. VDD FIGURE 18-20: VTH (INPUT THRESHOLD VOLTAGE) OF OSC1 INPUT (IN XT AND LF MODES) vs. VDD Applicable Devices 42 R42 42A 43 R43 44 ### FIGURE 19-5: TIMERO CLOCK TIMINGS **TABLE 19-5: TIMERO CLOCK REQUIREMENTS** | Parameter No. | Sym | Characteristic | | Min | Тур† | Max | Units | Conditions | |---------------|------|------------------------|----------------|---------------------------------|------|-----|-------|--------------------| | 40 | Tt0H | T0CKI High Pulse Width | No Prescaler | 0.5Tcy + 20 § | _ | _ | ns | | | | | | With Prescaler | 10* | _ | _ | ns | | | 41 | Tt0L | T0CKI Low Pulse Width | No Prescaler | 0.5Tcy + 20 § | _ | _ | ns | | | | | | With Prescaler | 10* | _ | _ | ns | | | 42 | Tt0P | T0CKI Period | | Greater of: | _ | _ | ns | N = prescale value | | | | | | 20 ns or <u>Tcy + 40 §</u><br>N | | | | (1, 2, 4,, 256) | - These parameters are characterized but not tested. - † Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - § This specification ensured by design. FIGURE 19-6: TIMER1, TIMER2, AND TIMER3 CLOCK TIMINGS TABLE 19-6: TIMER1, TIMER2, AND TIMER3 CLOCK REQUIREMENTS | Parameter | | | | Тур | | | | |-----------|-----------|---------------------------------------------------------------|-----------------|-----|-------------|-------|------------------------------------| | No. | Sym | Characteristic | Min | † | Max | Units | Conditions | | 45 | Tt123H | TCLK12 and TCLK3 high time | 0.5Tcy + 20 § | _ | | ns | | | 46 | Tt123L | TCLK12 and TCLK3 low time | 0.5Tcy + 20 § | _ | _ | ns | | | 47 | Tt123P | TCLK12 and TCLK3 input period | Tcy + 40 §<br>N | _ | <del></del> | | N = prescale value<br>(1, 2, 4, 8) | | 48 | TckE2tmrl | Delay from selected External Clock Edge to<br>Timer increment | 2Tosc § | | 6Tosc § | | | - \* These parameters are characterized but not tested. - † Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - § This specification ensured by design. **Applicable Devices** 42 R42 42A 43 R43 44 FIGURE 20-17: IoL vs. Vol, VDD = 5V #### **APPENDIX A: MODIFICATIONS** The following is the list of modifications over the PIC16CXX microcontroller family: - Instruction word length is increased to 16-bit. This allows larger page sizes both in program memory (8 Kwords verses 2 Kwords) and register file (256 bytes versus 128 bytes). - Four modes of operation: microcontroller, protected microcontroller, extended microcontroller, and microprocessor. - 22 new instructions. The MOVF, TRIS and OPTION instructions have been removed. - 4 new instructions for transferring data between data memory and program memory. This can be used to "self program" the EPROM program memory. - Single cycle data memory to data memory transfers possible (MOVPF and MOVFP instructions). These instructions do not affect the Working register (WREG). - 6. W register (WREG) is now directly addressable. - A PC high latch register (PCLATH) is extended to 8-bits. The PCLATCH register is now both readable and writable. - 8. Data memory paging is redefined slightly. - DDR registers replaces function of TRIS registers. - Multiple Interrupt vectors added. This can decrease the latency for servicing the interrupt. - 11. Stack size is increased to 16 deep. - 12. BSR register for data memory paging. - Wake up from SLEEP operates slightly differently. - 14. The Oscillator Start-Up Timer (OST) and Power-Up Timer (PWRT) operate in parallel and not in series. - PORTB interrupt on change feature works on all eight port pins. - 16. TMR0 is 16-bit plus 8-bit prescaler. - Second indirect addressing register added (FSR1 and FSR2). Configuration bits can select the FSR registers to auto-increment, auto-decrement, remain unchanged after an indirect address. - 18. Hardware multiplier added (8 x 8 $\rightarrow$ 16-bit) (PIC17C43 and PIC17C44 only). - 19. Peripheral modules operate slightly differently. - 20. Oscillator modes slightly redefined. - Control/Status bits and registers have been placed in different registers and the control bit for globally enabling interrupts has inverse polarity. - 22. Addition of a test mode pin. - In-circuit serial programming is not implemented. ### APPENDIX B: COMPATIBILITY To convert code written for PIC16CXX to PIC17CXX, the user should take the following steps: - Remove any TRIS and OPTION instructions, and implement the equivalent code. - Separate the interrupt service routine into its four vectors. - 3. Replace: ``` MOVF REG1, W with: MOVFP REG1, WREG ``` 4. Replace: ``` MOVF REG1, W MOVWF REG2 with: MOVPF REG1, REG2; Addr(REG1)<20h or MOVFP REG1, REG2; Addr(REG2)<20h ``` | Note: | | then 20h | | ooth at addres<br>instructions | | |-------|-------|----------|------|--------------------------------|--| | | MOVFP | REG1, | WREG | ; | | | | MOVPF | WREG, | REG2 | ; | | - 5. Ensure that all bit names and register names are updated to new data memory map location. - 6. Verify data memory banking. - 7. Verify mode of operation for indirect addressing. - 8. Verify peripheral routines for compatibility. - Weak pull-ups are enabled on reset. To convert code from the PIC17C42 to all the other PIC17C4X devices, the user should take the following steps. - If the hardware multiply is to be used, ensure that any variables at address 18h and 19h are moved to another address. - Ensure that the upper nibble of the BSR was not written with a non-zero value. This may cause unexpected operation since the RAM bank is no longer 0. - The disabling of global interrupts has been enhanced so there is no additional testing of the GLINTD bit after a BSF CPUSTA, GLINTD instruction. ### E.4 PIC16C6X Family of Devices | | | | | | | Memory | ory | | " | Peripherals | erals | | | Features | |--------------------------|----|--------|------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------|-------|----------------------------------------| | | | | Tolog | Tolk lade | TO LONG ON PLAN TO THE POOL OF THE POOL OF TO THE POOL OF TO THE POOL OF | | (LANS) SHIROLINING BEG | IND STE | TOO THE STATE OF T | Sold of the | 3 | | SHON | Situate BOY Phil | | | 19 | THAIL! | to to the second | 16 | N JOULL | Too. | ios sues | SHOP | TOPIEL | To to the state of | | though spends | SHOH! | SSOE TO LINO | | PIC16C62 | 20 | 2K | 1 | 128 | TMR2 | _ | SPI/I²C | 1 | _ | 22 | 3.0-6.0 | Yes | | 28-pin SDIP, SOIC, SSOP | | PIC16C62A <sup>(1)</sup> | 20 | 2K | 1 | 128 | TMR0,<br>TMR1, TMR2 | - | SPI/I2C | I | 7 | 22 | 2.5-6.0 | Yes | Yes | 28-pin SDIP, SOIC, SSOP | | PIC16CR62 <sup>(1)</sup> | 20 | 1 | 2K | 128 | TMR0,<br>TMR1, TMR2 | 1 | SPI/I²C | I | 7 | 22 | 2.5-6.0 | Yes | Yes | 28-pin SDIP, SOIC, SSOP | | PIC16C63 | 20 | 4K | - | 192 | TMR0,<br>TMR1, TMR2 | 2 | SPI/I²C,<br>USART | I | 10 | 22 | 2.5-6.0 | Yes | Yes | 28-pin SDIP, SOIC | | PIC16CR63 <sup>(1)</sup> | 20 | I | 4K | 192 | TMR0,<br>TMR1, TMR2 | 2 | SPI/I²C,<br>USART | I | 10 | 22 | 2.5-6.0 | Yes | Yes | 28-pin SDIP, SOIC | | PIC16C64 | 20 | 2K | I | 128 | TMR0,<br>TMR1, TMR2 | - | SPI/I2C | Yes | 80 | 33 | 3.0-6.0 | Yes | I | 40-pin DIP;<br>44-pin PLCC, MQFP | | PIC16C64A <sup>(1)</sup> | 20 | 2K | 1 | 128 | TMR0,<br>TMR1, TMR2 | 1 | SPI/I²C | Yes | 8 | 33 | 2.5-6.0 | Yes | Yes | 40-pin DIP;<br>44-pin PLCC, MQFP, TQFP | | PIC16CR64 <sup>(1)</sup> | 20 | I | 2K | 128 | TMR0,<br>TMR1, TMR2 | 1 | SPI/I²C | Yes | 8 | 33 | 2.5-6.0 | Yes | Yes | 40-pin DIP;<br>44-pin PLCC, MQFP, TQFP | | PIC16C65 | 20 | 4K | - | 192 | TMR0,<br>TMR1, TMR2 | 2 | SPI/I²C,<br>USART | Yes | 11 | 33 | 3.0-6.0 | Yes | - | 40-pin DIP;<br>44-pin PLCC, MQFP | | PIC16C65A <sup>(1)</sup> | 20 | 4K | 1 | 192 | TMR0,<br>TMR1, TMR2 | 2 | SPI/I²C,<br>USART | Yes | 11 | 33 | 2.5-6.0 | Yes | Yes | 40-pin DIP;<br>44-pin PLCC, MQFP, TQFP | | PIC16CR65 <sup>(1)</sup> | 20 | 1 | 4K | 192 | TMR0,<br>TMR1, TMR2 | 2 | SPI/I²C,<br>USART | Yes | 11 | 33 | 2.5-6.0 | Yes | Yes | 40-pin DIP;<br>44-pin PLCC, MQFP, TQFP | | | | | | | | | | | | | | | | | All PIC16/17 family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect, and high I/O current capability. All PIC16C6X family devices use serial programming with clock pin RB6 and data pin RB7. Please contact your local sales office for availability of these devices. <del>...</del> Note ### E.8 PIC17CXX Family of Devices | | | | | | Clock | Memory | ory | | Pe | Peripherals | <u>s</u> | | | • | Features | |-----------|---------|-----------|--------------|------------------------------------------|-----------------------------------|---------|-------|-----------------|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------| | | | | | S tolle led | (SOLOW) SOLION (STIN) LORE FOR | | | | | | | | | | | | | | | Toughbe | 10 10 10 10 10 10 10 10 10 10 10 10 10 1 | N VIOLIEN WILLER | (8)/9// | 6 | | 100 | CARCON IN | Tolling. | Sidn | \~∞.` | ્રે જા | (SION) | | | 14 | Y Unulys. | NOACH | MO2 | Stricks to on sound to seed was a | | 1770g | Stework Strikes | Tho St | A SOLOWOOF | S tautional state of the | 12/ | 10 40 40 80 80 80 80 80 80 80 80 80 80 80 80 80 | EA SOUN | Antibot of Angles | | PIC17C42 | 25 | 2K | 1 | 232 | TMR0,TMR1,<br>TMR2,TMR3 | 7 | 2 | Yes | ı | Yes | 11 | 33 | 4.5-5.5 | 22 | 40-pin DIP;<br>44-pin PLCC, MQFP | | PIC17C42A | 25 | X | I | 232 | TMR0,TMR1,<br>TMR2,TMR3 | 7 | 0 | Yes | Yes | Yes | 7 | 33 | 2.5-6.0 | 28 | 40-pin DIP;<br>44-pin PLCC, TQFP, MQFP | | PIC17CR42 | 25 | I | X | 232 | TMR0,TMR1,<br>TMR2,TMR3 | 7 | 0 | Yes | Yes | Yes | 7 | 33 | 2.5-6.0 | 28 | 40-pin DIP;<br>44-pin PLCC, TQFP, MQFP | | PIC17C43 | 25 | ¥ | I | 454 | TMR0,TMR1,<br>TMR2,TMR3 | 7 | 7 | Yes | Yes | Yes | 7 | 33 | 2.5-6.0 | 28 | 40-pin DIP;<br>44-pin PLCC, TQFP, MQFP | | PIC17CR43 | 25 | I | <del>4</del> | 454 | TMR0,TMR1,<br>TMR2,TMR3 | 7 | 7 | Yes | Yes | Yes | 7 | 33 | 2.5-6.0 | 28 | 40-pin DIP;<br>44-pin PLCC, TQFP, MQFP | | PIC17C44 | 25 | Ж | | 454 | TMR0,TMR1,<br>TMR2,TMR3 | 7 | 2 | Yes | Yes | Yes | 11 | 33 | 2.5-6.0 | 28 | 40-pin DIP;<br>44-pin PLCC, TQFP, MQFP | | All F | 7IC16/1 | 17 Fan | nily de | vices ha | ave Power-on Re | eset, | sel | ectable \ | Natcho | log Tim | er, sel | ectabl | e code pro | otect a | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. | DS30412C-page 220 | Delay From External Clock Edge68 | FOSC199 | |--------------------------------------------|--------------------------------------------------------| | Development Support143 | FS0 | | Development Tools143 | FS1 | | Device Drawings | FS2 | | 44-Lead Plastic Surface Mount (MQFP | FS3 | | 10x10 mm Body 1.6/0.15 mm Lead Form)209 | FSR0 | | DIGIT BORROW9 | FSR1 34, 40 | | Digit Carry (DC)9 | Fuzzy Logic Dev. System (fuzzyTECH®-MP) 143, 145 | | Duty Cycle75 | | | | G | | E | | | Floatrical Characteristics | General Format for Instructions | | Electrical Characteristics | General Purpose RAM | | PIC17C42 | General Purpose RAM Bank | | Absolute Maximum Ratings147 | General Purpose Register (GPR) | | Capture Timing | GLINTD 25, 37, 78, 105 | | CLKOUT and I/O Timing156 | GOTO | | DC Characteristics | GPR (General Purpose Register) | | External Clock Timing | Graphs | | Memory Interface Read Timing162 | IOH vs. VOH, VDD = 3V | | Memory Interface Write Timing161 | IOH vs. VOH, VDD = 5V | | PWM Timing159 | IOL vs. VOL, VDD = 3V | | RESET, Watchdog Timer, Oscillator Start-up | IOL vs. VOL, VDD = 5V | | Timer and Power-up Timer157 | Maximum IDD vs. Frequency | | Timer0 Clock Timings158 | (External Clock 125°C to -40°C) 167, 197 | | Timer1, Timer2 and Timer3 Clock Timing 158 | Maximum IPD vs. VDD Watchdog Disabled 168, 198 | | USART Module, Synchronous Receive 160 | Maximum IPD vs. VDD Watchdog Enabled 169, 199 | | USART Module, Synchronous Transmission 160 | RC Oscillator Frequency vs. | | PIC17C43/44 | VDD (Cext = 100 pF) | | Absolute Maximum Ratings175 | RC Oscillator Frequency vs. | | Capture Timing188 | VDD (Cext = 22 pF) | | CLKOUT and I/O Timing185 | RC Oscillator Frequency vs. | | DC Characteristics177 | VDD (Cext = 300 pF) | | External Clock Timing184 | Transconductance of LF Oscillator vs.VDD 166, 196 | | Memory Interface Read Timing191 | Transconductance of XT Oscillator vs. VDD 166, 196 | | Memory Interface Write Timing190 | Typical IDD vs. Frequency | | Parameter Measurement Information183 | (External Clock 25°C) 167, 197 | | RESET, Watchdog Timer, Oscillator Start-up | Typical IPD vs. VDD Watchdog Disabled 25°C . 168, 198 | | Timer and Power-up Timer Timing186 | Typical IPD vs. VDD Watchdog Enabled 25°C 169, 199 | | Timer0 Clock Timing187 | Typical RC Oscillator vs. Temperature 163, 193 | | Timer1, Timer2 and Timer3 Clock Timing 187 | VTH (Input Threshold Voltage) of I/O Pins vs. | | Timing Parameter Symbology182 | VDD 172, 202 | | USART Module Synchronous Receive | VTH (Input Threshold Voltage) of OSC1 Input | | Timing189 | (In XT, HS, <u>and L</u> P Modes) vs. VDD 173, 203 | | USART Module Synchronous Transmission | VTH, VIL of $\overline{MCLR}$ , T0CKI and OSC1 | | Timing189 | (In RC Mode) vs. VDD 173, 203 | | EPROM Memory Access Time Order Suffix31 | WDT Timer Time-Out Period vs. VDD 170, 200 | | Extended Microcontroller29 | | | Extended Microcontroller Mode31 | Н | | External Memory Interface31 | П | | External Program Memory Waveforms31 | Hardware Multiplier49 | | F | | | • | I | | Family of Devices6 | I/O Ports | | PIC14000213 | Bi-directional64 | | PIC16C5X214 | | | PIC16CXXX215 | I/O Ports | | PIC16C6X216 | Programming Considerations | | PIC16C7X217 | Read-Modify-Write Instructions64 Successive Operations | | PIC16C8X218 | INCF | | PIC16C9XX219 | INCF | | PIC17CXX220 | INCFSIZ | | FERR | INDF0 | | FOSC099 | INDF1 | | | 34, 40 | | Figure 6-12: | Program Counter using The CALL and | Figure 14-3: | Crystal Operation, Overtone Crystals | |---------------|-------------------------------------------|---------------|--------------------------------------------| | Ciaura 6 12. | GOTO Instructions | Figure 14 4 | (XT OSC Configuration) | | Figure 6-13: | BSR Operation (PIC17C43/R43/44) | Figure 14-4: | External Clock Input Operation | | Figure 7-1: | TLWT Instruction Operation | Ciauro 14 E | (EC OSC Configuration) | | Figure 7-2: | TABLWT Instruction Operation | Figure 14-5: | External Parallel Resonant Crystal | | Figure 7-3: | TLRD Instruction Operation | F: 44 C | Oscillator Circuit | | Figure 7-4: | TABLED Instruction Operation | Figure 14-6: | External Series Resonant Crystal | | Figure 7-5: | TABLWT Write Timing | F: 44.7 | Oscillator Circuit | | | (External Memory)46 | Figure 14-7: | RC Oscillator Mode | | Figure 7-6: | Consecutive TABLWT Write Timing | Figure 14-8: | Watchdog Timer Block Diagram 104 | | | (External Memory)47 | Figure 14-9: | Wake-up From Sleep Through Interrupt 105 | | Figure 7-7: | TABLRD Timing48 | Figure 15-1: | General Format for Instructions 108 | | Figure 7-8: | TABLRD Timing (Consecutive TABLRD | Figure 15-2: | Q Cycle Activity 109 | | | Instructions)48 | Figure 17-1: | Parameter Measurement Information 154 | | Figure 9-1: | RA0 and RA1 Block Diagram53 | Figure 17-2: | External Clock Timing 155 | | Figure 9-2: | RA2 and RA3 Block Diagram54 | Figure 17-3: | CLKOUT and I/O Timing 156 | | Figure 9-3: | RA4 and RA5 Block Diagram54 | Figure 17-4: | Reset, Watchdog Timer, | | Figure 9-4: | Block Diagram of RB<7:4> and RB<1:0> | • | Oscillator Start-Up Timer and | | · · | Port Pins55 | | Power-Up Timer Timing 157 | | Figure 9-5: | Block Diagram of RB3 and RB2 Port Pins56 | Figure 17-5: | Timer0 Clock Timings 158 | | Figure 9-6: | Block Diagram of RC<7:0> Port Pins58 | Figure 17-6: | Timer1, Timer2, And Timer3 Clock | | Figure 9-7: | PORTD Block Diagram | 94.0 0. | Timings | | riguic o 7. | (in I/O Port Mode)60 | Figure 17-7: | Capture Timings 159 | | Figure 0.9: | | Figure 17-8: | PWM Timings | | Figure 9-8: | PORTE Block Diagram (in I/O Bort Mode) 62 | Figure 17-9: | USART Module: Synchronous | | Figure 0.0. | (in I/O Port Mode) | rigule 17-9. | • | | Figure 9-9: | Successive I/O Operation | F' 47 40 | Transmission (Master/Slave) Timing 160 | | Figure 11-1: | TOSTA Register (Address: 05h, | Figure 17-10: | USART Module: Synchronous Receive | | = | Unbanked) | | (Master/Slave) Timing | | Figure 11-2: | Timer0 Module Block Diagram68 | Figure 17-11: | Memory Interface Write Timing 161 | | Figure 11-3: | TMR0 Timing with External Clock | Figure 17-12: | Memory Interface Read Timing 162 | | | (Increment on Falling Edge)68 | Figure 18-1: | Typical RC Oscillator Frequency | | Figure 11-4: | TMR0 Timing: Write High or Low Byte 69 | | vs. Temperature 163 | | Figure 11-5: | TMR0 Read/Write in Timer Mode70 | Figure 18-2: | Typical RC Oscillator Frequency | | Figure 12-1: | TCON1 Register (Address: 16h, Bank 3)71 | | vs. VDD | | Figure 12-2: | TCON2 Register (Address: 17h, Bank 3)72 | Figure 18-3: | Typical RC Oscillator Frequency | | Figure 12-3: | Timer1 and Timer2 in Two 8-bit | • | vs. VDD | | · · | Timer/Counter Mode73 | Figure 18-4: | Typical RC Oscillator Frequency | | Figure 12-4: | TMR1 and TMR2 in 16-bit Timer/Counter | · · | vs. VDD | | Ü | Mode74 | Figure 18-5: | Transconductance (gm) of LF Oscillator | | Figure 12-5: | Simplified PWM Block Diagram75 | | vs. VDD | | Figure 12-6: | PWM Output75 | Figure 18-6: | Transconductance (gm) of XT Oscillator | | Figure 12-7: | Timer3 with One Capture and One | ga | vs. VDD | | riguic 12 7. | Period Register Block Diagram78 | Figure 18-7: | Typical IDD vs. Frequency (External | | Figure 12-8: | Timer3 with Two Capture Registers | riguic 10-7. | Clock 25°C) | | rigule 12-0. | Block Diagram79 | Figure 18-8: | Maximum IDD vs. Frequency (External | | Figure 12 0: | | rigule 10-0. | | | Figure 12-9: | TMR1, TMR2, and TMR3 Operation in | F: 40 0: | Clock 125°C to -40°C) | | Fig. 40.40 | External Clock Mode80 | Figure 18-9: | Typical IPD vs. VDD Watchdog | | Figure 12-10: | TMR1, TMR2, and TMR3 Operation in | E: 10.10 | Disabled 25°C | | = | Timer Mode81 | Figure 18-10: | Maximum IPD vs. VDD Watchdog | | Figure 13-1: | TXSTA Register (Address: 15h, Bank 0) 83 | | Disabled | | Figure 13-2: | RCSTA Register (Address: 13h, Bank 0) 84 | Figure 18-11: | Typical IPD vs. VDD Watchdog | | Figure 13-3: | USART Transmit85 | | Enabled 25°C 169 | | Figure 13-4: | USART Receive85 | Figure 18-12: | Maximum IPD vs. VDD Watchdog | | Figure 13-5: | Asynchronous Master Transmission90 | | Enabled 169 | | Figure 13-6: | Asynchronous Master Transmission | Figure 18-13: | WDT Timer Time-Out Period vs. VDD 170 | | | (Back to Back)90 | Figure 18-14: | IOH vs. VOH, VDD = 3V | | Figure 13-7: | RX Pin Sampling Scheme91 | Figure 18-15: | IOH vs. VOH, VDD = 5V | | Figure 13-8: | Asynchronous Reception92 | Figure 18-16: | IOL vs. VOL, VDD = 3V | | Figure 13-9: | Synchronous Transmission94 | Figure 18-17: | IOL vs. VOL, VDD = 5V | | Figure 13-10: | Synchronous Transmission | | VTH (Input Threshold Voltage) of | | - | (Through TXEN)94 | - | I/O Pins (TTL) vs. VDD 172 | | Figure 13-11: | Synchronous Reception (Master Mode, | Figure 18-19: | VTH, VIL of I/O Pins (Schmitt Trigger) vs. | | 3 | SREN)95 | 3.12.12.101 | VDD | | Figure 14-1: | Configuration Word99 | Figure 18-20: | VTH (Input Threshold Voltage) of OSC1 | | Figure 14-2: | Crystal or Ceramic Resonator Operation | | Input (In XT and LF Modes) vs. VDD 173 | | 9 1 7 2. | (XT or LF OSC Configuration)100 | Figure 19-1: | Parameter Measurement Information 183 | | | (AT 51 E1 500 Configuration) 100 | riguie 13-1. | i didinotoi wodouroment inioimation 100 | | Figure 19-2: | External Clock Timing | 184 | Table 6-2: | EPROM Memory Access Time | | |---------------|-----------------------------------------|------|--------------|-----------------------------------------------------------|-----| | Figure 19-3: | CLKOUT and I/O Timing | 185 | | Ordering Suffix | .31 | | Figure 19-4: | Reset, Watchdog Timer, | | Table 6-3: | Special Function Registers | .34 | | | Oscillator Start-Up Timer, and | | Table 7-1: | Interrupt - Table Write Interaction | .45 | | | Power-Up Timer Timing | 186 | Table 8-1: | Performance Comparison | .49 | | Figure 19-5: | Timer0 Clock Timings | 187 | Table 9-1: | PORTA Functions | .54 | | Figure 19-6: | Timer1, Timer2, and Timer3 Clock | | Table 9-2: | Registers/Bits Associated with PORTA | .54 | | 3 | Timings | 187 | Table 9-3: | PORTB Functions | .57 | | Figure 19-7: | Capture Timings | | Table 9-4: | Registers/Bits Associated with PORTB | | | Figure 19-8: | PWM Timings | | Table 9-5: | PORTC Functions | | | Figure 19-9: | USART Module: Synchronous | | Table 9-6: | Registers/Bits Associated with PORTC | | | | Transmission (Master/Slave) Timing | 189 | Table 9-7: | PORTD Functions | | | Figure 19-10: | USART Module: Synchronous | | Table 9-8: | Registers/Bits Associated with PORTD | .61 | | | Receive (Master/Slave) Timing | 189 | Table 9-9: | PORTE Functions | | | Figure 19-11: | Memory Interface Write Timing | | Table 9-10: | Registers/Bits Associated with PORTE | | | | (Not Supported in PIC17LC4X Devices) | 190 | Table 11-1: | Registers/Bits Associated with Timer0 | | | Figure 19-12: | Memory Interface Read Timing | | Table 12-1: | Turning On 16-bit Timer | | | | (Not Supported in PIC17LC4X Devices) | 191 | Table 12-2: | Summary of Timer1 and Timer2 | | | Figure 20-1: | Typical RC Oscillator Frequency vs. | | | Registers | .74 | | ga.o _o | Temperature | 193 | Table 12-3: | PWM Frequency vs. Resolution at | | | Figure 20-2: | Typical RC Oscillator Frequency | | | 25 MHz | .76 | | ga. o _o | vs. VDD | 194 | Table 12-4: | Registers/Bits Associated with PWM | | | Figure 20-3: | Typical RC Oscillator Frequency | | Table 12-5: | Registers Associated with Capture | | | 1 1guio 20 0. | vs. VDD | 194 | Table 12-6: | Summary of TMR1, TMR2, and TMR3 | 0 | | Figure 20-4: | Typical RC Oscillator Frequency | 104 | 14510 12 0. | Registers | 81 | | 1 1ga10 20 1. | vs. VDD | 195 | Table 13-1: | Baud Rate Formula | | | Figure 20-5: | Transconductance (gm) of LF Oscillator | 100 | Table 13-2: | Registers Associated with Baud Rate | .00 | | riguic 20 3. | vs. VDD | 196 | Table 10-2. | Generator | 86 | | Figure 20-6: | Transconductance (gm) of XT Oscillator | 100 | Table 13-3: | Baud Rates for Synchronous Mode | | | riguic 20 0. | vs. VDD | 106 | Table 13-4: | Baud Rates for Asynchronous Mode | | | Figure 20-7: | Typical IDD vs. Frequency (External | 190 | Table 13-4: | Registers Associated with Asynchronous | .00 | | riguic 20 7. | Clock 25°C) | 107 | Table 15 5. | Transmission | an | | Figure 20-8: | Maximum IDD vs. Frequency (External | 191 | Table 13-6: | Registers Associated with Asynchronous | .90 | | | Clock 125°C to -40°C) | 107 | Table 13-0. | Reception | വാ | | Figure 20-9: | Typical IPD vs. VDD Watchdog | 191 | Table 13-7: | Registers Associated with Synchronous | .92 | | | Disabled 25°C | 100 | Table 13-7. | • | 0.4 | | Figure 20 10. | Maximum IPD vs. VDD Watchdog | 190 | Table 13-8: | Master Transmission Registers Associated with Synchronous | .94 | | Figure 20-10. | Disabled | 100 | Table 13-0. | | 06 | | Figure 20 11: | Typical IPD vs. VDD Watchdog | 190 | Table 13-9: | Master Reception Registers Associated with Synchronous | .90 | | rigule 20-11. | Enabled 25°C | 100 | Table 13-9. | Slave Transmission | 00 | | Figure 20 12: | | 199 | Toble 12 10: | Registers Associated with Synchronous | .90 | | Figure 20-12. | Maximum IPD vs. VDD Watchdog | 100 | Table 13-10: | | 00 | | Eiguro 20 12: | Enabled | | Toble 14 1: | Slave Reception | | | - | WDT Timer Time-Out Period vs. VDD | | Table 14-1: | Configuration Locations | UU | | - | IOH vs. VOH, VDD = 3V | | Table 14-2: | Capacitor Selection for Ceramic | 104 | | | IOH VS. VOH, VDD = 5V | | Toble 14.2: | Resonators | UI | | | IOL vs. VOL, VDD = 3V | | Table 14-3: | Capacitor Selection for Crystal | 104 | | | IOL VS. VOL, VDD = 5V | 202 | Table 4.4.4. | OscillatoR | UI | | Figure 20-18: | VTH (Input Threshold Voltage) of | 202 | Table 14-4: | Registers/Bits Associated with the | 104 | | Figure 20.42 | I/O Pins (TTL) vs. VDD | 202 | Table 45.4. | Watchdog Timer | | | Figure 20-19: | VTH, VIL of I/O Pins (Schmitt Trigger) | 000 | Table 15-1: | Opcode Field Descriptions | | | F' 00 00 | VS. VDD | 203 | Table 15-2: | PIC17CXX Instruction Set | | | Figure 20-20: | VTH (Input Threshold Voltage) of OSC1 | 000 | Table 16-1: | development tools from microchip1 | 40 | | | Input (In XT and LF Modes) vs. VDD | 203 | Table 17-1: | Cross Reference of Device Specs for | | | LIST OF TAE | RI FS | | | Oscillator Configurations and Frequencies | | | | | _ | | of Operation (Commercial Devices)1 | | | Table 1-1: | PIC17CXX Family of Devices | | Table 17-2: | External Clock Timing Requirements1 | | | Table 3-1: | Pinout Descriptions | | Table 17-3: | CLKOUT and I/O Timing Requirements1 | 56 | | Table 4-1: | Time-Out in Various Situations | | Table 17-4: | Reset, Watchdog Timer, | | | Table 4-2: | STATUS Bits and Their Significance | . 16 | | Oscillator Start-Up Timer and | | | Table 4-3: | Reset Condition for the Program Counter | | | Power-Up Timer Requirements1 | | | | and the CPUSTA Register | . 16 | Table 17-5: | Timer0 Clock Requirements1 | 58 | | Table 4-4: | Initialization Conditions For Special | | Table 17-6: | Timer1, Timer2, and Timer3 Clock | | | | Function Registers | | | Requirements1 | | | Table 5-1: | Interrupt Vectors/Priorities | | Table 17-7: | Capture Requirements1 | | | Table 6-1: | Mode Memory Access | . 30 | Table 17-8: | PWM Requirements1 | 159 |