

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 -</u> <u>Microcontrollers</u>"

#### Details

E·XF

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 32MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                 |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 12                                                                        |
| Program Memory Size        | 7KB (4K x 14)                                                             |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 512 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                               |
| Data Converters            | A/D 8x10b; D/A 1x8b                                                       |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 14-TSSOP (0.173", 4.40mm Width)                                           |
| Supplier Device Package    | 14-TSSOP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1614-e-st |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# 3.0 MEMORY ORGANIZATION

These devices contain the following types of memory:

- Program Memory
  - Configuration Words
  - Device ID
  - User ID
  - Flash Program Memory
- Data Memory
  - Core Registers
  - Special Function Registers
  - General Purpose RAM
  - Common RAM

The following features are associated with access and control of program memory and data memory:

- PCL and PCLATH
- Stack
- Indirect Addressing

## 3.1 **Program Memory Organization**

The enhanced mid-range core has a 15-bit program counter capable of addressing a  $32K \times 14$  program memory space. Table 3-1 shows the memory sizes implemented. Accessing a location above these boundaries will cause a wrap-around within the implemented memory space. The Reset vector is at 0000h and the interrupt vector is at 0004h (See Figure 3-1).

## 3.2 High-Endurance Flash

This device has a 128-byte section of high-endurance Program Flash Memory (PFM) in lieu of data EEPROM. This area is especially well suited for nonvolatile data storage that is expected to be updated frequently over the life of the end product. See Section 10.2 "Flash Program Memory Overview" for more information on writing data to PFM. See Section 3.2.1.2 "Indirect Read with FSR" for more information about using the FSR registers to read byte data stored in PFM.

| Device Program Memory Space<br>(Words) |       | Last Program Memory<br>Address | High-Endurance Flash<br>Memory Address<br>Range <sup>(1)</sup> |
|----------------------------------------|-------|--------------------------------|----------------------------------------------------------------|
| PIC16(L)F1614/8                        | 4,096 | 0FFFh                          | 0F80h-0FFFh                                                    |

Note 1: High-endurance Flash applies to low byte of each address in the range.

| Name       | Bit 7   | Bit 6  | Bit 5     | Bit 4     | Bit 3  | Bit 2     | Bit 1     | Bit 0   | Register<br>on Page |
|------------|---------|--------|-----------|-----------|--------|-----------|-----------|---------|---------------------|
| INTCON     | GIE     | PEIE   | TMR0IE    | INTE      | IOCIE  | TMR0IF    | INTF      | IOCIF   | 97                  |
| OPTION_REG | WPUEN   | INTEDG | TMR0CS    | TMR0SE    | PSA    |           | PS<2:0>   |         | 222                 |
| PIE1       | TMR1GIE | ADIE   | RCIE      | TXIE      | SSP1IE | CCP1IE    | TMR2IE    | TMR1IE  | 98                  |
| PIE2       | —       | C2IE   | C1IE      | —         | BCLIE  | TMR6IE    | TMR4IE    | CCP2IE  | 99                  |
| PIE3       | —       | —      | CWGIE     | ZCDIE     | —      | —         | CLC2IE    | CLC1IE  | 100                 |
| PIE4       | SCANIE  | CRCIE  | SMT2PWAIE | SMT2PRAIE | SMT2IE | SMT1PWAIE | SMT1PRAIE | SMT1IF  | 101                 |
| PIE5       | TMR3GIE | TMR3IE | TMR5GIE   | TMR5IE    | —      | AT1IE     | PID1EIE   | PID1DIE | 102                 |
| PIR1       | TMR1GIF | ADIF   | RCIF      | TXIF      | SSP1IF | CCP1IF    | TMR2IF    | TMR1IF  | 103                 |
| PIR2       | _       | C2IF   | C1IF      | —         | BCLIF  | TMR6IF    | TMR4IF    | CCP2IF  | 104                 |
| PIR3       | _       | _      | CWGIF     | ZCDIF     | _      | —         | CLC2IF    | CLC1IF  | 105                 |
| PIR4       | SCANIF  | CRCIF  | SMT2PWAIF | SMT2PRAIF | SMT2IF | SMT1PWAIF | SMT1PRAIF | SMT1IF  | 106                 |
| PIR5       | TMR3GIF | TMR3IF | TMR5GIF   | TMR5IF    | _      | AT1IF     | PID1EIF   | PID1DIF | 107                 |

TABLE 7-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by interrupts.



#### EXAMPLE 10-1: FLASH PROGRAM MEMORY READ

```
* This code block will read 1 word of program
* memory at the memory address:
   PROG_ADDR_HI: PROG_ADDR_LO
   data will be returned in the variables;
   PROG_DATA_HI, PROG_DATA_LO
   BANKSEL PMADRL
                             ; Select Bank for PMCON registers
            PROG_ADDR_LO
   MOVLW
                             ;
   MOVWF
            PMADRL
                             ; Store LSB of address
            PROG_ADDR_HI
   MOVLW
                              ;
   MOVWF
            PMADRH
                              ; Store MSB of address
   BCF
            PMCON1,CFGS
                             ; Do not select Configuration Space
   BSF
            PMCON1,RD
                              ; Initiate read
   NOP
                              ; Ignored (Figure 10-2)
   NOP
                              ; Ignored (Figure 10-2)
   MOVF
            PMDATL,W
                              ; Get LSB of word
   MOVWF
            PROG_DATA_LO
                             ; Store in user location
                             ; Get MSB of word
            PMDATH,W
   MOVF
   MOVWF
            PROG_DATA_HI
                             ; Store in user location
```

## 17.0 ANALOG-TO-DIGITAL CONVERTER (ADC) MODULE

The Analog-to-Digital Converter (ADC) allows conversion of an analog input signal to a 10-bit binary representation of that signal. This device uses analog inputs, which are multiplexed into a single sample and hold circuit. The output of the sample and hold is connected to the input of the converter. The converter generates a 10-bit binary result via successive approximation and stores the conversion result into the ADC result registers (ADRESH:ADRESL register pair). Figure 17-1 shows the block diagram of the ADC. The ADC voltage reference is software selectable to be either internally generated or externally supplied.

The ADC can generate an interrupt upon completion of a conversion. This interrupt can be used to wake-up the device from Sleep.





# **19.0 COMPARATOR MODULE**

Comparators are used to interface analog circuits to a digital circuit by comparing two analog voltages and providing a digital indication of their relative magnitudes. Comparators are very useful mixed signal building blocks because they provide analog functionality independent of program execution. The analog comparator module includes the following features:

- · Independent comparator control
- · Programmable input selection
- · Comparator output is available internally/externally
- · Programmable output polarity
- Interrupt-on-change
- · Wake-up from Sleep
- · Programmable Speed/Power optimization
- PWM shutdown
- Programmable and Fixed Voltage Reference

## **19.1** Comparator Overview

A single comparator is shown in Figure 19-1 along with the relationship between the analog input levels and the digital output. When the analog voltage at VIN+ is less than the analog voltage at VIN-, the output of the comparator is a digital low level. When the analog voltage at VIN+ is greater than the analog voltage at VIN-, the output of the comparator is a digital high level.

The comparators available for this device are located in Table 19-1.

#### TABLE 19-1: COMPARATOR AVAILABILITY PER DEVICE

| Device        | C1 | C2 |
|---------------|----|----|
| PIC16(L)F1618 | ٠  | ٠  |
| PIC16(L)F1614 | ٠  | ٠  |

#### FIGURE 19-1: SINGLE COMPARATOR







## FIGURE 22-4: TIMER1 GATE TOGGLE MODE



| R/W-0/u                                                                                                                                                                                 | R/W-0/u                                                                                                                                                                                                                                                            | R/W-0/u                                              | R/W-0/u                                            | R/W/HC-0/u                         | R-x/x                          | R/W-0/u          | R/W-0/u      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------|------------------------------------|--------------------------------|------------------|--------------|
| TMR1GE                                                                                                                                                                                  | T1GPOL                                                                                                                                                                                                                                                             | T1GTM                                                | T1GSPM                                             | T1GGO/<br>DONE                     | T1GVAL                         | T1GSS            | 3<1:0>       |
| bit 7                                                                                                                                                                                   |                                                                                                                                                                                                                                                                    |                                                      |                                                    |                                    |                                | I                | bit 0        |
|                                                                                                                                                                                         |                                                                                                                                                                                                                                                                    |                                                      |                                                    |                                    |                                |                  |              |
| Legend:                                                                                                                                                                                 |                                                                                                                                                                                                                                                                    |                                                      |                                                    |                                    |                                |                  |              |
| R = Readable                                                                                                                                                                            | bit                                                                                                                                                                                                                                                                | W = Writable                                         | bit                                                | U = Unimpler                       | nented bit, read               | d as '0'         |              |
| u = Bit is unch                                                                                                                                                                         | anged                                                                                                                                                                                                                                                              | x = Bit is unkr                                      | Iown                                               | -n/n = Value a                     | at POR and BO                  | R/Value at all o | other Resets |
| '1' = Bit is set                                                                                                                                                                        |                                                                                                                                                                                                                                                                    | '0' = Bit is clea                                    | ared                                               | HC = Bit is cle                    | eared by hardw                 | are              |              |
| bit 7 <b>TMR1GE:</b> Timer1 Gate Enable bit<br><u>If TMR1ON = 0</u> :<br>This bit is ignored<br><u>If TMR1ON = 1</u> :<br>1 = Timer1 counting is controlled by the Timer1 gate function |                                                                                                                                                                                                                                                                    |                                                      |                                                    |                                    |                                |                  |              |
| bit 6                                                                                                                                                                                   | T1GPOL: Tim                                                                                                                                                                                                                                                        | ner1 Gate Pola                                       | rity bit                                           |                                    |                                |                  |              |
|                                                                                                                                                                                         | 1 = Timer1 g<br>0 = Timer1 g                                                                                                                                                                                                                                       | ate is active-hi<br>ate is active-lo                 | gh (Timer1 cou<br>w (Timer1 cou                    | unts when gate<br>nts when gate i  | is high)<br>s low)             |                  |              |
| bit 5                                                                                                                                                                                   | T1GTM: Time                                                                                                                                                                                                                                                        | er1 Gate Toggle                                      | e Mode bit                                         |                                    |                                |                  |              |
|                                                                                                                                                                                         | 1 = Timer1 G<br>0 = Timer1 G<br>Timer1 gate fl                                                                                                                                                                                                                     | Bate Toggle mo<br>Bate Toggle mo<br>lip-flop toggles | de is enabled<br>de is disabled<br>on every rising | and toggle flip-<br>g edge.        | flop is cleared                |                  |              |
| bit 4                                                                                                                                                                                   | T1GSPM: Tin                                                                                                                                                                                                                                                        | ner1 Gate Sing                                       | le-Pulse Mode                                      | e bit                              |                                |                  |              |
|                                                                                                                                                                                         | 1 = Timer1 g<br>0 = Timer1 g                                                                                                                                                                                                                                       | ate Single-Puls<br>ate Single-Puls                   | e mode is ena<br>e mode is disa                    | abled and is cou<br>abled          | ntrolling Timer1               | gate             |              |
| bit 3                                                                                                                                                                                   | T1GGO/DON                                                                                                                                                                                                                                                          | E: Timer1 Gate                                       | e Single-Pulse                                     | Acquisition Sta                    | atus bit                       |                  |              |
|                                                                                                                                                                                         | 1 = Timer1 g<br>0 = Timer1 g                                                                                                                                                                                                                                       | ate single-puls<br>ate single-puls                   | e acquisition is<br>e acquisition h                | s ready, waiting<br>as completed o | for an edge<br>or has not been | started          |              |
| bit 2                                                                                                                                                                                   | <b>T1GVAL:</b> Timer1 Gate Value Status bit<br>Indicates the current state of the Timer1 gate that could be provided to TMR1H:TMR1L.<br>Unaffected by Timer1 Gate Enable (TMR1GE).                                                                                 |                                                      |                                                    |                                    |                                |                  |              |
| bit 0                                                                                                                                                                                   | T1GSS<1:0>: Timer1 Gate Source Select bits                                                                                                                                                                                                                         |                                                      |                                                    |                                    |                                |                  |              |
|                                                                                                                                                                                         | <b>T1GSS&lt;1:0&gt;:</b> Timer1 Gate Source Select bits<br>11 =Comparator 2 optionally synchronized output (C2_OUT_sync)<br>10 =Comparator 1 optionally synchronized output (C1_OUT_sync)<br>01 =Timer0 overflow output (T0_overflow)<br>00 =Timer1 gate pin (T1G) |                                                      |                                                    |                                    |                                |                  |              |

## REGISTER 22-2: T1GCON: TIMER1 GATE CONTROL REGISTER

The  $I^2C$  interface supports the following modes and features:

- Master mode
- Slave mode
- Byte NACKing (Slave mode)
- · Limited multi-master support
- · 7-bit and 10-bit addressing
- Start and Stop interrupts
- · Interrupt masking
- Clock stretching
- · Bus collision detection
- General call address matching
- · Address masking
- · Address Hold and Data Hold modes
- · Selectable SDA hold times

Figure 24-2 is a block diagram of the  $I^2C$  interface module in Master mode. Figure 24-3 is a diagram of the  $I^2C$  interface module in Slave mode.





#### 24.5.7 GENERAL CALL ADDRESS SUPPORT

The addressing procedure for the  $I^2C$  bus is such that the first byte after the Start condition usually determines which device will be the slave addressed by the master device. The exception is the general call address which can address all devices. When this address is used, all devices should, in theory, respond with an acknowledge.

The general call address is a reserved address in the  $I^{2}C$  protocol, defined as address 0x00. When the GCEN bit of the SSPxCON2 register is set, the slave module will automatically ACK the reception of this address regardless of the value stored in SSPxADD. After the slave clocks in an address of all zeros with the

R/W bit clear, an interrupt is generated and slave software can read SSPxBUF and respond. Figure 24-24 shows a general call reception sequence.

In 10-bit Address mode, the UA bit will not be set on the reception of the general call address. The slave will prepare to receive the second byte as data, just as it would in 7-bit mode.

If the AHEN bit of the SSPxCON3 register is set, just as with any other address reception, the slave hardware will stretch the clock after the eighth falling edge of SCL. The slave must then set its ACKDT value and release the clock with communication progressing as it would normally.

## FIGURE 24-24: SLAVE MODE GENERAL CALL ADDRESS SEQUENCE



## 24.5.8 SSP MASK REGISTER

An SSP Mask (SSPxMSK) register (Register 24-5) is available in I<sup>2</sup>C Slave mode as a mask for the value held in the SSPSR register during an address comparison operation. A zero ('0') bit in the SSPxMSK register has the effect of making the corresponding bit of the received address a "don't care".

This register is reset to all '1's upon any Reset condition and, therefore, has no effect on standard SSP operation until written with a mask value.

The SSP Mask register is active during:

- 7-bit Address mode: address compare of A<7:1>.
- 10-bit Address mode: address compare of A<7:0> only. The SSP mask has no effect during the reception of the first (high) byte of the address.

## 24.6.7 I<sup>2</sup>C MASTER MODE RECEPTION

Master mode reception (Figure 24-29) is enabled by programming the Receive Enable bit, RCEN bit of the SSPxCON2 register.

| Note: | The MSSP module must be in an Idle      |
|-------|-----------------------------------------|
|       | state before the RCEN bit is set or the |
|       | RCEN bit will be disregarded.           |

The Baud Rate Generator begins counting and on each rollover, the state of the SCL pin changes (high-to-low/ low-to-high) and data is shifted into the SSPSR. After the falling edge of the eighth clock, the receive enable flag is automatically cleared, the contents of the SSPSR are loaded into the SSPxBUF, the BF flag bit is set, the SSPxIF flag bit is set and the Baud Rate Generator is suspended from counting, holding SCL low. The MSSP is now in Idle state awaiting the next command. When the buffer is read by the CPU, the BF flag bit is automatically cleared. The user can then send an Acknowledge bit at the end of reception by setting the Acknowledge Sequence Enable, ACKEN bit of the SSPxCON2 register.

#### 24.6.7.1 BF Status Flag

In receive operation, the BF bit is set when an address or data byte is loaded into SSPxBUF from SSPSR. It is cleared when the SSPxBUF register is read.

#### 24.6.7.2 SSPOV Status Flag

In receive operation, the SSPOV bit is set when eight bits are received into the SSPSR and the BF flag bit is already set from a previous reception.

#### 24.6.7.3 WCOL Status Flag

If the user writes the SSPxBUF when a receive is already in progress (i.e., SSPSR is still shifting in a data byte), the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur).

