

## **HIGHLIGHTS**

This section of the manual contains the following major topics:

| 43.1 | Introduction                        | 43-2  |
|------|-------------------------------------|-------|
|      | Control and Status Registers        |       |
| 43.3 | Module Description                  | 43-18 |
| 43.4 | QEI Operation in Power-Saving Modes | 43-26 |
| 43.5 | Effects of a Reset                  | 43-26 |
| 43.6 | Related Application Notes           | 43-27 |
| 43.7 | Revision History                    | 43-28 |

Note:

This family reference manual section is meant to serve as a complement to device data sheets. Depending on the device variant, this manual section may not apply to all PIC32 devices.

Refer to the note at the beginning of the "Quadrature Encoder Interface (QEI)" chapter in the specific device data sheet to determine whether this document supports the device you are using.

Device data sheets and family reference manuals are available for download from the Microchip Worldwide Web site at: http://www.microchip.com.

### 43.1 INTRODUCTION

The Quadrature Encoder Interface (QEI) module provides the interface to incremental encoders for obtaining mechanical position data. Quadrature encoders, also known as incremental encoders or optical encoders, detect position and speed of rotating motion systems. Quadrature encoders enable closed-loop control of motor control applications, such as Switched Reluctance (SR) and AC Induction Motors (ACIM).

A typical quadrature encoder includes a slotted wheel attached to the shaft of the motor and an Emitter/Detector module that senses the slots in the wheel. Typically, three output channels, Phase A (QEA), Phase B (QEB) and Index (INDX) provide information on the movement of the motor shaft, including distance and direction.

The two channels, Phase A (QEA) and Phase B (QEB), are typically 90 degrees out of phase with respect to each other. The Phase A and Phase B channels have a unique relationship. If Phase A leads Phase B, the direction of the motor is deemed positive or forward. If Phase A lags Phase B, the direction of the motor is deemed negative or reverse. The Index pulse occurs once per mechanical revolution and is used as a reference to indicate an absolute position. Figure 43-1 illustrates the quadrature encoder interface signals.

The quadrature signals from the encoder can have four unique states (01, 00, 10, and 11) that reflect the relationship between QEA and QEB. Figure 43-1 illustrates these states for one count cycle. The order of the states get reversed when the direction of travel changes.

The quadrature decoder increments or decrements the 32-bit Up/Down Position Counter (POSxCNT) for each change of state. The counter increments when QEA leads QEB and decrements when QEB leads QEA.



Figure 43-1: Quadrature Encoder Interface Signals

Table 43-1 provides the truth table that describes how the quadrature signals are decoded.

Table 43-1: Truth Table for Quadrature Encoder

| Current Qua | drature State | Previous Qua | drature State | Action                       |
|-------------|---------------|--------------|---------------|------------------------------|
| QA          | QB            | QA           | QB            |                              |
| 1           | 1             | 1            | 1             | No count or direction change |
| 1           | 1             | 1            | 0             | Count up                     |
| 1           | 1             | 0            | 1             | Count down                   |
| 1           | 1             | 0            | 0             | Invalid state change; ignore |
| 1           | 0             | 1            | 1             | Count down                   |
| 1           | 0             | 1            | 0             | No count or direction change |
| 1           | 0             | 0            | 1             | Invalid state change; ignore |
| 1           | 0             | 0            | 0             | Count up                     |
| 0           | 1             | 1            | 1             | Count up                     |
| 0           | 1             | 1            | 0             | Invalid state change; ignore |
| 0           | 1             | 0            | 1             | No count or direction change |
| 0           | 1             | 0            | 0             | Count down                   |
| 0           | 0             | 1            | 1             | Invalid state change; ignore |
| 0           | 0             | 1            | 0             | Count down                   |
| 0           | 0             | 0            | 1             | Count up                     |
| 0           | 0             | 0            | 0             | No count or direction change |

Figure 43-2 illustrates the simplified block diagram of the QEI module. The QEI module consists of decoder logic to interpret the Phase A (QEA) and Phase B (QEB) signals, and an up/down counter to accumulate the count. The counter pulses are generated when the quadrature state changes. The count direction information must be maintained in a register until a direction change is detected. The module also includes digital noise filters, which condition the input signal.

The QEI module consists of the following key features:

- Four input pins: two phase signals, an index pulse, and a home pulse
- · Programmable digital noise filters on inputs
- · Quadrature decoder providing counter pulses and count direction
- · Count direction status
- 4x count resolution
- Index (INDX) pulse to reset the position counter
- General purpose 32-bit Timer/Counter mode
- · Interrupts generated by QEI or counter events
- · 32-bit velocity counter
- · 32-bit position counter
- · 32-bit index pulse counter
- · 32-bit interval timer
- · 32-bit position Initialization/Capture register
- · 32-bit Compare Less Than and Greater Than registers
- External Up/Down Count mode
- · External Gated Count mode
- · External Gated Timer mode
- · Interval Timer mode



PIC32 Family Reference Manual

## 43.2 CONTROL AND STATUS REGISTERS

The following registers are associated with the QEI module:

QEIxCON: QEIx Control Register

This register controls the QEI module operation.

QEIxIOC: QEIx I/O Control Register

This register controls the input/output mode of the QEI module.

QEIxSTAT: QEIx Status Register

This register provides the interrupt enable flag and status flag to indicate the status of the QEI module.

POSxCNT: Position Counter Register

This register contains the position counter.

POSxHLD: Position Counter Hold Register

**Note:** The Position Counter Hold register is not used in 32-bit devices. This register is provided to maintain uniformity with 16-bit architecture.

This register holds the contents of the POSxCNT register during read or write operations.

VELxCNT: Velocity Counter Register

This register stores the velocity value.

VELxHLD: Velocity Counter Hold Register

