## 32-bit RISC Microcontroller

# TXZ/TXZ+ Family

## Reference Manual Advanced Encoder Input Circuit (A-ENC-A)

**Revision 2.3** 

2022-05

## **TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION**

## Contents

| Preface                                                            | 5        |
|--------------------------------------------------------------------|----------|
| Related Documents                                                  | 5        |
| Conventions                                                        |          |
| Terms and Abbreviations                                            |          |
| 1. Outlines                                                        |          |
| 2. Configuration                                                   |          |
| 3. Function and Operation                                          |          |
| 3.1. Clock Supply                                                  |          |
| 3.2. Operation Mode                                                |          |
| 3.2.1. Encoder Mode                                                | 12       |
| 3.2.2. Sensor Mode                                                 |          |
| 3.2.2.1. Event Count                                               |          |
| 3.2.2.2. Timer Count                                               |          |
| 3.2.2.3. Phase Count                                               |          |
| 3.2.3. Timer Mode                                                  | 21       |
| 3.2.4. Phase Counter Mode                                          |          |
| 3.2.4.1. Phase Measurement                                         |          |
| 3.2.4.2. Phase Difference Measurement                              |          |
| 3.3. Function Description in Each Circuit                          |          |
| 3.3.1. Input Circuit                                               |          |
| 3.3.1.1. Sample Clock                                              |          |
| 3.3.1.2. Sampling Mode                                             |          |
| 3.3.1.3. Noise Cancelling                                          |          |
| 3.3.2. Decoder                                                     |          |
| 3.3.2.1. Rotational Edge Detection and Direction Signal Generation |          |
| 3.3.2.2. Z-input Detection Circuit                                 |          |
| 3.3.2.3. Skip Detection and Abnormal Input Detection               |          |
| 3.3.2.4. Edge Detection Error Detection                            |          |
| 3.3.2.5. Buffer Update Control                                     |          |
| 3.3.2.6. BEMF Detection Control                                    |          |
| 3.3.3. Counter                                                     |          |
| 3.3.3.1. Encoder Mode and Sensor Mode (Event Count)                | ود<br>عد |
| 3.3.3.2. Sensor Mode (Timer count) or Timer Mode                   |          |
| 3.3.4 Interrupt Control                                            | 38       |
| A Registers                                                        | 30       |
| 4. Registers                                                       | 20       |
| 4. 1. Register List                                                |          |
|                                                                    |          |
| 4.2.1. [EIXTINCK] (ENC Control Register)                           |          |
| 4.2.2. [EIVXKELUAD] (RELUAD Compare Register)                      |          |
|                                                                    |          |
| 4.2.4. [EIVXUIV1] (Counter Register)                               |          |

| 4.2.5. [ENxMCMP] (MCMP Compare Register)           | 46                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4.2.6. [ENxRATE] (Phase Count Rate Register)       | 46                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.7. [ENxSTS] (Status Register)                  | 47                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.8. [ENxINPCR] (Input Process Control Register) | 48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.9. [ENxSMPDLY] (Sample Delay Register)         | 49                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.10. [ENxINPMON] (Input Monitor Register)       | 49                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.11. [ENxCLKCR] (Sample Clock Control Register) | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.12. [ENxINTCR] (Interrupt Control Register)    | 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.2.13. [ENxINTF] (Interrupt Flag Register)        | 52                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Precaution for Usage                               | 53                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Revision History                                   | 54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| STRICTIONS ON PRODUCT USE                          | 59                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                    | <ul> <li>4.2.5. [ENxMCMP] (MCMP Compare Register)</li> <li>4.2.6. [ENxRATE] (Phase Count Rate Register)</li> <li>4.2.7. [ENxSTS] (Status Register)</li> <li>4.2.8. [ENxINPCR] (Input Process Control Register)</li> <li>4.2.9. [ENxSMPDLY] (Sample Delay Register)</li> <li>4.2.10. [ENxINPMON] (Input Monitor Register)</li> <li>4.2.11. [ENxCLKCR] (Sample Clock Control Register)</li> <li>4.2.12. [ENxINTCR] (Interrupt Control Register)</li> <li>4.2.13. [ENxINTCR] (Interrupt Flag Register)</li> <li>Precaution for Usage</li> <li>Revision History</li> </ul> |

## List of Figures

| Figure 2.1  | A-ENC Block Diagram                                                                   | 10  |
|-------------|---------------------------------------------------------------------------------------|-----|
| Figure 3.1  | ENCxZ input enabled ([ENxTNCR] <zen>=1)</zen>                                         | 12  |
| Figure 3.2  | ENCxZ input is disabled ([ENxTNCR] <zen>=0)</zen>                                     | 13  |
| Figure 3.3  | 3-phase decoding ([ENxTNCR] <p3en>=1)</p3en>                                          | 15  |
| Figure 3.4  | 2-phase decoding ([ENxTNCR] <p3en>=0)</p3en>                                          | 16  |
| Figure 3.5  | 3-phase decoding ([ENxTNCR] <p3en>=1)</p3en>                                          | 17  |
| Figure 3.6  | 2-phase decoding ([ENxTNCR] <p3en>=0)</p3en>                                          | 17  |
| Figure 3.7  | 3-phase decoding ([ENxTNCR] <p3en>=1)</p3en>                                          | 19  |
| Figure 3.8  | 2-phase decoding ([ENxTNCR] <p3en>=0)</p3en>                                          | 19  |
| Figure 3.9  | ENCxZ input is enabled. ([ENxTNCR] <zen>=1)</zen>                                     | 21  |
| Figure 3.10 | ENCxZ input is disabled. ([ENxTNCR] <zen>=0)</zen>                                    | 21  |
| Figure 3.11 | ENCxZ input is enabled ([ENxTNCR] <zen>=1)</zen>                                      | 23  |
| Figure 3.12 | ENCxZ input is disabled ([ENxTNCR] <zen>=0)</zen>                                     | 23  |
| Figure 3.13 | Operation in phase counter mode (phase difference measurement)                        | 25  |
| Figure 3.14 | Configuration of input circuit                                                        | 26  |
| Figure 3.15 | PWM synchronous sampling                                                              | 27  |
| Figure 3.16 | Noise cancelling (Continuous, <nct>=3)</nct>                                          | 28  |
| Figure 3.17 | Noise cancelling (Sampling in the PWM-on period. Noise cancelling timer stops in      | the |
| PWM-o       | ff period. <nct>=4)</nct>                                                             | 28  |
| Figure 3.18 | Noise cancelling (Sampling in the PWM-on period. Noise cancelling timer is cleared in | the |
| PWM-o       | ff period. <nct>=4)</nct>                                                             | 29  |
| Figure 3.19 | Configuration of the decoder                                                          | 30  |
| Figure 3.20 | Waveforms of 2-phase decoding                                                         | 31  |
| Figure 3.21 | Waveforms of 3-phase decoding                                                         | 32  |
| Figure 3.22 | Configuration of the counter (encoder mode and sensor mode (event count))             | 35  |
| Figure 3.23 | Configuration of the counter (sensor mode (timer count) or timer mode)                | 36  |
| Figure 3.24 | Configuration of the counter (sensor mode (phase count), and phase counter mode)      | 37  |
|             |                                                                                       |     |

### List of Tables

| Table 1.1 | Signal input pin              | 9  |
|-----------|-------------------------------|----|
| Table 2.1 | List of Signals               | 10 |
| Table 3.1 | Setting of operation mode     | 11 |
| Table 3.2 | List of interrupt events      | 38 |
| Table 3.3 | Interrupt events of each mode | 38 |
| Table 6.1 | Revision History              | 54 |

#### Preface

#### **Related Documents**

| Document name                               |
|---------------------------------------------|
| Exception                                   |
| Clock Control and Operation Mode            |
| Product Information                         |
| Advanced Programmable Motor Control Circuit |
| Programmable Motor Control Circuit Plus     |

#### Conventions

**FOSHIBA** 

- Numeric formats follow the rules as shown below: Hexadecimal: 0xABC
   Decimal: 123 or 0d123 – Only when it needs to be explicitly shown that they are decimal numbers. Binary: 0b111 – It is possible to omit the "0b" when the number of bit can be distinctly understood from a sentence.
- "\_N" is added to the end of signal names to indicate low active signals.
- It is called "assert" that a signal moves to its active level, "deassert" to its inactive level.
- When two or more signal names are referred, they are described like as [m: n]. Example: S[3: 0] shows four signal names S3, S2, S1 and S0 together.
- The characters surrounded by [] defines the register. Example: [ABCD]
- "n" substitutes suffix number of two or more same kind of registers, fields, and bit names. Example: [XYZ1], [XYZ2], [XYZ3] → [XYZn]
- "x" substitutes suffix number or character of units and channels in the Register List. In case of unit, "x" means A, B, and C ... Example: [ADACR0], [ADBCR0], [ADCCR0] → [ADxCR0] In case of channel, "x" means 0, 1, and 2 ... Example: [T32A0RUNA], [T32A1RUNA], [T32A2RUNA] → [T32AxRUNA]
- The bit range of a register is written like as [m: n]. Example: Bit[3: 0] expresses the range of bit 3 to 0.
- The configuration value of a register is expressed by either the hexadecimal number or the binary number. Example: [*ABCD*]<EFG> =0x01 (hexadecimal), [*XYZn*]<VW> =1 (binary)
- Word and Byte represent the following bit length.

| Byte:        | 8 bits  |
|--------------|---------|
| Half word:   | 16 bits |
| Word:        | 32 bits |
| Double word: | 64 bits |

- Properties of each bit in a register are expressed as follows:
  - R: Read only
  - W: Write only

R/W: Read and Write are possible

- Unless otherwise specified, register access supports only word access.
- The register defined as reserved must not be rewritten. Moreover, do not use the read value.
- The value read from the bit having default value of "—" is unknown.
- When a register containing both of writable bits and read-only bits is written, read-only bits should be written with their default value, in the cases that default is "—", follow the definition of each register.
- Reserved bits of the Write-only register should be written with their default value. In the cases that default is "—", follow the definition of each register.
- Do not use read-modified-write processing to the register of a definition which is different by writing and read out.



All other company names, product names, and service names mentioned herein may be trademarks of their respective companies.

#### Terms and Abbreviations

Some of abbreviations used in this document are as follows:

| A-PMD | Advanced Programmable Motor Control Circuit |
|-------|---------------------------------------------|
| ADC   | Analog to Digital Converter                 |
| BLDC  | Brushless DC (Motor)                        |
| BEMF  | Back Electromotive Force                    |
| CCW   | Counter Clockwise                           |
| CW    | Clockwise                                   |
| PMD+  | Programmable Motor Control Circuit Plus     |
| PWM   | Pulse Width Modulation                      |

## 1. Outlines

The advanced encoder input circuit (A-ENC) can operate as an input circuit of one channel (ENCxA/ENCxB/ENCxZ) per 1 unit. Below, the list of functions is shown.

| Function classification  | Function                                                | Functional Description                                                                                                                                                                                                                                                                                                                                                              |  |
|--------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                          | Encoder mode                                            | It is the mode which connects and uses an AB or ABZ type incremental form<br>encoder. In the combination of an Input Signal, a rotating direction is judged<br>and count-up/down operation is carried out for every rotational edge.                                                                                                                                                |  |
|                          | Sensor mode<br>(Event count)                            | It is the mode which connects and uses the Hall IC (U, V, W) of a 2-phase or<br>a 3-phase circuit. Whenever it detects the edge of U, V, and W of a Hall IC,<br>count-up/down operation of a pulse is performed. In the combination of an<br>Input Signal, a rotating direction is judged and count-up/down operation is<br>carried out.                                            |  |
| Sensor input             | Sensor mode                                             | It is the mode which connects and uses the Hall IC (U, V, W) of a 2-phase or a 3-phase circuit. Measure the interval of edge detection of U, V, W of Hall IC. The rotation direction can be judged by a combination of input signals.                                                                                                                                               |  |
|                          | (Timer count)                                           | The commutation trigger to the Programmable Motor Control Circuit (PMD) in sync with edge detection is generable.                                                                                                                                                                                                                                                                   |  |
|                          |                                                         | In a PWM synchronous sampling, it can respond to sensorless control of the brushless DC (BLDC) motor of a square-wave mode.                                                                                                                                                                                                                                                         |  |
|                          | Sensor mode<br>(Phase count)                            | It is the mode which connects and uses the Hall IC (U, V, W) of a 2-phase or<br>a 3-phase circuit. 16-bit counter operation is carried out with the clock of<br>arbitrary frequency, and the interval of edge detection of U, V, and W of a Hall<br>IC can be measured. A rotating direction can be judged in the combination of<br>Input signals. Up/down operation can be chosen. |  |
| General<br>purpose timer | Timer mode                                              | It is the mode which can be used as 32 bit timers which operate by fsys.<br>Capture by an ENCxZ input can be performed.                                                                                                                                                                                                                                                             |  |
| Phase counter            | Phase counter mode<br>(Phase measurement)               | It is the mode which measures the phase at the time of the edge detection of<br>an ENCxZ input, with a 16-bit counter which operates with the clock of<br>arbitrary frequency. Interrupt generating by a comparison function can be<br>performed.                                                                                                                                   |  |
|                          | Phase counter mode<br>(Phase difference<br>measurement) | With the 16-bit counter which operates with the clock of arbitrary frequency, the phase difference between a general-purpose timer output and an ENCxZ input can be measured.                                                                                                                                                                                                       |  |
| Noise Canceller          | Input circuit                                           | The sampling with a fsys dividing clock or the sampling in sync with a PWM signal can be performed. Noise cancel width can be chosen.                                                                                                                                                                                                                                               |  |