#### 24.6.7.4 Typical Receive Sequence:

- 1. The user generates a Start condition by setting the SEN bit of the SSPxCON2 register.
- 2. SSPxIF is set by hardware on completion of the Start.
- 3. SSPxIF is cleared by software.
- 4. User writes SSPxBUF with the slave address to transmit and the R/W bit set.
- 5. Address is shifted out the SDA pin until all eight bits are transmitted. Transmission begins as soon as SSPxBUF is written to.
- The MSSP module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSPxCON2 register.
- 7. The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPxIF bit.
- 8. User sets the RCEN bit of the SSPxCON2 register and the master clocks in a byte from the slave.
- 9. After the eighth falling edge of SCL, SSPxIF and BF are set.
- 10. Master clears SSPxIF and reads the received byte from SSPxBUF, clears BF.
- 11. Master sets ACK value sent to slave in ACKDT bit of the SSPxCON2 register and initiates the ACK by setting the ACKEN bit.
- 12. Master's ACK is clocked out to the slave and SSPxIF is set.
- 13. User clears SSPxIF.
- 14. Steps 8-13 are repeated for each received byte from the slave.
- 15. Master sends a not ACK or Stop to end communication.

# 24.6.13.2 Bus Collision During a Repeated Start Condition

During a Repeated Start condition, a bus collision occurs if:

