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>" | Obsolete | |--------------------------------------------------------------------------| | PIC | | 8-Bit | | 33MHz | | UART/USART | | POR, PWM, WDT | | 33 | | 8KB (4K x 16) | | OTP | | - | | 454 x 8 | | 4.5V ~ 6V | | - | | External | | -40°C ~ 125°C (TA) | | Through Hole | | 40-DIP (0.600", 15.24mm) | | 40-PDIP | | https://www.e-xfl.com/product-detail/microchip-technology/pic17c43-33e-p | | | ## 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: ## 8.0 HARDWARE MULTIPLIER All PIC17C4X devices except the PIC17C42, have an 8 x 8 hardware multiplier included in the ALU of the device. By making the multiply a hardware operation, it completes in a single instruction cycle. This is an unsigned multiply that gives a 16-bit result. The result is stored into the 16-bit PRODuct register (PRODH:PRODL). The multiplier does not affect any flags in the ALUSTA register. Making the 8 x 8 multiplier execute in a single cycle gives the following advantages: - · Higher computational throughput - Reduces code size requirements for multiply algorithms The performance increase allows the device to be used in applications previously reserved for Digital Signal Processors. Table 8-1 shows a performance comparison between the PIC17C42 and all other PIC17CXX devices, which have the single cycle hardware multiply. Example 8-1 shows the sequence to do an 8 x 8 unsigned multiply. Only one instruction is required when one argument of the multiply is already loaded in the WREG register. Example 8-2 shows the sequence to do an $8 \times 8$ signed multiply. To account for the sign bits of the arguments, each argument's most significant bit (MSb) is tested and the appropriate subtractions are done. ### **EXAMPLE 8-1:** 8 x 8 MULTIPLY ROUTINE ``` MOVFP ARG1, WREG MULWF ARG2 ; ARG1 * ARG2 -> ; PRODH:PRODL ``` ## EXAMPLE 8-2: 8 x 8 SIGNED MULTIPLY ROUTINE ``` ARG1, WREG MOVFP ARG2 MULWF ; ARG1 * ARG2 -> ; PRODH:PRODL ARG2, SB ; Test Sign Bit BTFSC PRODH, F SUBWF ; PRODH = PRODH - ARG1 MOVFP ARG2, WREG BTFSC ARG1, SB ; Test Sign Bit SUBWF PRODH, F ; PRODH = PRODH - ARG2 ``` TABLE 8-1: PERFORMANCE COMPARISON | Bastina | Davida | Program Memory | OI (M) | Tir | ne | |------------------|----------------------------|----------------|--------------|----------|----------| | Routine | Device | (Words) | Cycles (Max) | @ 25 MHz | @ 33 MHz | | 8 x 8 unsigned | PIC17C42 | 13 | 69 | 11.04 μs | N/A | | | All other PIC17CXX devices | 1 | 1 | 160 ns | 121 ns | | 8 x 8 signed | PIC17C42 | _ | _ | _ | N/A | | | All other PIC17CXX devices | 6 | 6 | 960 ns | 727 ns | | 16 x 16 unsigned | PIC17C42 | 21 | 242 | 38.72 μs | N/A | | | All other PIC17CXX devices | 24 | 24 | 3.84 µs | 2.91 μs | | 16 x 16 signed | PIC17C42 | 52 | 254 | 40.64 μs | N/A | | | All other PIC17CXX devices | 36 | 36 | 5.76 µs | 4.36 μs | Peripheral Data in RBPU (PORTA<7>) Weak Pull-Up Match Signal\_ from other, port pins **RBIF** Port Input Latch Data Bus RD\_DDRB (Q2) RD\_PORTB (Q2) D $\overline{\mathsf{OE}}$ WR\_DDRB (Q4) **~**CK D Port Q Data WR\_PORTB (Q4) PWM\_output PWM\_select Note: I/O pins have protection diodes to VDD and Vss. FIGURE 9-5: **BLOCK DIAGRAM OF RB3 AND RB2 PORT PINS** Example 9-1 shows the instruction sequence to initialize PORTB. The Bank Select Register (BSR) must be selected to Bank 0 for the port to be initialized. ## **EXAMPLE 9-1: INITIALIZING PORTB** MOVLB 0 ; Select Bank 0 CLRF PORTB ; Initialize PORTB by clearing ; output data latches MOVLW 0xCF ; Value used to initialize ; data direction MOVWF DDRB ; Set RB<3:0> as inputs RB<5:4> as outputs RB<7:6> as inputs ## **TABLE 9-3: PORTB FUNCTIONS** | Name | Bit | Buffer Type | Function | |------------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------| | RB0/CAP1 | bit0 | ST | Input/Output or the RB0/CAP1 input pin. Software programmable weak pullup and interrupt on change features. | | RB1/CAP2 | bit1 | ST | Input/Output or the RB1/CAP2 input pin. Software programmable weak pullup and interrupt on change features. | | RB2/PWM1 | bit2 | ST | Input/Output or the RB2/PWM1 output pin. Software programmable weak pull-up and interrupt on change features. | | RB3/PWM2 | bit3 | ST | Input/Output or the RB3/PWM2 output pin. Software programmable weak pull-up and interrupt on change features. | | RB4/TCLK12 | bit4 | ST | Input/Output or the external clock input to Timer1 and Timer2. Software programmable weak pull-up and interrupt on change features. | | RB5/TCLK3 | bit5 | ST | Input/Output or the external clock input to Timer3. Software programmable weak pull-up and interrupt on change features. | | RB6 | bit6 | ST | Input/Output pin. Software programmable weak pull-up and interrupt on change features. | | RB7 | bit7 | ST | Input/Output pin. Software programmable weak pull-up and interrupt on change features. | Legend: ST = Schmitt Trigger input. ## TABLE 9-4: REGISTERS/BITS ASSOCIATED WITH PORTB | 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<br>(Note1) | |---------------|--------|------------|---------------|--------------|--------|---------|--------|-----------|---------|-------------------------------|--------------------------------------------| | 12h, Bank 0 | PORTB | PORTB d | ata latch | | | | | | | xxxx xxxx | uuuu uuuu | | 11h, Bank 0 | DDRB | Data dired | ction registe | er for PORTE | 3 | | | | | 1111 1111 | 1111 1111 | | 10h, Bank 0 | PORTA | RBPU | | RA5 | RA4 | RA3 | RA2 | RA1/T0CKI | RA0/INT | 0-xx xxxx | 0-uu uuuu | | 06h, Unbanked | CPUSTA | _ | _ | STKAV | GLINTD | TO | PD | _ | _ | 11 11 | 11 qq | | 07h, Unbanked | INTSTA | PEIF | T0CKIF | TOIF | INTF | PEIE | T0CKIE | TOIE | INTE | 0000 0000 | 0000 0000 | | 16h, Bank 1 | PIR | RBIF | TMR3IF | TMR2IF | TMR1IF | CA2IF | CA1IF | TXIF | RCIF | 0000 0010 | 0000 0010 | | 17h, Bank 1 | PIE | RBIE | TMR3IE | TMR2IE | TMR1IE | CA2IE | CA1IE | TXIE | RCIE | 0000 0000 | 0000 0000 | | 16h, Bank 3 | TCON1 | CA2ED1 | CA2ED0 | CA1ED1 | CA1ED0 | T16 | TMR3CS | TMR2CS | TMR1CS | 0000 0000 | 0000 0000 | | 17h, Bank 3 | TCON2 | CA2OVF | CA10VF | PWM2ON | PWM10N | CA1/PR3 | TMR3ON | TMR2ON | TMR10N | 0000 0000 | 0000 0000 | Legend: x = unknown, u = unchanged, - = unimplemented read as '0', q = Value depends on condition. Shaded cells are not used by PORTB. Note 1: Other (non power-up) resets include: external reset through MCLR and the Watchdog Timer Reset. # 14.0 SPECIAL FEATURES OF THE CPU What sets a microcontroller apart from other processors are special circuits to deal with the needs of real time applications. The PIC17CXX family has a host of such features intended to maximize system reliability, minimize cost through elimination of external components, provide power saving operating modes and offer code protection. These are: - · OSC selection - Reset - Power-on Reset (POR) - Power-up Timer (PWRT) - Oscillator Start-up Timer (OST) - Interrupts - Watchdog Timer (WDT) - SLEEP - · Code protection The PIC17CXX has a Watchdog Timer which can be shut off only through EPROM bits. It runs off its own RC oscillator for added reliability. There are two timers that offer necessary delays on power-up. One is the Oscillator Start-up Timer (OST), intended to keep the chip in RESET until the crystal oscillator is stable. The other is the Power-up Timer (PWRT), which provides a fixed delay of 96 ms (nominal) on power-up only, designed to keep the part in RESET while the power supply stabilizes. With these two timers on-chip, most applications need no external reset circuitry. The SLEEP mode is designed to offer a very low current power-down mode. The user can wake from SLEEP through external reset, Watchdog Timer Reset or through an interrupt. Several oscillator options are also made available to allow the part to fit the application. The RC oscillator option saves system cost while the LF crystal option saves power. Configuration bits are used to select various options. This configuration word has the format shown in Figure 14-1. ## FIGURE 14-1: CONFIGURATION WORD | MOVFP | Move f to p | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [label] MOVFP f,p | | Operands: | $0 \le f \le 255$<br>$0 \le p \le 31$ | | Operation: | $(f) \rightarrow (p)$ | | Status Affected: | None | | Encoding: | 011p pppp ffff ffff | | Description: | Move data from data memory location 'f' to data memory location 'p'. Location 'f' can be anywhere in the 256 word data space (00h to FFh) while 'p' can be 00h to 1Fh. Either 'p' or 'f' can be WREG (a useful special situation). | | | MOVFP is particularly useful for transfer-<br>ring a data memory location to a periph-<br>eral register (such as the transmit buffer<br>or an I/O port). Both 'f' and 'p' can be<br>indirectly addressed. | | Words: | 1 | Cycles: Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |--------|--------------|---------|--------------| | Decode | Read | Execute | Write | | | register 'f' | | register 'p' | Example: MOVFP REG1, REG2 1 Before Instruction REG1 = 0x33, REG2 = 0x11 After Instruction REG1 = 0x33, REG2 = 0x33 MOVLB Move Literal to low nibble in BSR Syntax: [label] MOVLB k Operands: $0 \le k \le 15$ Operation: $k \rightarrow (BSR<3:0>)$ Status Affected: None Encoding: 1011 1000 uuuu kkkk Description: The four bit literal 'k' is loaded in the Bank Select Register (BSR). Only the low 4-bits of the Bank Select Register are affected. The upper half of the BSR is unchanged. The assembler will encode the "u" fields as '0'. Words: 1 Cycles: 1 Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |--------|-----------------------|---------|---------------| | Decode | Read<br>literal 'u:k' | Execute | Write literal | | | | | BSR<3:0> | Example: MOVLB 0x5 Before Instruction BSR register = 0x22 After Instruction BSR register = 0x25 **Note:** For the PIC17C42, only the low four bits of the BSR register are physically implemented. The upper nibble is read as '0'. NOTES: 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 | 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. FIGURE 18-2: TYPICAL RC OSCILLATOR FREQUENCY vs. VDD FIGURE 18-3: TYPICAL RC OSCILLATOR FREQUENCY vs. VDD FIGURE 18-13: WDT TIMER TIME-OUT PERIOD vs. VDD FIGURE 18-14: IOH vs. VOH, VDD = 3V 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-17: IoL vs. Vol, VDD = 5V FIGURE 18-18: VTH (INPUT THRESHOLD VOLTAGE) OF I/O PINS (TTL) VS. VDD **NOTES:** Applicable Devices 42 R42 42A 43 R43 44 FIGURE 19-12: MEMORY INTERFACE READ TIMING (NOT SUPPORTED IN PIC17LC4X DEVICES) TABLE 19-12: MEMORY INTERFACE READ REQUIREMENTS (NOT SUPPORTED IN PIC17LC4X DEVICES) | Parameter<br>No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |------------------|---------------------------------------------------------------------|-------------------------------------------------------|---------------|-----------|--------------|-------|------------| | 150 | TadV2alL | AD15:AD0 (address) valid to ALE↓ (address setup time) | 0.25Tcy - 10 | _ | _ | ns | | | 151 | TalL2adl | ALE↓ to address out invalid (address hold time) | 5* | _ | _ | ns | | | 160 | TadZ2oeL | AD15:AD0 hi-impedance to <del>OE</del> ↓ | 0* | _ | _ | ns | | | 161 | ToeH2adD | OE↑ to AD15:AD0 driven | 0.25Tcy - 15 | _ | _ | ns | | | 162 | 162 TadV2oeH Data in valid before <del>OE</del> ↑ (data setup time) | | 35 | _ | _ | ns | | | 163 | ToeH2adl | OE↑to data in invalid (data hold time) | 0 | _ | _ | ns | | | 164 | TalH | ALE pulse width | _ | 0.25Tcy § | _ | ns | | | 165 | ToeL | OE pulse width | 0.5Tcy - 35 § | _ | _ | ns | | | 166 | TalH2alH | ALE↑ to ALE↑(cycle time) | _ | Tcy § | _ | ns | | | 167 | Tacc | Address access time | _ | _ | 0.75Tcy - 30 | ns | | | 168 | Toe | Output enable access time (OE low to Data Valid) | _ | _ | 0.5Tcy - 45 | ns | | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. <sup>§</sup> This specification ensured by design. FIGURE 20-5: TRANSCONDUCTANCE (gm) OF LF OSCILLATOR vs. VDD FIGURE 20-6: TRANSCONDUCTANCE (gm) OF XT OSCILLATOR vs. VDD #### **PIC16CXXX Family of Devices** E.3 | | | | | Clock | Memory | lory | $ \downarrow $ | Perip | Peripherals | $\rightarrow$ | Features | |--------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------|-------------|------------|----------------|------------------|-------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Tollege | Tours done le | | | | | One of | | | | | | Vig. | 8 6 TO TO | W 1+) | (§. 1) | | | ON BOUG | | | to signature of the sig | | | TON | College Book of the College C | 10 | TOON TOUTON ERC | ALDOW SOUTH | * Ruleilli | To letter | Suid Of Religion | SUL SUL | (16 00 14 OC) | Secretary Mounote Selos | | PIC16C554 | 20 | 512 | 80 | TMR0 | | | 3 | 13 | 2.5-6.0 | | 18-pin DIP, SOIC; 20-pin SSOP | | PIC16C556 | 20 | <del>,</del> | 80 | TMR0 | I | I | 3 | 13 | 2.5-6.0 | ı | 18-pin DIP, SOIC; 20-pin SSOP | | PIC16C558 | 20 | 2K | 128 | TMR0 | ı | I | 3 | 13 | 2.5-6.0 | I | 18-pin DIP, SOIC; 20-pin SSOP | | PIC16C620 | 20 | 512 | 80 | TMR0 | 2 | Yes | 4 | 13 | 2.5-6.0 | Yes | 18-pin DIP, SOIC; 20-pin SSOP | | PIC16C621 | 20 | <del>*</del> | 80 | TMR0 | 2 | Yes | 4 | 13 | 2.5-6.0 | Yes | 18-pin DIP, SOIC; 20-pin SSOP | | PIC16C622 | 20 | 2K | 128 | TMR0 | 2 | Yes | 4 | 13 | 2.5-6.0 | Yes | 18-pin DIP, SOIC; 20-pin SSOP | | AII DIC16/17 | | oivo o viio | 0,0400 | Doug | Pose+ | 20000 | N olde | Jodoto, | Timor | 10000 | Ermily devised bours on Deast colonatable Westchard Times colonatable and and bigh I/O | All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C6XXX Family devices use serial programming with clock pin RB6 and data pin RB7. | ndirect Addressing | | TSTFSZ | 140 | |---------------------------------------------------------|-----|------------------------------------|----------| | Indirect Addressing | 39 | XORLW | 141 | | Operation | 40 | XORWF | 141 | | Registers | | Instruction Set Summary | 107 | | nitialization Conditions For Special Function Registers | 19 | INT Pin | | | nitializing PORTB | | INTE | | | nitializing PORTC | | INTEDG | | | nitializing PORTD | | Interrupt on Change Feature | , - | | nitializing PORTE | | Interrupt Status Register (INTSTA) | | | nstruction Flow/Pipelining | | Interrupt Status Register (INTSTA) | 22 | | | | • | 07 | | nstruction Set | | Context Saving | ∠۱ | | ADDLW | | Flag bits | 0.4 | | ADDWF | | TMR1IE | | | ADDWFC | 113 | TMR1IF | | | ANDLW | 113 | TMR2IE | 21 | | ANDWF | 114 | TMR2IF | 21 | | BCF | 114 | TMR3IE | 21 | | BSF | 115 | TMR3IF | 21 | | BTFSC | 115 | Interrupts | 21 | | BTFSS | | Logic | | | BTG | | Operation | | | CALL | | Peripheral Interrupt Enable | | | CLRF | | Peripheral Interrupt Request | | | | | | | | CLRWDT | | PWM | | | COMF | | Status Register | | | CPFSEQ | | Table Write Interaction | | | CPFSGT | 119 | Timing | 26 | | CPFSLT | 120 | Vectors | | | DAW | 120 | Peripheral Interrupt | | | DECF | 121 | RA0/INT Interrupt | 26 | | DECFSNZ | 122 | T0CKI Interrupt | 26 | | DECFSZ | 121 | TMR0 Interrupt | 26 | | GOTO | 122 | Vectors/Priorities | | | INCF | | Wake-up from SLEEP | | | INCFSNZ | | INTF | | | INCFSZ | | INTSTA | | | IORLW | _ | INTSTA Register | | | | | IORLW | | | IORWF | | | | | LCALL | | IORWF | 125 | | MOVFP | | | | | MOVLB | _ | L | | | MOVLR | | <b>-</b> | | | MOVLW | 127 | LCALL | 126 | | MOVPF | 128 | | | | MOVWF | 128 | Long Writes | 45 | | MULLW | 129 | | | | MULWF | 129 | М | | | NEGW | 130 | 101 | | | NOP | | Mamany | | | RETFIE | | Memory | 0.4 | | | | External Interface | | | RETLIN | | External Memory Waveforms | | | RETURN | | Memory Map (Different Modes) | | | RLCF | _ | Mode Memory Access | | | RLNCF | | Organization | | | RRCF | | Program Memory | 29 | | RRNCF | 134 | Program Memory Map | | | SETF | 134 | Microcontroller | | | SLEEP | 135 | Microprocessor | | | SUBLW | 135 | Minimizing Current Consumption | | | SUBWF | | MOVFP | | | SUBWFB | | | | | SWAPF | | MOVLB | | | | | MOVLR | | | TABLRD | - | MOVLW | | | TABLWT13 | • | MOVPF | | | TLRD | | MOVWF | | | TLWT | 140 | MPASM Assembler | 143, 144 | | 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 | | - | 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 | | | J | 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 | | | 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 | | 1 igule 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 | | | 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 | 197 | Table 13-7: | Registers Associated with Synchronous | .92 | | rigule 20-9. | 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-16. | VTH (Input Threshold Voltage) of | 202 | Table 14-4: | Registers/Bits Associated with the | 104 | | F: 20 40: | 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: 20 20: | 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 | ### **ON-LINE SUPPORT** Microchip provides two methods of on-line support. These are the Microchip BBS and the Microchip World Wide Web (WWW) site. Use Microchip's Bulletin Board Service (BBS) to get current information and help about Microchip products. Microchip provides the BBS communication channel for you to use in extending your technical staff with microcontroller and memory experts. To provide you with the most responsive service possible, the Microchip systems team monitors the BBS, posts the latest component data and software tool updates, provides technical help and embedded systems insights, and discusses how Microchip products provide project solutions. The web site, like the BBS, is used by Microchip as a means to make files and information easily available to customers. To view the site, the user must have access to the Internet and a web browser, such as Netscape or Microsoft Explorer. Files are also available for FTP download from our FTP site. ## Connecting to the Microchip Internet Web Site The Microchip web site is available by using your favorite Internet browser to attach to: #### www.microchip.com The file transfer site is available by using an FTP service to connect to: ### ftp.mchip.com/biz/mchip The web site and file transfer site provide a variety of services. Users may download files for the latest Development Tools, Data Sheets, Application Notes, User's Guides, Articles and Sample Programs. A variety of Microchip specific business information is also available, including listings of Microchip sales offices, distributors and factory representatives. Other data available for consideration is: - Latest Microchip Press Releases - Technical Support Section with Frequently Asked Questions - · Design Tips - Device Errata - Job Postings - Microchip Consultant Program Member Listing - Links to other useful web sites related to Microchip Products ## **Connecting to the Microchip BBS** Connect worldwide to the Microchip BBS using either the Internet or the CompuServe® communications network. ### **Internet:** You can telnet or ftp to the Microchip BBS at the address: ## mchipbbs.microchip.com ### **CompuServe Communications Network:** When using the BBS via the Compuserve Network, in most cases, a local call is your only expense. The Microchip BBS connection does not use CompuServe membership services, therefore you do not need CompuServe membership to join Microchip's BBS. There is no charge for connecting to the Microchip BBS. The procedure to connect will vary slightly from country to country. Please check with your local CompuServe agent for details if you have a problem. CompuServe service allow multiple users various baud rates depending on the local point of access. The following connect procedure applies in most locations. - Set your modem to 8-bit, No parity, and One stop (8N1). This is not the normal CompuServe setting which is 7E1. - 2. Dial your local CompuServe access number. - Depress the <Enter> key and a garbage string will appear because CompuServe is expecting a 7E1 setting. - Type +, depress the <Enter> key and "Host Name:" will appear. - 5. Type MCHIPBBS, depress the <Enter> key and you will be connected to the Microchip BBS. In the United States, to find the CompuServe phone number closest to you, set your modem to 7E1 and dial (800) 848-4480 for 300-2400 baud or (800) 331-7166 for 9600-14400 baud connection. After the system responds with "Host Name:", type NETWORK, depress the <Enter> key and follow CompuServe's directions. For voice information (or calling from overseas), you may call (614) 723-1550 for your local CompuServe number. Microchip regularly uses the Microchip BBS to distribute technical information, application notes, source code, errata sheets, bug reports, and interim patches for Microchip systems software products. For each SIG, a moderator monitors, scans, and approves or disapproves files submitted to the SIG. No executable files are accepted from the user community in general to limit the spread of computer viruses. ## Systems Information and Upgrade Hot Line The Systems Information and Upgrade Line provides system users a listing of the latest versions of all of Microchip's development systems software products. Plus, this line provides information on how customers can receive any currently available upgrade kits. The Hot Line Numbers are: 1-800-755-2345 for U.S. and most of Canada, and 1-602-786-7302 for the rest of the world. 960513 Trademarks: The Microchip name, logo, PIC, PICSTART, PICMASTER and PRO MATE are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. FlexROM, MPLAB and fuzzyLAB, are trademarks and SQTP is a service mark of Microchip in the U.S.A. fuzzyTECH is a registered trademark of Inform Software Corporation. IBM, IBM PC-AT are registered trademarks of International Business Machines Corp. Pentium is a trademark of Intel Corporation. Windows is a trademark and MS-DOS, Microsoft Windows are registered trademarks of Microsoft Corporation. CompuServe is a registered trademark of CompuServe Incorporated. All other trademarks mentioned herein are the property of their respective companies. ## WORLDWIDE SALES AND SERVICE ### **AMERICAS** ### **Corporate Office** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: 480-792-7627 Web Address: http://www.microchip.com ### **Rocky Mountain** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-7456 #### Atlanta 500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307 #### **Boston** 2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821 ## Chicago 333 Pierce Road, Suite 180 Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075 #### **Dallas** 4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924 #### Detroit Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260 ## Kokomo 2767 S. Albright Road Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387 ### Los Angeles 18201 Von Karman, Suite 1090 Irvine, CA 92612 Tel: 949-263-1888 Fax: 949-263-1338 ## **New York** 150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335 ### San Jose Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955 #### Toronto 6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509 ## ASIA/PACIFIC #### Australia Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia Tel: 61-2-9868-6733 Fax: 61-2-9868-6755 ### China - Beijing Microchip Technology Consulting (Shanghai) Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104 ### China - Chengdu Microchip Technology Consulting (Shanghai) Co., Ltd., Chengdu Liaison Office Rm. 2401, 24th Floor, Ming Xing Financial Tower No. 88 TIDU Street Chengdu 610016, China Tel: 86-28-6766200 Fax: 86-28-6766599 #### China - Fuzhou Microchip Technology Consulting (Shanghai) Co., Ltd., Fuzhou Liaison Office Unit 28F, World Trade Plaza No. 71 Wusi Road Fuzhou 350001, China Tel: 86-591-7503506 Fax: 86-591-7503521 ### China - Shanghai Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060 ## China - Shenzhen Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1315, 13/F, Shenzhen Kerry Centre, Renminnan Lu Shenzhen 518001, China Tel: 86-755-2350361 Fax: 86-755-2366086 ## **Hong Kong** Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 #### India Microchip Technology Inc. India Liaison Office Divvasree Chambers 1 Floor, Wing A (A3/A4) No. 11, O'Shaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062 #### Japan Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122 #### Korea Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934 ### Singapore Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-334-8870 Fax: 65-334-8850 ## Taiwan Microchip Technology Taiwan 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139 #### **EUROPE** #### Denmark Microchip Technology Nordic ApS Regus Business Centre Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910 #### France Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - Ier Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 **Germany** Microchip Technology GmbH Gustav-Heinemann Ring 125 D-81739 Munich, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44 ## Italy Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883 #### **United Kingdom** Arizona Microchip Technology Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820 01/18/02