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 | OTP | | EEPROM Size | - | | RAM Size | 454 x 8 | | Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V | | Data Converters | - | | Oscillator Type | External | | Operating Temperature | -40°C ~ 85°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/pic17lc43t-08i-pt | TABLE 1-1: PIC17CXX FAMILY OF DEVICES | Features | | PIC17C42 | PIC17CR42 | PIC17C42A | PIC17C43 | PIC17CR43 | PIC17C44 | |-----------------------------|----------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------| | Maximum Frequency of O | peration | 25 MHz | 33 MHz | 33 MHz | 33 MHz | 33 MHz | 33 MHz | | Operating Voltage Range | | 4.5 - 5.5V | 2.5 - 6.0V | 2.5 - 6.0V | 2.5 - 6.0V | 2.5 - 6.0V | 2.5 - 6.0V | | Program Memory x16 | (EPROM) | 2K | - | 2K | 4K | - | 8K | | | (ROM) | - | 2K | = | = | 4K | - | | Data Memory (bytes) | | 232 | 232 | 232 | 454 | 454 | 454 | | Hardware Multiplier (8 x 8) | ) | - | Yes | Yes | Yes | Yes | Yes | | Timer0 (16-bit + 8-bit post | scaler) | Yes | Yes | Yes | Yes | Yes | Yes | | Timer1 (8-bit) | | Yes | Yes | Yes | Yes | Yes | Yes | | Timer2 (8-bit) | | Yes | Yes | Yes | Yes | Yes | Yes | | Timer3 (16-bit) | | Yes | Yes | Yes | Yes | Yes | Yes | | Capture inputs (16-bit) | | 2 | 2 | 2 | 2 | 2 | 2 | | PWM outputs (up to 10-bit | t) | 2 | 2 | 2 | 2 | 2 | 2 | | USART/SCI | | Yes | Yes | Yes | Yes | Yes | Yes | | Power-on Reset | | Yes | Yes | Yes | Yes | Yes | Yes | | Watchdog Timer | | Yes | Yes | Yes | Yes | Yes | Yes | | External Interrupts | | Yes | Yes | Yes | Yes | Yes | Yes | | Interrupt Sources | | 11 | 11 | 11 | 11 | 11 | 11 | | Program Memory Code Pr | rotect | Yes | Yes | Yes | Yes | Yes | Yes | | I/O Pins | | 33 | 33 | 33 | 33 | 33 | 33 | | I/O High Current Capabil- | Source | 25 mA | 25 mA | 25 mA | 25 mA | 25 mA | 25 mA | | ity | Sink | 25 mA <sup>(1)</sup> | 25 mA <sup>(1)</sup> | 25 mA <sup>(1)</sup> | 25 mA <sup>(1)</sup> | 25 mA <sup>(1)</sup> | 25 mA <sup>(1)</sup> | | Package Types | | 40-pin DIP | 40-pin DIP | 40-pin DIP | 40-pin DIP | 40-pin DIP | 40-pin DIP | | | | 44-pin PLCC | 44-pin PLCC | 44-pin PLCC | 44-pin PLCC | 44-pin PLCC | 44-pin PLCC | | | | 44-pin MQFP | 44-pin MQFP | 44-pin MQFP | 44-pin MQFP | 44-pin MQFP | 44-pin MQFP | | | | | 44-pin TQFP | 44-pin TQFP | 44-pin TQFP | 44-pin TQFP | 44-pin TQFP | Note 1: Pins RA2 and RA3 can sink up to 60 mA. ### 3.0 ARCHITECTURAL OVERVIEW The high performance of the PIC17C4X can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC17C4X uses a modified Harvard architecture. This architecture has the program and data accessed from separate memories. So the device has a program memory bus and a data memory bus. This improves bandwidth over traditional von Neumann architecture, where program and data are fetched from the same memory (accesses over the same bus). Separating program and data memory further allows instructions to be sized differently than the 8-bit wide data word. PIC17C4X opcodes are 16-bits wide, enabling single word instructions. The full 16-bit wide program memory bus fetches a 16-bit instruction in a single cycle. A twostage pipeline overlaps fetch and execution of instructions. Consequently, all instructions execute in a single cycle (121 ns @ 33 MHz), except for program branches and two special instructions that transfer data between program and data memory. The PIC17C4X can address up to 64K x 16 of program memory space. The **PIC17C42** and **PIC17C42A** integrate 2K x 16 of EPROM program memory on-chip, while the **PIC17CR42** has 2K x 16 of ROM program memory on-chip. The **PIC17C43** integrates 4K x 16 of EPROM program memory, while the **PIC17CR43** has 4K x 16 of ROM program memory. The **PIC17C44** integrates 8K x 16 EPROM program memory. Program execution can be internal only (microcontroller or protected microcontroller mode), external only (microprocessor mode) or both (extended microcontroller mode). Extended microcontroller mode does not allow code protection. The PIC17CXX can directly or indirectly address its register files or data memory. All special function registers, including the Program Counter (PC) and Working Register (WREG), are mapped in the data memory. The PIC17CXX has an orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC17CXX simple yet efficient. In addition, the learning curve is reduced significantly. One of the PIC17CXX family architectural enhancements from the PIC16CXX family allows two file registers to be used in some two operand instructions. This allows data to be moved directly between two registers without going through the WREG register. This increases performance and decreases program memory usage. The PIC17CXX devices contain an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between data in the working register and any register file. The ALU is 8-bits wide and capable of addition, subtraction, shift, and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. The WREG register is an 8-bit working register used for ALU operations. All PIC17C4X devices (except the PIC17C42) have an 8 x 8 hardware multiplier. This multiplier generates a 16-bit result in a single cycle. Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a borrow and digit borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples. Although the ALU does not perform signed arithmetic, the Overflow bit (OV) can be used to implement signed math. Signed arithmetic is comprised of a magnitude and a sign bit. The overflow bit indicates if the magnitude overflows and causes the sign bit to change state. Signed math can have greater than 7-bit values (magnitude), if more than one byte is used. The use of the overflow bit only operates on bit6 (MSb of magnitude) and bit7 (sign bit) of the value in the ALU. That is, the overflow bit is not useful if trying to implement signed math where the magnitude, for example, is 11-bits. If the signed math values are greater than 7-bits (15-, 24-or 31-bit), the algorithm must ensure that the low order bytes ignore the overflow status bit. Care should be taken when adding and subtracting signed numbers to ensure that the correct operation is executed. Example 3-1 shows an item that must be taken into account when doing signed arithmetic on an ALU which operates as an unsigned machine. #### **EXAMPLE 3-1: SIGNED MATH** | Hex Value | Signed Value<br>Math | Unsigned Value<br>Math | |--------------|----------------------|------------------------| | FFh | -127 | 255 | | <u>+ 01h</u> | <u>+ 1</u> | <u>+ 1</u> | | = ? | = -126 (FEh) | = 0 (00h); | | | | Carry bit = $1$ | Signed math requires the result in REG to be FEh (-126). This would be accomplished by subtracting one as opposed to adding one. Simplified block diagrams are shown in Figure 3-1 and Figure 3-2. The descriptions of the device pins are listed in Table 3-1. FIGURE 4-2: TIME-OUT SEQUENCE ON POWER-UP (MCLR TIED TO VDD) FIGURE 4-3: TIME-OUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD) FIGURE 4-4: SLOW RISE TIME (MCLR TIED TO VDD) **TABLE 6-3: SPECIAL FUNCTION REGISTERS** | 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) | |--------------------|---------|--------------|----------------|--------------|--------------|---------------|---------------|-------------|-------------|-------------------------------|-------------------------------------| | Unbanke | ed | • | | | | | | • | | | • | | 00h | INDF0 | Uses con | tents of FSI | R0 to addres | ss data mem | ory (not a p | hysical regis | ster) | | | | | 01h | FSR0 | Indirect da | ata memory | address po | ointer 0 | | | | | xxxx xxxx | uuuu uuuu | | 02h | PCL | Low order | r 8-bits of P | С | | | | | | 0000 0000 | 0000 0000 | | 03h <sup>(1)</sup> | PCLATH | Holding re | egister for u | pper 8-bits | of PC | | | | | 0000 0000 | uuuu uuuu | | 04h | ALUSTA | FS3 | FS2 | FS1 | FS0 | OV | Z | DC | С | 1111 xxxx | 1111 uuuu | | 05h | TOSTA | INTEDG | T0SE | T0CS | PS3 | PS2 | PS1 | PS0 | _ | 0000 000- | 0000 000- | | 06h <sup>(2)</sup> | CPUSTA | _ | _ | STKAV | GLINTD | TO | PD | _ | _ | 11 11 | 11 qq | | 07h | INTSTA | PEIF | T0CKIF | T0IF | INTF | PEIE | T0CKIE | TOIE | INTE | 0000 0000 | 0000 0000 | | 08h | INDF1 | Uses con | tents of FSI | R1 to addres | ss data mem | lory (not a p | hysical regis | ster) | | | | | 09h | FSR1 | Indirect da | ata memory | address po | ointer 1 | | | | | xxxx xxxx | uuuu uuuu | | 0Ah | WREG | Working r | egister | | | | | | | xxxx xxxx | uuuu uuuu | | 0Bh | TMR0L | TMR0 reg | gister; low b | yte | | | | | | xxxx xxxx | uuuu uuuu | | 0Ch | TMR0H | TMR0 reg | jister; high l | oyte | | | | | | xxxx xxxx | uuuu uuuu | | 0Dh | TBLPTRL | Low byte | of program | memory tab | ole pointer | | | | | (4) | (4) | | 0Eh | TBLPTRH | High byte | of program | memory tal | ble pointer | | | | | (4) | (4) | | 0Fh | BSR | Bank sele | ct register | | | | | | | 0000 0000 | 0000 0000 | | Bank 0 | | • | | | | | | | | | • | | 10h | PORTA | RBPU | _ | RA5 | RA4 | RA3 | RA2 | RA1/T0CKI | RA0/INT | 0-xx xxxx | 0-uu uuuu | | 11h | DDRB | Data dired | ction registe | er for PORTE | 3 | | | | | 1111 1111 | 1111 1111 | | 12h | PORTB | PORTB d | ata latch | | | | | | | xxxx xxxx | uuuu uuuu | | 13h | RCSTA | SPEN | RX9 | SREN | CREN | _ | FERR | OERR | RX9D | 0000 -00x | 0000 -00u | | 14h | RCREG | Serial por | t receive re | gister | | | | | | xxxx xxxx | uuuu uuuu | | 15h | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | _ | TRMT | TX9D | 00001x | 00001u | | 16h | TXREG | Serial por | t transmit re | egister | | | | | | xxxx xxxx | uuuu uuuu | | 17h | SPBRG | Baud rate | generator | register | | | | | | xxxx xxxx | uuuu uuuu | | Bank 1 | | • | | | | | | | | | • | | 10h | DDRC | Data direc | ction registe | er for PORT | C | | | | | 1111 1111 | 1111 1111 | | 11h | PORTC | RC7/<br>AD7 | RC6/<br>AD6 | RC5/<br>AD5 | RC4/<br>AD4 | RC3/<br>AD3 | RC2/<br>AD2 | RC1/<br>AD1 | RC0/<br>AD0 | xxxx xxxx | uuuu uuuu | | 12h | DDRD | Data dired | ction registe | er for PORTI | 5 | | | | | 1111 1111 | 1111 1111 | | 13h | PORTD | RD7/<br>AD15 | RD6/<br>AD14 | RD5/<br>AD13 | RD4/<br>AD12 | RD3/<br>AD11 | RD2/<br>AD10 | RD1/<br>AD9 | RD0/<br>AD8 | xxxx xxxx | uuuu uuuu | | 14h | DDRE | Data dired | ction registe | er for PORTE | <u> </u> | 1 | • | | • | 111 | 111 | | 15h | PORTE | _ | _ | _ | _ | _ | RE2/WR | RE1/OE | RE0/ALE | xxx | uuu | | 16h | PIR | RBIF | TMR3IF | TMR2IF | TMR1IF | CA2IF | CA1IF | TXIF | RCIF | 0000 0010 | 0000 0010 | | 17h | PIE | RBIE | TMR3IE | TMR2IE | TMR1IE | CA2IE | CA1IE | TXIE | RCIE | 0000 0000 | 0000 0000 | 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 $\overline{\text{TO}}$ and $\overline{\text{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: 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. ### 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. #### 9.0 I/O PORTS The PIC17C4X devices have five I/O ports, PORTA through PORTE. PORTB through PORTE have a corresponding Data Direction Register (DDR), which is used to configure the port pins as inputs or outputs. These five ports are made up of 33 I/O pins. Some of these ports pins are multiplexed with alternate functions. PORTC, PORTD, and PORTE are multiplexed with the system bus. These pins are configured as the system bus when the device's configuration bits are selected to Microprocessor or Extended Microcontroller modes. In the two other microcontroller modes, these pins are general purpose I/O. PORTA and PORTB are multiplexed with the peripheral features of the device. These peripheral features are: - · Timer modules - Capture module - · PWM module - USART/SCI module - · External Interrupt pin When some of these peripheral modules are turned on, the port pin will automatically configure to the alternate function. The modules that do this are: - · PWM module - USART/SCI module When a pin is automatically configured as an output by a peripheral module, the pins data direction (DDR) bit is unknown. After disabling the peripheral module, the user should re-initialize the DDR bit to the desired configuration. The other peripheral modules (which require an input) must have their data direction bit configured appropriately. Note: A pin that is a peripheral input, can be configured as an output (DDRx<y> is cleared). The peripheral events will be determined by the action output on the port pin. ### 9.1 PORTA Register PORTA is a 6-bit wide latch. PORTA does not have a corresponding Data Direction Register (DDR). Reading PORTA reads the status of the pins. The RA1 pin is multiplexed with TMR0 clock input, and RA4 and RA5 are multiplexed with the USART functions. The control of RA4 and RA5 as outputs is automatically configured by the USART module. #### 9.1.1 USING RA2, RA3 AS OUTPUTS The RA2 and RA3 pins are open drain outputs. To use the RA2 or the RA3 pin(s) as output(s), simply write to the PORTA register the desired value. A '0' will cause the pin to drive low, while a '1' will cause the pin to float (hi-impedance). An external pull-up resistor should be used to pull the pin high. Writes to PORTA will not affect the other pins. **Note:** When using the RA2 or RA3 pin(s) as output(s), read-modify-write instructions (such as BCF, BSF, BTG) on PORTA are not rec- ommended. Such operations read the port pins, do the desired operation, and then write this value to the data latch. This may inadvertently cause the RA2 or RA3 pins to switch from input to output (or vice-versa). It is recommended to use a shadow register for PORTA. Do the bit operations on this shadow register and then move it to PORTA. FIGURE 9-1: RA0 AND RA1 BLOCK DIAGRAM ### 11.0 TIMER0 The Timer0 module consists of a 16-bit timer/counter, TMR0. The high byte is TMR0H and the low byte is TMR0L. A software programmable 8-bit prescaler makes an effective 24-bit overflow timer. The clock source is also software programmable as either the internal instruction clock or the RA1/T0CKI pin. The control bits for this module are in register T0STA (Figure 11-1). FIGURE 11-1: TOSTA REGISTER (ADDRESS: 05h, UNBANKED) | R/W - 0 | ) R/W - 0 | R/W - 0 | R/W - 0 | R/W - 0 | R/W - 0 | R/W - 0 | U - 0 | | | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------------------------------------------------------------------|-----------------------------|--------------------------|---------|-------|--------------------------------------------------------|--| | INTEDO | | TOCS | PS3 | PS2 | PS1 | PS0 | _ | R = Readable bit W = Writable bit | | | bit7 | | | | | | | bit0 | U = Unimplemented, Read as '0' -n = Value at POR reset | | | bit 7: | INTEDG: R<br>This bit self<br>1 = Rising 6<br>0 = Falling | ects the ed<br>edge of RA | lge upon w<br>.0/INT pin g | hich the ing<br>generates i | terrupt is d<br>nterrupt | etected | | | | | bit 6: | 0 = Falling edge of RA0/INT pin generates interrupt bit 6: T0SE: Timer0 Clock Input Edge Select bit This bit selects the edge upon which TMR0 will increment When T0CS = 0 1 = Rising edge of RA1/T0CKI pin increments TMR0 and/or generates a T0CKIF interrupt 0 = Falling edge of RA1/T0CKI pin increments TMR0 and/or generates a T0CKIF interrupt When T0CS = 1 Don't care | | | | | | | | | | bit 5: | TOCS: Time<br>This bit selection 1 = Internal<br>0 = TOCKI | ects the clo | ock source | for TMR0. | | | | | | | bit 4-1: | PS3:PS0: 7<br>These bits | | | | R0. | | | | | | | PS3:PS0 | Pre | scale Value | Э | | | | | | | | 0000<br>0001<br>0010<br>0011<br>0100<br>0101<br>0110<br>0111<br>1xxx | | 1:1<br>1:2<br>1:4<br>1:8<br>1:16<br>1:32<br>1:64<br>1:128<br>1:256 | | | | | | | | bit 0: | Unimplem | <b>ented</b> : Rea | ad as '0' | | | | | | | © 1996 Microchip Technology Inc. ### 11.1 <u>Timer0 Operation</u> When the TOCS (TOSTA<5>) bit is set, TMR0 increments on the internal clock. When TOCS is clear, TMR0 increments on the external clock (RA1/TOCKI pin). The external clock edge can be configured in software. When the TOSE (TOSTA<6>) bit is set, the timer will increment on the rising edge of the RA1/TOCKI pin. When TOSE is clear, the timer will increment on the falling edge of the RA1/TOCKI pin. The prescaler can be programmed to introduce a prescale of 1:1 to 1:256. The timer increments from 0000h to FFFFh and rolls over to 0000h. On overflow, the TMR0 Interrupt Flag bit (TOIF) is set. The TMR0 interrupt can be masked by clearing the corresponding TMR0 Interrupt Enable bit (TOIE). The TMR0 Interrupt Flag bit (TOIF) is automatically cleared when vectoring to the TMR0 interrupt vector. ### 11.2 <u>Using Timer0 with External Clock</u> When the external clock input is used for Timer0, it is synchronized with the internal phase clocks. Figure 11-3 shows the synchronization of the external clock. This synchronization is done after the prescaler. The output of the prescaler (PSOUT) is sampled twice in every instruction cycle to detect a rising or a falling edge. The timing requirements for the external clock are detailed in the electrical specification section for the desired device. #### 11.2.1 DELAY FROM EXTERNAL CLOCK EDGE Since the prescaler output is synchronized with the internal clocks, there is a small delay from the time the external clock edge occurs to the time TMR0 is actually incremented. Figure 11-3 shows that this delay is between 3Tosc and 7Tosc. Thus, for example, measuring the interval between two edges (e.g. period) will be accurate within $\pm 4Tosc$ ( $\pm 121$ ns @ 33 MHz). FIGURE 11-2: TIMERO MODULE BLOCK DIAGRAM FIGURE 11-3: TMR0 TIMING WITH EXTERNAL CLOCK (INCREMENT ON FALLING EDGE) # 12.0 TIMER1, TIMER2, TIMER3, PWMS AND CAPTURES The PIC17C4X has a wealth of timers and time-based functions to ease the implementation of control applications. These time-base functions include two PWM outputs and two Capture inputs. Timer1 and Timer2 are two 8-bit incrementing timers, each with a period register (PR1 and PR2 respectively) and separate overflow interrupt flags. Timer1 and Timer2 can operate either as timers (increment on internal Fosc/4 clock) or as counters (increment on falling edge of external clock on pin RB4/TCLK12). They are also software configurable to operate as a single 16-bit timer. These timers are also used as the time-base for the PWM (pulse width modulation) module. Timer3 is a 16-bit timer/counter consisting of the TMR3H and TMR3L registers. This timer has four other associated registers. Two registers are used as a 16-bit period register or a 16-bit Capture1 register (PR3H/CA1H:PR3L/CA1L). The other two registers are strictly the Capture2 registers (CA2H:CA2L). Timer3 is the time-base for the two 16-bit captures. TMR3 can be software configured to increment from the internal system clock or from an external signal on the RB5/TCLK3 pin. Figure 12-1 and Figure 12-2 are the control registers for the operation of Timer1, Timer2, and Timer3, as well as PWM1, PWM2, Capture1, and Capture2. #### FIGURE 12-1: TCON1 REGISTER (ADDRESS: 16h, BANK 3) | | R/W - 0 | R = Readable bit | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | bit7 | bit0 | W = Writable bit<br>-n = Value at POR reset | | bit 7-6: | CA2ED1:CA2ED0: Capture2 Mode Select bits 00 = Capture on every falling edge 01 = Capture on every rising edge 10 = Capture on every 4th rising edge 11 = Capture on every 16th rising edge | | | bit 5-4: | CA1ED1:CA1ED0: Capture1 Mode Select bits 00 = Capture on every falling edge 01 = Capture on every rising edge 10 = Capture on every 4th rising edge 11 = Capture on every 16th rising edge | | | bit 3: | T16: Timer1:Timer2 Mode Select bit 1 = Timer1 and Timer2 form a 16-bit timer 0 = Timer1 and Timer2 are two 8-bit timers | | | bit 2: | <b>TMR3CS</b> : Timer3 Clock Source Select bit<br>1 = TMR3 increments off the falling edge of the RB5/TCLK3 pin<br>0 = TMR3 increments off the internal clock | | | bit 1: | TMR2CS: Timer2 Clock Source Select bit 1 = TMR2 increments off the falling edge of the RB4/TCLK12 pin 0 = TMR2 increments off the internal clock | | | bit 0: | TMR1CS: Timer1 Clock Source Select bit 1 = TMR1 increments off the falling edge of the RB4/TCLK12 pin 0 = TMR1 increments off the internal clock | | | INCF | Increme | nt f | | | | | | | |-------------------|-------------------------------------------|------------------------------------|---------------|-----------|--|--|--|--| | Syntax: | [ label ] | INCF f | ,d | | | | | | | Operands: | $0 \le f \le 25$ $d \in [0,1]$ | $0 \le f \le 255$<br>$d \in [0,1]$ | | | | | | | | Operation: | (f) + 1 $\rightarrow$ | (dest) | | | | | | | | Status Affected: | OV, C, DC, Z | | | | | | | | | Encoding: | 0001 | 010d | ffff | ffff | | | | | | Description: | The contermented. If WREG. If back in reg | 'd' is 0 the<br>d' is 1 the | e result is p | olaced in | | | | | | Words: | 1 | | | | | | | | | Cycles: | 1 | | | | | | | | | Q Cycle Activity: | | | | | | | | | | Q1 | Q2 | Q3 | 3 | Q4 | | | | | | Q1 | Q2 | Q3 | Q4 | |--------|--------------|---------|-------------| | Decode | Read | Execute | Write to | | | register 'f' | | destination | Example: INCF CNT, 1 Before Instruction CNT = 0xFF Z = 0 C = ? After Instruction $\begin{array}{rcl} {\sf CNT} & = & {\sf 0x00} \\ {\sf Z} & = & 1 \\ {\sf C} & = & 1 \end{array}$ | INC | FSZ | Incremen | nt f, skip | if 0 | | | | |------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------|--------------------------------------|--------------------------------------------|--| | Syn | tax: | [ label ] | INCFSZ | f,d | | | | | Ope | rands: | $0 \le f \le 258$ $d \in [0,1]$ | 5 | | | | | | Ope | ration: | (f) + 1 $\rightarrow$ skip if res | | | | | | | Stat | us Affected: | None | | | | | | | Enc | oding: | 0001 | 111d | fff | f | ffff | | | Des | cription: | The conter<br>mented. If '<br>WREG. If 'c<br>back in reg<br>If the result<br>which is all<br>and an NO<br>it a two-cyc | d' is 0 the<br>d' is 1 the<br>lister 'f'.<br>t is 0, the<br>ready fetc<br>P is execc | e resul<br>resul<br>next i<br>ched, i | It is p<br>t is p<br>nstru<br>is dis | placed in<br>placed<br>uction,<br>scarded, | | | Wor | ds: | 1 | | | | | | | Cycl | les: | 1(2) | | | | | | | QC | ycle Activity: | | | | | | | | | Q1 | Q2 | Q3 | 3 | | Q4 | | | | Decode | Read register 'f' | Execu | ute | l . | Vrite to stination | | | If sk | ip: | | | | | | | | | Q1 | Q2 | Q3 | 3 | | Q4 | | | | Forced NOP | NOP | Execu | ute | | NOP | | | <u>Exa</u> | mple: | HERE<br>NZERO<br>ZERO | INCFSZ<br>: | CN | Т, | 1 | | | | Before Instru<br>PC | | S (HERE | ) | | | | | | After Instruction CNT = CNT + 1 If CNT = 0; PC = Address(ZERO) | | | | | | | If CNT ≠ PC = 0; Address (NZERO) **SLEEP Enter SLEEP mode** Syntax: [label] SLEEP Operands: None Operation: 00h $\rightarrow$ WDT; $0 \rightarrow WDT$ postscaler; $1 \rightarrow \overline{TO}$ ; $0 \rightarrow \overline{PD}$ TO, PD Status Affected: Encoding: 0000 0000 0000 0011 The power down status bit $(\overline{PD})$ is Description: cleared. The time-out status bit $(\overline{TO})$ is set. Watchdog Timer and its prescaler are cleared. The processor is put into SLEEP mode with the oscillator stopped. Words: Cycles: 1 Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |--------|----------------------------|---------|-----| | Decode | Read<br>register<br>PCLATH | Execute | NOP | Example: SLEEP Before Instruction TO = PD = After Instruction TO = PD = 0 † If WDT causes wake-up, this bit is cleared **SUBLW Subtract WREG from Literal** Syntax: [label] SUBLW k Operands: $0 \le k \le 255$ Operation: $k - (WREG) \rightarrow (WREG)$ Status Affected: OV, C, DC, Z Encoding: 1011 0010 kkkk WREG is subtracted from the eight bit Description: literal 'k'. The result is placed in WREG. Words: 1 Cycles: Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |--------|-------------|---------|----------| | Decode | Read | Execute | Write to | | | literal 'k' | | WRFG | Example 1: SUBLW 0x02 Before Instruction WREG С ? After Instruction WREG С ; result is positive 1 Z 0 Example 2: Before Instruction WREG С After Instruction WREG 0 С ; result is zero Ζ Example 3: Before Instruction WREG С After Instruction WREG FF ; (2's complement) С ; result is negative 0 Z 1 | XOR | LW | Exclusiv<br>WREG | Exclusive OR Literal with WREG | | | | | | |-------|---------------|------------------|-------------------------------------------------------------------------------------------|-------|----------|--|--|--| | Synt | ax: | [label] | XORLW I | k | | | | | | Ope | rands: | $0 \le k \le 25$ | 55 | | | | | | | Ope | ration: | (WREG) | .XOR. k – | → (WR | EG) | | | | | Statu | us Affected: | Z | Z | | | | | | | Enco | oding: | 1011 | 0100 | kkkk | kkkk | | | | | Desc | cription: | with the 8- | The contents of WREG are XOR'ed with the 8-bit literal 'k'. The result is placed in WREG. | | | | | | | Word | ds: | 1 | 1 | | | | | | | Cycl | es: | 1 | 1 | | | | | | | Q Cy | cle Activity: | | | | | | | | | | Q1 | Q2 | Q3 | | Q4 | | | | | | Decode | Read | Execute | ٠ ا | Vrite to | | | | Example: XORLW 0xAF literal 'k' WREG Before Instruction After Instruction WREG = 0xB5 WREG 0x1A | XORWF | Exclusive OR WREG with f | | | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|------|--| | Syntax: | [ label ] | XORWF | f,d | | | | Operands: | $0 \le f \le 255$<br>$d \in [0,1]$ | | | | | | Operation: | (WREG) .XOR. (f) $\rightarrow$ (dest) | | | | | | Status Affected: | Z | | | | | | Encoding: | 0000 | 110d | ffff | ffff | | | Description: | Exclusive OR the contents of WREG with register 'f'. If 'd' is 0 the result is stored in WREG. If 'd' is 1 the result is stored back in the register 'f'. | | | | | | Words: | 1 | | | | | | Cycles: | 1 | | | | | | Q Cycle Activity: | | | | | | | Q1 | Q2 | Q3 | 3 | Q4 | | Decode Write to Read Execute register 'f' destination Example: REG, 1 XORWF Before Instruction REG 0xAF WREG 0xB5 After Instruction REG 0x1A WREG 0xB5 ## Applicable Devices 42 R42 42A 43 R43 44 | | | Standard Operating Conditions (unless otherwise stated) Operating temperature | | | | | | | |--------------------|-------|-------------------------------------------------------------------------------|--------------------|-----------|------------|--------|------------------------------------------------------------|--| | DC CHARACTERISTICS | | | -40°C ≤ TA ≤ +40°C | | | | | | | | | | Operating v | oltage Vi | od range a | s desc | ribed in Section 17.1 | | | Parameter | | | | | | | | | | No. | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | | | | | Internal Program Memory<br>Programming Specs (Note 4) | | | | | | | | D110 | VPP | Voltage on MCLR/VPP pin | 12.75 | _ | 13.25 | V | Note 5 | | | D111 | VDDP | Supply voltage during programming | 4.75 | 5.0 | 5.25 | V | | | | D112 | IPP | Current into MCLR/VPP pin | _ | 25 ‡ | 50 ‡ | mA | | | | D113 | IDDP | Supply current during programming | _ | _ | 30 ‡ | mA | | | | D114 | TPROG | Programming pulse width | 10 | 100 | 1000 | μs | Terminated via internal/exter-<br>nal interrupt or a reset | | - \* 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. - † These parameters are for design guidance only and are not tested, nor characterized. - Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC17CXX devices be driven with external clock in RC mode. - 2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. - 3: Negative current is defined as coming out of the pin. - 4: These specifications are for the programming of the on-chip program memory EPROM through the use of the table write instructions. The complete programming specifications can be found in: PIC17CXX Programming Specifications (Literature number DS30139). - 5: The MCLR/VPP pin may be kept in this range at times other than programming, but is not recommended. - 6: For TTL buffers, the better of the two specifications may be used. Note: When using the Table Write for internal programming, the device temperature must be less than 40°C. Applicable Devices | 42 | R42 | 42A | 43 | R43 | 44 FIGURE 18-9: TYPICAL IPD vs. VDD WATCHDOG DISABLED 25°C FIGURE 18-10: MAXIMUM IPD vs. VDD WATCHDOG DISABLED 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-11: MEMORY INTERFACE WRITETIMING (NOT SUPPORTED IN PIC17LC4X DEVICES) TABLE 19-11: MEMORY INTERFACE WRITE REQUIREMENTS (NOT SUPPORTED IN PIC17LC4X DEVICES) | Parameter<br>No. | Sym | Characteristic | Min | Typ† | Max | Units | Conditions | |------------------|----------|-------------------------------------------------------|--------------|-----------|-----|-------|------------| | 150 | TadV2alL | AD<15:0> (address) valid to ALE↓ (address setup time) | 0.25Tcy - 10 | _ | _ | ns | | | 151 | TalL2adI | ALE↓ to address out invalid (address hold time) | 0 | _ | _ | ns | | | 152 | TadV2wrL | Data out valid to <del>WR</del> ↓ (data setup time) | 0.25Tcy - 40 | _ | _ | ns | | | 153 | TwrH2adl | WR↑ to data out invalid (data hold time) | _ | 0.25Tcy § | _ | ns | | | 154 | TwrL | WR pulse width | _ | 0.25Tcy § | _ | ns | | 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. ### 21.6 Package Marking Information 40-Lead PDIP/CERDIP 40 Lead CERDIP Windowed 44-Lead PLCC 44-Lead MQFP 44-Lead TQFP Example Example Example Example Example Microchip part number information Legend: MM...M XX...X Customer specific information\* AA Year code (last 2 digits of calendar year) BB Week code (week of January 1 is week '01') С Facility code of the plant at which wafer is manufactured C = Chandler, Arizona, U.S.A., S = Tempe, Arizona, U.S.A. D Mask revision number Ε Assembly code of the plant or country of origin in which part was assembled **lote**: In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line thus limiting the number of available characters for customer specific information. \* Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask rev#, and assembly code. For OTP marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price. #### **INDEX** CA1IE ......23 CA1IF ......24 CA1OVF ......72 Α CA2ED0 ......71 CA2ED1 ......71 ADDLW ......112 CA2H ......20, 35 ADDWF ......112 CA2IE ......23, 78 ADDWFC ......113 CA2IF ......24, 78 ALU ......9 ALU STATUS Register (ALUSTA) ......36 CA2OVF ......72 ALUSTA ......34, 36, 108 Calculating Baud Rate Error .....86 ALUSTA Register .......36 CALL ......39, 117 ANDLW ......113 Capacitor Selection ANDWF ......114 Ceramic Resonators ......101 Application Notes Crystal Oscillator ......101 AN552 ......55 Capture ......71, 78 Assembler .......144 Capture Sequence to Read Example ......78 Asynchronous Master Transmission ......90 Capture1 Asynchronous Transmitter ......89 Mode ......71 Overflow ......72 Capture2 В Mode 71 Overflow .......72 Bank Select Register (BSR) ......42 Carry (C) ......9 Banking .......42 Ceramic Resonators ......100 Baud Rate Formula ......86 Circular Buffer ......39 Baud Rate Generator (BRG) ......86 Clearing the Prescaler ......103 **Baud Rates** Clock/Instruction Cycle (Figure) ......14 Asynchronous Mode ......88 Clocking Scheme/Instruction Cycle (Section) ......14 Synchronous Mode ......87 CLRF ......117 BCF ......114 CLRWDT ......118 Bit Manipulation ......108 Code Protection .......99, 106 **Block Diagrams** COMF ......118 On-chip Reset Circuit ......15 Configuration PIC17C42 ......10 Bits ......100 PORTD ......60 Locations ......100 Oscillator ......100 Word ......99 RA0 and RA1 .....53 CPFSEQ ......119 RA2 and RA3 ......54 CPFSGT ......119 RA4 and RA5 ......54 CPFSLT ......120 RB3:RB2 Port Pins ......56 CPU STATUS Register (CPUSTA) ......37 RB7:RB4 and RB1:RB0 Port Pins ......55 CPUSTA ......34, 37, 105 RC7:RC0 Port Pins ......58 CREN ......84 Timer3 with One Capture and One Period Register .. 78 Crystal Operation, Overtone Crystals ......101 TMR1 and TMR2 in 16-bit Timer/Counter Mode ....... 74 Crystal or Ceramic Resonator Operation ......100 TMR1 and TMR2 in Two 8-bit Timer/Counter Mode .. 73 TMR3 with Two Capture Registers ......79 CSRC ......83 WDT ......104 BORROW .......9 BRG ......86 D BSF ......115 Data Memory BSR ......34, 42 GPR ......29, 32 BSR Operation ......42 Indirect Addressing ......39 BTFSC ......115 Organization ......32 BTFSS ......116 SFR ......29, 32 BTG .......116 Transfer to Program Memory ......43 DAW ......120 C DDRB ......19, 34, 55 DDRC ......19, 34, 58 DDRD ......19, 34, 60 C Compiler (MP-C) .......145 DDRE ......19, 34, 62 DECF ......121 CA1ED0 ......71 DECFSNZ ......122 CA1ED1 ......71 DECFSZ ......121 | MP-C C Compiler145 | PORTD | 19, 34, 60 | |------------------------------------------------|---------------------------------------|------------| | MPSIM Software Simulator143, 145 | PORTE | 19, 34, 62 | | MULLW129 | Power-down Mode | 105 | | Multiply Examples | Power-on Reset (POR) | 15, 99 | | 16 x 16 Routine50 | Power-up Timer (PWRT) | 15, 99 | | 16 x 16 Signed Routine51 | PR1 | 20, 35 | | 8 x 8 Routine49 | PR2 | 20, 35 | | 8 x 8 Signed Routine49 | PR3/CA1H | 20 | | MULWF129 | PR3/CA1L | 20 | | | PR3H/CA1H | 35 | | A.I. | PR3L/CA1L | 35 | | N | Prescaler Assignments | 69 | | | PRO MATE® Universal Programmer | 143 | | NEGW130 | PRODH | | | NOP130 | PRODL | | | | Program Counter (PC) | 41 | | 0 | Program Memory | | | O . | External Access Waveforms | 31 | | OERR84 | External Connection Diagram | | | Opcode Field Descriptions | Map | | | · | Modes | | | OSC Selection | Extended Microcontroller | 20 | | Oscillator | Microcontroller | | | Configuration | Microprocessor | | | Crystal100 | Protected Microcontroller | 20 | | External Clock101 | | | | External Crystal Circuit102 | Operation | | | External Parallel Resonant Crystal Circuit 102 | Organization | 29 | | External Series Resonant Crystal Circuit102 | Transfers from Data Memory | | | RC102 | Protected Microcontroller | | | RC Frequencies165, 195 | PS0 | , | | Oscillator Start-up Time (Figure)18 | PS1 | , | | Oscillator Start-up Timer (OST)15, 99 | PS2 | , | | OST15, 99 | PS3 | 38, 67 | | OV9, 36 | PUSH | 27, 39 | | Overflow (OV)9 | PW1DCH | 20, 35 | | | PW1DCL | 20, 35 | | <b>D</b> | PW2DCH | 20, 35 | | P | PW2DCL | 20, 35 | | | PWM | 71, 75 | | Package Marking Information210 | Duty Cycle | 76 | | Packaging Information205 | External Clock Source | | | Parameter Measurement Information154 | Frequency vs. Resolution | | | PC (Program Counter)41 | Interrupts | | | PCH41 | Max Resolution/Frequency for External | | | PCL34, 41, 108 | Clock Input | 77 | | PCLATH34, 41 | Output | | | PD | Periods | | | PEIE | PWM1 | | | PEIF22 | PWM1ON | | | Peripheral Bank42 | PWM2 | | | Peripheral Interrupt Enable | | | | Peripheral Interrupt Request (PIR)24 | PWM2ON | • | | PICDEM-1 Low-Cost PIC16/17 Demo Board 143, 144 | PWRT | 15, 99 | | PICDEM-2 Low-Cost PIC16CXX Demo Board 143, 144 | | | | PICDEM-3 Low-Cost PIC16C9XXX Demo Board 144 | R | | | PICMASTER® RT In-Circuit Emulator143 | | | | | RA1/T0CKI pin | 67 | | PICSTART® Low-Cost Development System143 | RBIE | | | PIE | RBIF | | | Pin Compatible Devices | RBPU | | | PIR | RC Oscillator | | | PM0 | | | | PM199, 106 | RC Oscillator Frequencies | • | | POP27, 39 | RCIE | | | POR15, 99 | RCIF | | | PORTA19, 34, 53 | RCREG 19, 34 | | | PORTB | RCSTA 19 | | | PORTC | Reading 16-bit Value | 69 | | 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 | 94.0 .0 0. | 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: | <u> </u> | 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 | 5 | 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 | 1 1gul 6 13-1. | i didinotoi wodouroment inioimation 100 |