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 | 16KB (8K 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 | -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/pic17lc44t-08i-pt | # FIGURE 7-3: TLRD INSTRUCTION OPERATION FIGURE 7-4: TABLRD INSTRUCTION OPERATION 3: If "i" = 1, then TBLPTR = TBLPTR + 1, If "i" = 0, then TBLPTR is unchanged. #### 9.4.1 PORTE AND DDRE REGISTER PORTE is a 3-bit bi-directional port. The corresponding data direction register is DDRE. A '1' in DDRE configures the corresponding port pin as an input. A '0' in the DDRE register configures the corresponding port pin as an output. Reading PORTE reads the status of the pins, whereas writing to it will write to the port latch. PORTE is multiplexed with the system bus. When operating as the system bus, PORTE contains the control signals for the address/data bus (AD15:AD0). These control signals are Address Latch Enable (ALE), Output Enable ( $\overline{OE}$ ), and Write ( $\overline{WR}$ ). The control signals $\overline{OE}$ and $\overline{WR}$ are active low signals. The timing for the system bus is shown in the Electrical Characteristics section. **Note:** This port is 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, this port is a general purpose I/O. Example 9-4 shows the instruction sequence to initialize PORTE. The Bank Select Register (BSR) must be selected to Bank 1 for the port to be initialized. #### **EXAMPLE 9-4: INITIALIZING PORTE** | MOVLB | 1 | ; | Select Bank 1 | |-------|-------|---|--------------------------| | CLRF | PORTE | ; | Initialize PORTE data | | | | ; | latches before setting | | | | ; | the data direction | | | | ; | register | | MOVLW | 0x03 | ; | Value used to initialize | | | | ; | data direction | | MOVWF | DDRE | ; | Set RE<1:0> as inputs | | | | ; | RE<2> as outputs | | | | ; | RE<7:3> are always | | | | ; | read as '0' | FIGURE 9-8: PORTE BLOCK DIAGRAM (IN I/O PORT MODE) ### 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: | | ects the ed<br>S = 0<br>edge of RA<br>edge of RA | lge upon w<br>.1/T0CKI pi | hich TMR0<br>n incremei | nts TMR0 a | and/or gene | | CKIF interrupt<br>CKIF interrupt | | 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. # 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 | | ## FIGURE 13-2: RCSTA REGISTER (ADDRESS: 13h, BANK 0) | R/W - ( | | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | bit 0 W = Writable bit -n = Value at POR reset (x = unknown) | | bit 7: | SPEN: Serial Port Enable bit 1 = Configures RA5/RX/DT and RA4/TX/CK pins as serial port pins 0 = Serial port disabled | | bit 6: | RX9: 9-bit Receive Enable bit 1 = Selects 9-bit reception 0 = Selects 8-bit reception | | bit 5: | SREN: Single Receive Enable bit This bit enables the reception of a single byte. After receiving the byte, this bit is automatically cleared. Synchronous mode: 1 = Enable reception 0 = Disable reception Note: This bit is ignored in synchronous slave reception. Asynchronous mode: Don't care | | bit 4: | CREN: Continuous Receive Enable bit This bit enables the continuous reception of serial data. Asynchronous mode: 1 = Enable reception 0 = Disables reception Synchronous mode: 1 = Enables continuous reception until CREN is cleared (CREN overrides SREN) 0 = Disables continuous reception | | bit 3: | Unimplemented: Read as '0' | | bit 2: | FERR: Framing Error bit 1 = Framing error (Updated by reading RCREG) 0 = No framing error | | bit 1: | OERR: Overrun Error bit 1 = Overrun (Cleared by clearing CREN) 0 = No overrun error | | bit 0: | RX9D: 9th bit of receive data (can be the software calculated parity bit) | TABLE 13-3: BAUD RATES FOR SYNCHRONOUS MODE | BAUD<br>RATE | Fosc = 3 | 3 MHz | SPBRG<br>value | Fosc = 2 | 5 MHz | SPBRG<br>value | FOSC = 20 | 0 MHz | SPBRG<br>value | FOSC = 10 | 6 MHz | SPBRG<br>value | |--------------|----------|--------|----------------|----------|--------|----------------|-----------|--------|----------------|-----------|--------|----------------| | (K) | KBAUD | %ERROR | (decimal) | KBAUD | %ERROR | (decimal) | KBAUD | %ERROR | (decimal) | KBAUD | %ERROR | (decimal) | | 0.3 | NA | _ | _ | NA | _ | _ | NA | _ | _ | NA | _ | _ | | 1.2 | NA | _ | _ | NA | _ | _ | NA | _ | _ | NA | _ | _ | | 2.4 | NA | _ | _ | NA | _ | _ | NA | _ | _ | NA | _ | - | | 9.6 | NA | _ | _ | NA | _ | _ | NA | _ | _ | NA | _ | - | | 19.2 | NA | _ | _ | NA | _ | _ | 19.53 | +1.73 | 255 | 19.23 | +0.16 | 207 | | 76.8 | 77.10 | +0.39 | 106 | 77.16 | +0.47 | 80 | 76.92 | +0.16 | 64 | 76.92 | +0.16 | 51 | | 96 | 95.93 | -0.07 | 85 | 96.15 | +0.16 | 64 | 96.15 | +0.16 | 51 | 95.24 | -0.79 | 41 | | 300 | 294.64 | -1.79 | 27 | 297.62 | -0.79 | 20 | 294.1 | -1.96 | 16 | 307.69 | +2.56 | 12 | | 500 | 485.29 | -2.94 | 16 | 480.77 | -3.85 | 12 | 500 | 0 | 9 | 500 | 0 | 7 | | HIGH | 8250 | _ | 0 | 6250 | _ | 0 | 5000 | _ | 0 | 4000 | _ | 0 | | LOW | 32.22 | _ | 255 | 24.41 | _ | 255 | 19.53 | _ | 255 | 15.625 | _ | 255 | | BAUD | FOSC = 10 MI | Hz | SPBRG | FOSC = 7.159 | ) MHz | SPBRG | FOSC = 5.068 | 3 MHz | SPBRG | |-------------|--------------|--------|--------------------|--------------|--------|--------------------|--------------|--------|--------------------| | RATE<br>(K) | KBAUD | %ERROR | value<br>(decimal) | KBAUD | %ERROR | value<br>(decimal) | KBAUD | %ERROR | value<br>(decimal) | | 0.3 | NA | _ | _ | NA | _ | _ | NA | _ | _ | | 1.2 | NA | _ | _ | NA | _ | _ | NA | _ | _ | | 2.4 | NA | _ | _ | NA | _ | _ | NA | _ | _ | | 9.6 | 9.766 | +1.73 | 255 | 9.622 | +0.23 | 185 | 9.6 | 0 | 131 | | 19.2 | 19.23 | +0.16 | 129 | 19.24 | +0.23 | 92 | 19.2 | 0 | 65 | | 76.8 | 75.76 | -1.36 | 32 | 77.82 | +1.32 | 22 | 79.2 | +3.13 | 15 | | 96 | 96.15 | +0.16 | 25 | 94.20 | -1.88 | 18 | 97.48 | +1.54 | 12 | | 300 | 312.5 | +4.17 | 7 | 298.3 | -0.57 | 5 | 316.8 | +5.60 | 3 | | 500 | 500 | 0 | 4 | NA | _ | _ | NA | _ | _ | | HIGH | 2500 | _ | 0 | 1789.8 | _ | 0 | 1267 | _ | 0 | | LOW | 9.766 | _ | 255 | 6.991 | _ | 255 | 4.950 | _ | 255 | | BAUD<br>RATE | Fosc = 3.579 | MHz | SPBRG<br>value | FOSC = 1 MH | Z | SPBRG<br>value | FOSC = 32.76 | 8 kHz | SPBRG<br>value | |--------------|--------------|--------|----------------|-------------|--------|----------------|--------------|--------|----------------| | (K) | KBAUD | %ERROR | (decimal) | KBAUD | %ERROR | (decimal) | KBAUD | %ERROR | (decimal) | | 0.3 | NA | _ | _ | NA | _ | _ | 0.303 | +1.14 | 26 | | 1.2 | NA | _ | | 1.202 | +0.16 | 207 | 1.170 | -2.48 | 6 | | 2.4 | NA | _ | | 2.404 | +0.16 | 103 | NA | _ | _ | | 9.6 | 9.622 | +0.23 | 92 | 9.615 | +0.16 | 25 | NA | _ | _ | | 19.2 | 19.04 | -0.83 | 46 | 19.24 | +0.16 | 12 | NA | _ | _ | | 76.8 | 74.57 | -2.90 | 11 | 83.34 | +8.51 | 2 | NA | _ | _ | | 96 | 99.43 | _3.57 | 8 | NA | _ | _ | NA | _ | _ | | 300 | 298.3 | -0.57 | 2 | NA | _ | _ | NA | _ | _ | | 500 | NA | _ | | NA | _ | _ | NA | _ | _ | | HIGH | 894.9 | _ | 0 | 250 | _ | 0 | 8.192 | _ | 0 | | LOW | 3.496 | _ | 255 | 0.976 | _ | 255 | 0.032 | _ | 255 | ### FIGURE 13-5: ASYNCHRONOUS MASTER TRANSMISSION ## FIGURE 13-6: ASYNCHRONOUS MASTER TRANSMISSION (BACK TO BACK) TABLE 13-5: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION | 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 resets<br>(Note1) | |-------------|-------|-------------|------------------------------|---------|--------|-------|-------|-------|-----------|-------------------------------|-----------------------------------------| | 16h, Bank 1 | PIR | RBIF | TMR3IF | TMR2IF | TMR1IF | CA2IF | CA1IF | TXIF | RCIF | 0000 0010 | 0000 0010 | | 13h, Bank 0 | RCSTA | SPEN | RX9 | SREN | CREN | _ | FERR | OERR | RX9D | 0000 -00x | 0000 -00u | | 16h, Bank 0 | TXREG | Serial port | transmit re | egister | | | | | | xxxx xxxx | uuuu uuuu | | 17h, Bank 1 | PIE | RBIE | TMR3IE | TMR2IE | TMR1IE | CA2IE | CA1IE | TXIE | RCIE | 0000 0000 | 0000 0000 | | 15h, Bank 0 | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | _ | TRMT | TX9D | 00001x | 00001u | | 17h, Bank 0 | SPBRG | Baud rate | Baud rate generator register | | | | | | xxxx xxxx | uuuu uuuu | | Legend: x = unknown, u = unchanged, - = unimplemented read as a '0', shaded cells are not used for asynchronous transmission. Note 1: Other (non power-up) resets include: external reset through MCLR and Watchdog Timer Reset. ### 14.1 Configuration Bits The PIC17CXX has up to seven configuration locations (Table 14-1). These locations can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. Any write to a configuration location, regardless of the data, will program that configuration bit. A TABLWT instruction is required to write to program memory locations. The configuration bits can be read by using the TABLRD instructions. Reading any configuration location between FE00h and FE07h will read the low byte of the configuration word (Figure 14-1) into the TABLATL register. The TABLATH register will be FFh. Reading a configuration location between FE08h and FE0Fh will read the high byte of the configuration word into the TABLATL register. The TABLATH register will be FFh. Addresses FE00h thorough FE0Fh are only in the program memory space for microcontroller and code protected microcontroller modes. A device programmer will be able to read the configuration word in any processor mode. See programming specifications for more detail. TABLE 14-1: CONFIGURATION LOCATIONS | Bit | Address | |--------------------|----------------------| | FOSC0 | FE00h | | FOSC1 | FE01h | | WDTPS0 | FE02h | | WDTPS1 | FE03h | | PM0 | FE04h | | PM1 | FE06h | | PM2 <sup>(1)</sup> | FE0Fh <sup>(1)</sup> | Note 1: This location does not exist on the PIC17C42. Note: When programming the desired configuration locations, they must be programmed in ascending order. Starting with address FE00h. ### 14.2 <u>Oscillator Configurations</u> #### 14.2.1 OSCILLATOR TYPES The PIC17CXX can be operated in four different oscillator modes. The user can program two configuration bits (FOSC1:FOSC0) to select one of these four modes: LF: Low Power Crystal XT: Crystal/Resonator EC: External Clock Input RC: Resistor/Capacitor ## 14.2.2 CRYSTAL OSCILLATOR / CERAMIC RESONATORS In XT or LF modes, a crystal or ceramic resonator is connected to the OSC1/CLKIN and OSC2/CLKOUT pins to establish oscillation (Figure 14-2). The PIC17CXX Oscillator design requires the use of a parallel cut crystal. Use of a series cut crystal may give a frequency out of the crystal manufacturers specifications. For frequencies above 20 MHz, it is common for the crystal to be an overtone mode crystal. Use of overtone mode crystals require a tank circuit to attenuate the gain at the fundamental frequency. Figure 14-3 shows an example of this. FIGURE 14-2: CRYSTAL OR CERAMIC RESONATOR OPERATION (XT OR LF OSC CONFIGURATION) See Table 14-2 and Table 14-3 for recommended values of C1 and C2. Note 1: A series resistor may be required for AT strip cut crystals. ### 14.3 Watchdog Timer (WDT) The Watchdog Timer's function is to recover from software malfunction. The WDT uses an internal free running on-chip RC oscillator for its clock source. This does not require any external components. This RC oscillator is separate from the RC oscillator of the OSC1/CLKIN pin. That means that the WDT will run, even if the clock on the OSC1/CLKIN and OSC2/CLK-OUT pins of the device has been stopped, for example, by execution of a SLEEP instruction. During normal operation and SLEEP mode, a WDT time-out generates a device RESET. The WDT can be permanently disabled by programming the configuration bits WDTPS1:WDTPS0 as '00' (Section 14.1). Under normal operation, the WDT must be cleared on a regular interval. This time is less the minimum WDT overflow time. Not clearing the WDT in this time frame will cause the WDT to overflow and reset the device. #### 14.3.1 WDT PERIOD The WDT has a nominal time-out period of 12 ms, (with postscaler = 1). The time-out periods vary with temperature, VDD and process variations from part to part (see DC specs). If longer time-out periods are desired, a postscaler with a division ratio of up to 1:256 can be assigned to the WDT. Thus, typical time-out periods up to 3.0 seconds can be realized. The CLRWDT and SLEEP instructions clear the WDT and the postscaler (if assigned to the WDT) and prevent it from timing out thus generating a device RESET condition. The TO bit in the CPUSTA register will be cleared upon a WDT time-out. #### 14.3.2 CLEARING THE WDT AND POSTSCALER The WDT and postscaler are cleared when: - · The device is in the reset state - A SLEEP instruction is executed - A CLRWDT instruction is executed - Wake-up from SLEEP by an interrupt The WDT counter/postscaler will start counting on the first edge after the device exits the reset state. #### 14.3.3 WDT PROGRAMMING CONSIDERATIONS It should also be taken in account that under worst case conditions (VDD = Min., Temperature = Max., max. WDT postscaler) it may take several seconds before a WDT time-out occurs. The WDT and postscaler is the Power-up Timer during the Power-on Reset sequence. #### 14.3.4 WDT AS NORMAL TIMER When the WDT is selected as a normal timer, the clock source is the device clock. Neither the WDT nor the postscaler are directly readable or writable. The overflow time is 65536 Tosc cycles. On overflow, the $\overline{\text{TO}}$ bit is cleared (device is not reset). The CLRWDT instruction can be used to set the $\overline{\text{TO}}$ bit. This allows the WDT to be a simple overflow timer. When in sleep, the WDT does not increment. **ADDLW ADD Literal to WREG** Syntax: [label] ADDLW Operands: $0 \le k \le 255$ Operation: $(WREG) + k \rightarrow (WREG)$ Status Affected: OV, C, DC, Z Encoding: 1011 0001 kkkk kkkk Description: The contents of WREG are added to the 8-bit literal 'k' and the result is placed in WREG. Words: 1 Cycles: 1 Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |--------|-------------|---------|----------| | Decode | Read | Execute | Write to | | | literal 'k' | | WREG | Example: ADDLW 0x15 Before Instruction WREG = 0x10 After Instruction WREG = 0x25 **ADDWF** ADD WREG to f [ label ] ADDWF Syntax: f,d Operands: $0 \le f \le 255$ $d \in [0,1]$ Operation: (WREG) + (f) $\rightarrow$ (dest) Status Affected: OV, C, DC, Z 0000 111d ffff Encoding: ffff Description: Add WREG to register 'f'. If 'd' is 0 the result is stored in WREG. If 'd' is 1 the result is stored back in register 'f'. Words: 1 1 Cycles: Q Cycle Activity: Q1 Q2 Q3 Q4 Decode Read Execute Write to register 'f' destination Example: ADDWF REG, 0 Before Instruction WREG = 0x17REG = 0xC2 After Instruction WREG = 0xD9REG = 0xC2 | CPFSLT | | f with WREG | i, | DAW | Decimal Adj | ust WREG Register | | | |--------------------------|----------------------------------------------|------------------------------------------------------|------------------------|--------------------------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------|--|--| | | skip if f < | | | Syntax: | [ <i>label</i> ] DAW | f,s | | | | Syntax: | [label] ( | CPFSLT f | | Operands: | $0 \leq f \leq 255$ | | | | | Operands: | $0 \le f \le 25$ | 5 | | | s ∈ [0,1] | | | | | Operation: | (f) – (WREG<br>skip if (f) <<br>(unsigned of | | | Operation: | • | >>9] .OR. [DC = 1] then<br>0> + 6 $\rightarrow$ f<3:0>, s<3:0>; | | | | Status Affected: | None | . , | | | WREG<3:0 | $0> \to f<3:0>, s<3:0>;$ | | | | Encoding: | 0011 0000 ffff ffff | | | | If [WREG<7:4> | >>9] .OR. [C = 1] then | | | | Description: | location 'f' t<br>performing | the contents of<br>to the contents<br>an unsigned su | of WREG by ubtraction. | Status Affected | else<br>WREG<7:4 | 4> + 6 → f<7:4>, s<7:4><br>4> → f<7:4>, s<7:4> | | | | | | en the fetched in | | Encoding: | 0010 11 | lls ffff ffff | | | | | discarded a instead mation. | and an NOP is eath | executed | Description: | WREG resulting tion of two variations | DAW adjusts the eight bit value in WREG resulting from the earlier addition of two variables (each in packed | | | | Words: | 1 | | | | packed BCD re | nd produces a correct esult. | | | | Cycles: | 1 (2) | | | | | t is placed in Data | | | | Q Cycle Activity: | | | | | memo<br>WRE | ory location 'f' and<br>G. | | | | Q1<br>Decode | Q2<br>Read | Q3<br>Execute | Q4<br>NOP | | | t is placed in Data | | | | Decode | register 'f' | Execute | NOP | | memo | ory location 'f'. | | | | If skip: | | | | Words: | 1 | | | | | Q1 | Q2 | Q3 | Q4 | Cycles: | 1 | | | | | Forced NOP | NOP | Execute | NOP | Q Cycle Activit | = | | | | | Example: Before Instru | NLESS<br>LESS | CPFSLT REG<br>:<br>: | | Q1<br>Decode | Q2<br>Read<br>register 'f' | Q3 Q4 Execute Write register 'f' and other | | | | PC | | ddress (HERE) | | | | specified register | | | | W | = ? | | | Example1: | DAW REG1, | , , | | | | After Instruct<br>If REG | | REG; | | Example i: Before Ins | | U | | | | PC<br>If REG<br>PC | = Ac<br>≥ W | ddress (LESS) REG; ddress (NLESS | ) | WREG<br>REG1<br>C<br>DC | $\Theta = 0xA5$ | | | | | | | | | After Instr<br>WREG<br>REG1<br>C<br>DC<br><u>Example 2</u> : | $\Theta = 0x05$ | | | | | | | | | Before Ins<br>WREG<br>REG1<br>C<br>DC | G = 0xCE | | | | After Instruction WREG = REG1 DC 0x24 0x24 0 | DCFSNZ | Decreme | ent f, ski | p if not ( | ) | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------|----------| | Syntax: | [label] D | CFSNZ | f,d | | | Operands: | $0 \le f \le 25$ $d \in [0,1]$ | 5 | | | | Operation: | $(f) - 1 \rightarrow$ skip if not | . , , | | | | Status Affected: | None | | | | | Encoding: | 0010 | 011d | ffff | ffff | | Description: | The contents of register 'f' are decremented. If 'd' is 0 the result is placed in WREG. If 'd' is 1 the result is placed back in register 'f'. | | | | | | If the result which is all and an NC ing it a two | ready fet<br>P is exec | ched, is di<br>cuted inste | scarded, | Words: 1 Cycles: 1(2) Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |--------|--------------|---------|-------------| | Decode | Read | Execute | Write to | | | register 'f' | | destination | If skip: | Q1 | Q2 | Q3 | Q4 | |------------|-----|---------|-----| | Forced NOP | NOP | Execute | NOP | Example: HERE DCFSNZ TEMP, 1 ZERO : NZERO : Before Instruction TEMP\_VALUE = ? After Instruction TEMP\_VALUE = TEMP\_VALUE - 1, If $TEMP_VALUE = 0$ ; PC = Address (ZERO) If TEMP\_VALUE $\neq$ 0; PC = Address (NZERO) GOTO Unconditional Branch Syntax: [label] GOTO k Operands: $0 \le k \le 8191$ Operation: $k \rightarrow PC<12:0>$ ; $k<12:8> \rightarrow PCLATH<4:0>$ , $PC<15:13> \rightarrow PCLATH<7:5>$ Status Affected: None Encoding: 110k kkkk kkkk kkkk Description: GOTO allows an unconditional branch anywhere within an 8K page boundary. The thirteen bit immediate value is loaded into PC bits <12:0>. Then the upper eight bits of PC are loaded into PCLATH. GOTO is always a two-cycle instruction. Words: 1 Cycles: 2 Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |------------|--------------|---------|-----| | Decode | Read literal | Execute | NOP | | | 'k'<7:0> | | | | Forced NOP | NOP | Execute | NOP | Example: GOTO THERE After Instruction PC = Address (THERE) RETFIE Return from Interrupt Syntax: [label] RETFIE Operands: None Operation: $TOS \rightarrow (PC)$ ; $0 \to \text{GLINTD};$ PCLATH is unchanged. Status Affected: GLINTD Encoding: 0000 0000 0000 0101 Description: Return from Interrupt. Stack is POP'ed and Top of Stack (TOS) is loaded in the PC. Interrupts are enabled by clearing the GLINTD bit. GLINTD is the global interrupt disable bit (CPUSTA<4>). Words: 1 Cycles: 2 Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |------------|---------------------------|---------|-----| | Decode | Read<br>register<br>T0STA | Execute | NOP | | Forced NOP | NOP | Execute | NOP | Example: RETFIE After Interrupt PC = TOS GLINTD = 0 RETLW Return Literal to WREG Syntax: [label] RETLW k Operands: $0 \le k \le 255$ Operation: $k \rightarrow (WREG); TOS \rightarrow (PC);$ PCLATH is unchanged Status Affected: None Encoding: 1011 0110 kkkk kkkk Description: WREG is loaded with the eight bit literal 'k'. The program counter is loaded from the top of the stack (the return address). The high address latch (PCLATH) remains unchanged. Words: 1 Cycles: 2 Q Cycle Activity: | Q1 | Q2 | Q3 | Q4 | |------------|-------------|---------|----------| | Decode | Read | Execute | Write to | | | literal 'k' | | WREG | | Forced NOP | NOP | Execute | NOP | Example: CALL TABLE ; WREG contains table ; offset value ; WREG now has ; table value : TABLE ADDWF PC ; WREG = offset RETLW k0 ; Begin table RETLW k1 ; : : RETLW kn ; End of table Before Instruction WREG = 0x07 After Instruction WREG = value of k7 | RETURN | Return fi | rom Sub | routine | | |------------------|----------------------------------------|-----------|-------------|----------| | Syntax: | [ label ] | RETUR | N | | | Operands: | None | | | | | Operation: | $TOS \to F$ | PC; | | | | Status Affected: | None | | | | | Encoding: | 0000 | 0000 | 0000 | 0010 | | Description: | Return fro<br>popped ar<br>is loaded i | d the top | of the stad | ck (TOS) | | Words: | 1 | | | | Words: 1 Cycles: 2 | Q | Cycle | Activity: | | |---|-------|-----------|--| | | | _ | | | Q1 | Q2 | Q3 | Q4 | |------------|--------------------------|---------|-----| | Decode | Read<br>register<br>PCL* | Execute | NOP | | Forced NOP | NOP | Execute | NOP | <sup>\*</sup> Remember reading PCL causes PCLATH to be updated. This will be the high address of where the RETURN instruction is located. Example: RETURN After Interrupt PC = TOS | RLCF | LCF Rotate Left f through Carry | | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------|--| | Syntax: | [ label ] | RLCF f, | d | | | | Operands: | $0 \le f \le 25$ $d \in [0,1]$ | 5 | | | | | Operation: | $f$ <n> <math>\rightarrow</math> d <math>f</math>&lt;7&gt; <math>\rightarrow</math> C <math>\rightarrow</math> d&lt;0:</n> | <b>;</b> | | | | | Status Affected: | С | | | | | | Encoding: | 0001 | 101d | ffff | ffff | | | Description: | one bit to t<br>Flag. If 'd'<br>WREG. If ' | The contents of register 'f' are rotated one bit to the left through the Carry Flag. If 'd' is 0 the result is placed in WREG. If 'd' is 1 the result is stored back in register 'f'. | | | | | Words: | 1 | | | | | | Cycles: | 1 | | | | | | Q Cycle Activity: | | | | | | | Q1 | Q2 | Q3 | | Q4 | | | Decode | Read<br>register 'f' | Execute | | rite to<br>tination | | | Example: | RLCF | REG | , 0 | | | Before Instruction REG = 1110 0110 C = 0 After Instruction REG = 1110 0110 WREG = 1100 1100 C = 1 NOTES: TABLE 16-1: DEVELOPMENT TOOLS FROM MICROCHIP | Product | ** MPLAB™<br>Integrated<br>Development<br>Environment | MPLAB™ C<br>Compiler | MP-DriveWay<br>Applications<br>Code<br>Generator | fuzzyTECH®-MP<br>Explorer/Edition<br>Fuzzy Logic<br>Dev. Tool | *** PICMASTER®/<br>PICMASTER-CE<br>In-Circuit<br>Emulator | ICEPIC<br>Low-Cost<br>In-Circuit<br>Emulator | ****PRO MATE™<br>II Universal<br>Microchip<br>Programmer | PICSTART® Lite<br>Ultra Low-Cost<br>Dev. Kit | PICSTART® Plus<br>Low-Cost<br>Universal<br>Dev. Kit | |-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------|--------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | PIC12C508, 509 | SW007002 | SW006005 | I | I | EM167015/<br>EM167101 | I | DV007003 | I | DV003001 | | PIC14000 | SW007002 | SW006005 | I | I | EM147001/<br>EM147101 | 1 | DV007003 | I | DV003001 | | PIC16C52, 54, 54A,<br>55, 56, 57, 58A | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167015/<br>EM167101 | EM167201 | DV007003 | DV162003 | DV003001 | | PIC16C554, 556, 558 | SW007002 | SW006005 | I | DV005001/<br>DV005002 | EM167033/<br>EM167113 | | DV007003 | I | DV003001 | | PIC16C61 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167021/<br>N/A | EM167205 | DV007003 | DV162003 | DV003001 | | PIC16C62, 62A,<br>64, 64A | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167025/<br>EM167103 | EM167203 | DV007003 | DV162002 | DV003001 | | PIC16C620, 621, 622 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167023/<br>EM167109 | EM167202 | DV007003 | DV162003 | DV003001 | | PIC16C63, 65, 65A,<br>73, 73A, 74, 74A | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167025/<br>EM167103 | EM167204 | DV007003 | DV162002 | DV003001 | | PIC16C642, 662* | SW007002 | SW006005 | | I | EM167035/<br>EM167105 | İ | DV007003 | DV162002 | DV003001 | | PIC16C71 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167027/<br>EM167105 | EM167205 | DV007003 | DV162003 | DV003001 | | PIC16C710, 711 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167027/<br>EM167105 | 1 | DV007003 | DV162003 | DV003001 | | PIC16C72 | SW007002 | SW006005 | SW006006 | I | EM167025/<br>EM167103 | 1 | DV007003 | DV162002 | DV003001 | | PIC16F83 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167029/<br>EM167107 | 1 | DV007003 | DV162003 | DV003001 | | PIC16C84 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167029/<br>EM167107 | EM167206 | DV007003 | DV162003 | DV003001 | | PIC16F84 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167029/<br>EM167107 | 1 | DV007003 | DV162003 | DV003001 | | PIC16C923, 924* | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM167031/<br>EM167111 | | DV007003 | 1 | DV003001 | | PIC17C42,<br>42A, 43, 44 | SW007002 | SW006005 | SW006006 | DV005001/<br>DV005002 | EM177007/<br>EM177107 | 1 | DV007003 | I | DV003001 | | *Contact Microchip Technology for availability date **MPLAB Integrated Development Environment includes MPLAB-SIM Simulator and MPASM Assembler | inology for availa<br>velopment Enviro | ability date | s MPLAB-SIM Si | mulator and | ***AII PICMASTER and PICMA<br>PRO MATE II programmer<br>****PRO MATE socket modules:<br>ordering guide for specific o | and PICMAST<br>rogrammer<br>t modules are<br>or specific ord | II PICMASTER and PICMASTER-CE ordering pa<br>PRO MATE II programmer<br>RO MATE socket modules are ordered separately<br>ordering guide for specific ordering part numbers | ***All PICMASTER and PICMASTER-CE ordering part numbers above include PRO MATE II programmer PRO MATE II programmer PRO MATE socket modules are ordered separately. See development systems ordering guide for specific ordering part numbers | lude<br>stems | | Product | TRUEGAUG | TRUEGAUGE® Development Kit | | SEEVAL® Designers Kit | Hopping Code Security Programmer Kit | Security Prog | | Hopping Code Security Eval/Demo Kit | ity Eval/Demo Kit | | All 2 wire and 3 wire<br>Serial EEPROM's | | N/A | | DV243001 | | N/A | | N/A | | | MTA11200B | | DV114001 | | N/A | | N/A | | N/A | | | HCS200, 300, 301 * | | N/A | | N/A | | PG306001 | | DM303001 | 001 | Applicable Devices 42 R42 42A 43 R43 44 ### FIGURE 17-9: USART MODULE: SYNCHRONOUS TRANSMISSION (MASTER/SLAVE) TIMING #### TABLE 17-9: SERIAL PORT SYNCHRONOUS TRANSMISSION REQUIREMENTS | Parameter<br>No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |------------------|----------|---------------------------------------------------------|-----|------|-----|-------|------------| | 120 | TckH2dtV | SYNC XMIT (MASTER & SLAVE) Clock high to data out valid | _ | _ | 65 | ns | | | 121 | TckRF | Clock out rise time and fall time (Master Mode) | _ | 10 | 35 | ns | | | 122 | TdtRF | Data out rise time and fall time | _ | 10 | 35 | ns | | <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. ### FIGURE 17-10: USART MODULE: SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING TABLE 17-10: SERIAL PORT SYNCHRONOUS RECEIVE REQUIREMENTS | Parameter<br>No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |------------------|----------|---------------------------------------------------------------|-----|------|-----|-------|------------| | 125 | TdtV2ckL | SYNC RCV (MASTER & SLAVE) Data hold before CK↓ (DT hold time) | 15 | _ | _ | ns | | | 126 | TckL2dtl | Data hold after CK↓ (DT hold time) | 15 | _ | _ | ns | | <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. 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 NOTES: | Receive Status and Control Register83 | SWAPF | 137 | |-------------------------------------------|---------------------------------|--------| | Register File Map33 | SYNC | 83 | | Registers | Synchronous Master Mode | 93 | | ALUSTA27, 36 | Synchronous Master Reception | 95 | | BRG86 | Synchronous Master Transmission | 93 | | BSR27 | Synchronous Slave Mode | 97 | | CPUSTA37 | • | | | File Map | <b>-</b> | | | FSR040 | Т | | | FSR140 | | | | INDF040 | T0CKI Pin | | | INDF140 | TOCKIE | | | INTSTA | T0CKIF | | | PIE | T0CS | 38, 67 | | PIR | T0IE | 22 | | RCSTA84 | T0IF | 22 | | Special Function Table34 | T0SE | 38, 67 | | TOSTA | T0STA | 34, 38 | | TCON1 | T16 | 71 | | TCON2 | Table Latch | 40 | | | Table Pointer | 40 | | TMR181 | Table Read | | | TMR281 | Example | 48 | | TMR381 | Section | | | TXSTA83 | Table Reads Section | | | WREG27 | | | | Reset | TABLRD Operation | | | Section15 | Timing | | | Status Bits and Their Significance | TLRD | | | Time-Out in Various Situations | TLRD Operation | 44 | | Time-Out Sequence | Table Write | | | RETFIE | Code | 46 | | | Interaction | 45 | | RETLW | Section | | | RETURN | TABLWT Operation | | | RLCF | Terminating Long Writes | | | RLNCF | Timing | | | RRCF | TLWT Operation | | | RRNCF | To External Memory | | | RX Pin Sampling Scheme91 | | | | RX984 | To Internal Memory | | | RX9D84 | TABLRD | | | | TABLWT | | | | TBLATH | | | S | TBLATL | 40 | | | TBLPTRH | 34, 40 | | Sampling91 | TBLPTRL | 34, 40 | | Saving STATUS and WREG in RAM27 | TCLK12 | 71 | | SETF | TCLK3 | 71 | | SFR | TCON1 | | | SFR (Special Function Registers) | TCON2 | , | | SFR As Source/Destination | Terminating Long Writes | • | | Signed Math 9 | Time-Out Sequence | | | <u> </u> | Timer Resources | | | SLEEP | | | | Software Simulator (MPSIM)145 | Timer0 | b/ | | SPBRG | Timer1 | _ | | Special Features of the CPU | 16-bit Mode | | | Special Function Registers29, 32, 34, 108 | Clock Source Select | | | SPEN | On bit | 72 | | SREN84 | Section | 71, 73 | | Stack | Timer2 | | | Operation | 16-bit Mode | 74 | | Pointer | Clock Source Select | | | Stack | On bit | | | STKAL 39 | Section | | | STKAV | Timer3 | 1, 1, | | SUBLW | Clock Source Select | 7/ | | | | | | SUBWF | On bit | | | SUBWFB 136 | Section | 71. 77 |