| Table I.I. Signal input pir | Table | 1.1 | Signal | input | pin |
|-----------------------------|-------|-----|--------|-------|-----|
|-----------------------------|-------|-----|--------|-------|-----|

| Signal na              | me    | Encoder<br>A, B, Z | Hall sensor<br>U, V, W |
|------------------------|-------|--------------------|------------------------|
|                        | ENCxA | A                  | U                      |
| Connecting<br>terminal | ENCxB | В                  | V                      |
|                        | ENCxZ | Z                  | W                      |

## 2. Configuration





|    |            |                                     | -      |                                     |
|----|------------|-------------------------------------|--------|-------------------------------------|
| No | Symbol     | Signal name                         | I/O    | Related Reference manual            |
| 1  | fsys       | System clock                        | Input  | Clock Control and Operation<br>Mode |
| 2  | ENCxA      | Encoder input A pin                 | Input  | Product Information                 |
| 3  | ENCxB      | Encoder input B pin                 | Input  | Product Information                 |
| 4  | ENCxZ      | Encoder input Z pin                 | Input  | Product Information                 |
| 5  | ENCxPWMON  | PWM signal for sampling             | Input  | Product Information                 |
| 6  | ENCxCTRGO  | The commutation trigger to the PMD  | Output | Product Information                 |
| 7  | ENCxPSGI   | General purpose timer output signal | Input  | Product Information                 |
| 8  | ENCxTIMPLS | Divided pulse signal                | Output | Product Information                 |
| 9  | INTENCx0   | Encoder input interrupt 0           | Output | Exception, Product Information      |
| 10 | INTENCx1   | Encoder input interrupt 1           | Output | Exception                           |

| Table 2.1 | List of | Signals |
|-----------|---------|---------|
|-----------|---------|---------|

## 3. Function and Operation

## 3.1. Clock Supply

When using A-ENC, set an applicable clock enable bit to "1" (Clock supply) in clock supply and stop register A for fsys (*[CGFSYSENA]* and *[CGFSYSMENA]*), clock supply and stop register B for fsys (*[CGFSYSMENB]*), clock supply and stop register C for fsys (*[CGFSYSMENC]*), and clock supply and stop register for fc (*[CGFCEN]*).

An applicable register and the bit position vary according to a product. Therefore, the register may not exist with the product. Please refer to "Clock Control and Operation Mode" of the reference manual for the details.

## 3.2. Operation Mode

The operation mode is determined with *[ENxTNCR]*<MODE[2:0]>, <P3EN>, and <ZEN>. They are 13 types in total. The fields should not be set to other combinations.

The following table lists the operation mode settings:

| [ENxTNCR]               |             | In must min   | Mada                |                                                                        |
|-------------------------|-------------|---------------|---------------------|------------------------------------------------------------------------|
| <mode[2:0]></mode[2:0]> | <zen></zen> | <p3en></p3en> | input pin           | Μοαε                                                                   |
| 000                     | 0           |               | ENCxA, ENCxB        | Encoder mode (without the ENCxZ)                                       |
| 000                     | 1           | 0             | ENCxA, ENCxB, ENCxZ | Encoder mode (use of the ENCxZ)                                        |
| 001                     | 0           | 0             | ENCxA, ENCxB        | Sensor mode (event count and the 2-phase input)                        |
| 001                     | 0           | 1             | ENCxA, ENCxB, ENCxZ | Sensor mode (event count and the 3-phase input)                        |
| 010                     | 0 0         |               | ENCxA, ENCxB        | Sensor mode (timer count and the 2-phase input)                        |
| 010 0                   |             | 1             | ENCxA, ENCxB, ENCxZ | Sensor mode (timer count and the 3-phase input)                        |
| 011                     | 0           |               | -                   | Timer mode                                                             |
| UTI                     | 1           | U             | ENCxZ               | Timer mode (use of the ENCxZ)                                          |
| 110                     | 0           | 0             | ENCxA, ENCxB        | Sensor mode (phase count and the 2-phase input)                        |
| 110                     | U           | 1             | ENCxA, ENCxB, ENCxZ | Sensor mode (phase count and the 3-phase input)                        |
|                         | 0           |               | -                   | Phase counter mode (phase measurement)                                 |
| 111                     | 1           | 0             | ENCxZ               | Phase counter mode (phase measurement and use of the ENCxZ)            |
|                         | 1           | 1             | ENCxZ               | Phase counter mode (phase difference measurement and use of the ENCxZ) |

#### Table 3.1 Setting of operation mode

#### 3.2.1. Encoder Mode

The A-ENC supports the high-speed position sensor (phase determination) that determines the phase input from the incremental encoder (AB encoder or ABZ encoder).

- Rotational edge detection is performed, a divided pulse is output, and an interrupt can be generated.
- Rotational edge pulses are counted and an interrupt can be generated at the specified counter value.
- Determines the rotational direction.
- Up/down count (controlled by the rotational direction)
- Sets the range of counts.
- Sets the rotational direction for the detection.
- An abnormal error detection flag is available.
- (1) The ENCxZ input is enabled. (*[ENxTNCR]*<ZEN>=1)

#### [ENxRELOAD]<RELOADH[15:0]>=0x0380, [ENxINT]<INTH[15:0]>=0x0002