- a) A low level is sampled on SDA when SCL goes from low level to high level (Case 1).
- b) SCL goes low before SDA is asserted low, indicating that another master is attempting to transmit a data '1' (Case 2).

When the user releases SDA and the pin is allowed to float high, the BRG is loaded with SSPxADD and counts down to zero. The SCL pin is then deasserted and when sampled high, the SDA pin is sampled.

If SDA is low, a bus collision has occurred (i.e., another master is attempting to transmit a data '0', Figure 24-36). If SDA is sampled high, the BRG is reloaded and begins counting. If SDA goes from high-to-low before the BRG times out, no bus collision occurs because no two masters can assert SDA at exactly the same time.

If SCL goes from high-to-low before the BRG times out and SDA has not already been asserted, a bus collision occurs. In this case, another master is attempting to transmit a data '1' during the Repeated Start condition, see Figure 24-37.

If, at the end of the BRG time-out, both SCL and SDA are still high, the SDA pin is driven low and the BRG is reloaded and begins counting. At the end of the count, regardless of the status of the SCL pin, the SCL pin is driven low and the Repeated Start condition is complete.

FIGURE 24-36: BUS COLLISION DURING A REPEATED START CONDITION (CASE 1)







## 25.2 Clock Accuracy with Asynchronous Operation