**Note:** The Velocity Counter Hold register is not used in 32-bit devices. This register is provided to maintain uniformity with 16-bit architecture.

This register holds the contents of the VELxCNT register during read or write operations.

INDXxCNT: Index Counter Register

This register contains the index counter.

INDXxHLD: Index Counter Hold Register

**Note:** The Index Counter Hold register is not used in 32-bit devices. This register is provided to maintain uniformity with 16-bit architecture.

This register holds the contents of the INDXxCNT register during read or write operations.

INTxTMR: Interval Timer Register

This register holds the Counter Pulse Interval Timer value.

· INTxHLD: Interval Timer Hold Register

This register holds the contents of the Interval Timer Hold register during read and write operations.

QEIxCMPL: Compare Low Register

This register contains low side compare value for the POSxCNT register.

QEIxICC: Initialization/Capture/Compare High Register

This register contains initialization, capture, and high side compare values for the POSxCNT register.

Table 43-2 provides a brief summary of the related Oscillator module registers. Corresponding registers appear after the summaries, followed by a detailed description of each register.

Table 43-2: QEI Module SFR Summary

| Register<br>Name <sup>(1)</sup> | Bit<br>Range | Bit 31/15 | Bit 30/14    | Bit 29/13 | Bit 28/12  | Bit 27/11  | Bit 26/10 | Bit 25/9 | Bit 24/8 | Bit 23/7 | Bit 22/6 | Bit 21/5   | Bit 20/4 | Bit 19/3 | Bit 18/2 | Bit 17/1 | Bit 16/0 |
|---------------------------------|--------------|-----------|--------------|-----------|------------|------------|-----------|----------|----------|----------|----------|------------|----------|----------|----------|----------|----------|
| QEIxCON                         | 31:16        | _         | _            | _         | _          | _          | _         | _        | _        | _        | _        | _          | _        | -        | _        | _        | _        |
|                                 | 15:0         | QEIIEN    | _            | QEISIDL   |            | PIMOD<2:0> |           | IMV<     | (1:0>    | _        |          | INTDIV<2:0 | >        | CNTPOL   | GATEN    | CCM      | <1:0>    |
| QEIxIOC                         | 31:16        | _         | _            | _         | _          | _          | _         | _        | _        | _        | _        | _          | _        | -        | _        | _        | HCAPEN   |
|                                 | 15:0         | QCAPEN    | FLTREN       | (         | QFDIV<2:0> |            | OUTFN     | IC<1:0>  | SWPAB    | HOMPOL   | IDXPOL   | QEBPOL     | QEAPOL   | HOME     | INDEX    | QEB      | QEA      |
| QEIxSTAT                        | 31:16        | _         | _            | _         | _          | _          | _         | _        | _        | _        | _        | _          | _        | _        | _        | _        | _        |
|                                 | 15:0         | _         | _            | PCHEQIRQ  | PCHEQIEN   | PCLEQIRQ   | PCLEQIEN  | POSOVIRQ | POSOVIEN | PCIIRQ   | PCIIEN   | VELOVIRQ   | VELOVIEN | HOMIRQ   | HOMIEN   | IDXIRQ   | IDXIEN   |
| POSxCNT                         | 31:16        |           |              |           |            |            |           |          | POSCNT<  | :31:16>  |          |            |          |          |          |          |          |
|                                 | 15:0         |           |              |           |            |            |           |          | POSCNT   | <15:0>   |          |            |          |          |          |          |          |
| POSxHLD <sup>(2)</sup>          | 31:16        |           |              |           |            |            |           |          | POSHLD<  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 15:0         |           |              |           |            |            |           |          | POSHLD   | <15:0>   |          |            |          |          |          |          |          |
| VELxCNT                         | 31:16        |           |              |           |            |            |           |          | VELCNT<  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 15:0         |           |              |           |            |            |           |          | VELCNT-  | <15:0>   |          |            |          |          |          |          |          |
| VELxHLD <sup>(2)</sup>          | 31:24        |           |              |           |            |            |           |          | VELHLD<  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 23:16        |           |              |           |            |            |           |          | VELHLD-  | <15:0>   |          |            |          |          |          |          |          |
| INDXxCNT                        | 31:24        |           |              |           |            |            |           |          | INDXCNT  | <31:16>  |          |            |          |          |          |          |          |
|                                 | 23:16        |           |              |           |            |            |           |          | INDXCNT  | <15:0>   |          |            |          |          |          |          |          |
| INDXxHLD <sup>(2)</sup>         | 31:24        |           |              |           |            |            |           |          | INDXHLD  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 23:16        |           |              |           |            |            |           |          | INDXHLD  | <15:0>   |          |            |          |          |          |          |          |
| INTxTMR                         | 31:24        |           |              |           |            |            |           |          | INTTMR<  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 23:16        |           |              |           |            |            |           |          | INTTMR   | <15:0>   |          |            |          |          |          |          |          |
| INTxHLD                         | 31:24        |           |              |           |            |            |           |          | INTHLD<  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 23:16        |           | INTHLD<15:0> |           |            |            |           |          |          |          |          |            |          |          |          |          |          |
| QEIxCMPL                        | 31:24        |           |              |           |            |            |           |          | QEICMPL- | <31:16>  |          |            |          |          |          |          |          |
|                                 | 23:16        |           |              |           |            |            |           |          | QEICMPL  | <15:0>   |          |            |          |          |          |          |          |
| QEIxICC                         | 31:24        |           |              |           |            |            |           |          | QEIICC<  | 31:16>   |          |            |          |          |          |          |          |
|                                 | 23:16        |           | QEIICC<15:0> |           |            |            |           |          |          |          |          |            |          |          |          |          |          |

PIC32 Family Reference Manual

Note 1: With the exception of those noted, all registers have an associated Clear, Set, and Invert register at an offset of 0x4, 0x8, and 0xC bytes, respectively. These registers have the same name, with CLR, SET, or INV appended to the end of the register name (e.g., QEIxCONCLR). Writing a '1' to any bit position in these registers will clear, set, or invert valid bits in the associated register. Reads from the these registers should be ignored.

<sup>2:</sup> This register, which has no Clear, Set, or Invert registers, is not used in 32-bit devices. It is provided to maintain uniformity with 16-bit architecture.

Register 43-1: QEIxCON: QEIx Control Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| 24.24        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31:24        |                   | _                 | -                 | _                 | _                 | -                 | -                | _                |
| 00:40        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 23:16        | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
| 45.0         | R/W-0             | U-0               | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |
| 15:8         | QEIEN             | _                 | QEISIDL           |                   | PIMOD<2:0         | >                 | IMV<1:0>         |                  |
| 7:0          | U-0               | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |
|              | _                 |                   | INTDIV<2:0>       |                   | CNTPOL            | GATEN             | CCM-             | <1:0>            |

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'
-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-16 Unimplemented: Read as '0'

Legend:

bit 15 QEIEN: Quadrature Encoder Interface Module Enable bit

1 = QEI module is enabled

0 = QEI module is disabled; however, SFRs can be read or written

bit 14 **Unimplemented:** Read as '0'

bit 13 QEISIDL: Stop in Idle Mode bit

1 = Discontinue module operation when device enters Idle mode

0 = Continue module operation in Idle mode

bit 12-10 PIMOD<2:0>: Position Counter Initialization Mode Select bits

111 = Modulo Count mode for position counter and every index event resets the position counter

110 = Modulo Count mode for position counter

101 = Resets the position counter when the position counter equals QEIxICC register

100 = Second index event after home event initializes position counter with the contents of the QEIxICC register

011 = First index event after home event initializes position counter with the contents of the QEIxICC register

010 = Next index input event initializes the position counter with contents of QEIxICC register

001 = Every Index input event resets the position counter

000 = Index input event does not affect position counter

bit 9-8 **IMV<1:0>:** Index Match Value bits

11 = Index match occurs when QEB = 1 and QEA = 1

10 = Index match occurs when QEB = 1 and QEA = 0

01 = Index match occurs when QEB = 0 and QEA = 1

00 = Index match occurs when QEB = 0 and QEA = 0

bit 7 Unimplemented: Read as '0'

bit 6-4 **INTDIV<2:0>:** Timer Input Clock Prescale Select bits (Interval timer, Main timer (position counter), velocity counter and index counter internal clock divider select)

111 = 1:128 prescale value

110 = 1:64 prescale value

101 = 1:32 prescale value

100 = 1:16 prescale value

011 = 1:8 prescale value

010 = 1:4 prescale value

001 = 1:2 prescale value

000 = 1:1 prescale value

# **PIC32 Family Reference Manual**

### Register 43-1: QEIxCON: QEIx Control Register (Continued)

- bit 3 CNTPOL: Position, Velocity, and Index Counter/Timer Direction Select bit
  - 1 = Counter direction is negative unless modified by external Up/Down signal
  - 0 = Counter direction is positive unless modified by external Up/Down signal
- bit 2 GATEN: External Count Gate Enable bit
  - 1 = External gate signal controls position counter/timer operation
  - 0 = External gate signal does not affect position counter/timer operation
- bit 1-0 **CCM<1:0>:** Counter Control Mode Selection bits
  - 11 = Internal Timer with external Gate mode
  - 10 = External clock count with external Gate mode
  - 01 = External clock count with external Up/Down mode
  - 00 = Quadrature Encoder mode

Register 43-2: QEIxIOC: QEIx I/O Control Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| 04:04        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31:24        | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
| 00:40        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | R/W-0            |
| 23:16        | _                 | _                 | _                 | _                 | _                 | _                 | _                | HCAPEN           |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |
| 15:8         | QCAPEN            | FLTREN            |                   | QFDIV<2:0>        |                   | OUTFN             | C<1:0>           | SWPAB            |
| 7.0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R-x               | R-x               | R-x              | R-x              |
| 7:0          | HOMPOL            | IDXPOL            | QEBPOL            | QEAPOL            | HOME              | INDEX             | QEB              | QEA              |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-16 Unimplemented: Read as '0'

bit 16 HCAPEN: Position Counter Input Capture by Home Event Enable bit

1 = HOMEx input event (positive edge) triggers a position capture event

0 = HOMEx input event (positive edge) does not trigger a position capture event

bit 15 QCAPEN: Position Counter Input Capture by Index Event Enable bit

1 = Index match event (positive edge) triggers a position capture event

0 = Index match event (positive edge) does not trigger a position capture event

bit 14 FLTREN: QEA/QEB/INDX/HOMEx Digital Filter Enable bit

1 = Input Pin Digital filter is enabled

0 = Input Pin Digital filter is disabled (bypassed)

bit 13-11 QFDIV<2:0>: QEA/QEB/INDX/HOMEx Digital Input Filter Clock Select bits

111 = 1:128 clock divide

110 = 1:64 clock divide

101 = 1:32 clock divide

100 = 1:16 clock divide

011 = 1:8 clock divide

010 = 1:4 clock divide

001 = 1:2 clock divide

000 = 1:1 clock divide

bit 10-9 OUTFNC<1:0>: QEI Module Output Function Mode Select bits

11 = The CNTCMPx pin goes high when POSxCNT ≤ QEIxCMPL or POSxCNT ≥ QEIxICC

10 = The CNTCMPx pin goes high when POSxCNT ≤ QEIxCMPL

01 = The CNTCMPx pin goes high when POSxCNT ≥ QEIxICC

00 = Output is disabled

bit 8 SWPAB: Swap QEA and QEB Inputs bit

1 = QEAx and QEBx are swapped prior to quadrature decoder logic

0 = QEAx and QEBx are not swapped

bit 7 HOMPOL: HOMEx Input Polarity Select bit

1 = Input is inverted

0 = Input is not inverted

bit 6 IDXPOL: INDXx Input Polarity Select bit

1 = Input is inverted

0 = Input is not inverted

bit 5 QEBPOL: QEBx Input Polarity Select bit

1 = Input is inverted

0 = Input is not inverted

#### Register 43-2: QEIxIOC: QEIx I/O Control Register (Continued)

```
bit 4
           QEAPOL: QEAx Input Polarity Select bit
           1 = Input is inverted
           0 = Input is not inverted
bit 3
          HOME: Status of HOMEx Input Pin after Polarity Control bit (read-only)
           1 = Pin is at logic '1', if HOMPOL bit is set to '0'
               Pin is at logic '0', if HOMPOL bit is set to '1'
           0 = Pin is at logic '0', if HOMPOL bit is set to '0'
               Pin is at logic '1', if HOMPOL bit is set to '1'
bit 2
          INDEX: Status of INDXx Input Pin after Polarity Control bit (Read-Only)
           1 = Pin is at logic '1', if IDXPOL bit is set to '0'
               Pin is at logic '0', if IDXPOL bit is set to '1'
           0 = Pin is at logic '0', if IDXPOL bit is set to '0'
               Pin is at logic '1', if IDXPOL bit is set to '1'
bit 1
           QEB: Status of QEBx Input Pin after Polarity Control and SWPAB Pin Swapping bit (read-only)
           1 = Physical pin QEB is at logic '1', if QEBPOL bit is set to '0' and SWPAB bit is set to '0'
               Physical pin QEB is at logic '0', if QEBPOL bit is set to '1' and SWPAB bit is set to '0'
               Physical pin QEA is at logic '1', if QEBPOL bit is set to '0' and SWPAB bit is set to '1'
               Physical pin QEA is at logic '0', if QEBPOL bit is set to '1' and SWPAB bit is set to '1'
           0 = Physical pin QEB is at logic '0', if QEBPOL bit is set to '0' and SWPAB bit is set to '0'
               Physical pin QEB is at logic '1', if QEBPOL bit is set to '1' and SWPAB bit is set to '0'
               Physical pin QEA is at logic '0', if QEBPOL bit is set to '0' and SWPAB bit is set to '1'
               Physical pin QEA is at logic '1', if QEBPOL bit is set to '1' and SWPAB bit is set to '1'
bit 0
           QEA: Status of QEAx Input Pin after Polarity Control and SWPAB Pin Swapping bit (read-only)
           1 = Physical pin QEA is at logic '1', if QEAPOL bit is set to '0' and SWPAB bit is set to '0'
               Physical pin QEA is at logic '0', if QEAPOL bit is set to '1' and SWPAB bit is set to '0'
               Physical pin QEB is at logic '1', if QEAPOL bit is set to '0' and SWPAB bit is set to '1'
               Physical pin QEB is at logic '0', if QEAPOL bit is set to '1' and SWPAB bit is set to '1'
           0 = Physical pin QEA is at logic '0', if QEAPOL bit is set to '0' and SWPAB bit is set to '0'
               Physical pin QEA is at logic '1', if QEAPOL bit is set to '1' and SWPAB bit is set to '0'
               Physical pin QEB is at logic '0', if QEAPOL bit is set to '0' and SWPAB bit is set to '1'
               Physical pin QEB is at logic '1', if QEAPOL bit is set to '1' and SWPAB bit is set to '1'
```

Register 43-3: QEIxSTAT: QEIx Status Register

| Bit<br>Range | Bit<br>31/23/15/7     | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------|-----------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| 24.24        | U-0                   | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31:24        | _                     | _                 |                   | _                 | _                 |                   | _                | _                |
| 00.40        | U-0                   | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 23:16        | _                     | -                 |                   | _                 |                   |                   | _                | _                |
| 45.0         | U-0                   | U-0               | HS, R/C-0         | R/W-0             | HS, R/C-0         | R/W-0             | HS, R/C-0        | R/W-0            |
| 15:8         | _                     | _                 | PCHEQIRQ          | PCHEQIEN          | PCLEQIRQ          | PCLEQIEN          | POSOVIRQ         | POSOVIEN         |
| 7.0          | HS, R/C-0             | R/W-0             | HS, R/C-0         | R/W-0             | HS, R/C-0         | R/W-0             | HS, R/C-0        | R/W-0            |
| 7:0          | PCIIRQ <sup>(1)</sup> | PCIIEN            | VELOVIRQ          | VELOVIEN          | HOMIRQ            | HOMIEN            | IDXIRQ           | IDXIEN           |

**Legend:** HS = Hardware Settable C = Clearable bit

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-14 Unimplemented: Read as '0'

bit 12

bit 13 PCHEQIRQ: Position Counter Greater Than Compare Status bit

1 = POSxCNT > QEIxICC

0 = POSxCNT ≤ QEIxICC

PCHEQIEN: Position Counter Greater Than Compare Interrupt Enable bit

1 = Interrupt is enabled0 = Interrupt is disabled

bit 11 PCLEQIRQ: Position Counter Less Than Compare Status bit

1 = POSxCNT < QEIxCMPL 0 = POSxCNT > QEIxCMPL

bit 10 PCLEQIEN: Position Counter Less Than or Equal Compare Interrupt Enable bit

1 = Interrupt is enabled0 = Interrupt is disabled

bit 9 **POSOVIRQ:** Position Counter Overflow Status bit

1 = Overflow has occurred0 = Overflow has not occurred

bit 8 **POSOVIEN:** Position Counter Overflow Interrupt Enable bit

1 = Interrupt is enabled0 = Interrupt is disabled

bit 7 **PCIIRQ:** Position Counter (Homing) Initialization Process Complete Status bit<sup>(1)</sup>

1 = POSxCNT was reinitialized0 = POSxCNT was not reinitialized

bit 6 PCIIEN: Position Counter (Homing) Initialization Process Complete Interrupt Enable bit

1 = Interrupt is enabled0 = Interrupt is disabled

bit 5 **VELOVIRQ:** Velocity Counter Overflow Status bit

1 = Overflow has occurred0 = Overflow has not occurred

bit 4 **VELOVIEN:** Velocity Counter Overflow Interrupt Enable bit

1 = Interrupt is enabled0 = Interrupt is disabled

**Note 1:** This status bit is only applicable to PIMOD<2:0> modes '011' and '100'.

# **PIC32 Family Reference Manual**

## Register 43-3: QEIxSTAT: QEIx Status Register (Continued)

bit 3 **HOMIRQ:** Status Flag for Home Event Status bit

1 = Home event has occurred

0 = Home event has not occurred

bit 2 **HOMIEN:** Home Input Event Interrupt Enable bit

1 = Interrupt is enabled

0 = Interrupt is disabled

bit 1 IDXIRQ: Status Flag for Index Event Status bit

1 = Index event has occurred0 = Index event has not occurred

IDXIEN: Index Input Event Interrupt Enable bit

1 = Interrupt is enabled

bit 0

0 = Interrupt is disabled

**Note 1:** This status bit is only applicable to PIMOD<2:0> modes '011' and '100'.

Register 43-4: POSxCNT: Position Counter Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 21.24        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 31:24        | POSCNT<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 00.46        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 23:16        | POSCNT<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 15:8         | POSCNT<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7.0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 7:0          |                   |                   |                   | POSCN             | IT<7:0>           |                   |                  |                  |  |  |  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 POSCNT<31:0>: Position Counter Value

Register 43-5: POSxHLD: Position Counter Hold Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 21.24        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 31:24        | POSHLD<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 00.46        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 23:16        | POSHLD<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 15:8         | POSHLD<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7.0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 7:0          |                   | POSHLD<7:0>       |                   |                   |                   |                   |                  |                  |  |  |  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 **POSHLD<31:0>:** Hold register for reading and writing the Position Counter register (POSxCNT)

Register 43-6: VELxCNT: Velocity Counter Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 24.24        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 31:24        | VELCNT<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 00.40        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 23:16        | VELCNT<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 15:8         | VELCNT<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
|              |                   |                   |                   | VELCN             | T<7:0>            |                   |                  |                  |  |  |  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 **VELCNT<31:0>:** Velocity Counter Value bits

Register 43-7: VELxHLD: Velocity Counter Hold Register

|              | ı                 |                   | <u> </u>          |                   |                   |                   |                  | 1                |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
| 24.04        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 31:24        | VELHLD<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 22.40        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 23:16        | VELHLD<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 15:8         | VELHLD<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
|              |                   |                   |                   | VELHL             | D<7:0>            |                   |                  |                  |  |  |  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 **VELHLD<31:0>:** Velocity Counter Hold Value bits

Register 43-8: INDXxCNT: Index Counter Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 24.24        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 31:24        | INDXCNT<31:24>    |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 22.46        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 23:16        | INDXCNT<23:16>    |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 15:8         | INDXCNT<15:8>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
|              |                   | INDXCNT<7:0>      |                   |                   |                   |                   |                  |                  |  |  |  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 INDXCNT<31:0>: Index Counter Value bits

Register 43-9: INDXxHLD: Index Counter Hold Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 24.04        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 31:24        | INDXHLD<31:24>    |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 00.40        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 23:16        | INDXHLD<23:16>    |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 45.0         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
| 15:8         | INDXHLD<15:8>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |
|              |                   | INDXHLD<7:0>      |                   |                   |                   |                   |                  |                  |  |  |  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 INDXHLD<31:0>: Hold register for reading and writing the Index Counter Word register (INDXxCNT)

# **PIC32 Family Reference Manual**

## Register 43-10: INTxTMR: Interval Timer Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|
| 31:24        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTTMR<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |
| 00:40        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
| 23:16        | INTTMR<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |
| 15:8         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTTMR<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTTMR<7:0>       |                   |                   |                   |                   |                   |                  |                  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 INTTMR<31:0>: Interval Timer Value bits

## Register 43-11: INTxHLD: Interval Timer Hold Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|
| 31:24        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTHLD<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |
| 23:16        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTHLD<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |
| 15:8         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTHLD<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | INTHLD<7:0>       |                   |                   |                   |                   |                   |                  |                  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 **INTHLD<31:0>:** Words used to form the Interval Timer Hold register (INTxHLD)

Register 43-12: QEIxCMPL: Compare Low Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|
| 04:04        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
| 31:24        | QEICMPL<31:24>    |                   |                   |                   |                   |                   |                  |                  |  |
| 00:40        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
| 23:16        | QEICMPL<23:16>    |                   |                   |                   |                   |                   |                  |                  |  |
| 15:8         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | QEICMPL<15:8>     |                   |                   |                   |                   |                   |                  |                  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | QEICMPL<7:0>      |                   |                   |                   |                   |                   |                  |                  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 **QEICMPL<31:0>:** Low Side Compare value for the POSxCNT register.

Register 43-13: QEIxICC: Initialization/Capture/Compare High Register

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|
| 04.04        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
| 31:24        | QEIICC<31:24>     |                   |                   |                   |                   |                   |                  |                  |  |
| 00:40        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
| 23:16        | QEIICC<23:16>     |                   |                   |                   |                   |                   |                  |                  |  |
| 15:8         | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | QEIICC<15:8>      |                   |                   |                   |                   |                   |                  |                  |  |
| 7:0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |
|              | QEIICC<7:0>       |                   |                   |                   |                   |                   |                  |                  |  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown

bit 31-0 QEIICC<31:0>: Initialize/Capture/Compare High bits

## 43.3 MODULE DESCRIPTION

#### 43.3.1 Position Counter

The position counter is 32 bits wide and is contained in the POSxCNT register. The counter counts the number of pulses generated by an encoder.

If the POSOVIEN bit (QEIxSTAT<8>) is set, and the position counter rolls over from 0x7FFFFFF to 0x80000000, or from 0x80000000 to 0x7FFFFFF, an interrupt will be generated.

The operating mode of the position counter is controlled by the CCM<1:0> bits (QEIxCON<1:0>). The position counter supports the following operating modes:

- Quadrature Count Mode
- External Count with External Up/Down Mode
- External Count with External Gate Mode
- Internal Timer with External Gate Mode

#### 43.3.1.1 QUADRATURE COUNT MODE

In this mode, the QEA/EXTCNT and QEB/DIR/GATE inputs are decoded to generate count pulses and direction information to control the POSxCNT and VELxCNT registers. The INDXxCNT register counts when a valid edge is detected on INDX input. Figure 43-1 illustrates the timing diagram of the Quadrature Count mode operation.

### 43.3.1.2 EXTERNAL COUNT WITH EXTERNAL UP/DOWN MODE

In this mode, the QEA/EXTCNT input is considered as an external count signal, and the QEB/DIR/GATE input provides the count direction information. The count direction is positive unless overridden by the CNTPOL bit (QEIxCON<3>). Figure 43-3 illustrates the timing diagram of an External Count with External Up/Down mode operation.



#### 43.3.1.3 EXTERNAL COUNT WITH EXTERNAL GATE MODE

In this mode, the QEA/EXTCNT input is considered as an external count signal. If the GATEN bit (QEIxCON<2>) is set, and QEB/DIR/GATE = 0, the QEB/DIR/GATE input will inhibit the counter signal. If the GATEN bit is cleared, the gate signal does not affect the counter operation. The default count direction is positive. If the CNTPOL bit (QEIxCON<3>) is set, the count direction is negative. Figure 43-4 illustrates the timing diagram of an External Count with External Gate mode operation.



Figure 43-4: External Count with External Gate Mode

#### 43.3.1.4 INTERNAL TIMER WITH EXTERNAL GATE MODE

In this mode, the velocity, index and interval counter of the position counter uses an internal clock as the count source. The internal clock is divided by the clock divider using the INTDIV<2:0> bits (QEIxCON<6:4>). If the GATEN bit (QEIxCON<2>) is set, and QEB/DIR/GATE = 0, the QEB/DIR/GATE input will inhibit the counter signal. If the GATEN bit is cleared, the gate signal does not affect the operation of the counter. The default count direction is positive. If the CNTPOL bit (QEIxCON<3>) is set, the count direction is negative. Figure 43-5 illustrates the timing diagram of an Internal Timer mode operation.



## 43.3.2 Velocity Counter

The 32-bit wide Velocity Counter (VELxCNT) register increments or decrements based on the signal from the quadrature decoder logic. Reading this register resets the register. The index input or any of the modes specified by the PIMOD<2:0> bits (QEIxCON<12:10>) does not affect the operation of the velocity counter. If the velocity counter rolls over from 0x7FFFFFFF to 0x80000000, or from 0x80000000 to 0x7FFFFFFF, and the VELOVIEN bit (QEIxSTAT<4>) is set, an interrupt will be generated. Figure 43-6 illustrates the timing diagram of the Velocity Counter operation.

**Note:** The velocity counter specifies the distance traveled between the time interval of each sample. Reading the VELxCNT register results in counter reset. The user application should read the velocity counter at a rate of 1 kHz to 4 kHz.



#### 43.3.3 Index Counter

The 32-bit wide Index Counter (INDXxCNT) register counts index events. It is incremented or decremented based on the direction output of the quadrature logic decoder (see Figure 43-2). For more information, refer to 43.3.7 "Index Event".

#### 43.3.4 Interval Timer

When a motor runs at a very low speed, the encoder does not generate enough pulses for accurate speed measurement. Therefore, instead of counting the number of pulses, the pulse duration can be measured. The 32-bit Interval Timer (INTxTMR) register is used to measure the time interval between each decoded quadrature count pulse when the motor operates at a very low speed. The timer counts at a rate specified by the INTDIV<2:0> bits (QEIxCON<6:4>). The interval timer is cleared when the first count pulse is detected. When the next count pulse is detected, the current contents of the interval timer are transferred to the Interval Timer Hold (INTxHLD) register, the interval timer is cleared, and then the process repeats. The interval timer hold registers always contain the most recent completed timing measurements. Figure 43-7 illustrates the timing diagram of the Interval Timer operation.

**Note:** If the INTxHLD register is read when a new position count pulse is detected, the contents of the INTxHLD register are not updated to avoid incoherent data reading.



## 43.3.5 Initialization/Capture Register

The 32-bit general purpose Initialization/Capture (QEIxIC) register can be used to initialize the position counter and capture the contents of the position counter. The QEIxIC register can perform only one of these tasks at a time, but the mode of operation may be changed during operation. Typical application examples include:

- On power-up, the machine needs to orient itself to a known reference point. The QEIxIC register is loaded with the "home" position. The position counter is configured via the PIMOD bits to initialize the position counter on the first index event following a home event. The home and index events occur and the contents of the QEIxIC register are loaded into the Position Counter (POSxCNT) register.
- A user connects a "Touch Probe" to the machine via the "HOME" input to measure a
  previously machined item. The machine scans the item in a pattern, constantly moving the
  machine until a probe contact occurs. The probe contact causes the QEIxIC register to capture the position. The position information is then relayed to another computer for analysis.



© 2015-2019 Microchip Technology Inc.

## 43.3.6 Position Comparator

The QEIxCMPL and QEIxICC registers and the associated comparator provide the ability to compare the contents of the Position Counter (POSxCNT) register to a specified value. The comparator provides two outputs: equality detect, and less than or greater than detect. The comparator equality output can be enabled to generate interrupts via the PCLEQIEN bit (QEIxSTAT<10>). The less than or equal, or greater than or equal output can be output on a device pin. The selection is made by setting the OUTFNC<1:0> bits (QEIxIOC<10:9>). The comparator output can be used to detect an illegal move operation by an end user and the comparator output can be connected to appropriate external circuitry to prevent the illegal move.

Sometimes, the potential for costly damage to a part, or a machine due to an operator, programming, or a machine failure is too much to accept. The QEIxCMPL and QEIxICC registers can be configured to define a bounds of travel beyond which a Fault is generated. The values in these registers are continually compared to the position counter. The comparator output can be directed to a device pin. This Fault detected signal can be used to shut down the machine operation to prevent damage or injury.

The comparator can also be used to reset the position counter when a match is detected.

Figure 43-8, on the previous page, illustrates the index reset position counter operation.

#### 43.3.7 Index Event

The IMV<1:0> bits (QEIxCON<9:8>) specify the state of the QEA and QEB input signals required to acknowledge an index event. An index event is accepted when an index pulse occurs while the value of the QEA and QEB inputs match the condition set in the IMV<1:0> bits. This prevents further index events from being accepted until the index input signal is deasserted, and ensures that only one index event occurs for each index input pulse. Figure 43-8, on the previous page, illustrates the index reset position counter operation.

#### 43.3.8 Position Counter Initialization Modes

By using the PIMOD<2:0> bits (QEIxCON<12:10>), the user application can specify how the position counter is initialized during the module operation.

- Mode 0 The position counter is unaffected by the index input.
- Mode 1 The position counter is cleared whenever an index input event is detected.
- Mode 2 The position counter is initialized with the contents of the QEIxICC register on the
  next detected index input event. When the index event occurs, the PIMOD<2:0> bits are
  cleared, and then the counter operates in Mode 0.
- Mode 3 The position counter is initialized with the contents of the QEIxICC register on the
  next detected index input event following the assertion of the home input. When an index
  event occurs following the home event, the PIMOD<2:0> bits are cleared, and then the
  counter operates in Mode 0.
- Mode 4 The position counter is initialized with the contents of the QEIxICC register on the second detected index input event following the assertion of the home input. When the second index event occurs following the home event, the PIMOD<2:0> bits are cleared, and then the counter operates in Mode 0.
- Mode 5 The position counter is cleared when the position counter value equals the QEIxICC register value.
- Mode 6 The position counter is loaded with the contents of the QEIxCMPL register when
  the position counter value equals the QEIxICC register value and a count up pulse is
  detected. The counter is loaded with the contents of the QEIxICC register when the
  position counter value equals the QEIxCMPL register value and a count down pulse is
  detected.
- Mode 7 Same as mode 6, with the additional feature of the position counter being cleared whenever an index input event is detected

## 43.3.9 Digital Input Filter

The QEI module uses digital noise filters to reject noise on the incoming index and quadrature phase signals. These filters reject low-level noise and large, short duration noise spikes that typically occur in motor systems.

The filtered output signals can change only after an input level has the same value for three consecutive rising clock edges. The result is that short noise spikes between rising clock edges are ignored, and pulses shorter than two clock periods are rejected.

The filter clocks rate determines the low passband of the filter. A slower filter clock results in a passband rejecting lower frequencies.

The digital filter is enabled by setting the FLTREN bit (QEIxIOC<14>). The QFDIV<2:0> bits (QEIxIOC<13:11>) select the filter clock divider ratio for the clock signal.

Figure 43-9 illustrates the simplified block diagram of the digital noise filter.

Figure 43-9: Block Diagram of Digital Noise Filter



#### 43.3.10 Interrupts

The following are the sources of QEI interrupts:

- · Position counter overflow or underflow event
- Velocity counter overflow or underflow event
- · Position counter initialization process complete
- · Position counter greater than or equal compare interrupt
- · Position counter less than or equal compare interrupt
- · Index event interrupt
- · Home event interrupt

The QEIx Status (QEIxSTAT) register contains the individual interrupt enable bits and the corresponding interrupt status bits for each interrupt source. A status bit indicates that an interrupt request has occurred. The module reduces all of the QEI interrupts to a single interrupt signal to the interrupt controller module.

## 43.4 QEI OPERATION IN POWER-SAVING MODES

## 43.4.1 Sleep Mode

When the device enters Sleep mode, QEI operations cease. The POSxCNT register stops at the current value. The QEI does not respond to active signals on the QEA, QEB or INDX pins. The QEIxCON register remains unchanged.

#### 43.4.2 Idle Mode

When the device enters Idle mode, the QEISIDL bit (QEIxCON<13>) determines whether the QEI module stops in Idle mode or continues to operate in Idle mode.

If QEISIDL = 1, the QEI module enters into a power-saving mode and performs the same functions as in Sleep mode. If QEISIDL = 0, the module does not enter into a power-saving mode and continues operation in Idle mode.

### 43.5 EFFECTS OF A RESET

A Reset forces module registers to their initial Reset state.

### 43.6 RELATED APPLICATION NOTES

This section lists application notes that are related to this section of the manual. These application notes may not be written specifically for the PIC32 device family, but the concepts are pertinent and could be used with modification and possible limitations. The current application notes related to the Quadrature Encoder Interface (QEI) module are:

Title Application Note #

No applications notes at this time

N/A

**Note:** Please visit the Microchip web site (www.microchip.com) for additional application notes and code examples for the PIC32 family of devices.

### 43.7 REVISION HISTORY

## **Revision A (June 2015)**

This is the initial released version of this document.

### **Revision B (October 2019)**

Figure 43-2: "Quadrature Encoder Interface (QEI) Module Block Diagram" was updated with new information.

Renamed the following registers:

- QEIxLEC Register was changed to Register 43-12: QEIxCMPL: Compare Low Register
- QEIxIC Register was changed to Register 43-13: QEIxICC: Initialization/Capture/Compare High Register

The bit definitions for the following bits were corrected:

- PCHEQIRQ: Position Counter Greater Than Compare Status bit
- PCLEQIRQ: Position Counter Less Than Compare Status bit

Removed notes that were not applicable to 32 bit devices from the following Registers:

- Register 43-5: POSxHLD: Position Counter Hold Register
- Register 43-7: VELxHLD: Velocity Counter Hold Register
- Register 43-8: INDXxCNT: Index Counter Register

The QEIxGEC register was removed.

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- · Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

#### **Trademarks**

The Microchip name and logo, the Microchip logo, Adaptec, AnyRate, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PackeTime, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TempTrackr, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, FlashTec, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, Vite, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, INICnet, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet Iogo, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified Iogo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, SAM-ICE, Serial Quad I/O, SMART-I.S., SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2015-2019, Microchip Technology Incorporated, All Rights Reserved.

ISBN: 978-1-5224-5158-7

For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality.



## **Worldwide Sales and Service**

#### **AMERICAS**

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199

Tel: 480-792-7200 Fax: 480-792-7277 Technical Support:

http://www.microchip.com/ support

Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614

Fax: 678-957-1455

Austin, TX Tel: 512-257-3370

**Boston**Westborough, MA
Tel: 774-760-0087
Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071

Fax: 630-285-0071

Fax: 630-285-0075

Dallas

Addison, TX
Tel: 972-818-7423
Fax: 972-818-2924

Detroit Novi, MI

Tel: 248-848-4000

Houston, TX Tel: 281-894-5983

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380

Tel: 317-536-2380 **Los Angeles** Mission Viejo, CA

Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800

**Raleigh, NC** Tel: 919-844-7510

New York, NY Tel: 631-435-6000

**San Jose, CA** Tel: 408-735-9110 Tel: 408-436-4270

**Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078

#### ASIA/PACIFIC

Australia - Sydney Tel: 61-2-9868-6733

**China - Beijing** Tel: 86-10-8569-7000

China - Chengdu Tel: 86-28-8665-5511

**China - Chongqing** Tel: 86-23-8980-9588

**China - Dongguan** Tel: 86-769-8702-9880

China - Guangzhou Tel: 86-20-8755-8029 China - Hangzhou

Tel: 86-571-8792-8115

China - Hong Kong SAR Tel: 852-2943-5100

**China - Nanjing** Tel: 86-25-8473-2460

China - Qingdao Tel: 86-532-8502-7355

**China - Shanghai** Tel: 86-21-3326-8000

**China - Shenyang** Tel: 86-24-2334-2829

**China - Shenzhen** Tel: 86-755-8864-2200

China - Suzhou Tel: 86-186-6233-1526

China - Wuhan

Tel: 86-27-5980-5300 China - Xian

Tel: 86-29-8833-7252 China - Xiamen

Tel: 86-592-2388138 China - Zhuhai

Tel: 86-756-3210040

#### ASIA/PACIFIC

India - Bangalore Tel: 91-80-3090-4444

India - New Delhi Tel: 91-11-4160-8631

India - Pune Tel: 91-20-4121-0141

Japan - Osaka

Tel: 81-6-6152-7160 Japan - Tokyo

Tel: 81-3-6880- 3770 Korea - Daegu

Tel: 82-53-744-4301 **Korea - Seoul** Tel: 82-2-554-7200

Malaysia - Kuala Lumpur Tel: 60-3-7651-7906

Malaysia - Penang Tel: 60-4-227-8870

Philippines - Manila Tel: 63-2-634-9065

**Singapore** Tel: 65-6334-8870

**Taiwan - Hsin Chu** Tel: 886-3-577-8366

Taiwan - Kaohsiung Tel: 886-7-213-7830

**Taiwan - Taipei** Tel: 886-2-2508-8600

**Thailand - Bangkok** Tel: 66-2-694-1351

Vietnam - Ho Chi Minh Tel: 84-28-5448-2100

#### **EUROPE**

**Austria - Wels** Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

Denmark - Copenhagen Tel: 45-4450-2828

Fax: 45-4485-2829
Finland - Espoo

Tel: 358-9-4520-820 France - Paris

Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Germany - Garching Tel: 49-8931-9700

**Germany - Haan** Tel: 49-2129-3766400

**Germany - Heilbronn** Tel: 49-7131-72400

Germany - Karlsruhe Tel: 49-721-625370

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Germany - Rosenheim** Tel: 49-8031-354-560

Israel - Ra'anana Tel: 972-9-744-7705

Italy - Milan

Tel: 39-0331-742611 Fax: 39-0331-466781

**Italy - Padova** Tel: 39-049-7625286

**Netherlands - Drunen** Tel: 31-416-690399 Fax: 31-416-690340

Norway - Trondheim Tel: 47-7288-4388

Poland - Warsaw Tel: 48-22-3325737

Romania - Bucharest Tel: 40-21-407-87-50

**Spain - Madrid**Tel: 34-91-708-08-90
Fax: 34-91-708-08-91 **Sweden - Gothenberg** 

Tel: 46-31-704-60-40

Sweden - Stockholm

Tel: 46-8-5090-4654

UK - Wokingham

Tel: 44-118-921-5800 Fax: 44-118-921-5820