| fsys                              |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
|-----------------------------------|------------------|--------------------|----------|-------|-----|-----|----------|-----|-------|------------|------|-----|-----|
| ENCxA                             |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
| ENCxB                             |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
| ENCxZ                             |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
| Rotational edge pulse<br>ENCLK .  |                  |                    |          |       |     |     |          |     |       |            |      |     | Л   |
| Internal Z-phase detection signal |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
| Z-phase detection <zdet></zdet>   | •<br>            |                    |          |       |     |     |          |     |       |            |      |     |     |
| Rotation direction <ud></ud>      |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
| Rotation                          | •                |                    | CW dired | ction |     |     | <b>→</b> |     | (     | CCW direct | tion |     |     |
| Counter clear                     |                  |                    |          |       |     |     |          |     |       |            |      |     |     |
| ENCxTIMPLS<br>(Divided by 2)      |                  |                    | [        |       | [   |     |          |     |       |            |      |     | Γ   |
| Counter                           | 110 <sup>-</sup> | 111 1 <sup>-</sup> | 12 0     | 1     | 2 3 | 0 1 | C        | ) 3 | 80 37 | 7F 37E     | 0    | 380 | 37F |
| Interrupt INTENCx1                |                  |                    |          | [     |     |     |          |     |       |            |      |     |     |



#### (2) The ENCxZ input is disabled. (*[ENxTNCR]*<ZEN>=0)

#### [ENxRELOAD]<RELOADH[15:0]>=0x0380, [ENxINT]<INTH[15:0]>=0x0002

| fsys                                                                      |                        |       |     |     |   |     |       |           |     |          |
|---------------------------------------------------------------------------|------------------------|-------|-----|-----|---|-----|-------|-----------|-----|----------|
| ENCxA                                                                     |                        |       |     |     |   |     |       |           |     |          |
| ENCxB                                                                     |                        |       |     |     |   |     |       |           |     |          |
| ENCxZ                                                                     |                        |       |     |     |   |     |       |           |     |          |
| Rotational edge pulse<br>ENCLK                                            |                        |       |     |     |   |     |       | ſ         |     | Л        |
| Internal Z-phase<br>detection signal -<br>Z-phase detection <zdet></zdet> |                        | ſ     |     |     |   |     |       |           |     |          |
| Rotation direction <ud><br/>Rotation direction</ud>                       | •                      |       |     |     | → |     |       |           |     | <b>→</b> |
| Counter clear                                                             |                        |       |     |     |   |     | CCW c | lirection |     |          |
| ENCxTIMPLS<br>(Divided by 2) -                                            |                        |       |     |     |   |     | ſ     |           |     | Л        |
| Counter                                                                   | 110 111 1 <sup>7</sup> | 113 0 | 1 2 | 0 1 | 0 | 380 | 37F   | 37E       | 37D | 37C      |
| Interrupt INTENCx1                                                        |                        |       | [   |     |   |     |       |           |     |          |

Figure 3.2 ENCxZ input is disabled ([ENxTNCR]<ZEN>=0)

In encoder mode, the incremental encoder inputs should be connected to the ENCxA, ENCxB, and ENCxZ pins. The encoder multiplies the ENCxA and the ENCxB signals by 4 to count the rotational edge pulses.

During the CW rotation (i.e., ENCxA has the 90-degree phase lead to ENCxB), the counter counts up; when the value of the counter reaches the value of <RELOADH>, the counter is cleared to "0x0000" on the next ENCLK.

During the CCW rotation (i.e., ENCxA has the 90-degree phase lag to ENCxB), the counter counts down; when the value of the counter reaches "0x0000", the counter is set to the value of <RELOADH> on the next ENCLK.

Additionally, when <ZEN>=1, the counter is cleared to "0x0000" on the rising edge of ENCxZ during the CW rotation and on the falling edge of ENCxZ during the CCW rotation. If the ENCLK matches ENCxZ detection timing, the counter is cleared to "0x0000" without increment or decrement.

When "1" is written to *[ENxTNCR]*<ENCLR>, the counter is cleared to "0x0000".

*[ENxSTS]*<UD> is set to "1" during the CW rotation and is cleared to "0" during the CCW rotation.

The detection direction (CW direction or CCW direction) can be set with *[ENxTNCR]*<DECMD[1:0]>. Except when <DECMD>=00, a rotational edge is detected based on the comparison between the input status (*[ENxINPMON]*<DETMONA>, <DETMONB>, <DETMONZ>) at the previously detected edge and the current input value.

ENCXTIMPLS is a division of ENCLK, and the division ratio is selected by [ENXTNCR]<ENDEV>.

When *[ENxINTCR]*<CMPIE>=1, if the value of <INTH> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<MCMPIE>=1, if the value of *[ENxMCMP]*<MCMPH[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

However, when <ZEN>=1, a match interrupt does not occur during *[ENxSTS]*<ZDET>=0. After the encoder input is enabled, if the A-ENC detects the first ENCxZ, <ZDET> is set to "1".

<ZDET> and *[ENxSTS]*<UD> are cleared to "0" when *[ENxTNCR]*<ENRUN>=0.

#### 3.2.2. Sensor Mode

The counter supports low-speed position sensing (zero-cross determination) to deal 2-phase Hall sensor input and 3-phase Hall sensor input. There are three modes, event count mode, timer count mode, and phase count mode.

In timer count mode or phase count mode, when a BLDC motor is driven on rectangular waveforms from the PMD, the A-ENC can perform zero-cross detection of an induced voltage using PWM synchronous sampling. (BEMF Detection Control)

#### 3.2.2.1. Event Count

The counter counts using rotational edge detection.

- Rotational edge detection is performed, a divided pulse is output, and an interrupt can be generated.
- Rotational edge pulses are counted and an interrupt can be generated at the specified counter value.
- Determines the rotational direction.
- Sets up- or down count (controls by the determination of rotational direction).
- Specifies the rotational detection direction.
- Abnormal error detection flag
- (1) 3-phase decoding (*[ENxTNCR]*<P3EN>=1)

#### [ENxINT]<INTH[15:0]>=0x0002



#### Figure 3.3 3-phase decoding ([ENxTNCR]<P3EN>=1)

#### (2) 2-phase decoding (*[ENxTNCR]*<P3EN>=0)

#### *[ENxINT]*<INTH[15:0]>=0x0002

| fsys                                                     |   |    |           |    |     |     |   |       |       |    |         |       |       |   |
|----------------------------------------------------------|---|----|-----------|----|-----|-----|---|-------|-------|----|---------|-------|-------|---|
| ENCxA(U)                                                 |   |    |           |    |     |     |   |       |       |    |         |       |       |   |
| ENCxB(V)                                                 |   |    |           |    |     |     |   |       |       |    |         |       |       |   |
| ENCxZ(W)                                                 |   |    |           |    |     |     |   |       |       |    |         |       |       |   |
| Rotational edge pulse<br>ENCLK                           |   |    |           |    |     |     | [ |       |       |    |         |       |       |   |
| Rotation direction <ud></ud>                             |   |    |           |    |     |     |   |       |       |    |         |       |       |   |
| Dototion                                                 |   |    |           |    |     |     |   |       |       |    |         |       |       |   |
| Rotation                                                 | • | CV | V directi | on |     |     |   |       |       | CC | W dired | ction |       | • |
| Counter clear                                            |   | CV | V directi | on |     |     |   |       |       | CC | W dired | ction |       | - |
| Counter clear<br>ENCxTIMPLS<br>(Divided by 2)            |   | cv | V directi | on |     |     |   |       |       |    | W direo |       |       |   |
| Counter clear<br>ENCxTIMPLS<br>(Divided by 2)<br>Counter |   |    | FF (      | on | 1 2 | 2 3 |   | <br>1 | ) FFI |    | W dired |       | C FFI |   |

#### Figure 3.4 2-phase decoding ([ENxTNCR]<P3EN>=0)

Hall sensor inputs (U, V, and W) should be connected to ENCxA, ENCxB, and ENCxZ. When <P3EN>=0, the counter multiplies a 2-phase input (ENCxA or ENCxB) by 4; when <P3EN>=1, the counter multiplies a 3-phase input (ENCxA, ENCxB, or ENCxZ) by 6. After that, the counter counts the Rotational edge pulse.

During the CW rotation (i.e., ENCxA has 90-degree (2-phase input) or 120-degree (3-phase input) phase lead to ENCxB channel), the counter performs up counting. When the value of the counter reaches "0xFFFF", the counter is cleared to "0x0000" on the next ENCLK.

During the CCW rotation (i.e., ENCxA has 90-degree (2-phase input) or 120-degree (3-phase input) phase lag to ENCxB), the counter performs down counting. When the value of the counter reaches "0x0000", the counter is set to "0xFFFF" on the next ENCLK.

When "1" is written to *[ENxTNCR]*<ENCLR>, the counter is cleared to "0x0000".

When the CW rotation is detected, *[ENxSTS]*<UD> is set to "1". When the CCW rotation is detected, *[ENxSTS]*<UD> is cleared to "0".

The detection direction (CW direction or CCW direction) can be set with *[ENxTNCR]*<DECMD[1:0]>. Except when <DECMD>=00, a rotational edge is detected based on the comparison between the input status (*[ENxINPMON]*<DETMONA>, <DETMONB>, <DETMONZ>) at the previously detected edge and the current input value.

ENCxTIMPLS is a division of ENCLK, and the division ratio is selected by [ENxTNCR]<ENDEV>.

When *[ENxINTCR]*<CMPIE>=1, if the value of <INTH> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<MCMPIE>=1, if the value of <MCMPH> and the counter value become equal, an INTENCx1 interrupt occurs.

#### 3.2.2.2. Timer Count

(1) 3-phase decoding (*[ENxTNCR]*<P3EN>=1)

*[ENxINT]*<INTH[15:0]><INTL[15:0]>=0x00000002



Figure 3.5 3-phase decoding ([ENxTNCR]<P3EN>=1)

(2) 2-phase decoding (*[ENxTNCR]*<P3EN>=0)

*[ENxINT]*<INTH[15:0]><INTL[15:0]>=0x00000002



Figure 3.6 2-phase decoding ([ENxTNCR]<P3EN>=0)

Hall sensor inputs (U, V, and W) should be connected to ENCxA, ENCxB, and ENCxZ. When <P3EN>=0, the counter multiplies a 2-phase input (ENCxA or ENCxB) by 4; when <P3EN>=1, the counter multiplies a 3-phase input (ENCxA, ENCxB, or ENCxZ) by 6. After that, the counter generates a 4-fold or 6-fold rotational edge pulse (ENCLK).

The counter always performs up counting and is cleared to "0x00000000" on ENCLK. When "1" is written to *[ENxTNCR]*<ENCLR>, the counter is cleared to "0x00000000".

The counter value is captured on ENCLK. The captured value can be read from the *[ENxCNT]* register.

When "1" is written to *[ENxTNCR]*<SFTCAP>, the counter value is captured. The timing of capturing can be specified by the user. The captured value can be read from the *[ENxCNT]* register.

The value of the *[ENxCNT]* register (captured value) is maintained regardless of the value of *[ENxTNCR]* <ENRUN>.

When the CW rotation is detected, *[ENxSTS]*<UD> is set to "1". When the CCW rotation is detected, *[ENxSTS]* <UD> is cleared to "0". When <ENRUN>=0, <UD> is cleared to "0". If the rotational direction is reversed, *[ENxSTS]*<REVERR> is set to "1". This flag is cleared upon reading.

The detection direction (CW direction or CCW direction) can be set with *[ENxTNCR]*<DECMD[1:0]>. Except when <DECMD>=00, a rotational edge is detected based on the comparison between the input status *[ENxINPMON]*<DETMONA><DETMONB><DETMONZ> at the previously detected edge and the current input value.

When *[ENxINTCR]*<RLDIE>=1, if the value of *[ENxRELOAD]*<RELOADH[15:0]><RELOADL[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<CMPIE>=1, if the value of *[ENxINT]*<INTH[15:0]><INTL[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<MCMPIE>=1, if the value of *[ENxMCMP]*<MCMPH[15:0]><MCMPL[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs. When *[ENxTNCR]*<MCMPMD>=1, if the counter value is the value of <MCMPH> or more, an INTENCx1 interrupt occurs.

#### 3.2.2.3. Phase Count

(1) 3-phase decoding (*[ENxTNCR]*<P3EN>=1)



Figure 3.7 3-phase decoding (*[ENxTNCR]*<P3EN>=1)

#### (2) 2-phase decoding (*[ENxTNCR]*<P3EN>=0)



Figure 3.8 2-phase decoding ([ENxTNCR]<P3EN>=0)

Hall sensor inputs (U, V, and W) should be connected to ENCxA, ENCxB, and ENCxZ. When <P3EN>=0, the counter multiplies a 2-phase input (ENCxA or ENCxB) by 4; when <P3EN>=1, the counter multiplies a 3-phase input (ENCxA, ENCxB, or ENCxZ) by 6. After that, the counter generates a 4-fold or 6-fold rotational edge pulse (ENCLK).

The counter can be set to up/down count by the <UDMD> setting and the *[ENxRATE]* register setting at the specified frequency. When the counter is set to up count, if the value of the counter and the value of <RELOADH> become equal, the counter is cleared to "0x0000". When the counter is set to down count, if the value of the counter reaches "0x0000", the counter is set to the value of <RELOADH>.

When "1" is written to <ENCLR>, the counter is cleared to "0x0000".

When <TOVMD>=1, the counter stops at the value of <RELOADH>.

The counter value is captured on ENCLK. The captured value can be read from the [ENxCNT] register.

When "1" is written to <SFTCAP>, the counter value is captured. The timing of capturing can be specified by the user. The captured value can be read from the *[ENxCNT]* register.

The value of the *[ENxCNT]* register (captured value) is maintained regardless of the value of <ENRUN>.

When the CW rotation is detected, <UD> is set to "1". When the CCW rotation is detected, <UD> is cleared to "0". When <ENRUN>=0, <UD> is cleared to "0".

The detection direction (CW direction or CCW direction) can be set with *[ENxTNCR]*<DECMD[1:0]>. Except when <DECMD>=00, a rotational edge is detected based on the comparison between the input status *[ENxINPMON]*<DETMONA><DETMONB><DETMONZ> at the previously detected edge and the current input value.

When *[ENxINTCR]*<CMPIE>=1, if the value of *[ENxINT]*<INTH[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<MCMPIE>=1, if the value of *[ENxMCMP]*<MCMPH[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

#### 3.2.3. Timer Mode

This mode can be used as a general-purpose 32-bit timer.

- 32-bit up counter (counts using the fsys clock)
- Counter clear control (software clear, compare match clear, and external trigger)
- A match interrupt occurs using the compare function.
- Capture functions: external trigger capture (interrupt can be generated), software capture
- (1) The ENCxZ input is enabled. (*[ENxTNCR]*<ZEN>=1)

*[ENxINT]*<INTH[15:0]><INTL[15:0]>=0x00000006

|                                           |                               | И                                                  |
|-------------------------------------------|-------------------------------|----------------------------------------------------|
| fsys                                      |                               |                                                    |
| ENCxZ                                     |                               |                                                    |
| Internal Z-phase<br>detection signal      | ∩                             |                                                    |
| Z-phase edge<br>selection <zesel></zesel> | 10                            | 01                                                 |
| Counter clear                             |                               |                                                    |
| ENCxTIMPLS<br>(Divided by 2)              |                               |                                                    |
| Counter                                   | 2 3 4 5 6 7 8 9 A B 0 1 2 3 4 | 31 32 33 34 35 36 37 38 39 40 41 0 1 2 3 4 5 6 7 8 |
| Capture register                          | 0(ini) B                      | B 41                                               |
| Interrupt INTENCx0                        |                               |                                                    |
| Interrupt INTENCx1                        | Capture interrupt             | Capture interrupt                                  |
|                                           | Compare interrupt             | I Compare interrupt                                |

#### Figure 3.9 ENCxZ input is enabled. ([ENxTNCR]<ZEN>=1)

(2) The ENCxZ input is disabled. (*[ENxTNCR]*<ZEN>=0)

[ENxINT]<INTH[15:0]><INTL[15:0]>=0x00000006



#### Figure 3.10 ENCxZ input is disabled. ([ENxTNCR]<ZEN>=0)

When <ZEN>=1, a ENCxZ input can work as the external trigger. When <ZEN>=0, the external trigger is not used.

The counter always performs up counting.

When "1" is written to [ENxTNCR]<ENCLR>, the counter is cleared to "0x00000000".

When <ZEN>=1, if *[ENxTNCR]*<ZESEL> is set to "01", the counter is cleared on the rising edge of the ENCxZ. When <ZESEL>=10, the counter is cleared on the falling edge of the ENCxZ. When <ZESEL>=11, the counter is cleared on the both edge of the ENCxZ.

When the ENCxZ edge is detected, the counter value is captured. The captured value can be read from the *[ENxCNT]* register.

When "1" is written to *[ENxTNCR]*<SFTCAP>, the counter value is captured. The timing of capturing can be specified by the user. The captured value can be read from the *[ENxCNT]* register.

The value of the *[ENxCNT]* register (captured value) is maintained regardless of the value of *[ENxTNCR]* <ENRUN>. The clearing event of the captured value is only a reset.

When *[ENxINTCR]*<RLDIE>=1, the value of *[ENxRELOAD]*<RELOADH[15:0]>, <RELOADL[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<CMPIE>=1, the value of *[ENxINT]*<INTH[15:0]>, <INTL[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<MCMPIE>=1, the value of *[ENxMCMP]*<MCMPH[15:0]>, <MCMPL[15:0]> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxTNCR]*<MCMPMD>=1, if the counter value is *[ENxMCMP]*<MCMPH[15:0]>, <MCMPL[15:0]> or more, an INTENCx1 interrupt occurs.

#### 3.2.4. Phase Counter Mode

#### 3.2.4.1. Phase Measurement

This mode can be used as a 16-bit counter that can be controlled at the specified frequency.

- Up/down count control is available.
- Sets the compare function and match interrupt.
- Clears and captures the counter using a ENCxZ input, and then occurs an interrupt.
- (1) The ENCxZ input is enabled. (*[ENxTNCR]*<ZEN>=1) *[ENxINT]*<INTH[15:0]>=0x0006





(2) The ENCxZ input is disabled. (*[ENxTNCR]*<ZEN>=0) *[ENxINT]*<INTH[15:0]>=0x0006

| <i>[ENxRATE]</i> <rate><br/>Specified clock<br/>ENCxZ</rate> |                                |                                               |
|--------------------------------------------------------------|--------------------------------|-----------------------------------------------|
| Internal Z-phase detection signal                            |                                |                                               |
| Z-phase edge<br>selection <zesel><br/>Counter clear</zesel>  | 10                             | 01                                            |
| Software capture<br>ENCxTIMPLS<br>(Divided by 2)             | ∏                              |                                               |
| Counter                                                      | 2 3 4 5 6 7 8 9 A B C D E F 10 | 31 32 33 34 35 36 0 1 2 3 4 5 6 7 8 9 A B C D |
| Capture register                                             | 0(ini) A                       | Α                                             |
| Interrupt INTENCx1                                           | Compare interrupt              | Compare interrupt                             |

#### Figure 3.12 ENCxZ input is disabled ([ENxTNCR]<ZEN>=0)

When <ZEN>=1, a ENCxZ input can work as the external trigger. When <ZEN>=0, the external trigger is not used.

The counter controls up/down counting with the *[ENxTNCR]*<UDMD> and the *[ENxRATE]* registers at the specified frequency.

When the counter performs up counting, if the value of the counter becomes equal to the value of *[ENxRELOAD]* <RELOADH[15:0]>, the counter is cleared to "0x0000".

When the counter preforms down counting, if the value of the counter reaches "0x0000", the counter is set to the value of *[ENxRELOAD]*<RELOADH>.

When *[ENxTNCR]*<TOVMD>=1, the counter stops at the value of *[ENxRELOAD]*<RELOADH>.

When "1" is written to [ENxTNCR]<ENCLR>, the counter is cleared to "0x0000".

When <ZEN>=1, if *[ENxTNCR]*<ZESEL>=01, the counter is cleared to "0x0000" on the rising edge of the ENCxZ; if <ZESEL>=10, the counter is cleared to "0x0000" on the falling edge of the ENCxZ; if <ZESEL>=11, the counter is cleared to "0x0000" on the both edges.

When an edge of the ENCxZ is detected, the counter value is captured. The captured value can be read from the *[ENxCNT]* register.

When "1" is written to *[ENxTNCR]*<SFTCAP>, the counter value is captured. Capturing can be performed at the specified timing. The captured valued can be read from the *[ENxCNT]* register.

The value of the *[ENxCNT]* register (captured value) is maintained regardless of the value of *[ENxTNCR]* <ENRUN>. The clearing event of the captured value is only a reset.

When *[ENxINTCR]*<CMPIE>=1, if the value of *[ENxINT]*<INTH> and the counter value become equal, an INTENCx1 interrupt occurs.

When *[ENxINTCR]*<MCMPIE>=1, if the value of *[ENxMCMP]*<MCMPH> and the counter value become equal, an INTENCx1 interrupt occurs.

#### 3.2.4.2. Phase Difference Measurement

In phase counter mode, when <P3EN>=<ZEN>=1, the counter enters phase difference measurement mode. In this mode, the up/down counter is controlled with the general purpose timer output (ENCxPSGI) and the ENCxZ input.

- When the general purpose timer output and the ENCxZ input are equal, the counter operation is set to up counting. When the general purpose timer output and the ENCxZ input are not equal, the counter operation is set to down counting.
- The value of the counter is captured on the edge of the general purpose timer output. At this time the counter can be cleared and an interrupt can be generated.



Figure 3.13 Operation in phase counter mode (phase difference measurement)

When an edge of the general purpose timer output (ENCxPSGI) signal is detected, the counter is captured and cleared. At this time, the detection edge is set with *[ENxTNCR]*<ZESEL>. When "1" is written to *[ENxTNCR]*<ENCLR>, the counter is cleared to "0x0000".

The captured value indicates the phase difference between the ENCxZ input and the general purpose timer output (ENCxPSGI) signal. The standard value (captured value is "0x0000") is assumed that the phase difference between the ENCxZ input and the general purpose timer output (ENCxPSGI) signal is 1/4 cycle.

## **3.3. Function Description in Each Circuit**

#### 3.3.1. Input Circuit



Figure 3.14 Configuration of input circuit

The input circuit samples the inputs from the pins (ENCxA, ENCxB, ENCxZ) on the specified sampling signal to reduce the noise using the digital noise canceller.

#### 3.3.1.1. Sample Clock

The sample clock can be selected from fsys, fsys/2, fsys/4, or fsys/8 with [ENxCLKCR]<SPLCKS>.

#### 3.3.1.2. Sampling Mode

(1) Continuous sampling ([ENxINPCR]<SYNCSPLEN>=0)

In continuous sampling, the input circuit samples the input clock on sample clocks.

(2) PWM synchronous sampling (*[ENxINPCR]*<SYNCSPLEN>=1)

In PWM synchronous sampling, the input circuit samples the input clock synchronously with PWM signals from the PMD.

 PWM-on period sampling (*[ENxINPCR]*<SYNCSPLND>=0) In PWM-on period sampling, the input circuit samples the input signal on the specified sample clock selected with *[ENxCLKCR]*<SPLCKS> for the PWM-on period.

The PWM on-delay setting can be set with *[ENxSMPDLY]*<SMPDLY> when the input circuit samples an on-delay period.

Start delay time = <SMPDLY> × Sample clock cycle

- Note: After enabling ENC(after changing *[ENxTNCR]*<ENRUN> from "0" to "1"), the first delay time may not match the value of <SMPDLY>.
- PWM off-edge sampling (*[ENxINPCR]*<SYNCSPLND>=1) ENCxPWMON signal serves as a sampling signal, and the input circuit samples the input signal on the off-edge of ENCxPWMON signal.

| Sample clock            |                                      | 111111111             |                                                       |
|-------------------------|--------------------------------------|-----------------------|-------------------------------------------------------|
| PWM signal<br>ENCxPWMON | [ENxSMPDLY] <s<br>setting tim</s<br> | SMPDLY>               | <i>[ENxSMPDLY]</i> <smpdly><br/>setting time</smpdly> |
| Sampling enable         |                                      |                       |                                                       |
| Sampling signal         |                                      | 11111                 |                                                       |
|                         |                                      | (a) PWM on-period sam | npling                                                |
| PWM signal<br>ENCxPWMON |                                      |                       |                                                       |
| Sampling enable         |                                      |                       |                                                       |
| Sampling signal         |                                      | Ì                     | Ì                                                     |
|                         |                                      | (b) PWM off-edge sam  | pling                                                 |

#### Figure 3.15 PWM synchronous sampling

#### 3.3.1.3. Noise Cancelling

(1) Continuous sampling (*[ENxINPCR]*<SYNCSPLEN>=0)

A noise cancelling time can be set with *[ENxINPCR]*<NCT[6:0]>. A noise cancelling time can be calculated as follows:

Noise cancelling time = <NCT> × Sample clock cycle

Note: When <NCT> is set to "0", noise cancelling is disabled.





- (2) Sampling in the PWM-on period (*[ENxINPCR]*<SYNCSPLEN>=1)
- Noise cancelling timer stops during the "Low" period of sampling signal (*[ENxINPCR]*<SYNCNCZEN>=0)
- Noise cancelling timer is cleared during the "Low" period of sampling signal (*[ENxINPCR]*<SYNCNCZEN>=1)









Figure 3.18 Noise cancelling (Sampling in the PWM-on period. Noise cancelling timer is cleared in the PWM-off period. <NCT>=4)

#### 3.3.2. Decoder



Figure 3.19 Configuration of the decoder

The decoder detects a rotational edge and rotational direction from 2-phase or 3-phase inputs after noise cancelling. It also detects the ENCxZ in the encoder mode, and the edge of ENCxZ signal in the timer mode and the phase counter mode.

#### 3.3.2.1. Rotational Edge Detection and Direction Signal Generation

(1) 2-phase decoding (*[ENxTNCR]*<P3EN>=0)

Supports encoder mode and sensor mode (2-phase input). In 2-phase decoding, four input pattern variations (rotational edge) are detected.

For the inputs in CW direction, when a rotational edge of  $(1) \rightarrow (2)$ ,  $(2) \rightarrow (3)$ ,  $(3) \rightarrow (4)$ , or  $(4) \rightarrow (1)$  is detected, the status of *[ENxSTS]*<UD> is "1".

For the inputs in CCW direction, when a rotational edge of  $(4) \rightarrow (3)$ ,  $(3) \rightarrow (2)$ ,  $(2) \rightarrow (1)$ , or  $(1) \rightarrow (4)$  is detected, the status of *[ENxSTS]*<UD> is "0".



Figure 3.20 Waveforms of 2-phase decoding

#### (2) 3-phase decoding (*[ENxTNCR]*<P3EN>=1)

Available only in sensor mode (3-phase input).

3-phase decoding detects variations of 6 input patterns (rotational edge).

For inputs in CW direction, when a rotational edge of  $(1) \rightarrow (2)$ ,  $(2) \rightarrow (3)$ ,  $(3) \rightarrow (4)$ ,  $(4) \rightarrow (5)$ ,  $(5) \rightarrow (6)$ , or  $(6) \rightarrow (1)$ . The status of *[ENxSTS]*<UD> is set to "1".

For inputs in CCW direction, when a rotational edge of  $(6) \rightarrow (5)$ ,  $(5) \rightarrow (4)$ ,  $(4) \rightarrow (3)$ ,  $(3) \rightarrow (2)$ ,  $(2) \rightarrow (1)$ , or  $(1) \rightarrow (6)$ , the status of *[ENxSTS]*<UD> is set to "0".



Figure 3.21 Waveforms of 3-phase decoding

#### 3.3.2.2. Z-input Detection Circuit

The decoder detects an edge of the ENCxZ input.

- Encoder mode
   The decoder detects a rising edge in CW direction and detects a falling edge in CCW direction.
- Timer mode and Phase counter mode The decoder selects a detection edge either from a rising edge, falling edge, or both edges with [ENxTNCR]<ZESEL>.

#### **3.3.2.3. Skip Detection and Abnormal Input Detection**

(1) Skip detection

Skip detection is enabled when *[ENxTNCR]*<SDTEN>=1.

• Combination of skip detection in 2-phase decoding (*[ENxTNCR]*<P3EN>=0)

Reverse skip detection:  $(1) \rightarrow (3), (2) \rightarrow (4), (3) \rightarrow (1), (4) \rightarrow (2)$ 

• Combination of skip detection in 3-phase decoding (*[ENxTNCR]*<P3EN>=1)

| Skip detection in CW direction:  | $(1) \rightarrow (3), (2) \rightarrow (4), (3) \rightarrow (5), (4) \rightarrow (6), (5) \rightarrow (1), (6) \rightarrow (2)$ |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Skip detection in CCW direction: | $(1) \rightarrow (5), (2) \rightarrow (6), (3) \rightarrow (1), (4) \rightarrow (2), (5) \rightarrow (3), (6) \rightarrow (4)$ |
| Reverse skip detection:          | $(1) \rightarrow (4), (4) \rightarrow (1), (2) \rightarrow (5), (5) \rightarrow (2), (3) \rightarrow (6), (6) \rightarrow (3)$ |

• Combination that skip detection flag (*[ENxSTS]*<SKPDT>) is set to "1"

| In Sensor mode (event count, timer cou | nt);                                                                                                                           |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Skip detection in CW direction:        | $(1) \rightarrow (3), (2) \rightarrow (4), (3) \rightarrow (5), (4) \rightarrow (6), (5) \rightarrow (1), (6) \rightarrow (2)$ |
| Skip detection in CCW direction:       | $(1) \rightarrow (5), (2) \rightarrow (6), (3) \rightarrow (1), (4) \rightarrow (2), (5) \rightarrow (3), (6) \rightarrow (4)$ |

(2) Abnormal input detection

In sensor mode (event count, timer count, or phase count), if an edge detection of which three inputs are all "0" or all "1" in 3-phase decoding, is detected, the encoder determines these inputs are abnormal. If an abnormal input is detected, *[ENxSTS]*<INERR> is set to "1".

#### 3.3.2.4. Edge Detection Error Detection

The encoder determines an error when a direction that is not the specified direction with *[ENxTNCR]*<DECMD> is detected. An edge detection error detection is one of the interrupt events. *[ENxSTS]*<PDERR> is set to "1", when an error is detected.

• Skip detection is disabled. (*[ENxTNCR]*<SDTEN>=0)

During the CW rotational edge detection (*[ENxTNCR]*<DECMD>=01): an error occurs when a rotational edge of CCW direction is detected.

During the CCW rotational edge detection (*[ENxTNCR]*<DECMD>=10): an error occurs when a rotational edge of CW direction is detected.

• Skip detection is enabled. (*[ENxTNCR]*<SDTEN>=1)

During the CW rotational edge detection (*[ENxTNCR]*<DECMD>=01): an error occurs when a skip in CCW direction, a reverse skip, or rotational edge of CCW direction is detected.

During the CCW rotational edge detection (*[ENxTNCR]*<DECMD>=10):



an error occurs when a skip in CW direction, a reverse skip, or rotational edge of CW direction is detected.

#### 3.3.2.5. Buffer Update Control

When *[ENxTNCR]*<DECMD>=00, the buffer is always enabled. In this case, rotational edge detection and skip detection are determined by the variations of input signals.

If <DECMD> is set to other than "00", buffer updating is only performed when a rotational edge is detected. Therefore, the buffers (*[ENxINPMON]* <DETMONA>, <DETMONB> and <DETMONZ>) have stored the input state at the previous rotational edge detection. The edge detection and skip detection are determined by comparing the buffer values (*[ENxINPMON]* <DETMONA>, <DETMONB> and <DETMONZ>) with the current input values (*[ENxINPMON]*<SPLMONA>, <SPLMONB> and <SPLMONZ>).

#### 3.3.2.6. BEMF Detection Control

In sensor mode (timer count and phase count), BEMF detection control is enabled when *[ENxINPCR]* <SYNCSPLEN>=1 (PWM synchronous sampling). It can stop (suspend) or start (restart) the rotational edge detection.

This control is used when position detection is performed on the induced voltage of the BLDC motor driven on rectangular waveforms generated by the PMD (position sensorless control).

- (1) Starting the rotational edge detection
- Command operation: Write "1" to [ENxINPCR]<PDSTT>
- Event operation: An INT compare match from the counter circuit
- (2) Stopping the rotational edge detection
- Command operation: Write "1" to [ENxINPCR]<PDSTP>
- Event operation: A rotational edge is detected.

#### 3.3.3. Counter

The counter circuit consists of the clock generator, counter, compare function, and capture function. Usable functions vary depending on the operation mode.

#### 3.3.3.1. Encoder Mode and Sensor Mode (Event Count)



#### Figure 3.22 Configuration of the counter (encoder mode and sensor mode (event count))

The counter circuits use a rotational edge pulse (ENCLK) from the decoder, a 16-bit up/down counter operating on rotational direction signal (DIR), and three types of compare functions: <RELOADH>, <INTH>, and <MCMPH>.

In encoder mode, the counter is cleared by a match of RELOAD compare during the CW rotation. When a CCW rotation is used, if the counter is determined as "0x0000", the value of the <RELOADH> is loaded to the counter.

In encoder mode, when ENCxZ is enabled (*[ENxTNCR]*<ZEN>=1), a match signal of INT compare and MCMP compare are ignored during when the encoder input is enabled (*[ENxTNCR]*<ENRUN>=1) to when an edge of the first ENCxZ is detected.

The value of the up/down counter can be read by the counter register (*[ENxCNT]*). When *[ENxINTCR]* </br><MCMPIE>=1, a MCMP completion signal serves as a commutation trigger for the PMD.

#### 3.3.3.2. Sensor Mode (Timer count) or Timer Mode



#### Figure 3.23 Configuration of the counter (sensor mode (timer count) or timer mode)

The counter consists of the 32-bit counter operating on the system clock (fsys), three-types of the compare functions (RELOAD, INT, and MCMP), and the capture function.

The MCMP compare function can select the selection type from match compare and compare in size. When comparison in size is selected (*[ENxTNCR]*<MCMPMD>=1), comparison starts by setting the *[ENxMCMP]* register. If the conditions are met, a MCMP completion signal is output and comparison finishes.

The counter is cleared by a match of INT compare or RELOAD compare in timer mode.

In sensor mode (timer count), the counter is captured and cleared when a rotational edge is detected (ENCLK). In timer mode, the counter is captured and cleared when a Z-edge is detected (ZDETECT). The captured value can be read by reading the counter register (*[ENxCNT]*).

When *[ENxINTCR]*<MCMPIE>=1, a MCMP completion signal serves as a commutation trigger signal for the PMD.

#### 3.3.3.3. Sensor Mode (Phase count) or Phase Counter Mode



#### Figure 3.24 Configuration of the counter (sensor mode (phase count), and phase counter mode)

The counter consists of the clock generator specified with *[ENxRATE]*, a 16-bit up/down counter operating on the clock signal and direction signal from the clock generator, three-types of compare match comparators (<RELOADH>, <INTH>, and <MCMPH>), and capture function.

The counter clock is specified with the *[ENxRATE]* register at the specified rate.

The up/down counter is specified with *[ENxTNCR]*<UDMD>. However, in phase counter mode (phase difference measurement) (*[ENxTNCR]*<MODE>=111, <ZEN>=1, <P3EN>=1), up / down control is performed with the PZXOR signal

When the counter is set to up counting, the counter is cleared by a match of RELOAD compare. When the counter is set to down counting, if the counter is determined as "0x0000", the value of the <RELOADH> is loaded to the counter.

In sensor mode (phase count), the counter is captured and cleared when a rotational edge is detected on ENCLK. In phase counter mode, the counter is captured and cleared when a Z-edge is detected (ZDETECT). The captured value can be read by reading the counter register (*[ENxCNT]*).

When *[ENxINTCR]*<MCMPIE>=1, a MCMP completion signal serves as a commutation trigger signal for the PMD.

#### 3.3.4. Interrupt Control

The counter outputs two types of interrupts among the 6 types of interrupt events. An interrupt is enabled to output with the interrupt control register (*[ENxINTCR]*) according to the interrupt event. An interrupt event can be checked with an interrupt flag (*[ENxINTF]*).

The interrupt flag register (*[ENxINTF]*) is set by the occurrence of the interrupt event, and the flag is cleared by reading the register.

| Interrupt<br>event   | Description                                                                                                                                                                                                                                                                  | Mode                                                                                                    | Interrupt<br>enable<br>[ENxINTCR] | Event flag<br>[ENxINTF] | Interrupt<br>output |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------------|---------------------|--|
| Divided<br>pulse     | When a rotational edge pulse is divided by 1 to 128 with <b>[ENxTNCR]</b> <endev>, this interrupt is sent.</endev>                                                                                                                                                           | Encoder mode<br>Sensor mode (event count)                                                               | <tplsie></tplsie>                 | <tplsf></tplsf>         | INTENCx0            |  |
| Capture              | When the value of the counter is captured due to the external trigger (ENCxZ input), this interrupt is sent.                                                                                                                                                                 | Timer mode<br>Phase counter mode                                                                        | <capie></capie>                   | <capf></capf>           | INTENCx0            |  |
|                      | When the value of the counter is captured due to ENCLK, this interrupt is sent.                                                                                                                                                                                              | Sensor mode (timer count, phase count)                                                                  |                                   |                         |                     |  |
| Detection<br>error   | When an edge detection error ( <b>[ENxSTS]</b><br><pderr>) or the skip detection (<b>[ENxSTS]</b><br/><skpdt>) occurs, this interrupt is sent.</skpdt></pderr>                                                                                                               | Encoder mode<br>Sensor mode (event count,<br>timer count and phase<br>count)                            | <errie></errie>                   | <errf></errf>           | INTENCx0            |  |
| A match of INT       | When the value of the <b>[ENxINT]</b> register matches the counter value, this interrupt is sent.                                                                                                                                                                            | All modes                                                                                               | <cmpie></cmpie>                   | <intcpf></intcpf>       | INTENCx1            |  |
| A match of<br>RELOAD | When the value of the <b>[ENxRELOAD]</b> register matches the counter value, this interrupt is sent.                                                                                                                                                                         | Sensor mode (timer count<br>and phase count)<br>Timer mode<br>Phase counter mode<br>(phase measurement) | <rldie></rldie>                   | <rldcpf></rldcpf>       | INTENCx1            |  |
| MCMP                 | When <b>[ENxTNCR]</b> <mcmpmd>=0, if the<br/><b>[ENxMCMP]</b> register matches the counter value,<br/>this interrupt is sent. When <mcmpmd>=1, if the<br/>counter value is the value of the <b>[ENxMCMP]</b><br/>register or more, this interrupt is sent.</mcmpmd></mcmpmd> | Sensor mode (timer count)<br>Timer mode                                                                 | <mcmpie></mcmpie>                 |                         |                     |  |
| completion           | When the value of the <b>[ENXMCMP]</b> register matches the counter value, this interrupt is sent.                                                                                                                                                                           | Encoder mode<br>Sensor mode (event count<br>and phase count)<br>Phase counter mode                      |                                   |                         |                     |  |

#### Table 3.2 List of interrupt events

 Table 3.3
 Interrupt events of each mode

| Mode                      | Interrupt event                                                              |
|---------------------------|------------------------------------------------------------------------------|
| Encoder Mode              | Divided pulse, Detection error, A match of INT, MCMP completion              |
| Sensor Mode (event count) | Divided pulse, Detection error, A match of INT, MCMP completion              |
| Sensor Mode (timer count) | Capture, Detection error, A match of INT, A match of RELOAD, MCMP completion |
| Sensor Mode (phase count) | Capture, Detection error, A match of INT, A match of RELOAD, MCMP completion |
| Timer Mode                | Capture, A match of INT, A match of RELOAD, MCMP completion                  |
| Phase Counter Mode        | Capture, A match of INT, A match of RELOAD, MCMP completion                  |

## 4. Registers

## 4.1. Register List

The following table lists the control registers and their addresses:

| Perinheral function            | Channel/Unit | Base Address |  |  |
|--------------------------------|--------------|--------------|--|--|
| r enpheral faneta              | onannei/onit | TYPE1        |  |  |
| Advanced Encoder Input Circuit | ch0          | 0x400F7000   |  |  |

| Register Name                  | Address (Base+) |        |
|--------------------------------|-----------------|--------|
| ENC Control Register           | [ENxTNCR]       | 0x0000 |
| RELOAD Compare Register        | [ENxRELOAD]     | 0x0004 |
| INT Compare Register           | [ENxINT]        | 0x0008 |
| Counter Register               | [ENxCNT]        | 0x000C |
| MCMP Compare Register          | [ENxMCMP]       | 0x0010 |
| Phase Count Rate Register      | [ENxRATE]       | 0x0014 |
| Status Register                | [ENxSTS]        | 0x0018 |
| Input Process Control Register | [ENxINPCR]      | 0x001C |
| Sample Delay Register          | [ENxSMPDLY]     | 0x0020 |
| Input Monitor Register         | [ENxINPMON]     | 0x0024 |
| Sample Clock Control Register  | [ENxCLKCR]      | 0x0028 |
| Interrupt Control Register     | [ENxINTCR]      | 0x002C |
| Interrupt Flag Register        | [ENxINTF]       | 0x0030 |

Note: The registers which can be updated in operation are *[ENxTNCR]*<SFTCAP>, <ENRUN>, and <ENCLR>, and *[ENxINPCR]*<PDSTP> and <PDSTT>. The other registers should not be updated in operation.

### 4.2. Details of Registers

When describing the register function for each operation mode, it is explained after showing the operation mode in [xx mode].

#### 4.2.1. [ENxTNCR] (ENC Control Register)

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 28    | CMPSEL     | 0           | R/W  | [Timer mode]<br>Counter clear condition.<br>0: A match of the <i>[ENxINT]</i> register<br>1: A match of the <i>[ENxRELOAD]</i> register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27:26 | UDMD[1:0]  | 00          | R/W  | [Sensor mode (phase count), Phase counter mode (phase<br>measurement)]<br>Sets the up/down count setting.<br>00: Up count<br>01: Down count<br>10,11: Sets to up or down count setting with the <b>[ENxRATE]</b><br>register<br>When this field is set to "10" or "11", if <b>[ENxRATE]</b> < 0, the<br>counter is set to down count setting. If <b>[ENxRATE]</b> ≥ 0, the<br>counter is set to up count setting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25    | TOVMD      | 0           | R/W  | Sets the counter operation when the <i>[ENxRELOAD]</i> register<br>matches the value of the counter (timeout operation setting).<br>[Sensor mode (timer count)]<br>0: Counting continues.<br>1: Counting stops.<br>When the counter stops, the match should be cleared by<br>software to restart the counter.<br>[Timer mode, Sensor mode (phase count), Phase counter mode<br>(phase measurement)]<br>0: The counter is cleared and counting continues.<br>1: Counting stops<br>When the counter stops, the match should be cleared by<br>software to restart the counter.<br>[Encoder mode]<br>Regardless of the <tovmd> setting, when the motor drives on<br/>CW direction, the counter is cleared and counting continues,<br/>when the motor drives on CCW direction, counting continues.<br/>[Sensor mode (event count)]<br/>This bit is not used for a match of RELOAD.</tovmd> |
| 24    | MCMPMD     | 0           | R/W  | [Sensor mode (timer count), or Timer mode]<br>Compare mode for the <i>[ENxMCMP]</i> register.<br>0: Compare match ( <i>[ENxMCMP]</i> = counter value)<br>1: Comparison in size ( <i>[ENxMCMP]</i> ≤ counter value)<br>Set <mcmpmd> to "0" except in sensor mode (timer count) or<br/>timer mode.</mcmpmd>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| T | 0 | S | Η | B | A |
|---|---|---|---|---|---|
|   |   |   |   |   |   |

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:22 | DECMD[1:0] | 00          | R/W  | <ul> <li>[Encoder mode or Sensor mode]</li> <li>Sets the detection direction for the decoder.</li> <li>00: CW or CCW edge detection Detects the variation of input signals (ENCxA, ENCxB, and ENCxZ).</li> <li>01: CW edge detection Detects the variation of the input signal from the previous state on rotational edge detection to the current state. (The result of detection Detects the variation of the input signal from the previous state on rotational edge detection to the current state. (The result of detection Detects the variation of the input signal from the previous state on rotational edge detection to the current state. (The result of detection is maintained.)</li> <li>11: CW or CCW edge detection Detects the variation of the input signal from the previous state on rotational edge detection to the current state. (The result of detection Detects the variation of the input signal from the previous state on rotational edge detection to the current state. (The result of detection) Set <decmd> to "00" in timer mode or phase counter mode.</decmd></li> </ul> |
| 21    | SDTEN      | 0           | R/W  | [Encoder mode or Sensor mode]<br>Sets skip detection.<br>0: Detection is disabled.<br>1: Detection is enabled.<br>For details, refer to "3.3.2.3.Skip Detection and Abnormal Input<br>Detection".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20    | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19:17 | MODE[2:0]  | 000         | R/W  | Sets the operation mode.<br>000: Encoder mode<br>001: Sensor mode (event count)<br>010: Sensor mode (timer count)<br>011: Timer mode<br>100: Reserved<br>101: Reserved<br>101: Sensor mode (phase count)<br>111:Phase counter mode<br>In Phase counter mode, when <zen>=<p3en>=1, the operation<br/>mode becomes "phase difference measurement".<br/>There are 13 operation modes. The operation mode is<br/>determined by <mode> <p3en> and <zen> (Refer to "Table</zen></p3en></mode></p3en></zen>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16    | P3EN       | 0           | R/W  | 3.1 Setting of operation mode").         [Sensor mode]         Sets the decoding mode (2-phase/3-phase input selection)         0: 2-phase decoding         1: 3-phase decoding         [Phase counter mode (phase difference measurement)]         Set <p3en> and <zen> to "1".         [Encoder mode, Timer mode, or Phase counter mode (phase measurement)]         Set <p3en> to "0".         (Refer to "Table 3.1 Setting of operation mode").</p3en></zen></p3en>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:13 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12  | TRGCAPMD   | 0           | R/W  | [Sensor mode (timer count or phase count), Timer mode, or<br>Phase counter mode]<br>Trigger capture operation selection<br>0: Capturing and clearing the counter<br>1: Only capturing<br>Selects the capture operation at rotational edge detection in<br>sensor mode (timer count or phase count).<br>Selects the capture operation when the ENCxZ input is enabled<br>in timer mode or phase counter mode.<br>When software capturing is used, the counter is not cleared.<br>[Encoder mode and Sensor mode (event count)]<br>Capture is not performed |
| 11  | SFTCAP     | 0           | w    | <ul> <li>[Sensor mode (timer count, phase count), Timer mode, or Phase counter mode]</li> <li>Performs software capturing. <ol> <li>Captures the value of the counter.</li> </ol> </li> <li>When this bit to "1", the value of the counter is captured. To obtain the captured value, read the <i>[ENxCNT]</i> register.</li> <li>Writing "0" has no meaning. Read as "0".</li> <li>[Encoder mode and Sensor mode (event count)]</li> <li>Write as "0".</li> </ul>                                                                                       |
| 10  | ENCLR      | 0           | W    | Clears the counter.<br>1: Clear<br>When this bit to "1", the counter is cleared to "0". After the<br>counter is cleared, the counter restarts operation.<br>Writing "0" has no meaning. Read as "0".<br><sftcap> and <enclr> should not be set to "1" at the same<br/>time.</enclr></sftcap>                                                                                                                                                                                                                                                             |
| 9:8 | ZESEL[1:0] | 00          | R/W  | [Timer mode or Phase counter mode]<br>Selects the detection edge when the ENCxZ input is enabled.<br>(The ENCxZ input/the ENCxPSGI input)<br>00: Reserved<br>01: A rising edge is detected.<br>10: A falling edge is detected.<br>11: Both edges are detected.<br>In the phase counter mode (phase difference measurement), the<br>detection target is the ENCxPSGI input.                                                                                                                                                                               |
| 7   | ZEN        | 0           | R/W  | [Encoder mode, Timer mode, or Phase counter mode (phase<br>measurement)]<br>Enables/disables Z-phase input.<br>0: The ENCxZ input is disabled.<br>1: The ENCxZ input is enabled.<br>[Phase counter mode (phase difference measurement)]<br>Set <p3en> and <zen> to "1".<br/>[Sensor mode]<br/>Set <zen> to "0".<br/>(Refer to "Table 3.1 Setting of operation mode").</zen></zen></p3en>                                                                                                                                                                 |
| 6   | ENRUN      | 0           | R/W  | Enables/disables the encoder input circuit.<br>0: Disabled<br>1: Enabled<br>When <enrun>=1, <zdet> is cleared to "0" and the encoder<br/>input circuit is also enabled.<br/>When <enrun>=0, the encoder input circuit is disabled.</enrun></zdet></enrun>                                                                                                                                                                                                                                                                                                |
| 5:3 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Bit | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | ENDEV[2:0] | 000         | R/W  | [Encoder mode, or Sensor mode (event count)] Sets the ratio of a divided output (ENCxTIMPLS) of a rotational edge pulse. According to this setting, a rotational edge pulse is divided and this pulse is used as an interrupt event. 000: divided by 1 001: divided by 2 010: divided by 4 011: divided by 8 100: divided by 16 101: divided by 32 110: divided by 64 111: divided by 128 [Sensor mode (timer count and phase count), Timer mode, and Phase counter mode] There is no division output. |

Note: When setting <ENRUN>=1, do not change other bits at the same time. Operation settings other than <ENRUN> must be set before setting <ENRUN>=1.

#### 4.2.2. [ENxRELOAD] (RELOAD Compare Register)

| Bit   | Bit Symbol    | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|---------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RELOADH[15:0] | 0x0000      | R/W  | [Encoder mode]<br>Sets the maximum value of the counter.<br>[ENxTNCR] <zen>=1:<br/>Set "Number of input pulses per rotation × 4".<br/>[ENxTNCR]<zen>=0:<br/>Set "Number of input pulses per rotation" × 4 -1"<br/>[Sensor mode (phase count) or Phase counter mode]<br/>Sets the maximum value (count range per rotation) of the<br/>counter. [Sensor mode (timer count) or Timer mode]<br/>This field is used as the register to compare with the counter. If a<br/>match occurs, an interrupt occurs. Sets the upper 16 bits of 32<br/>bits for comparison. [Sensor mode (event count)]<br/>This field is not used.</zen></zen> |
| 15:0  | RELOADL[15:0] | 0x0000      | R/W  | [Sensor mode (timer count) or Timer mode]<br>Sets the lower 16 bits for 32-bit comparison.<br>[Others]<br>This field is not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 4.2.3. [ENxINT] (INT Compare Register)

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | INTH[15:0] | 0x0000      | R/W  | [Encoder mode or Sensor mode (event count)]<br>Sets the value on 16 bits for comparison with the counter.<br>When the counter matches the value of <inth>, an INT match<br/>signal occurs. At this time, an interrupt can be generated.<br/>[Sensor mode (timer count) or Timer mode]<br/>Sets the value on 32 bits for comparison with the counter. Sets<br/>the upper 16 bits of 32 bits to <inth> for comparison.<br/>When the counter matches the value of <inth>, an INT match<br/>signal occurs. At this time, an interrupt can be generated.<br/>[Sensor mode (phase count) or Phase counter mode]<br/>Sets the value on 16 bits for comparison with the counter.<br/>When the counter matches the value of <inth>, an INT match<br/>signal occurs. At this time, an interrupt can be generated.</inth></inth></inth></inth> |
| 15:0  | INTL[15:0] | 0x0000      | R/W  | [Sensor mode (timer count) or Timer mode]<br>Sets the lower 16 bits for 32-bit comparison.<br>[Others]<br>This field is not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Note) In sensor mode (phase count, timer count), it is used for BEMF control (Refer to "3.3.2.6.BEMF Detection Control").

### 4.2.4. [ENxCNT] (Counter Register)

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | CNTH[15:0] | 0x0000      | R    | <ul> <li>[Encoder mode or Sensor mode (event count)]</li> <li>Read the counter value of a rotational edge pulse.</li> <li>[Sensor mode (timer count or phase count)]</li> <li>Read the captured value at rotational edge detection/at the ENCxZ input edge detection or software capture.</li> <li>[Timer mode or Phase counter mode (phase measurement)]</li> <li>Read the captured value at the ENCxZ input edge detection or the software capture.</li> <li>[Sensor mode (timer count) or Timer mode]</li> <li>Read the value of the upper 16 bits at 32-bit capturing.</li> <li>[Phase counter mode (phase difference measurement)]</li> <li>Read the captured value at the software capture or the ENCxPSGI signal edge detection.</li> </ul> |
| 15:0  | CNTL[15:0] | 0x0000      | R    | <ul> <li>[Encoder mode, Sensor mode (event count or phase count), or<br/>Phase counter mode]</li> <li>This field is not used.</li> <li>[Sensor mode (timer count) or Timer mode]</li> <li>Read the value of the lower 16 bits at 32-bit capturing.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 4.2.5. [ENxMCMP] (MCMP Compare Register)

| Bit   | Bit Symbol  | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | MCMPH[15:0] | 0x0000      | R/W  | [Sensor mode (timer count) or Timer mode]<br>Sets the value on 32 bits for comparison with the counter. Set<br>this field to the upper 16 bits of 32 bits for comparison.<br>An interrupt can be generated.<br><u>Comparison in size ([ENxTNCR]<mcmpmd>=1)</mcmpmd></u><br>An MCMP completion signal is output when<br>[ENxMCMP] < a counter value is established.<br>In this mode, one completion signal is output in each time the<br>register is written.<br><u>Compare match mode ([ENxTNCR]<mcmpmd>=0)</mcmpmd></u><br>An MCMP completion signal is output when<br>[ENxMCMP] = a counter value is established.<br>[Except Sensor mode (timer count) or Timer mode]<br>Sets the value on 16 bits for comparison with the counter. An<br>interrupt can be generated.<br>An MCMP completion signal is output when<br>[ENxMCMP] |
| 15:0  | MCMPL[15:0] | 0x0000      | R/W  | [Sensor mode (timer count) or Timer mode]<br>Set this field to the lower 16 bits of 32 bits for comparison.<br>[Others]<br>This field is not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 4.2.6. [ENxRATE] (Phase Count Rate Register)

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:0  | RATE[15:0] | 0x0000      | R/W  | [Sensor mode (phase count) or Phase counter mode]<br>Set the count frequency of the counter.<br>Clock frequency generation: fsys × <rate> /2<sup>16</sup><br/>Depending on the <i>[ENxTNCR]</i><udmd> setting, the value of<br/><rate> can be specified as a signed bit or unsigned bit. If the<br/>value of <rate> is negative, the counter counts down.<br/><udmd>=0x: Unsigned, 0 or more/less than 1.0<br/>(0x0000 to 0xFFFF)<br/><udmd>=1x: Signed, -0.5 or more/less than 0.5<br/>(0x8000 to 0x7FFF, two's complement)<br/>When <rate>=0x0000, <i>[ENxCNT]</i> does not count.<br/>[Encoder mode, Sensor mode (event count and timer count),<br/>and Timer mode]<br/>Unused.</rate></udmd></udmd></rate></rate></udmd></rate> |

#### 4.2.7. [ENxSTS] (Status Register)

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                            |
| 14    | REVERR     | 0           | R    | [Sensor mode (timer count)]<br>Sets the flag at inversion of <ud> when the both edges are<br/>detected. (Note1) (Note2)<br/>0: -<br/>1: An inversion of <ud> is detected.<br/>When <i>[ENxTNCR]</i><enrun>=0, this bit is set to "0".<br/>After <enrun> is set to "1", the flag that shows inversion is<br/>not set at the first rotating edge pulse (ENCLK).</enrun></enrun></ud></ud> |
| 13    | UD         | 0           | R    | [Encoder mode or Sensor mode (event count, timer count, or<br>phase count)]<br>Determination state of the rotation direction.<br>0: CCW (Counterclockwise)<br>1: CW (Clockwise)<br>When the motor rotates to CW direction, this bit is "1". When<br>the motor rotates to CCW direction, this bit is "0". If<br>[ENxTNCR] <enrun>=0, "0" is always set.</enrun>                          |
| 12    | ZDET       | 0           | R    | <ul> <li>[Encoder mode]</li> <li>Detects passing of the ENCxZ input.</li> <li>0: A ENCxZ input is not detected after the encoder input has been enabled.</li> <li>1: A ENCxZ input is detected.</li> <li>This bit is cleared when <i>[ENxTNCR]</i><enrun>=0.</enrun></li> </ul>                                                                                                         |
| 11:3  | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                            |
| 2     | SKPDT      | 0           | R    | [Sensor mode (event count, timer count)]<br>Detects a skip detection flag when skip detection is enabled.<br>(Note1)<br>0: Undetected<br>1: A skip is detected.                                                                                                                                                                                                                         |
| 1     | PDERR      | 0           | R    | [Encoder mode, Sensor mode (event count, timer count, or<br>phase count)]<br>Detects an edge detection error flag. (Note1)<br>0: Undetected<br>1: An error is detected.                                                                                                                                                                                                                 |
| 0     | INERR      | 0           | R    | [Sensor mode (event count, timer count, or phase count)]<br>Detects an abnormal input error. (Note1)<br>0: No abnormal error<br>1: Abnormal error<br>This bit is set to "1" when all 3-phase inputs on 3-phase<br>decoding are "Low" or "High".                                                                                                                                         |

Note1: The flag is cleared by reading this register.

Note2: After the mode transition, make sure to read this register first to clear the flag.

#### 4.2.8. [ENxINPCR] (Input Process Control Register)

| Bit   | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                           |
| 14:8  | NCT        | 0x00        | R/W  | Sets the noise cancel time. (Note1)<br>Setting range: 0 to 127 (0x00 to 0x7F)<br>Cancel time: Setting value × Sample clock cycle<br>(with the <i>[ENxCLKCR]</i> <splcks> setting)<br/>When this field is set to "0x00", noise cancelling does not<br/>operate. The sampling clock in PWM-off edge sample mode is<br/>a PWM signal.</splcks>                                                            |
| 7     | PDSTP      | 0           | W    | [Sensor mode (timer count or phase count)]<br>Sets the rotational edge detection stop command at PWM<br>synchronous sampling. (BEMF detection control)<br>0: -<br>1: Stops rotational edge detection<br>When this bit is set to "1", rotational edge detection is stopped.<br>Writing "0" has no meaning.<br>Read as "0".<br>Do not set <pdstp> and <pdstt> to "1" at the same time.</pdstt></pdstp>   |
| 6     | PDSTT      | 0           | w    | [Sensor mode (timer count or phase count)]<br>Sets the rotational edge detection start command at PWM<br>synchronous sampling. (BEMF detection control)<br>0: -<br>1: Starts rotational edge detection<br>When this bit is set to "1", rotational edge detection is started.<br>Writing "0" has no meaning.<br>Read as "0".<br>Do not set <pdstp> and <pdstt> to "1" at the same time.</pdstt></pdstp> |
| 5:3   | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                           |
| 2     | SYNCNCZEN  | 0           | R/W  | Controls a noise cancel counter when sampling is performed in<br>the PWM-on period.<br>0: The counter stops in the PWM-off period.<br>1: The counter stops and cleared in the PWM-off period.<br>This setting is used to enable the PWM synchronous sampling<br>( <syncsplen>=1) and to select the PWM sampling in the<br/>PWM-on period (<syncsplnd>=0).</syncsplnd></syncsplen>                      |
| 1     | SYNCSPLND  | 0           | R/W  | Selects the PWM synchronous sampling<br>0: Sampling in the PWM-on period<br>1: Sampling in the PWM-off edge<br>This setting is enabled when the PWM synchrony sampling is<br>enabled ( <syncsplen>=1).</syncsplen>                                                                                                                                                                                     |
| 0     | SYNCSPLEN  | 0           | R/W  | Enables the PWM synchronous sampling<br>0: Continuous sampling<br>1: PWM synchronous sampling(Note1)<br>This bit enables the PWM synchronous sampling. (Note2)<br>When <syncsplen> is set to "1" in sensor mode (timer<br/>count or phase count), BEMF detection control is enabled on<br/>decoding operation.</syncsplen>                                                                             |

Note1: For the PWM synchronous sampling (<SYNCSPLEN>=1), set <NCT> to "1" or more.

Note2: For details of the PMD, refer to "Programmable Motor Control Circuit Plus" or "Advanced Programmable Motor Control Circuit" of the reference manual.

#### 4.2.9. [ENxSMPDLY] (Sample Delay Register)

| Bit  | Bit Symbol  | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -           | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:0  | SMPDLY[7:0] | 0x00        | R/W  | Sampling start delay time<br>Setting range: 0 to 255 (0x00 to 0xFF)<br>Start delay time: <smpdly> setting value × Sampling cycle<br/>(with the <i>[ENxCLKCR]</i><splcks> setting)<br/>Sets the sampling start delay time after the PWM-on edge, when<br/>the sampling in the PWM-on period is selected (<i>[ENxINPCR]</i><br/><syncsplen>=1, <i>[ENxINPCR]</i><syncsplnd>=0).</syncsplnd></syncsplen></splcks></smpdly> |

Note: After enabling ENC(after changing *[ENxTNCR]*<ENRUN> from "0" to "1"), the first delay time may not match the value of <SMPDLY>.

#### 4.2.10. [ENxINPMON] (Input Monitor Register)

| Bit  | Bit Symbol | After reset | Туре | Function                                                                                                                            |
|------|------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | -          | 0           | R    | Read as "0".                                                                                                                        |
| 6    | DETMONZ    | 0           | R    | Monitors the rotational edge detection status for NCZ.<br>(Note1) (Note2)<br>Stores the value of NCZ at rotational edge detection.  |
| 5    | DETMONB    | 0           | R    | Monitors the rotational edge detection status for NCB.<br>(Note1) (Note2)<br>Stores the value of NCB at rotational edge detection.  |
| 4    | DETMONA    | 0           | R    | Monitors the rotational edge detection status for NCA.<br>(Note1) (Note2)<br>Stores the value of NCA at rotational edge detection.  |
| 3    | -          | 0           | R    | Read as "0".                                                                                                                        |
| 2    | SPLMONZ    | 0           | R    | Monitors the status of ENCxZ after noise cancelling.<br>Stores the status of NCZ that is the ENCxZ input after noise<br>cancelling. |
| 1    | SPLMONB    | 0           | R    | Monitors the status of ENCxB after noise cancelling.<br>Stores the status of NCB that is the ENCxB input after noise<br>cancelling. |
| 0    | SPLMONA    | 0           | R    | Monitors the status of ENCxA after noise cancelling.<br>Stores the status of NCA that is the ENCxA input after noise cancelling.    |

Note1: When [ENxTNCR]<DECMD>=00, this bit indicates the previous value of <SPLMONn>(n=A, B, Z).
 Note2: This bit indicates the previous value of <SPLMONn>(n=A, B, Z) until the first rotational edge detection after changing [ENxTNCR]<ENRUN> to "1" or writing "1" to [ENxINPCR]<PDSTT>.

#### 4.2.11. [ENxCLKCR] (Sample Clock Control Register)

| Bit  | Bit Symbol  | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | -           | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                |
| 1:0  | SPLCKS[1:0] | 00          | R/W  | Sets the sampling frequency.<br>00: fsys<br>01: fsys/2<br>10: fsys/4<br>11: fsys/8<br>Sets the sampling frequency for the ENCxA input, the ENCxB<br>input, and the ENCxZ input.<br>On PWM synchronous sampling, this field is disabled, when off<br>edge sampling is set ( <i>[ENxINPCR]</i> <syncsplen>=1 and<br/><i>[ENxINPCR]</i><syncsplnd>=1).</syncsplnd></syncsplen> |

#### 4.2.12. [ENxINTCR] (Interrupt Control Register)

| Bit  | Bit Symbol | After reset | Туре | Function                                                                                                                                                                                                                                                                                                                                |
|------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | -          | 0           | R    | Read as "0".                                                                                                                                                                                                                                                                                                                            |
| 5    | MCMPIE     | 0           | R/W  | Enables/disables a MCMP completion interrupt.<br>0: Disabled<br>1: Enabled<br>When this bit to "1", an INTENCx1 occurs at MCMP completion.                                                                                                                                                                                              |
| 4    | RLDIE      | 0           | R/W  | Enables/disables a RELOAD interrupt.<br>0: Disabled<br>1: Enabled<br>When this bit to "1", an INTENCx1 occurs when the counter<br>matches the value of the RELOAD register.<br>A RELOAD interrupt does not occur in encoder mode or sensor<br>mode (event count).                                                                       |
| 3    | CMPIE      | 0           | R/W  | Enables/disables a INT interrupt.<br>0: Disabled<br>1: Enabled<br>When this bit to "1", an INTENCx1 occurs when the counter<br>matches the value of the INT register.                                                                                                                                                                   |
| 2    | ERRIE      | 0           | R/W  | Enables/disable a detection error interrupt.<br>0: Disabled<br>1: Enabled<br>When this bit to "1", an edge detection error ( <i>[ENxSTS]</i><br><pderr>=1) occurs, or when a skip is detected (<i>[ENxSTS]</i><br/><skpdt>=1), an INTENCx0 occurs.<br/>An interrupt does not occur in timer mode or phase counter mode.</skpdt></pderr> |
| 1    | CAPIE      | 0           | R/W  | Enables/disable a capture trigger interrupt.<br>0: Disabled<br>1: Enabled<br>When this bit to "1", if the value of the counter is captured due to<br>the external trigger (an ENCxZ input) or the rotational edge pulse<br>(ENCLK), an INTENCx0 occurs.<br>An interrupt does not occur in encoder mode or sensor mode<br>(event count). |
| 0    | TPLSIE     | 0           | R/W  | Enables/disable a rotational divided edge interrupt.<br>0: Disabled<br>1: Enabled<br>When this bit to "1", an INTENCx0 occurs by rotational edge<br>divided pulses.<br>An interrupt occurs only in encoder mode and sensor mode (event<br>count).                                                                                       |

#### 4.2.13. [ENxINTF] (Interrupt Flag Register)

| Bit  | Bit Symbol | After reset | Туре | Function                                                                                                                                                                |
|------|------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | -          | 0           | R    | Read as "0".                                                                                                                                                            |
| 5    | MCMPF      | 0           | R    | MCMP completion flag<br>0: No flag<br>1: The flag is generated.                                                                                                         |
| 4    | RLDCPF     | 0           | R    | RELOAD match flag<br>0: No flag<br>1: The flag is generated.<br>This bit is not set in encoder mode or sensor mode (event<br>count).                                    |
| 3    | INTCPF     | 0           | R    | INT match flag<br>0: No flag<br>1: The flag is generated.                                                                                                               |
| 2    | ERRF       | 0           | R    | Detection error flag<br>0: No flag<br>1: The flag is generated.<br>This bit is not set in timer mode or phase counter mode.                                             |
| 1    | CAPF       | 0           | R    | Capture flag<br>0: No flag<br>1: The flag is generated.<br>This bit is not set by soft capture.<br>This bit is not set in encoder mode or sensor mode (event<br>count). |
| 0    | TPLSF      | 0           | R    | Rotational edge divided pulse flag<br>0: No flag<br>1: The flag is generated.<br>This bit is enabled in encoder mode or sensor mode (event<br>count).                   |

Note: Each flag is set by the occurrence of the event that was enabled, and it is cleared by reading. When *[ENxTNCR]*<ENRUN>=0, each flag is set to "0".

## 5. Precaution for Usage

• Before the clock supply is shut down, it should be checked that A-ENC has stopped. And, before the operation mode is changed to the stop mode, it should be checked that A-ENC has stopped.

## 6. Revision History

| Revision | Date       | Description   |
|----------|------------|---------------|
| 1.0      | 2017-09-08 | First release |

| Revision | Date       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.0      | 2018-02-28 | <ul> <li>The entire document</li> <li>Z-input, Z signal, Encoder input Z, Z-phase→ENCxZ</li> <li>Encoder input () →ENCxA(U), Encoder input B, B-phase→ENCxB</li> <li>Encoder input () →ENCxA(U), Encoder input V→ENCxB(V)</li> <li>Encoder: "DIR'→Rotational direction <ud>"</ud></li> <li>"1. Outline"</li> <li>Table 2.1"</li> <li>"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption'&gt;"Interruption</li></ul> |

| Revision | Date       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.1      | 2018-10-10 | <ul> <li>Conventions<br/>Modified explanation of trademark</li> <li>"1. Outlines"<br/>Function Description of Phase counter: "Interrupt request" →"Interrupt"</li> <li>"2." Figure 2.1: "Encoder input circuit"→ "A-ENC",<br/>"Interrupt request"→"Interrupt"</li> <li>Table 2.1: "The PWM signal for a sampling"→"PWM signal for sampling"<br/>"Timer output signal in general"→"General purpose timer output signal"</li> <li>"3." Changed term of "3.2.1.", "3.2.2.1.", "3.2.4.1.", "3.2.4.2.", "3.3.4.":<br/>"Interrupt request"→"Interrupt"</li> <li>"3.1." Deleted "When attempting to stop supplying as well.</li> <li>"3.3.1." Figure 3.14 Corrected "<syncsplmd>"→"<syncsplnd>"</syncsplnd></syncsplmd></li> <li>"3.3.1.2." Corrected "<syncsplmd>"→"<syncsplnd>"</syncsplnd></syncsplmd></li> <li>"3.3.3.3." Explanation, Figure 3.24: "<i>[ENxRATE]</i></li> <li>RATE&gt;'→"<i>[ENxRATE]</i>"</li> <li>"3.3.4." Table 3.2 Corrected "Sensor mode"→"Sensor mode (event count,<br/>timer count and phase count)" of Detection error.</li> <li>"4.2.1." Added explanation to Function column of MODE[2: 0], P3EN,</li> <li>TRGCAPMD, SFTCAP, ENCLR, ZEN and ENDEV[2:0]. Note) was added.<br/>Modified Function column of TRGCAPMD: "2-input"→"ENCxZ input"</li> <li>"4.2.4." Function column of CNTH[15:0]:<br/>"phase counter mode"→ "Phase counter mode (phase measurement)"<br/>Added explanation of "<udmd>=1x."<br/>Added explanation of "HDBD=1x."<br/>Added explanation of of ther mode.</udmd></li> <li>"4.2.6." Function column of RATE[15:0]<br/>Modified explanation of other mode.</li> <li>"4.2.8." Added register name to Function column of NCT. Corrected<br/>"<syncsplmd>"→"<syncsplnd>" to Function column.</syncsplnd></syncsplmd></li> <li>-"4.2.9." Added register name to Function column of SMPDLY[7:0].</li> <li>"4.2.1." Corrected "<syncsplnd>" to Function column of<br/>SMPDLY[7:0].</syncsplnd></li> <li>"4.2.1." Corrected "<syncsplnd>" to Function column of<br/>SMPDLY[7:0].</syncsplnd></li> <li>"4.2.1.1." Corrected "<syncsplnd>" to Function column of<br/>SMPDLY[7:0].</syncsplnd></li> <li>"5." Added '5. Precaution for Usage" chapter</li> <li>"5." Added '5. Precaution for Usage" chapter</li> </ul> |

| Revision | Date       | Description                                                                                                                                                               |
|----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |            | - All over document Added bit field to bit symbol                                                                                                                         |
|          |            | - Prefer Modified trademark term                                                                                                                                          |
|          |            | - Audeu TAZ+ Tariliy                                                                                                                                                      |
|          |            | - 1. Outimes Table 1.1. Hole sensor 7 Hall sensor                                                                                                                         |
|          |            | $\sim$ 3.1. Older Supply Added clock supply and stop register C for rays                                                                                                  |
|          |            | - "3.2.1 Encoder Mode" "specified count value" $\rightarrow$ "specified counter value"                                                                                    |
|          |            | (2): " <reload>"→"<reloadh>"</reloadh></reload>                                                                                                                           |
|          |            | - "3.2.2. Sensor Mode Added "(BEMF Detection Control)"                                                                                                                    |
|          |            | - "3.2.2.1.Event Count" "specified count value"→"specified counter value"                                                                                                 |
|          |            | Figure 3.3: Changed the waveform of ENCxB, ENCxZ                                                                                                                          |
|          |            | (2): "Hall sensor"→"Rotational edge"                                                                                                                                      |
|          |            | Added "(2-phase input) or 120-degree (3-phase input)"                                                                                                                     |
|          |            | - "3.2.3. Limer Mode"                                                                                                                                                     |
|          |            | Figure 3.10: Changed the waveform of Counter, Capture register                                                                                                            |
|          |            | - 3.2.4.1.Phase Measurement                                                                                                                                               |
|          |            | - "3 3 1 2 Sampling Mode" Title of Figure 3 14: "PMN" -> "PWM"                                                                                                            |
|          |            | - "3.3.1.3 Noise Cancelling" (1): " <syncspi en="">=1"<math>\rightarrow</math>"<syncspi en="">=0"</syncspi></syncspi>                                                     |
|          |            | - "3.3.2. Decoder" Revised the second sentence.                                                                                                                           |
|          |            | - "3.3.2.3.Skip Detection and Abnormal Input Detection"                                                                                                                   |
|          |            | (1): Deleted "If a skip is detected, <skpdt> is set to "1"."</skpdt>                                                                                                      |
|          |            | Added an item "Combination that skip detection flag                                                                                                                       |
|          |            | ( <i>[ENxSTS]</i> <skpdt>) is set to "1""</skpdt>                                                                                                                         |
|          |            | - "3.3.2.4. Edge Detection Error Detection"                                                                                                                               |
|          |            | Added <b>[ENXSIS]</b> <pderr> is set to 1, when an error is detected.<br/>2nd term: "<math>\leq</math>SDETENS" <math>\rightarrow</math> "<math>\leq</math>SDTENS"</pderr> |
|          |            | - "3 3 3 1 Encoder Mode and Sensor Mode (Event Count)"                                                                                                                    |
| 2.2      | 2020-10-19 | Figure 3.22: Added ZDETECT signal                                                                                                                                         |
|          |            | - "3.3.3.2.Sensor Mode (Timer count) or Timer Mode"                                                                                                                       |
|          |            | Figure 3.23: Added <tovmd> and <trgcapmd></trgcapmd></tovmd>                                                                                                              |
|          |            | - "3.3.3.Sensor Mode (Phase count) or Phase Counter Mode"                                                                                                                 |
|          |            | Figure 3.24: Added <1OVMD> and <1RGCAPMD><br>" <mcmpen>"→"<mcmpie>"<br/>- "3.3.4 Interrupt Control" Table 3.2: "PDERR"→"<i>IEN</i>×STSI/PDERR&gt;"</mcmpie></mcmpen>      |
|          |            |                                                                                                                                                                           |
|          |            | "SKPDT"→" <i>IFNxSTSI</i> ~SKPDT>"                                                                                                                                        |
|          |            | "SKPDT"→"[ENXSTS] <skpdt>"<br/>"count value"→"counter value"</skpdt>                                                                                                      |
|          |            | - "4.1.Register List" Base address list: Revised the item row                                                                                                             |
|          |            | Register address list: "Address"→"Address (Base+)"                                                                                                                        |
|          |            | - "4.2.Details of Registers"                                                                                                                                              |
|          |            | "4.2.1." to "4.2.13." Form line: "Description" →"Function"                                                                                                                |
|          |            | 4.2.1. DECMD/Function: phase count mode → phase counter mode<br>SDTEN/Function: Added "For details, refer to "3.3.2.3                                                     |
|          |            | Deleted "When a skin is detected an error flag ( ) is set "                                                                                                               |
|          |            | ZESEL/Function: "PSGI"→"ENCxPSGI"                                                                                                                                         |
|          |            | "4.2.2." RELOADH/Function: Separated the description of encoder mode                                                                                                      |
|          |            | by the setting of <zen></zen>                                                                                                                                             |
|          |            | "4.2.3." INTH/Function: Deleted "This match signal can be used as a                                                                                                       |
|          |            | rotational edge detection start signal when the PWM                                                                                                                       |
|          |            | synchronous sampling is enabled." to the sensor mode                                                                                                                      |
|          |            | Added Hole<br>"A 2 A " _ CNTH/Function: "count value" →"counter value"                                                                                                    |
|          |            | 4.2.4. CNTL/Function: "phase count mode"→"phase counter mode"                                                                                                             |
|          |            | "4.2.5." MCMPH/Function: " <mcmpmd>"→"<i>IENxTNCR1</i><mcmpmd>"</mcmpmd></mcmpmd>                                                                                         |
|          |            | "4.2.7." REVERR/Function: Added "After <enrun> is set to "1". the</enrun>                                                                                                 |
|          |            | inverted flag is not set at the first rotating edge pulse (ENCLK)."                                                                                                       |
|          |            | SKPDT/Function: Added "[Sensor mode (event count, timer count)]"                                                                                                          |

| Revision | Date       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.3      | 2022-05-16 | <ul> <li>Figure 2.1 Added fsys</li> <li>Table 2.1 Added fsys, Correction of errors</li> <li>3.2.2.2. Changed <i>[ENxINT]</i>, <i>[ENxRELOAD]</i>, <i>[ENxMCMP]</i> from 16bit to 32bit notation, Changed 0x0000 to 0x00000000</li> <li>Figure 3.22 ZDETECT changed to "from decode".</li> <li>Changed from "CTRGO" in Figure 3.22, Figure 3.23, and Figure 3.24 to "ENCxCTRGO".</li> <li>Figure 3.23 Changed from "Comparison in size" to " Compare match or Comparison in size". Changed from "<i>[ENxTNCR]</i><mode[2:1]>=11" to "</mode[2:1]></li> <li><i>[ENxTNCR]</i><mode[2:1]>=01".</mode[2:1]></li> <li>4.2.2 Changed the function description of RELOADL[15:0]</li> <li>4.2.5 Changed the function description of MCMPL[15:0]</li> </ul> |

#### **RESTRICTIONS ON PRODUCT USE**

Toshiba Corporation and its subsidiaries and affiliates are collectively referred to as "TOSHIBA". Hardware, software and systems described in this document are collectively referred to as "Product".

- TOSHIBA reserves the right to make changes to the information in this document and related Product without notice.
- This document and any information herein may not be reproduced without prior written permission from TOSHIBA. Even with TOSHIBA's written permission, reproduction is permissible only if reproduction is without alteration/omission.
- Though TOSHIBA works continually to improve Product's quality and reliability, Product can malfunction or fail. Customers are responsible for complying with safety standards and for providing adequate designs and safeguards for their hardware, software and systems which minimize risk and avoid situations in which a malfunction or failure of Product could cause loss of human life, bodily injury or damage to property, including data loss or corruption. Before customers use the Product, create designs including the Product, or incorporate the Product into their own applications, customers must also refer to and comply with (a) the latest versions of all relevant TOSHIBA information, including without limitation, this document, the specifications, the data sheets and application notes for Product and the precautions and conditions set forth in the "TOSHIBA Semiconductor Reliability Handbook" and (b) the instructions for the applications, including but not limited to (a) determining the appropriateness of the use of this Product in such design or applications; (b) evaluating and determining the applicability of any information contained in this document, or in charts, diagrams, programs, algorithms, sample application circuits, or any other referenced documents; and (c) validating all operating parameters for such designs and applications. TOSHIBA ASSUMES NO LIABILITY FOR CUSTOMERS' PRODUCT DESIGN OR APPLICATIONS.
- PRODUCT IS NEITHER INTENDED NOR WARRANTED FOR USE IN EQUIPMENTS OR SYSTEMS THAT REQUIRE EXTRAORDINARILY HIGH LEVELS OF QUALITY AND/OR RELIABILITY, AND/OR A MALFUNCTION OR FAILURE OF WHICH MAY CAUSE LOSS OF HUMAN LIFE, BODILY INJURY, SERIOUS PROPERTY DAMAGE AND/OR SERIOUS PUBLIC IMPACT ("UNINTENDED USE"). Except for specific applications as expressly stated in this document, Unintended Use includes, without limitation, equipment used in nuclear facilities, equipment used in the aerospace industry, lifesaving and/or life supporting medical equipment, equipment used for automobiles, trains, ships and other transportation, traffic signaling equipment, equipment used to control combustions or explosions, safety devices, elevators and escalators, and devices related to power plant. IF YOU USE PRODUCT FOR UNINTENDED USE, TOSHIBA ASSUMES NO LIABILITY FOR PRODUCT. For details, please contact your TOSHIBA sales representative or contact us via our website.
- Do not disassemble, analyze, reverse-engineer, alter, modify, translate or copy Product, whether in whole or in part.
- Product shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable laws or regulations.
- The information contained herein is presented only as guidance for Product use. No responsibility is assumed by TOSHIBA for any infringement of patents or any other intellectual property rights of third parties that may result from the use of Product. No license to any intellectual property right is granted by this document, whether express or implied, by estoppel or otherwise.
- ABSENT A WRITTEN SIGNED AGREEMENT, EXCEPT AS PROVIDED IN THE RELEVANT TERMS AND CONDITIONS OF SALE FOR PRODUCT, AND TO THE MAXIMUM EXTENT ALLOWABLE BY LAW, TOSHIBA (1) ASSUMES NO LIABILITY WHATSOEVER, INCLUDING WITHOUT LIMITATION, INDIRECT, CONSEQUENTIAL, SPECIAL, OR INCIDENTAL DAMAGES OR LOSS, INCLUDING WITHOUT LIMITATION, LOSS OF PROFITS, LOSS OF OPPORTUNITIES, BUSINESS INTERRUPTION AND LOSS OF DATA, AND (2) DISCLAIMS ANY AND ALL EXPRESS OR IMPLIED WARRANTIES AND CONDITIONS RELATED TO SALE, USE OF PRODUCT, OR INFORMATION, INCLUDING WARRANTIES OR CONDITIONS OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, ACCURACY OF INFORMATION, OR NONINFRINGEMENT.
- Do not use or otherwise make available Product or related software or technology for any military purposes, including without limitation, for the design, development, use, stockpiling or manufacturing of nuclear, chemical, or biological weapons or missile technology products (mass destruction weapons). Product and related software and technology may be controlled under the applicable export laws and regulations including, without limitation, the Japanese Foreign Exchange and Foreign Trade Law and the U.S. Export Administration Regulations. Export and re-export of Product or related software or technology are strictly prohibited except in compliance with all applicable export laws and regulations.
- Please contact your TOSHIBA sales representative for details as to environmental matters such as the RoHS compatibility of Product. Please use Product in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. TOSHIBA ASSUMES NO LIABILITY FOR DAMAGES OR LOSSES OCCURRING AS A RESULT OF NONCOMPLIANCE WITH APPLICABLE LAWS AND REGULATIONS.

### **TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION**

https://toshiba.semicon-storage.com/