The factory calibrates the internal oscillator block output (INTOSC). However, the INTOSC frequency may drift as VDD or temperature changes, and this directly affects the asynchronous baud rate. Two methods may be used to adjust the baud rate clock, but both require a reference clock source of some kind.

The first (preferred) method uses the OSCTUNE register to adjust the INTOSC output. Adjusting the value in the OSCTUNE register allows for fine resolution changes to the system clock source. See **Section 5.2.2.3 "Internal Oscillator Frequency Adjustment"** for more information.

The other method adjusts the value in the Baud Rate Generator. This can be done automatically with the Auto-Baud Detect feature (see **Section 25.4.1 "Auto-Baud Detect**"). There may not be fine enough resolution when adjusting the Baud Rate Generator to compensate for a gradual change in the peripheral clock frequency.



## SIMPLIFIED CWG BLOCK DIAGRAM (PUSH-PULL MODE)

PIC16(L)F1614/8

#### REGISTER 28-8: CWGxCLKCON: CWGx CLOCK SELECTION CONTROL REGISTER

| U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0/0 |
|-------|-----|-----|-----|-----|-----|-----|---------|
| —     | —   | —   | —   | —   | —   | —   | CS      |
| bit 7 |     |     |     |     |     |     | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | q = Value depends on condition                        |

bit 0

bit 3-0

CS: CWGx Clock Selection bit

1 = HFINTOSC 16 MHz is selected

0 = Fosc is selected

#### REGISTER 28-9: CWGxISM: CWGx INPUT SELECTION REGISTER

| U-0   | U-0 | U-0 | U-0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-------|-----|-----|-----|---------|---------|---------|---------|
| —     | —   | —   | —   |         | IS<     | 3:0>    |         |
| bit 7 |     |     |     |         |         |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | q = Value depends on condition                        |

#### bit 7-4 Unimplemented: Read as '0'

IS<3:0>: CWGx Input Selection bits

1111 = Reserved. No channel connected.

- •
- •
- 1011 = Reserved. No channel connected.
- 1010 = PWM4\_out
- 1001 = PWM3\_out
- 1000 = Reserved. No channel connected.
- 0111 = Reserved. No channel connected.
- 0110 = LC2\_out
- 0101 = LC1\_out
- 0100 = CCP2\_out
- 0011 = CCP1\_out
- 0010 = C2\_OUT\_sync
- 0001 = C1\_OUT\_sync
- 0000 = CWGxIN pin







#### 30.6.9 COUNTER MODE

This mode increments the timer on each pulse of the SMTx\_signal input. This mode is asynchronous to the SMT clock and uses the SMTx\_signal as a time source. The SMTxCPW register will be updated with the current SMTxTMR value on the falling edge of the SMTxWIN input. See Figure 30-18.

## 31.5 Period Set Point and Error Measurement

The ATxSTPT register pair controls the period set point of the AT module. The signal period captured in the ATxPER register pair at every signal input pulse. The unsigned 15-bit ATxSTPT value is subtracted from the unsigned 15-bit ATxPER value and the signed 16-bit result is placed in the ATxERR register pair.

The ATxSTPT value is double buffered requiring an ATxSTPTL value write for the ATxSTPTH value to take effect. This is done so that all 16 bits update at the same time, thereby avoiding a miscalculation of the error.

#### FIGURE 31-7: ANGULAR TIMER SET POINT CALCULATION BLOCK DIAGRAM



## 31.6 Capture and Compare Functions

The angular timer contains multiple built-in capture/compare modules. These are controlled by their respective ATxCCONy registers where "x" refers to the AT instance and "y' refers to the Capture/Compare instance within that AT module.

This particular device contains three capture/compare modules within the AT module. The CCyMODE bit of the ATxCCONy register controls whether each particular module is in Capture or Compare mode. The polarity of each module's respective output signal is controlled by the CCyPOL bit of the ATxCCONy register (Register 31-21). Both the Capture and Compare modes use an edge detect that runs off of the ATxclk signal.

## 31.6.1 CAPTURE MODE

Capture mode is selected when the CCyMODE bit (of the ATxCCONy register) = 1. Refer to Figure 31-8.

In Capture mode, the value of the phase counter is written to the respective ATxCCy registers on the rising edge of the capture input signal.

The capture event also generates a pulse that can be used for the following:

- Trigger an ADC reading
- CLC logic input
- Set the CCyIF bit

See **Section 31.7 "Interrupts**" for more details on the interrupts triggered by the AT module.

The capture input signal source is selected by the capture/compare's respective ATxCSELy register (Register 31-22), and its polarity is selected by the ATxCAPyP bit of the ATxCCONy register (Register 31-21). Note that when in Capture mode, the ATxCCy register pair is read-only.

## 31.6.2 COMPARE MODE

Compare mode is selected when the CCyMODE bit (of the ATxCCONy register) = 0. Refer to Figure 31-9.

In Compare mode, the module compares the current value in the ATxCCy register pair to the phase counter value. When the two values are equal then a compare event is generated and output to the following:

- Trigger an ADC reading
- CLC logic input
- · Set the CCyIF bit

See **Section 31.7 "Interrupts**" for more details on the interrupts triggered by the AT module.

## REGISTER 31-11: ATxPHSH: ANGULAR TIMER PHASE COUNTER HIGH REGISTER

| U-0                                   | U-0                                                                          | U-0 | U-0 | U-0 | U-0                                | R-x/x       | R-x/x |  |  |
|---------------------------------------|------------------------------------------------------------------------------|-----|-----|-----|------------------------------------|-------------|-------|--|--|
| —                                     | —                                                                            | —   | —   |     | —                                  | PHS•        | <9:8> |  |  |
| bit 7                                 |                                                                              |     |     |     |                                    |             | bit 0 |  |  |
|                                       |                                                                              |     |     |     |                                    |             |       |  |  |
| Legend:                               |                                                                              |     |     |     |                                    |             |       |  |  |
| R = Readable bit W = Writable bit U = |                                                                              |     |     |     | U = Unimplemented bit, read as '0' |             |       |  |  |
| u = Bit is uncha                      | anged $x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Re$ |     |     |     |                                    | ther Resets |       |  |  |

bit 7-2 Unimplemented: Read as '0'

1' = Bit is set

bit 1-0 PHS<9:8>: Most Significant bits of ATxPHS. ATxPHS is the instantaneous value of the phase counter.

q = Value depends on condition

#### REGISTER 31-12: ATxPHSL: ANGULAR TIMER PHASE COUNTER LOW REGISTER

'0' = Bit is cleared

| R-x/x    | R-x/x | R-x/x | R-x/x | R-x/x | R-x/x | R-x/x | R-x/x |  |  |  |
|----------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
| PHS<7:0> |       |       |       |       |       |       |       |  |  |  |
| bit 7    |       |       |       |       |       |       | bit 0 |  |  |  |
|          |       |       |       |       |       |       |       |  |  |  |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | q = Value depends on condition                        |

bit 7-0 **PHS<7:0>:** Least Significant bits of ATxPHS. ATxPHS is the instantaneous value of the phase counter.

## 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging





VIEW C

| l                        | Units |           | MILLIMETERS |      |  |  |
|--------------------------|-------|-----------|-------------|------|--|--|
| Dimension Lim            | its   | MIN       | NOM         | MAX  |  |  |
| Number of Pins           | Ν     | 20        |             |      |  |  |
| Pitch                    | е     | 1.27 BSC  |             |      |  |  |
| Overall Height           | А     | -         | -           | 2.65 |  |  |
| Molded Package Thickness | A2    | 2.05      | -           | -    |  |  |
| Standoff §               | A1    | 0.10      | -           | 0.30 |  |  |
| Overall Width            | Е     |           | 10.30 BSC   |      |  |  |
| Molded Package Width     | E1    | 7.50 BSC  |             |      |  |  |
| Overall Length           | D     | 12.80 BSC |             |      |  |  |
| Chamfer (Optional)       | h     | 0.25      | -           | 0.75 |  |  |
| Foot Length              | L     | 0.40      | -           | 1.27 |  |  |
| Footprint                | L1    | 1.40 REF  |             |      |  |  |
| Lead Angle               | Θ     | 0°        | -           | -    |  |  |
| Foot Angle               | φ     | 0°        | -           | 8°   |  |  |
| Lead Thickness           | С     | 0.20      | -           | 0.33 |  |  |
| Lead Width               | b     | 0.31      | -           | 0.51 |  |  |
| Mold Draft Angle Top     | α     | 5°        | -           | 15°  |  |  |
| Mold Draft Angle Bottom  | β     | 5°        | -           | 15°  |  |  |

#### Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. § Significant Characteristic
- 3. Dimension D does not include mold flash, protrusions or gate burrs, which shall not exceed 0.15 mm per end. Dimension E1 does not include interlead flash or protrusion, which shall not exceed 0.25 mm per side.
- Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only.
- 5 Datums A & B to be determined at Datum H.

Microchip Technology Drawing No. C04-094C Sheet 2 of 2