

# Stray-Field Immune, High-Speed, Hall-Effect Angle Sensor IC

# FEATURES AND BENEFITS

- Contactless 0° to 360° angle sensor IC for angular position, rotational speed, and direction measurement
  - Hall-effect technology
  - End of shaft
  - Stray-field immune
- Designed to meet ASIL D top-level safety requirements in a single- or dual-die package when used in conjunction with appropriate system-level control
- 11.2 bits noise-free resolution with 300 G field and 12.5 kHz bandwidth
- Default 25 µs latency with 12.5 kHz bandwidth Programmable from 15 to 45 μs
- On-chip low-power mode and turns count feature to keep track of motor position in automotive applications when the vehicle is turned off
  - Turns Counter tracks motion in 90° increments
  - Low Power Mode with user-programmable duty cycle reduces power consumption

Continued on next page ...

# PACKAGES:

24-pin eTSSOP (Suffix LP) 14-pin TSSOP (Suffix LE)



Single SoC

# DESCRIPTION

The A33020 is a 360° angle sensor IC that provides contactless high-resolution angular position information based on magnetic sensing technology. The A33020 is a system-on-chip (SoC) architecture that includes angle sensing, digital signal processing, and various output options: SPI, PWM, motor commutation (U,V,W), and encoder outputs (A, B, I). Also integrated in the device is on-chip EEPROM technology, capable of supporting a high number of read/write cycles, for flexible end-of-line programming of calibration parameters.

The low 25 µs latency of the A33020 makes it ideal for automotive applications requiring fast 0° to 360° angle measurements, such as electronic power steering (EPS), seatbelt motor systems, transmission actuators, shift-by-wire systems, electronic braking systems, and throttle systems.

The A33020 is targeting single-die ASIL D compliance when used in conjunction with appropriate system level controls.

The A33020 also includes integrated linearization features. This allows the A33020 to correct for misalignment between the IC and the target magnet with minimal added latency.

The A33020 includes an on-chip Turns Counter and Low Power Mode. The Turns Counter tracks motion of the target magnet in increments of 90°. The Low Power Mode reduces power consumption to enable direct connection to the vehicle battery and reduce current drain when the vehicle is in the key-off state.





# FEATURES AND BENEFITS (continued)

- Wide operating range (3.7 to 18 V) enables direct connection to vehicle battery
- Low Power Mode with user-programmable duty cycle reduces power consumption when IC is not operating in normal operation mode
- Linearization to reduce error from misalignment between sensor and target magnet.
- SPI interface allows use of multiple independent sensors for applications requiring redundancy

# **DESCRIPTION** (continued)

The A33020 is available in a single-die 14-pin TSSOP and a dualdie 24-pin eTSSOP package. Both packages are lead (Pb) free with 100% matte-tin lead frame plating. The A33020 will be qualified to AEC-Q100 grade 0.

|                                         | Table |
|-----------------------------------------|-------|
| Features and Benefits                   | 1     |
| Description                             | 1     |
| Packages                                | 1     |
| Selection Guide                         | 3     |
| Absolute Maximum Ratings                |       |
| Thermal Characteristics                 | 3     |
| Pinout Diagrams and Terminal Lists      |       |
| Characteristic Performance              | 6     |
| Functional Description                  | 12    |
| Overview                                | 12    |
| Angle Measurements                      | 12    |
| Input Magnetic Flux Density Definitions | 14    |
| System Level Timing                     | 14    |
| Impact of High Speed Sensing            | 15    |
| Operational Modes                       | 15    |
| PWM Output                              | 15    |
| Incremental Output Interface (ABI)      | 16    |
| ABI/UVW Output Configuration            |       |
| ABI Inversion                           | 19    |
| Index Pulse                             | 20    |
| Zero Degree Position Indication         | 21    |
| Effective Speed of Slew Time            |       |
| Brushless DC Motor Output (UVW)         | 24    |
| Angle Hysteresis                        | 25    |
| Low Power Mode                          | 26    |
| Average Current Consumption In LPM      | 26    |
| Turns Counting and Low Power Mode       | 26    |
| Turns Count Reset                       |       |
| Transport Mode                          | 29    |
| Linearization Feature                   |       |
| Device Programming Interfaces           | 31    |
| Interface Structure                     | 31    |
| SPI                                     | 32    |
| Timing                                  | 32    |

- 5-bit CRC on SPI messages
- ABI and UVW interfaces provide high resolution and lowest latency angle information
- EEPROM with Error Correction Control (ECC) for trimming calibration
- EEPROM programmable angle reference (0°) position and rotation direction (CW or CCW)
- AEC-Q100 Grade 0 qualified

## **Table of Contents**

| Message Frame                                         | 33 |
|-------------------------------------------------------|----|
| MISO Response on Receipt of Bad CRC                   | 36 |
| MISO Response Following a Write                       | 36 |
| Manchester Interface                                  | 37 |
| Entering Manchester Communication Mode                | 37 |
| Transaction Types                                     | 37 |
| EEPROM and Shadow Memory Usage                        | 40 |
| Enabling EEPROM Access                                | 40 |
| EEPROM and Shadow Access Protections                  | 40 |
| Write Transactions to Extended Memory: EEPROM,        |    |
| Shadow, and Volatile                                  | 40 |
| Read Transaction from EEPROM and                      |    |
| Other Extended Locations                              |    |
| Shadow Memory Read and Write Transactions             |    |
| EEPROM Margin Check                                   |    |
| Primary Serial Interface Register Reference           | 42 |
| Extended Memory Table                                 | 58 |
| EEPROM (Nonvolatile), Shadow (Volatile),              |    |
| And Miscellaneous (Volatile)                          |    |
| EEPROM                                                |    |
| Volatile Memory                                       |    |
| Safety And Diagnostics                                |    |
| Error Reporting Through SPI                           |    |
| Information Flags                                     |    |
| Error Reporting Through PWM                           |    |
| Error Reporting in ABI/UVW                            |    |
| A33020, Turns Count and Low Power Mode Error Checking |    |
| Application Information                               | 85 |
| I/O Structures                                        | 87 |
| Package Outline Drawings                              | 88 |
| Revision History                                      | 90 |
| Appendix                                              | 91 |



#### **SELECTION GUIDE**

| Part Number           | System Die | Nominal B <sub>IN</sub> | Interface<br>Voltage | Package       | Packing                    |
|-----------------------|------------|-------------------------|----------------------|---------------|----------------------------|
| A33020LLEATR-300      | Single     | 300 G                   | 3.3 V                |               |                            |
| A33020LLEATR-600      | Single     | 400 G                   | 3.3 V                | 14-pin TSSOP  | 4000 pieces per 13-in reel |
| A33020LLEATR300-5     | Single     | 300 G                   | 5 V                  | 14-pill 1330P | 4000 pieces per 13-in reel |
| A33020LLEATR-600-5    | Single     | 400 G                   | 5 V                  |               |                            |
| A33020LLPBTR-DD-300   | Dual       | 300 G                   | 3.3 V                |               |                            |
| A33020LLPBTR-DD-600   | Dual       | 400 G                   | 3.3 V                |               | 1000 pieces per 12 in real |
| A33020LLPBTR-DD-300-5 | Dual       | 300 G                   | 5 V                  | 24-pin eTSSOP | 4000 pieces per 13-in reel |
| A33020LLPBTR-DD-600-5 | Dual       | 400 G                   | 5 V                  |               |                            |

#### **ABSOLUTE MAXIMUM RATINGS**

| Characteristic                                                                     | Symbol              | Notes                                       | Rating     | Unit |
|------------------------------------------------------------------------------------|---------------------|---------------------------------------------|------------|------|
| Forward Supply Voltage                                                             | V <sub>CC</sub>     | Not sampling angles                         | 38         | V    |
| Reverse Supply Voltage                                                             | V <sub>RCC</sub>    | Not sampling angles                         | -18        | V    |
| Digital I/O Forward Voltage<br>(MOSI, MISO, SCLK, CS, A/U, B/V,<br>I/W, WAKE, BYP) | V <sub>DIG</sub>    | 3.3 or 5 V interface selected               | 5.65       | V    |
| Digital I/O Reverse Voltage                                                        | V <sub>RDIG</sub>   |                                             | -0.5       | V    |
| PWM Forward Voltage                                                                | V <sub>PWM</sub>    |                                             | 18         | V    |
| PWM Reverse Voltage                                                                | V <sub>RPWM</sub>   |                                             | -0.5       | V    |
| Operating Ambient Temperature                                                      | T <sub>A</sub>      | L range                                     | -40 to 150 | °C   |
| Maximum Junction Temperature                                                       | T <sub>J(MAX)</sub> |                                             | 165        | °C   |
| Storage Temperature                                                                | T <sub>STG</sub>    |                                             | -65 to 170 | °C   |
|                                                                                    |                     | HBM testing per AEC-Q100; TSSOP-14 package  | >4         | kV   |
| ESD Rating                                                                         | V <sub>ESD</sub>    | HBM testing per AEC-Q100; eTSSOP-24 package | 3.5 [1]    | kV   |

<sup>[1]</sup> All GND pins shorted together.

#### **THERMAL CHARACTERISTICS**: May require derating at maximum conditions; see Operating Characteristics section.

| Characteristic             | Symbol           | Test Conditions*                                              | Value | Unit |
|----------------------------|------------------|---------------------------------------------------------------|-------|------|
| Deskans Themsel Desistence |                  | LE-14 package on 4-layer PCB based on JEDEC standard JESD51-7 | 82    | °C/W |
| Package Thermal Resistance | κ <sub>θJA</sub> | LP-24 package on 4-layer PCB based on JEDEC standard JESD51-7 | 69    | °C/W |

\*Additional thermal information available on the Allegro website.



## PINOUT DIAGRAMS AND TERMINAL LISTS



#### **Terminal List Table**

| Number  | Name | Function                                                                  |
|---------|------|---------------------------------------------------------------------------|
| 1, 2    | VCC  | Power supply                                                              |
| 3       | PWM  | PWM angle output and Manchester Communications                            |
| 4       | BYP  | External bypass capacitor terminal for internal regulator                 |
| 5, 6, 7 | GND  | Device ground terminal                                                    |
| 8       | CS   | SPI Chip Select terminal (active low input)                               |
| 9       | SCLK | SPI Clock terminal input                                                  |
| 10      | MOSI | SPI Controller Output / Peripheral Input                                  |
| 11      | MISO | SPI Controller Input / Peripheral Output                                  |
| 12      | A/U  | Option 1: Quadrature A output signal<br>Option 2: U output signal         |
| 13      | B/V  | Option 1: Quadrature B output signal<br>Option 2: V output signal         |
| 14      | I/W  | Option 1: Quadrature I (index) output signal<br>Option 2: W output signal |



# A33020



## Package LP 24-pin eTSSOP Pinout Drawing (Dual Die)

#### **Terminal List Table**

|        | Die 1  |                                                           |  |  |  |  |
|--------|--------|-----------------------------------------------------------|--|--|--|--|
| Number | Name   | Function                                                  |  |  |  |  |
| 1      | SCLK 1 | SPI Clock terminal input                                  |  |  |  |  |
| 2      | CS 1   | SPI Chip Select terminal (active low input)               |  |  |  |  |
| 3      | MOSI 1 | SPI Controller Output/Peripheral Input                    |  |  |  |  |
| 4      | MISO 1 | SPI Controller Input/Peripheral Output                    |  |  |  |  |
| 5      | A/U 1  | Option 1: Quadrature A output; Option 2: U<br>Output      |  |  |  |  |
| 6      | B/V 1  | Option 1: Quadrature B output; Option 2: V<br>Output      |  |  |  |  |
| 7      | I/W 1  | Option 1: Quadrature I output; Option 2: W<br>Output      |  |  |  |  |
| 8      | GND 1  | Device ground terminal                                    |  |  |  |  |
| 9      | BYP 1  | External bypass capacitor terminal for internal regulator |  |  |  |  |
| 10     | PWM 1  | PWM angle output and Manchester<br>Communications         |  |  |  |  |
| 11, 12 | VCC 1  | Power supply                                              |  |  |  |  |

|        | Die 2  |                                                              |  |  |  |  |  |
|--------|--------|--------------------------------------------------------------|--|--|--|--|--|
| Number | Name   | Function                                                     |  |  |  |  |  |
| 13     | SCLK 2 | SPI Clock terminal input                                     |  |  |  |  |  |
| 14     | CS 2   | SPI Chip Select terminal (active low input)                  |  |  |  |  |  |
| 15     | MOSI 2 | SPI Controller Output/ Peripheral Input                      |  |  |  |  |  |
| 16     | MISO 2 | SPI Controller Input/ Peripheral Output                      |  |  |  |  |  |
| 17     | A/U 2  | Option 1: Quadrature A output; Option 2:<br>U Output         |  |  |  |  |  |
| 18     | B/V 2  | Option 1: Quadrature B output; Option 2: V Output            |  |  |  |  |  |
| 19     | I/W 2  | Option 1: Quadrature I output; Option 2:<br>W Output         |  |  |  |  |  |
| 20, 21 | GND 2  | Device ground terminal                                       |  |  |  |  |  |
| 22     | BYP 2  | External bypass capacitor terminal for<br>internal regulator |  |  |  |  |  |
| 23     | PWM 2  | PWM angle output and Manchester<br>Communications            |  |  |  |  |  |
| 24     | VCC 2  | Power supply                                                 |  |  |  |  |  |



## CHARACTERISTIC PERFORMANCE

#### OPERATING CHARACTERISTICS: Valid over operating voltage and temperatures, unless otherwise specified

| Characteristics                          | Symbol                   | Test Conditions                                                                                                                              | Min.  | Тур. | Max.  | Unit  |
|------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------|-------|
| ELECTRICAL CHARACTERIST                  | ICS                      |                                                                                                                                              |       |      |       |       |
| Cumple Mathema [1][6]                    | N/                       | Interface voltage 3.3 V                                                                                                                      | 3.7   | _    | 18    | V     |
| Supply Voltage [1][6]                    | V <sub>CC</sub>          | Interface voltage 5.0 V                                                                                                                      | 4.8   | _    | 18    | V     |
| Cummbu Cumment                           | т                        | Sampling angles, normal power mode, $T_A \ge 25^{\circ}C$ , one die                                                                          | _     | _    | 19    | mA    |
| Supply Current                           | I <sub>CC</sub>          | Sampling angles, normal power mode, $T_A < 25^{\circ}C$ , one die                                                                            | -     | _    | 22    | mA    |
| Transport Mode Supply Current            | I <sub>CC(TRANS)</sub>   | In Transport mode, $T_A = 25^{\circ}C$ , sampling disabled, one die                                                                          | —     | 30   | -     | μA    |
| Low-Power Mode Sleep Current             | $I_{CC(LP\_SLEEP)}$      | $I_{CC}$ in sleep state during Low Power Mode; V <sub>CC</sub> = 12 V, $T_A = 25^{\circ}$ C, one die                                         | _     | 34   | -     | μA    |
| Low-Power Mode Wake Current              | I <sub>CC(LP_WAKE)</sub> | $I_{CC}$ in awake state during Low Power Mode; V <sub>CC</sub> = 12 V, T <sub>A</sub> = 25°C, one die                                        | _     | 4.5  | _     | mA    |
| Low-Power Mode Average<br>Supply Current | I <sub>CC(AVG_LP)</sub>  | Average I <sub>CC</sub> in Low Power Mode with default 1.7 ms sleep time settings, one die                                                   | _     | 60   | _     | μA    |
| Low-Power Mode Sleep Time [4]            | t <sub>SLEEP_LP</sub>    | Programmable Sleep time duration in Low Power Mode Capable of tracking up to 10k RPM with $B_{IN} \ge 200$ G with default settings of 1.7 ms | 0.5   | 1.7  | 100   | ms    |
| Low-Power Mode Awake time                | t <sub>WAKE_LP</sub>     | Awake time duration in Low Power Mode with default settings                                                                                  | _     | 9    | _     | μs    |
| Low-Power Mode Exit Ramp Rate            | SR <sub>LPM_EXIT</sub>   | Slowest ramp rate allowed when exiting LPM; applied to SCLK, MOSI, CS pins                                                                   | 100   | _    | _     | mV/µs |
|                                          |                          | Main oscillator                                                                                                                              | 13.6  | 16   | 18.4  | MHz   |
| Clock Frequency                          | f <sub>CLK</sub>         | 2 MHz oscillator                                                                                                                             | 1.7   | 2    | 2.3   | MHz   |
|                                          |                          | 250 kHz oscillator                                                                                                                           | 212.5 | 250  | 287.5 | kHz   |
| Undervoltage Flag Threshold              | V <sub>UVD(HIGH)</sub>   | dV/dt = +1 V/ms, A33020 sampling enabled                                                                                                     | _     | _    | 3.75  | V     |
| Sindervoltage hag mieshold               | V <sub>UVD(LOW)</sub>    | dV/dt = -1 V/ms, A33020 sampling disabled                                                                                                    | 3.35  | _    | _     | V     |
| Overvoltage Flag Threshold [5]           | V <sub>OVD(HIGH)</sub>   |                                                                                                                                              | 21    | 22   | -     | V     |
| Overvoltage hag threshold log            | V <sub>OVD(LOW)</sub>    |                                                                                                                                              | 20    | 21   | _     | V     |
| Forward Supply Zener Clamp<br>Voltage    | V <sub>ZUP</sub>         | $I_{CC} = I_{CC(max)} + 3 \text{ mA}$                                                                                                        | 38    | _    | -     | V     |
| Reverse Supply Zener Clamp<br>Voltage    | V <sub>RZUP</sub>        | $I_{CC} = I_{RCC(min)}$                                                                                                                      | _     | _    | -18   | V     |
| Reverse Battery Current                  | I <sub>RCC</sub>         | V <sub>CC</sub> = -18 V                                                                                                                      | -5    | _    | -     | mA    |
| Power-On Time <sup>[2][4]</sup>          | t <sub>PO</sub>          |                                                                                                                                              | _     | 0.5  | _     | ms    |



#### OPERATING CHARACTERISTICS (continued): Valid over operating voltage and temperatures, unless otherwise specified

| Characteristics               | Symbol           | Test Conditions                                                                                             | Min. | Тур. | Max. | Unit |
|-------------------------------|------------------|-------------------------------------------------------------------------------------------------------------|------|------|------|------|
| ELECTRICAL CHARACTERIST       | ICS              |                                                                                                             |      |      |      |      |
| Internal Bandwidth            |                  | IIR_BW_SEL = 0                                                                                              | _    | 6.25 | -    | kHz  |
|                               | BW               | IIR_BW_SEL = 1 (default)                                                                                    | -    | 12.5 | -    | kHz  |
|                               |                  | IIR_BW_SEL = 2                                                                                              | _    | 25   | -    | kHz  |
|                               |                  | IIR_BW_SEL = 3                                                                                              | _    | 50   | -    | kHz  |
| Bypass Pin Output Voltage [3] | V <sub>BYP</sub> | $T_A = 25^{\circ}C, C_{BYP} = 0.1 \ \mu\text{F}, 3.3 \ \text{V}$ interface voltage                          | 2.97 | 3.3  | 3.63 | V    |
|                               |                  | $T_A = 25^{\circ}C, C_{BYP} = 0.1 \ \mu\text{F}, 5 \ \text{V}$ interface voltage, $V_{CC} \ge 6 \ \text{V}$ | 4.35 | 5    | 5.65 | V    |

<sup>[1]</sup> Conditions of maximum supply voltage and ambient temperature must not exceed maximum junction temperature. At elevated ambient temperatures, the maximum operational voltage is reduced. See plot below. Plot is based on R<sub>0JA</sub>, using a four-layer JEDEC standard PCB.



[2] SPI transactions will be valid within ≈ 500 µs of power on. Time for valid angle depends on filter bandwidth (typically 0.5 ms after power-on when using a 12.5 kHz bandwidth). Angle is considered valid once ANG\_RDY (bit 0 of serial address 0xC) is set to 1, and no error flags are present.

[3] The output voltage specification is to aid in PCB design. The pin is not intended to drive any external circuitry. The specifications indicate the peak capacitor charging and discharging currents to be expected during normal operation. Parameter is not measured at final test. Determined by design..

<sup>[4]</sup> Parameter is not measured at final test. Determined by design.

<sup>[5]</sup> Contact Allegro for additional OVD threshold options.

<sup>[6]</sup> Supply voltage ramp rate should be no slower than 5 V/ms when first energizing (0 to 5 V in 1 ms). Once device is powered on, the rate of change on V<sub>CC</sub> must be limited to less than 1 V/µs for changes larger than 1 V in magnitude.



#### **OPERATING CHARACTERISTICS (continued)**: Valid over operating voltage and temperatures, unless otherwise specified

| Characteristics                | Symbol               | Test Conditions                                                                           | Min. | Тур. | Max. | Unit |
|--------------------------------|----------------------|-------------------------------------------------------------------------------------------|------|------|------|------|
| SPI INTERFACE SPECIFICATI      | ONS [1]              |                                                                                           |      | ,    |      |      |
| Load Resistance                | RL                   |                                                                                           | 100  | _    | -    | kΩ   |
|                                | 0                    | Loading on digital output (MISO) pin with frequency up to 10<br>MHz                       | _    | _    | 20   | pF   |
| Load Capacitance               | CL                   | Loading on digital output (MISO) pin with frequency up to 1<br>MHz                        | _    | -    | 50   | pF   |
| Input Leakage Current          | I <sub>L_SPI</sub>   | Leakage current into MOSI, SCLK, <del>CS</del> pins<br>Bus voltage ≤ V <sub>IH(MAX)</sub> | _    | _    | 70   | μA   |
| SPI AND ABI/UVW INTERFACE      | E VOLTAGE S          | SPECIFICATIONS (3.3 V MODE)                                                               |      |      |      |      |
| Digital Input High Voltage     | V <sub>IH</sub>      | MOSI, SCLK, CS pins                                                                       | 2.8  | _    | 3.63 | V    |
| Digital Input Low Voltage      | V <sub>IL</sub>      | MOSI, SCLK, CS pins                                                                       | _    | _    | 0.5  | V    |
| Digital Output High Voltage    | V <sub>OH</sub>      | MISO, ABI/UVW pins, C <sub>L</sub> = 50 pF, Freq ≤ 1 MHz                                  | 2.93 | 3.3  | 3.63 | V    |
| Digital Output Low Voltage     | V <sub>OL</sub>      | MISO, ABI/UVW pins, $C_L = 50 \text{ pF}$ , Freq $\leq 1 \text{ MHz}$                     | _    | 0.3  | 0.5  | V    |
| SPI AND ABI/UVW INTERFACE      | VOLTAGE S            | PECIFICATIONS (5 V MODE)                                                                  |      |      |      |      |
| Digital Input High Voltage     | V <sub>IH</sub>      | MOSI, SCLK, $\overline{CS}$ pins, $V_{CC} \ge 6 V$                                        | 3.75 | _    | 5.5  | V    |
| Digital Input Low Voltage      | V <sub>IL</sub>      | MOSI, SCLK, $\overline{CS}$ pins, $V_{CC} \ge 6 V$                                        | _    | _    | 0.5  | V    |
| Digital Output High Voltage    | V <sub>OH</sub>      | MISO, ABI/UVW pins, C <sub>L</sub> = 50 pF, Freq $\leq$ 1 MHz, V <sub>CC</sub> > 6 V      | 4    | 5    | 5.5  | V    |
| Digital Output Low Voltage     | V <sub>OL</sub>      | MISO, ABI/UVW pins, C <sub>L</sub> = 50 pF, Freq $\leq$ 1 MHz, V <sub>CC</sub> > 6 V      | _    | 0.3  | 0.5  | V    |
| SPI INTERFACE TIMING SPEC      | IFICATIONS           | [1]                                                                                       |      |      |      |      |
| SPI Message Length             | SPILENGTH            |                                                                                           | 32   | _    | 32   | bits |
|                                |                      | MISO pins, C <sub>L</sub> ≤ 20 pF                                                         | 0.1  | -    | 10   | MHz  |
| SPI Clock Frequency            | f <sub>SCLK</sub>    | MISO pins, C <sub>L</sub> ≤ 50 pF                                                         | 0.1  | -    | 1    | MHz  |
| SPI Clock Duty Cycle           | D <sub>fSCLK</sub>   | SPI <sub>CLKDC</sub>                                                                      | 40   | -    | 60   | %    |
| SPI Frame Rate                 | t <sub>SPI</sub>     | SPI message is 32 bits                                                                    | 3    | _    | 289  | kHz  |
| Chip Select to First SCLK Edge | t <sub>CS</sub>      | Time from CS going low to SCLK falling edge                                               | 50   | _    | -    | ns   |
| Chip Select Idle Time          | t <sub>CS_IDLE</sub> | Time CS must be high between SPI message frames                                           | 200  | _    | -    | ns   |
| Data Output Valid Time         | t <sub>DAV</sub>     | Data output valid after SCLK falling edge, $C_L = 20 \text{ pF}$                          | _    | -    | 50   | ns   |
| MOSI Setup Time                | t <sub>s∪</sub>      | Input setup time before SCLK rising edge                                                  | 25   | -    | -    | ns   |
| MOSI Hold Time                 | t <sub>HD</sub>      | Input hold time after SCLK rising edge                                                    | 40   | _    | -    | ns   |
| SCLK to CS Hold Time           | t <sub>CHD</sub>     | Hold SCLK high time before CS rising edge                                                 | 5    | -    | -    | ns   |

<sup>[1]</sup> Parameter is not measured at final test. Determined by design.



#### OPERATING CHARACTERISTICS (continued): Valid over operating voltage and temperatures, unless otherwise specified

| Characteristics                               | Symbol                      | Test Conditions                                                                                                             | Min. | Тур. | Max.            | Unit       |
|-----------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------|------|------|-----------------|------------|
| PWM INTERFACE SPECIFICAT                      | IONS                        |                                                                                                                             |      |      |                 |            |
|                                               |                             | PWM Frequency Min. Setting, T <sub>A</sub> in specification                                                                 | -    | 125  | -               | Hz         |
| PWM Carrier Frequency                         | f <sub>PWM</sub>            | PWM Programmable options                                                                                                    | -    | 16   | _               | steps      |
|                                               |                             | PWM Frequency Max Setting, T <sub>A</sub> in specification                                                                  | -    | 16   | -               | kHz        |
| PWM Output Low Clamp <sup>[1]</sup>           | D <sub>PWM(min)</sub>       | 2% corresponds to PWM_PORCH_SEL EEPROM<br>field set to 000;<br>8% corresponds to PWM_PORCH_SEL EEPROM<br>field set to 110   | 2    | _    | 8               | %          |
| PWM Output High Clamp <sup>[1]</sup>          | D <sub>PWM(max)</sub>       | 92% corresponds to PWM_PORCH_SEL EEPROM<br>field set to 110;<br>98% corresponds to PWM_PORCH_SEL EEPROM<br>field set to 000 | 92   | _    | 98              | %          |
| PWM Output Clamp Step Size [1]                | D <sub>PWM(step_size)</sub> | PWM_PORCH_SEL EEPROM field                                                                                                  | -    | 1    | -               | %          |
| PWM Output Leakage Current                    |                             | Output voltage ≤ 5.5 V, output FET off                                                                                      | -    | -    | 100             | μA         |
| PWM Saturation Voltage                        | V <sub>PWMSAT(LOW)</sub>    | Sink current = 4.7 mA, V <sub>CC</sub> = 5 V, output FET on                                                                 | -    | -    | 0.35            | V          |
| PWM Max Operational Pull-Up<br>Voltage        | V <sub>SPWM</sub>           |                                                                                                                             | _    | _    | 5.65            | V          |
| PWM Output Current Limiter <sup>[1]</sup>     | I <sub>PWMLIMIT</sub>       | Output FET on, T <sub>A</sub> = 25°C,<br>Short circuit protection                                                           | 20   | _    | 50              | mA         |
| PWM Max Operational<br>Current <sup>[1]</sup> | I <sub>PWMSC(SINK)</sub>    | Recommended max. operational PWM current                                                                                    | _    | _    | 20              | mA         |
| PWM Load Capacitance [1]                      | C <sub>PWMLX</sub>          |                                                                                                                             | -    | -    | 4.7             | nF         |
| Output Load Resistance                        | R <sub>P(PULLUP)</sub>      |                                                                                                                             | -    | 1500 | -               | Ω          |
| INCREMENTAL OUTPUT SPEC                       |                             |                                                                                                                             |      |      |                 |            |
| ABI and UVW Output Angular<br>Hysteresis      | hys <sub>ANG</sub>          | Programmable                                                                                                                | 0    | -    | 1.41            | degrees    |
| AB Channel Resolution                         | RES <sub>AB</sub>           | Programmable via EEPROM, 4 bit field; specified in pulses per revolution, PPR                                               | 1    | _    | 2048            | PPR        |
| AB Quadrature Resolution                      | RES <sub>AB_INT</sub>       | Equal to 4 × RESAB, specified in counts per revolution, CPR                                                                 | 4    | -    | 8192            | CPR        |
| UVW Poles Pairs                               | N <sub>pole</sub>           | DC commutation signals; programmable via EEPROM, 4-bit field                                                                | 1    | _    | 16              | pole pairs |
| Maximum Sourcing Current                      | I <sub>SOURCE</sub>         | Output voltage ≥ 2.8 V; IO voltage of 3.3 or 5 V                                                                            | -    | 1.0  | -               | mA         |
| Maximum Sinking Current                       | I <sub>SINK</sub>           | Output voltage ≤ 0.5 V; IO voltage of 3.3 or 5 V                                                                            | -    | 1.0  | -               | mA         |
| MANCHESTER SPECIFICATIO                       | NS [1]                      |                                                                                                                             |      |      |                 |            |
| Bit Rate                                      | -                           | Communication rate                                                                                                          | 4.0  | -    | 100.0           | kbps       |
| Manchester Input High Voltage                 | V <sub>MAN(H)</sub>         | Data pulses on PWM                                                                                                          | 2.8  | -    | V <sub>CC</sub> | V          |
| Manchester Input Low Voltage                  | V <sub>MAN(L)</sub>         | Data pulses on PWM                                                                                                          | 0    | _    | 1.2             | V          |

<sup>[1]</sup> Parameter is not measured at final test. Determined by design.



#### OPERATING CHARACTERISTICS (continued): Valid over operating voltage and temperatures, unless otherwise specified

| Characteristics                                              | Symbol                      | Test Conditions                                                                                                                            | Min  | Тур     | Мах  | Unit    |
|--------------------------------------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|---------|------|---------|
| MAGNETIC CHARACTERIST                                        | ICS                         |                                                                                                                                            |      |         |      |         |
|                                                              | 5                           | For part numbers with suffix 300                                                                                                           | _    | 300 [2] | 400  | G       |
| Input Magnetic Flux Density [1]                              | B <sub>IN</sub>             | For part numbers with suffix 600                                                                                                           | -    | 400 [2] | 600  | G       |
| Input Magnetic Flux Density in Low Power Mode <sup>[1]</sup> | B <sub>IN(LP)</sub>         | For 300 or 600 part variant, Low Power Mode Enabled<br>Support turns count tracking up to 10 krpm with 1.7 ms<br>sleep time <sup>[7]</sup> | 200  | _       | _    | G       |
| ANGLE CHARACTERISTICS                                        |                             |                                                                                                                                            |      |         |      |         |
| Number of Angle Bits                                         | N <sub>SPI</sub>            | Angle message length, SPI output                                                                                                           | -    | 16      | _    | bits    |
|                                                              |                             | Angular latency, bandwidth = 6.25 kHz                                                                                                      | 36.9 | 45      | 53.1 | μs      |
|                                                              |                             | Angular latency, bandwidth = 12.5 kHz                                                                                                      | 20.5 | 25      | 29.5 | μs      |
| Response Time <sup>[3][5]</sup>                              | t <sub>RESPONSE</sub>       | Angular latency, bandwidth = 25 kHz                                                                                                        | 16.4 | 20      | 23.6 | μs      |
|                                                              |                             | Angular latency, bandwidth = 50 kHz                                                                                                        | 12.3 | 15      | 17.7 | μs      |
|                                                              | t <sub>ANG</sub>            | Register update rate.<br>ABI update rate, no interpolation (INTERPOLATOR_BYPASS = 1).                                                      | -    | 2       | _    | μs      |
| Refresh Rate <sup>[4]</sup>                                  |                             | ABI Angle update rate with 8× interpolation.<br>(INTERPOLATOR_BYPASS = 0, INTERPOLATOR_RATE = 0)                                           | -    | 0.25    | _    | μs      |
|                                                              | t <sub>ANG_interp</sub>     | ABI Angle update rate with 4× interpolation.<br>(INTERPOLATOR_BYPASS = 0, INTERPOLATOR_RATE = 1)                                           | -    | 0.5     | _    | μs      |
| A L E [6]                                                    |                             | T <sub>A</sub> = 25°C, ideal magnet alignment, RPM = 0                                                                                     | -1.0 | ±0.5    | 1.0  | degrees |
| Angle Error <sup>[6]</sup>                                   | ERR <sub>ANG</sub>          | T <sub>A</sub> = 150°C, ideal magnet alignment, target rpm = 0                                                                             | -2.0 | ±0.9    | 2.0  | degrees |
| Angle Error Due to DC Stray<br>Field                         |                             | T <sub>A</sub> = 25°C, B <sub>stray</sub> = 50 G DC, B <sub>IN</sub> = 300 G                                                               | -    | ±0.1    | ±0.4 | degrees |
| Angle Error Due to AC Stray<br>Field                         |                             | $T_A = 25^{\circ}$ C, AC stray field according to ISO11452-8 Test<br>Level IV, B <sub>IN</sub> = 300 G                                     | -    | ±0.1    | ±0.4 | degrees |
| Angle Drift Due to                                           |                             | Change in angle from 25°C;<br>T <sub>A</sub> = 150°C, ideal magnet alignment, target rpm = 0                                               | -1.2 | ±0.5    | 1.2  | degrees |
| Temperature <sup>[6]</sup>                                   | ANGLE <sub>DRIFT</sub>      | Change in angle from 25°C;<br>$T_A = -40$ °C, ideal magnet alignment, target rpm = 0                                                       | -    | ±0.5    | _    | degrees |
| Angle Drift Over Lifetime                                    | ANGLE <sub>DRIFT_Life</sub> | B <sub>IN</sub> = 300 G, average maximum drift observed following<br>AEC-Q100 qualification testing                                        | _    | 0.5     | _    | degrees |

[1] The Input Magnetic Flux Density B<sub>IN</sub> is defined in the "Input Magnetic Flux Density Definitions" section.
[2] During Normal Mode operation, there is no strict minimum value for B<sub>IN</sub> as a smaller input field will only lead to a lower resolution: therefore, it is not recommended to operate below 50 G for the 300 part variant and below 100 G for the 600 part variant. Note: During Low Power Mode, higher field levels may be required to ensure proper turns tracking.

[3] Not directly measured at final test, based on oscillator measurements.

[4] The rate at which a new angle reading will be ready.

[6] Angle Error and Drift inferred through channel characterization and signal path testing. Not directly measured at final test. [7] For a different max rotation speed during Low Power Mode, see Table 6.



<sup>[5]</sup> Response time is measured at the time between the magnet crossing a given angle and the part reporting that angle.

#### OPERATING CHARACTERISTICS (continued): Valid over operating voltage and temperatures, unless otherwise specified

| Characteristics                             | Symbol                  | Test C                                                    | Conditions     |                        | Min. | Тур.  | Max. | Unit    |
|---------------------------------------------|-------------------------|-----------------------------------------------------------|----------------|------------------------|------|-------|------|---------|
| ANGLE CHARACTERISTICS                       | (continued)             |                                                           |                |                        |      |       |      |         |
|                                             |                         |                                                           |                | T <sub>A</sub> = 25°C  | _    | 0.065 | _    | degrees |
|                                             |                         |                                                           | BW = 6.25 kHz  | T <sub>A</sub> = 150°C | -    | 0.110 | _    | degrees |
|                                             |                         |                                                           |                | T <sub>A</sub> = 25°C  | -    | 0.075 | _    | degrees |
| Angle Noise [3][4]                          | N <sub>ANG</sub>        | Target RPM = 0, 3 sigma;<br>300 G for 300 part variant;   | BW = 12.5 kHz  | T <sub>A</sub> = 150°C | -    | 0.160 | _    | degrees |
|                                             | ANG                     | 400 G for 600 part variant                                | BW = 25 kHz    | T <sub>A</sub> = 25°C  | -    | 0.100 | _    | degrees |
|                                             |                         |                                                           | DVV - 25 KHZ   | T <sub>A</sub> = 150°C | -    | 0.180 | _    | degrees |
|                                             |                         |                                                           | BW = 50 kHz    | T <sub>A</sub> = 25°C  | -    | 0.120 | _    | degrees |
|                                             |                         |                                                           | BW - 50 KHZ    | T <sub>A</sub> = 150°C | -    | 0.240 | _    | degrees |
|                                             |                         |                                                           | BW = 6.25 kHz  | T <sub>A</sub> = 25°C  | -    | 11.4  | _    | bits    |
|                                             |                         |                                                           | DW - 0.25 KHZ  | T <sub>A</sub> = 150°C | -    | 10.7  | -    | bits    |
|                                             |                         |                                                           | BW = 12.5 kHz  | T <sub>A</sub> = 25°C  | -    | 11.2  | _    | bits    |
| Noise Free Number of Bits <sup>[2][4]</sup> | h                       | Target RPM = 0, 6 sigma;                                  | DVV - 12.3 KHZ | T <sub>A</sub> = 150°C | -    | 10.1  | _    | bits    |
|                                             | b <sub>NOISE_FREE</sub> | 300 G for 300 part variant;<br>400 G for 600 part variant | BW = 25 kHz    | T <sub>A</sub> = 25°C  | -    | 10.8  | _    | bits    |
|                                             |                         |                                                           | DVV - 25 KHZ   | T <sub>A</sub> = 150°C | -    | 10.0  | -    | bits    |
|                                             |                         |                                                           | BW = 50 kHz    | T <sub>A</sub> = 25°C  | -    | 10.6  | _    | bits    |
|                                             |                         |                                                           | DVV - 50 KHZ   | T <sub>A</sub> = 150°C | _    | 9.6   | _    | bits    |
| TEMPERATURE SENSOR [1]                      |                         |                                                           |                |                        |      |       |      |         |
| Temperature                                 | TEMP <sub>BITS</sub>    | Main and redundant                                        |                |                        | -    | 12    | -    | bits    |
| Temperature Resolution                      |                         | 1°C = 8 counts                                            |                |                        | -    | 0.125 | _    | °C      |
| Quartemperature Thread and                  | OVT                     |                                                           | -              | 170                    | _    | °C    |      |         |
| Overtemperature Threshold                   | UVT                     |                                                           |                | -                      | -60  | _     | °C   |         |

[1] Parameter is not measured at final test. Determined by design. [2] The Noise Free Number of Bits is defined as:  $log_2(360/(6 \times \sigma))$  where  $\sigma$  is the rms angle noise. [3] This value represents 3-sigma or three times the standard deviation of the measured samples. [4] Based on characterization data, not measured at final test.



## FUNCTIONAL DESCRIPTION

#### **Overview**

The A33020 is an automotive-qualified, four channel, rotary position sensor. The four channels provide redundant angle sensing within a single monolithic surface mount device.

This device is an advanced, programmable system-on-chip (SoC), incorporating six planar Hall-effect, analog signal conditioning, high-speed sampling analog-to-digital converters, digital filtering, digital signal processing (which includes two separate signal paths, primary and secondary), and multiple output options. Available outputs options include SPI, PWM, and motor commutation outputs (U, V, W) or encoder outputs (A, B, I).

The primary (or main) channel is comprised of six planar Hall plates measuring the magnetic field perpendicular to the package. The three secondary channels are each a subset of four Hall plates out of the six from the main channel (see Angle Measurements section below for more details). The information from each channel is processed in parallel to compute an angle measurement based on the input magnetic fields. The resulting angle information, primary and secondary, is passed through additional processing and made available as four independent outputs. In addition, the A33020 compares the primary angle to the secondary angles to monitor the integrity of the angle information.

Zero angle, filtering, linearization, and diagnostic adjustment options are available in the A33020. These options are configurable in onboard EEPROM, providing a wide range of sensing solutions in the same device.

## **Angle Measurements**

The A33020 is capable of rejecting common-mode stray fields, based on the calculation of the equivalent center of mass of the measured magnetic fields. The concept of center of mass is an analogy to understand how the A33020 is a stray-field immune sensor: indeed, if the same additional mass is applied to a

group of weights, the angular position of the center of mass is unchanged. The A33020 has six planar Hall plates equally spaced in a 2 mm diameter circle (Figure 2, not to scale). The magnetic center is attracted toward a given Hall plate if it measures a positive magnetic field or repelled if it measures a negative magnetic field. While placed in front of the right rotating magnet, the magnetic center follows the same rotation as the magnet. The A33020 measures the position of this magnetic center and returns its angular position.

To evaluate the magnet angle position  $\delta_{MAIN}$ , the A33020 realizes the following calculation:

$$\delta_{MAIN} = atan2 \left( \frac{\frac{\sqrt{3}}{2} (CH_B + CH_C)}{CH_A + \frac{1}{2} (CH_B - CH_C)} \right)$$

Equation 1: Magnet angle position calculation

with:

- $CH_A = HP1-HP4$
- $CH_B = HP2-HP5$
- $CH_C = HP3-HP6$

HPi is the magnetic field measured by the Hall plate i along the direction Z, perpendicular to the surface of the chip.

The A33020 also measures three redundant angles using the functions  $f_1$ ,  $f_2$  and  $f_3$ :

- $\delta_{AB} = f_1(CH_A, CH_B)$
- $\delta_{BC} = f_2(CH_B, CH_C)$
- $\delta_{CA} = f_3(CH_C, CH_A)$

A33020 compares the main and redundant angles at each clock cycle and switches to safe state if a sufficiently high mismatch is detected.



# A33020

# Stray-Field Immune, Precision, Hall-Effect Angle Sensor IC



# Figure 2: Axial view of the A33020 and the cylinder magnet with diametrical magnetization (showing default 0°position)

The A33020 is intended to work as an end-of-shaft angle sensor, in front of a rotating magnet. To achieve 360° absolute angle position, the magnet can be a:

- Two-pole ring, cylinder, or block magnet with diametrical magnetization (Figure 3). The typical magnetic field observed by these channels is presented in the Input Magnetic Flux Density Definitions section.
- Four-pole ring, cylinder, or block magnet with magnetization parallel to the axis of rotation (Figure 4).







Figure 4: Isometric view of the A33020 and the cylinder magnet with four-pole axial magnetization



A33020

#### Input Magnetic Flux Density Definitions

Each of the three signal channels observes a differential field as the magnet rotates above the IC. When discussing sensor performance, it is often easier to use the single-ended value of the input magnetic flux density,  $B_{IN}$ , instead of the differential value.  $B_{IN}$  is the average single-ended field exhibited across all Hall plates. For a perfectly aligned system,  $B_{IN}$  is the maximum field any single Hall plate experiences over a complete magnet rotation. Its relationship to the differential channel field is shown in Figure 5.  $B_{IN}$  is defined as:

$$B_{IN} = \frac{1}{3} \times \sqrt{\left(\frac{\sqrt{3}}{2}(CH_B + CH_C)\right)^2 + \left(CH_A + \frac{1}{2}(CH_B - CH_C)\right)^2}$$

 $B_{\rm IN}$  defines the device resolution, where a high  $B_{\rm IN}$  results in better resolution.



Figure 5: Differential channels and B<sub>IN</sub> over magnet position with ideal IC position

## **System Level Timing**

Internal registers are updated with a new angle value every  $t_{ANG}$ . The delay from time of the input until generation of a processed angle value is  $t_{RESPONSE}$ . SPI, which is asynchronously clocked, results in a varying latency depending on sampling frequency and SCLK speed. Register values transmitted are latched on the first SCLK edge of the SPI response frame. This results in a variable age of the angle data, ranging from  $t_{RESPONSE} + t_{SPI}$  to  $t_{RESPONSE} + t_{ANG} + t_{SPI}$ , where  $t_{SPI}$  is the length of a read response packet, and  $t_{ANG}$  is the update rate of the angle register.

Similar to SPI, when using the PWM output, the output packet is not synchronized with the internal update rate of the sensor. The angle is latched at the beginning of the carrier frequency period (effectively at the rising edge of the PWM output). Because of this, the age of the angle value, once read by the system microcontroller, may be up to  $t_{RESPONSE} + t_{ANG} + 1/f_{PWM}$ .



Figure 6: Signal Path Block Diagram Corresponding to Bandwidth 25 kHz



# Impact of High-Speed Sensing

Due to signal path latency, the angle information is delayed by  $t_{RESPONSE}$ . This delay equates to a greater angle value as the rotational velocity increases (i.e., a magnet rotating at 20,000 rpm traverses twice as much angular distance in a fixed time period as a magnet rotating at 10,000 rpm), and is referred to as angular lag.

The lag is directly proportional to rpm, and may be compensated for externally, if the velocity is known.

# **Operational Modes**

## **PWM OUTPUT**

The A33020 provides a pulse-width-modulated open-drain output, with the duty cycle (DC) proportional to the main channel angle output. The PWM output is enabled by setting the parameter PWM\_ENABLE (extended: 0x3F [17])

The PWM period is defined as shown in Figure 7. The PWM period may be measured by observing the rising edge to rising edge time. The PWM duty cycle is the rising edge to falling edge time as a percent of the PWM period. The fixed front porch and back porch are configurable by the EEPROM parameter PWM\_PORCH\_SEL (extended: 0x3F [13:11]). The front and back porches are used to identify the PWM frame by the host. The parameter PWM\_PERIOD (extended: 0x3F [10:7]) configures the PWM carrier frequency.



Figure 7: PWM Terms Definition

#### Table 1: PWM\_PORCH\_SEL

| Value | Fixed Time (% Duty Cycle)<br>(Fixed Time = Front Porch and Back Porch) |
|-------|------------------------------------------------------------------------|
| 0     | 2                                                                      |
| 1     | 3                                                                      |
| 2     | 4                                                                      |
| 3     | 5                                                                      |
| 4     | 6                                                                      |
| 5     | 7                                                                      |
| 6     | 8                                                                      |
| 7     | 0                                                                      |

#### Table 2: PWM\_PERIOD

| Value | Frequency (Hz) |
|-------|----------------|
| 0     | 125            |
| 1     | 167            |
| 2     | 250            |
| 3     | 333            |
| 4     | 500            |
| 5     | 667            |
| 6     | 800            |
| 7     | 1000           |
| 8     | 1333           |
| 9     | 1600           |
| 10    | 2000           |
| 11    | 2667           |
| 12    | 4000           |
| 13    | 5333           |
| 14    | 8000           |
| 15    | 16000          |



## **Incremental Output Interface (ABI)**

The A33020 offers an incremental output mode in the form of quadrature A/B and Index outputs to emulate an optical or mechanical encoder. The A and B signals toggle with a 50% duty cycle (relative to angular distance, not necessarily time) at a frequency of  $2^{N}$  cycles per magnetic revolution, giving a cycle resolution of  $(360 / 2^{N})$  degrees per cycle. B is offset from A by <sup>1</sup>/<sub>4</sub> of the cycle period. The I signal is an index pulse that occurs once per revolution to mark the zero (0) angle position. One revolution is shown in Figure 8.

Since A and B are offset by <sup>1</sup>/<sub>4</sub> of a cycle, they are in quadrature and together have four unique states per cycle. Each state represents  $R = [360 \div (4 \times 2^N)]$  degrees of the full revolution. This angular distance is the quadrature resolution of the encoder. The order in which the states change, or the order of the edge transitions from A to B, allow the direction of rotation to be determined. If a given B edge (rising/falling) precedes the following A edge, the angle is increasing from the perspective of the electrical (sensor) angle and the angle position should be incremented by the quadrature resolution (R) at each state transition. Conversely, if a given A edge precedes the following B edge, the angle is decreasing from the perspective of the electrical (sensor) angle and the angle position should be decremented by the quadrature resolution (R) at each state transition. The angle position accumulator wraps each revolution back to 0.

The quadrature states are designated as Q1 through Q4 in the following diagrams, and are defined as follows:

Table 3: Quadrature States

| State Name | A | В |
|------------|---|---|
| Q1         | 0 | 0 |
| Q2         | 0 | 1 |
| Q3         | 1 | 1 |
| Q4         | 1 | 0 |

Note that the A/B progression is a gray coding sequence where only one signal transitions at a time. The state progression must be as follows to be valid:

Increasing angle:  $Q1 \rightarrow Q2 \rightarrow Q3 \rightarrow Q4 \rightarrow Q1 \rightarrow Q2 \rightarrow Q3 \rightarrow Q4$ Decreasing angle:  $Q4 \rightarrow Q3 \rightarrow Q2 \rightarrow Q1 \rightarrow Q4 \rightarrow Q2 \rightarrow Q32 \rightarrow Q1$ 



Figure 8: One Full Magnetic Revolution



The duration of one cycle is referred to as 360 electrical degrees, or 360e. One half of a cycle is therefore 180e and one quarter of a cycle (one quadrature state, or R degrees) is 90e. This is the terminology used to express variance from perfect signal behavior.

Ideally, the A and B cycle would be as shown below for a constant velocity.

Practically, the edge rate of the A and B signals, and the switching threshold of the receiver I/Os, will affect the quadrature periods: Here, an exaggeration of the switching thresholds shows that Q4 and Q2, which are fall-fall and rise-rise, have the expected 90e period, whereas Q1 is less than expected and Q3 is greater than expected due to imbalance in switching thresholds.





# **ABI/UVW OUTPUT CONFIGURATION**

The A33020 uses three pins to output either ABI information or UVW information. The main angle is used to generate the ABI signals. The parameter ABI\_0\_UVW\_1 (extended: 0x25 [0]) selects the protocol ABI or UVW. The ABI or UVW outputs are enabled or disabled by setting the parameter ABI\_UVW\_EN (extended: 0x25 [15]).

The A33020 ABI output resolution and quantity of UVW pole

pairs is configurable by setting the parameter ABI\_UVW\_ RESOLUTION (extended: 0x25 [5:2]) The options for ABI Cycle Resolution and Quadrature State Resolution are shown in Table 4.

Figure 11 shows the maximum RPM for a given ABI resolution. A rotation rate faster than that shown in the figure will result in a skipped ABI step. In this case slew rate limiting (see Slew Rate Limiting Section) will be required to maintain absolute angle position via ABI.

| ABI_UVW_<br>RESOLUTION | Cycle<br>Resolution<br>(Bits = N) | Quadrature<br>Resolution<br>(Bits = N+2) | Cycles<br>per<br>Revolution<br>(A or B) | Quadrature<br>States<br>per<br>Revolution | Cycle<br>Resolution<br>(Degrees) | Quadrature<br>Resolution<br>(R)<br>(Degrees) | UVW<br>Quantity of<br>Poles-Pairs | UVW Cycle Width<br>(Mechanical<br>Degrees) |
|------------------------|-----------------------------------|------------------------------------------|-----------------------------------------|-------------------------------------------|----------------------------------|----------------------------------------------|-----------------------------------|--------------------------------------------|
| O[1]                   | 14                                | 16                                       | 16384                                   | 65536                                     | 0.0220                           | 0.0055                                       | 1                                 | 360.00                                     |
| 1[1]                   | 13                                | 15                                       | 8192                                    | 32768                                     | 0.0439                           | 0.0110                                       | 2                                 | 180.00                                     |
| 2[1]                   | 12                                | 14                                       | 4096                                    | 16384                                     | 0.0879                           | 0.0220                                       | 3                                 | 120.00                                     |
| 3                      | 11                                | 13                                       | 2048                                    | 8192                                      | 0.1758                           | 0.0439                                       | 4                                 | 90.00                                      |
| 4                      | 10                                | 12                                       | 1024                                    | 4096                                      | 0.3516                           | 0.0879                                       | 5                                 | 72.00                                      |
| 5                      | 9                                 | 11                                       | 512                                     | 2048                                      | 0.7031                           | 0.1758                                       | 6                                 | 60.00                                      |
| 6                      | 8                                 | 10                                       | 256                                     | 1024                                      | 1.4063                           | 0.3516                                       | 7                                 | 51.43                                      |
| 7                      | 7                                 | 9                                        | 128                                     | 512                                       | 2.8125                           | 0.7031                                       | 8                                 | 45.00                                      |
| 8                      | 6                                 | 8                                        | 64                                      | 256                                       | 5.6250                           | 1.4063                                       | 9                                 | 40.00                                      |
| 9                      | 5                                 | 7                                        | 32                                      | 128                                       | 11.2500                          | 2.8125                                       | 10                                | 36.00                                      |
| 10                     | 4                                 | 6                                        | 16                                      | 64                                        | 22.5000                          | 5.6250                                       | 11                                | 32.73                                      |
| 11                     | 3                                 | 5                                        | 8                                       | 32                                        | 45.0000                          | 11.2500                                      | 12                                | 30.00                                      |
| 12                     | 2                                 | 4                                        | 4                                       | 16                                        | 90.0000                          | 22.5000                                      | 13                                | 27.69                                      |
| 13                     | 1                                 | 3                                        | 2                                       | 8                                         | 180.0000                         | 45.000                                       | 14                                | 25.71                                      |
| 14                     | 0                                 | 2                                        | 1                                       | 4                                         | 360.0000                         | 90.000                                       | 15                                | 24.00                                      |
| 15                     | n/a                               | n/a                                      | n/a                                     | n/a                                       | n/a                              | n/a                                          | 16                                | 22.50                                      |

#### Table 4: ABI/UVW Cycle Resolution and Quadrature State Resolution

[1] Not recommended for use with ABI.





#### Figure 11: A33020 / ABI\_UVW\_RESOLUTION selection

## **ABI INVERSION**

The logic levels of the ABI pins may be inverted by setting the ABI\_UVW\_INVERT\_OUT\_EN (extended: 0x25 [1]) bit within EEPROM. This also applies if using the UVW output logic.



# **INDEX PULSE**

The index pulse I (or Z in some descriptions) marks the absolute zero (0) position of the encoder. Under rotation, this allows the receiver to synchronize to a known mechanical/magnetic posi-

tion, and then use the incremental A/B signals to keep track of the absolute position. To support a range of ABI receivers, the I pulse has four widths, defined by the ABI\_INDEX\_MODE EEPROM field (extended: 0x25 [13:12]):



#### Figure 12: Index Pulse

# ABI Count-Up Behavior at Power-Up

ABI interface can be configured to communicate the current absolute angle position at power-on. The behavior at start-up is the following.

- During t<sub>PO\_D</sub>, the interface is determined by the error reporting on ABI and PWM
  - Depending on the error reporting mode and PWM frequency, this state may require  $\approx 16$  ms to clear
- The interface will catch-up with the actual measured angle by moving in a positive or negative direction, whichever is faster. The time for catching up is at most:

$$t_{catch-up} = \frac{180^{\circ}}{R} \times ABI_SLEW_TIME$$

• After catching up with the measured angle, the sensor will operate normally.

If ABI\_SLEW\_RATE is set to 0, there is no catch-up phase. The ABI lines simply output the current magnetic angle following device power-on.

When ABI\_SLEW\_RATE is non-zero, the ABI output will automatically count up to the current angle following any powercycle, reset, or error state (if ABI error reporting is enabled). ABI count-up following a power-cycle or reset may be disabled by setting the ABI\_SR\_DLY\_EN field in EEPROM (extended address 0x25, bit 17), provided ABI error reporting is enabled.



Figure 13: ABI Startup Behavior



# Zero Degree Position Indication

The edge of the index pulse corresponding to the zero position, as observed by the sensor, will change based on rotation direction, as shown in Figure 144.

With the magnet rotating such that the observed angle is increasing, the  $0^{\circ}$  position will be indicated by the rising edge of the

Index pulse. If the magnet is rotated in the opposite direction (or if ROT\_DIR\_P and ROT\_DIR\_S are changed) to produce a decreasing angle value, the 0° position will be represented by the falling edge of the Index pulse.

The ABI resolution and I pulse mode selection (described above in Figure 13) determine the width of the Index pulse and the corresponding shift zero position indication.



Figure 14: Index Pulse Corresponding to Zero Position



# Slew Rate Limiting for ABI

Slew rate limiting feature may be used to reduce quadrature state errors. The feature is enabled by setting a non-zero value to the parameter ABI\_SLEW\_RATE (extended: 0x25 [11:6]). The slew time sets the minimum amount of time that the output must remain in its current state before changing to the next state. This prevents the output from skipping states and can ensure controllers are able to read the state before it changes. This option separates the sensor's observed angle change from the ABI output rate and can be used to control two circumstances:

• The angle sample does not monotonically increase or decrease at the quadrature resolution, thereby skipping one or more quadrature states. In this case, the slew rate limiting logic transitions the ABI signals in the required valid sequence, at the slew rate, until the ABI output catches up with the angle samples, at which point the normal sample rate output resumes. This skipping will most likely occur either at very low velocities, if the noise is high, or at very high velocities when the angle changes more than the quadrature resolution in one angle sample period.

• The ABI receiver at the host end cannot reliably detect edge transitions that are spaced at the sample rate of 0.25  $\mu$ s (default refresh rate for ABI). The slew limit time can be set greater than the nominal angle sample update period, providing the velocity of the angle rotation would not on average require ABI transitions greater than the angle sample rate.

In both cases, the ABI output will correctly track the rotation position; however, the speed of the ABI edges will be accomplished at the slew rate limit set in EEPROM. Whenever slew rate limiting occurs, the SLR flag (primary: 0x0C [4]) asserts to inform the system of the occurrence.

Figure 15 illustrates the difference between a bad ABI without slew rate limiting and the corrected output via slew rate limiting.



Figure 15: Slew Rate Limiting



# **Effective Speed of Slew Time**

When slew rate limiting occurs, the ABI update rate is no longer dependent on the observed rotation rate, but instead occurs at a period set by the following EEPROM parameters. This change in the edge rate is observed as a change in the target velocity, and this perceived velocity depends on the following parameters:

- ABI\_SLEW\_RATE (extended: 0x25 [11:6])
- ABI\_UVW\_RESOLUTION (extended: 0x25 [5:2])

Table 5 shows the equivalent RPMs for select combinations of slew time and ABI resolution. ABI\_SLEW\_RATE sets to 0 disables the slew rate limiting.

When designing a system, it is important to note these rpm will occur for any change in rotation direction (i.e., motor transitioning from CW to CCW rotation), when both hysteresis and ABI slew rate limiting are enabled, as the IC back fills the ABI edges for the programmed hysteresis window ANGLE\_HYST (extended: 0x25 [22:20]).

| EEPRON                     | I Setting         |                      | Velocity (RPM) b<br>adrature Resolut |                      |
|----------------------------|-------------------|----------------------|--------------------------------------|----------------------|
| ABI_SLEW_RATE<br>(Decimal) | Slew Time<br>(µs) | 12-bit<br>Quadrature | 11-bit<br>Quadrature                 | 10-bit<br>Quadrature |
| 1                          | 0.25              | 58,593.8             | 117,187.5                            | 234,375.0            |
| 2                          | 0.375             | 39,062.5             | 78,125.0                             | 156,250.0            |
| 3                          | 0.5               | 29,296.9             | 58,593.8                             | 117,187.5            |
| 4                          | 0.625             | 23,437.5             | 46,875.0                             | 93,750.0             |
| 5                          | 0.75              | 19,531.3             | 39,062.5                             | 78,125.0             |
| 6                          | 0.875             | 16,741.1             | 33,482.1                             | 66,964.3             |
| 7                          | 1                 | 14,648.4             | 29,296.9                             | 58,593.8             |
| 8                          | 1.125             | 13,020.8             | 26,041.7                             | 52,083.3             |
|                            |                   |                      |                                      |                      |
| 62                         | 7.875             | 1,860.1              | 3,720.2                              | 7,440.5              |
| 63                         | 8                 | 1,831.1              | 3,662.1                              | 7,324.2              |

# Table 5: Equivalent RPMs for select combinations of slew time and ABI resolution



# **Brushless DC Motor Output (UVW)**

The A33020 features U, V, and W output signals for stator commutation of brushless DC (BLDC) motors. The output is modeselectable for 1 to 16 pole-pairs. The BLDC signals (U, V, and W) are generated based on the quantity of pole-pairs and on angle information from either the primary or secondary channel. The U, V, and W outputs switch when the measured mechanical angle crosses the value where a change should occur. If hysteresis is used, then the UVW edges will update based off the rotation direction and hysteresis window. Hysteresis can be applied to the compensated angle to moderate jitter in the angle output due to noise or mechanical vibration. Figure 177 and Figure 188 below show the U, V, and W example waveforms for three and five pole-pair BLDC motors.





# **Angle Hysteresis**

Hysteresis can be applied to the compensated angle to moderate jitter in the angle output due to noise or mechanical vibration. The parameter ANGLE\_HYS (extended: 0x25 [22:20]) defines the width of an angle window at 16-bits. Mathematically, the width of this window in degrees is:

Angle Hysteresis = 
$$\frac{360}{2^{16}} \times 2^{(ANGLE\_HYS+1)}$$

The parameter ANGLE\_HYS is a 3-bit EEPROM field, allowing a range of  $\approx 0.01^{\circ}$  to  $\approx 1.41^{\circ}$  of hysteresis to be applied. The hysteresis compensated angle is applied to the UVW/ABI output. This same angle populates the ABI\_UVW\_ANGLE field (primary: 0x14 [15:0]) within the primary serial register space and may be read via SPI.

The effect of the hysteresis is shown in Figure 199. The current angle position as measured by the sensor is at the head of the hysteresis window. As long as the sensor (electrical) angle advances in the same direction of rotation, the hysteresis-compensated angle is

Sensor angle position

equal to the channel angle output, minimizing latency. If the sensor angle reverses direction, the hysteresis-compensated angle is held static until the sensor angle exits the hysteresis window in either direction. If the exit is in the opposite direction of rotation where the head was, the head flips to the opposite end of the hysteresis window and that becomes the new reference direction. The current direction of rotation, or head for the purposes of hysteresis, is reported by the parameter ROT H (primary: 0xC [1]).

This behavior has the following consequences:

- 1. If the hysteresis window is greater than the output resolution, the output angle will skip consecutive resolution steps.
  - a. To prevent skipped ABI steps, a non-zero slew rate should be set whenever hysteresis is applied.
- 2. If there is jitter due to noise or mechanical vibration, especially at a static angle position or very slow rotation, the angle will tend to bias to one side of the window, depending on the direction of rotation as the angular velocity approaches zero (i.e., towards the current head) rather than to the average position of the jitter.



Figure 19: Effect of Hysteresis



# Low Power Mode

The A33020 Low Power Mode (LPM) feature is special operating mode to continue to monitor turns count information at reduced angle resolution and power. In LPM operating mode, the dedicated signal path cycles between the wake state for angle sampling and sleep state for minimal power consumption. Low power mode is only entered if all of the following conditions are met:

- The SPI pins (SCLK, MOSI,  $\overline{CS}$ ) at low logic level, AND
- Low Power Mode is enabled, LPM\_DIS\_C = 0 (Extended: 0x24 [9])

In Low Power Mode (LPM), the IC does not provide angle readings over the available SPI, Manchester, ABI/UVW, or PWM interfaces, the majority of the analog and digital circuitry are powered down, and the sensor IC periodically cycles between LPW LPM wake and sleep states. For most of the time, the sensor IC is held in a lower-power quiescent current sleep state. In this state, the IC consumes minimal power to retain the turns count information. Periodically, the sensor IC enters the awake state to monitor the input angle via a reduced power signal path and update the turns count. The sleep time of the Low Power Mode operation is adjustable by programming on-chip EEPROM settings.

## STATE TRANSITIONS WITHIN LOW POWER MODE

The SPI input pins are used as the primary arbiter of low power mode. When all three SPI pins inputs (MOSI, SCLK,  $\overline{CS}$ ) are pulled low for at least 64  $\mu$ s, the sensor enters the LPM mode.

In the wake state the input angle is sampled. Once the angle sample is complete the IC enters LPM sleep state. In the sleep state the low frequency oscillator remains active, along with a digital counter to monitor the sleep period and logic to detect the state of the SPI pins. Expiration of the sleep counter transitions the sensor from sleep to wake state.

If a logic high on any SPI input is observed, Low Power Mode is exited.

# AVERAGE CURRENT CONSUMPTION IN LPM

Assuming the sensor is moving between the two LPM states in a periodic manner, the effective current draw observed from the system is the average of the two different current consumptions, weighted by the time of each state.

 $I_{CC(LP \ AVG)} = \frac{t_{LP \ sleep}}{t_{LP \ total}} I_{LP \ sleep} + \frac{t_{LP \ wake}}{t_{LP \ total}} I_{LP \ wake}$ Where  $t_{LP \ total} = t_{LP \ sleep} + t_{LP \ wake}$  The wake state time  $(t_{WAKE\_LP})$  is fixed by Allegro. This is the required amount of time the internal circuitry requires to accurately sample the input angle.

The amount of time the sensor spends in sleep mode is programmable via EEPROM.

# **Turns Counting and Low Power Mode**

Certain automotive angle sensing applications require the ability to track angular position, even in key-off conditions. In the key-off state, most voltage regulators in the vehicle are not operational. Therefore, sensors that must operate in the key-off state are often powered directly from the vehicle battery (12 V). Examples of such applications include:

- Seat-belt passive safety systems
- EPS motor position

Often, these motor and seat-belt systems are geared down so that multiple angle sensor rotations need to be counted by the angle sensor IC. For this reason, the A33020 includes a circuit that counts the rotational turns of a magnet. When sensor ICs are connected to the vehicle battery, it is often desirable to operate in low-power mode during a key-off conditions, to reduce the power draw on the battery. Also, the sensor IC is often required to track the turns-count of the magnet in the same key-off conditions. The A33020 monitors and keeps track of turns, even when set to Low Power Mode. This allows the system to accurately and consistently track steering wheel position or seat-belt extension in a key-on or key-off condition. Traditionally, this key-off requirement is achieved by a combination of relatively complex mechanical and electronic components. The A33020 helps reduce system-level complexity and eliminate many system components by performing both the absolute angle measurement and the tracking of turns-count, while maintaining low battery power consumption at vehicle key-off.

During normal operation the turns counter logic tracks the magnet position and updates a counter to track angle in 90-degree increments. The two turns-counters turns\_count\_p and turns count\_count\_s are redundant and use independent internal logic. A hysteresis of  $\pm 5.625^{\circ}$  is applied at the incremental boundaries. For example, if the current angle is  $45^{\circ}$  the turns-count increments when the angle increases above approximately 96°, and decrements when the angle decreases below approximately  $-6^{\circ}$ . The parameters TC\_HYST\_DIS\_P (extended: 0x3E [6]) and TC\_HYST\_DISP\_S (extended: 0x3F [6]) are available to disable the turns count hysteresis feature.

The turns-count value is reported in the parameters, TURNS\_



COUNT\_P (primary: 0x13 [10:0]), TURNS\_COUNT\_S (primary: 0x1A [10:0]), TURNS\_COUNT\_LATCH\_P (primary: 0x19 [10:0]), TURNS\_COUNT\_LATCH\_S (primary: 0x1B [10:0]). The turns counter saturates at +1023 and -1024 in 90 degree increments. If a counter register saturates, the Turns Count error flags, TCO\_ERROR\_P (primary: 0x13 [12]), TCO\_ ERROR\_S (primary: 0x1A [12]), TCO\_ERROR\_LATCH\_P (primary: 0x19 [12]), and TCO\_ERROR\_LATCH\_S (primary: 0x1B [12]), assert and stay asserted until the turns counter register is reset via the Control register.

During Low Power mode, the A33020 dedicated low power mode signal path periodically measures the magnet position and updates the turns count based on the angular change from the previous angle measurement. The design minimizes the amount of logic that is drawing power, allowing for efficient turns count tracking during battery-operated low-power modes If the angle changes by  $\geq 180$  degrees within a sleep period, the direction change is ambiguous and may be interpreted as a rotation in the opposite direction. Any sample-to-sample delta greater than the maximum low power angle delta, set to  $120^{\circ}$  for safety margin, sets the Turns Count Warning Flag. This is intended to give some indication the velocity exceeds the maximum possible for the configured LPM sample rate.

The sleep time settings (Extended: 0x3F [5:2]) are reported in Table 6.



Figure 20: Turns count example application



# A33020









| LPM_SLEEP_ | Sleep Time [1] | Average I <sub>CC</sub> <sup>[1]</sup> |          |          | Maximum RPM |         |         |
|------------|----------------|----------------------------------------|----------|----------|-------------|---------|---------|
| TIME       | (ms)           | (μΑ)                                   | at 200 G | at 150 G | at 100 G    | at 75 G | at 50 G |
| 0          | 1.7            | 58                                     | 10,073   | 9,502    | 8,341       | 7,141   | 4,535   |
| 1          | 1.9            | 55                                     | 9,012    | 8,502    | 7,463       | 6,389   | 4,057   |
| 2          | 2.5            | 50                                     | 6,849    | 6,461    | 5,672       | 4,856   | 3,084   |
| 3          | 3.5            | 45                                     | 4,892    | 4,615    | 4,051       | 3,468   | 2,202   |
| 4          | 5              | 42                                     | 3,424    | 3,230    | 2,836       | 2,428   | 1,542   |
| 5          | 10             | 38                                     | 1,712    | 1,615    | 1,418       | 1,214   | 771     |
| 6          | 50             | 35                                     | 342      | 323      | 283         | 242     | 154     |
| 7          | 100            | 34                                     | 171      | 161      | 141         | 121     | 77      |
| 8          | 0.5            | 113                                    | 34,248   | 32,308   | 28,361      | 24,281  | 15,420  |
| 9          | 0.6            | 100                                    | 28,540   | 26,923   | 23,634      | 20,234  | 12,850  |
| 10         | 0.7            | 91                                     | 24,463   | 23,077   | 20,258      | 17,343  | 11,014  |
| 11         | 0.8            | 84                                     | 21,405   | 20,192   | 17,725      | 15,175  | 9,637   |
| 12         | 0.9            | 78                                     | 19,027   | 17,949   | 15,756      | 13,489  | 8,566   |
| 13         | 1              | 74                                     | 17,124   | 16,154   | 14,180      | 12,140  | 7,710   |
| 14         | 1.2            | 67                                     | 14,270   | 13,461   | 11,817      | 10,117  | 6,425   |
| 15         | 5 1.5 61       |                                        | 11,416   | 10,769   | 9,453       | 8,093   | 5,140   |

Table 6: Low Power Mode Sleep Time Configuration

[1] Typical values are at 25°C and 30 G.



# **Turns Count Reset**

The A33020 primary and secondary turns counter reset after a reset event. The external controller may invoke a reset using the tcr field in the CTRL register (primary: 0xD [0])). Following a reset, the primary and secondary turns count initialize according to the parameters TURNS\_CNT\_INIT\_P (extended: 0x3E [1]) and TURNS\_CNT\_INIT\_S (extended: 0x3F [1]). These parameters configure the turns count registers to initiate at zero or a value between zero and three, corresponding with the quadrant of the initial angle reading. All incremental counts are tracked relative to the initial point, as measured by the turns count logic. Note it is recommended that the parameters TURNS\_CNT\_INIT\_P and TURNS\_CNT\_INIT\_S are set to the same value.

# **Transport Mode**

Transport mode is effectively an additional sleep mode feature of the A33020, but with the Low Power Mode Sleep State Oscillator disabled such that no turns counting occurs. To invoke transport mode, the parameter TRANSPORT\_EN (extended: 0x24 [8]) is set to 1. Then, when low power mode is enabled, (SPI inputs held low), transport mode is entered. As soon as one of the incoming SPI lines is high, the A33020 will wake up again.

In practice, when using transport mode, the parameter TRANS-PORT\_EN (extended: 0x24 [8]) is set to 0 in EEPROM but the corresponding TRANSPORT\_EN bit in shadow memory (extended: 0x64 [8]) is set to 1. In this case, the TRANSPORT\_ EN bit in shadow memory will clear after exiting transport mode. Otherwise said, the A33020 will enter transport mode the first time the SPI inputs are held low but will enter low power mode the following times the SPI inputs are held low.

# Linearization Feature

The A33020 contains sixteen fixed segments linearization for the main and all three redundant signal paths. Linearization allows for the conversion of the sensor measured magnetic field data into a customer desired output. This can be used to correct minor imperfections in the magnet or mounting tolerances.

Linearization converts the measured angle (sensed by the IC) into

a corrected output angle. Typically, this is used to align the measured angle to the mechanical angle (the actual magnet position).

The IC performs linearization by taking the measured angle and adding / subtracting a correction factor. This correction factor will differ over measured angle and is based on linearization coefficients stored in EEPROM. There are 16 coefficients, or "y" entries (16 for each main and redundant channels), corresponding to 16 measured angles corresponding to [0° 22.5° 45° ... 315° 337.5°]. For electrical angles not matching an entry in the EEPROM table, the correction factor is calculated by linearly interpolating between the two closest coefficients.

The "y" linearization EEPROM fields are 8-bit signed values, each coefficient has a range of -128 to 127 LSB, corresponding to a correction of -11.25 to +11.25 degrees (0.088° step size). The EEPROM fields name are XX\_LINEARIZATION\_YY with XX standing for AB, BC, CA, or MAIN and YY ranging from 0 to 15. YY = 0 corresponds to the angle correction for the measured position 0°. YY = 1 corresponds to the angle correction for the measured position 22.5°. See Table 7 for more details. For example, MAIN\_LINEARIZATION\_7 is the angle correction applied to the measured MAIN\_ANGLE = 157.5°.

Figure 22 is shown as an example or a nonlinear curve that is corrected by the sensor. In this example, the "y" values contained within EEPROM fields YY = 3, 4, and 8 are positive numbers while the "y" values within EEPROM fields YY = 6 and 7 are negative numbers (5 is basically no correction).

The A33020 sample programmer can be used to calculate the linearization coefficients or, alternatively, a MATLAB function is given in the corresponding appendix at the end of this datasheet.

Note that, in case of a short stroke  $[\Theta 1 \ \Theta 2]$  ( $|\Theta 2 - \Theta 1| < 360^\circ$ ), it is recommended to calibrate over  $[\Theta 1 - 360/16 \ \Theta 2 + 360/16]$  in order to have a proper linearization at the range ends. Alternatively, if previous proposal is not possible, it is recommended in the calculation to extrapolate the measured angles at the first neighbor calibration angles. For example, if the range is  $[20 \ 100^\circ]$ , it is recommended to program XX\_LINEARIZATION\_0 and XX\_ LINEARIZATION\_5 in addition to XX\_LINEARIZATION\_1 to XX\_LINEARIZATION\_4.







#### Table 7: EEPROM Names and Angles

| EEPROM Field<br>XX stands for AB, BC, CA, or MAIN | Corresponding measured angle to be corrected (deg) |
|---------------------------------------------------|----------------------------------------------------|
| XX_LINEARIZATION_0                                | 0                                                  |
| XX_LINEARIZATION_1                                | 22.5                                               |
| XX_LINEARIZATION_2                                | 45                                                 |
| XX_LINEARIZATION_3                                | 67.5                                               |
| XX_LINEARIZATION_4                                | 90                                                 |
| XX_LINEARIZATION_5                                | 112.5                                              |
| XX_LINEARIZATION_6                                | 135                                                |
| XX_LINEARIZATION_7                                | 157.5                                              |
| XX_LINEARIZATION_8                                | 180                                                |
| XX_LINEARIZATION_9                                | 202.5                                              |
| XX_LINEARIZATION_10                               | 225                                                |
| XX_LINEARIZATION_11                               | 247.5                                              |
| XX_LINEARIZATION_12                               | 270                                                |
| XX_LINEARIZATION_13                               | 292.5                                              |
| XX_LINEARIZATION_14                               | 315                                                |
| XX_LINEARIZATION_15                               | 337.5                                              |



# A33020

## **DEVICE PROGRAMMING INTERFACES**

The A33020 can be programmed in two ways:

- Using the SPI interface for input and output
- Using a *Manchester protocol* on the PWM pin to send and receive data

The A33020 does not require special supply voltages to write to the EEPROM.

All accessible fields of the IC may be read and written using both protocols. If EEPROM locking is used, write access using either protocol may be limited.

# **Interface Structure**

The A33020 consists of two memory blocks: Primary serial registers (direct memory), and extended memory Shadow memory, EEPROM, and some miscellaneous volatile registers. The primary serial interface registers are used for direct writes and reads by the host controller for frequently required information (for example, angle data, warning flags, field strength, and temperature). All forms of communication (including the extended locations) operate through the primary registers, whether it be via SPI or Manchester.

The primary serial registers provide data and address location for accessing extended memory locations. Accessing these extended locations is done in an indirect fashion: the controller writes into the primary interface to give a command to the sensor to access the extended locations. The read/write is executed and the result is again presented in the primary interface.

This concept is shown in Figure 24 below.

For writing extended locations, the primary interface registers INDIRECT\_WR\_ADDRESS (primary: 0x1), INDIRECT\_WR\_ DATA\_MSB (primary: 0x2), and INDIRECT\_WR\_DATA\_LSB (primary 0x3) are used for writing extended memory locations. INDIRECT\_WR\_ADDRESS holds the address of the target extended memory location to be written. INDIRECT\_WR\_ DATA\_MSB and INDIRECT\_WR\_DATA\_LSB contain the two high bytes and the two low bytes for the extended location contents. The INDIRECT\_WR\_STATUS (primary: 0x4) register is used for commands and status information. Refer to the section Read Transaction from EEPROM for further information and other register fields associated with indirect memory transactions.

For reading extended locations, the primary interface registers INDIRECT\_RD\_ADDRESS (primary: 0x5), INDIRECT\_RD\_ DATA\_MSB (primary: 0x7), and INDIRECT\_RD\_DATA\_LSB (primary 0x8) are used for reading extended memory locations. INDIRECT\_RD\_ADDRESS holds the address of the target extended memory location to be read. INDIRECT\_RD\_DATA\_ MSB and INDIRECT\_RD\_DATA\_LSB contain the two high bytes and the two low bytes for the extended location contents. The INDIRECT\_RD\_STATUS (primary: 0x6) register is used for commands and status information. Refer to the section Read Transaction from EEPROM for further information and other register fields associated with indirect memory transactions.

For more information on EEPROM and shadow memory read and write access, see EEPROM and Shadow Memory section.

The primary serial interface can be accessed using the SPI and using the Manchester interface. These two interfaces are detailed in the following sections.



Figure 24: Serial Registers allow access to extended memory (EEPROM and Shadow) SPI



# SPI

The A33020 provides a full-duplex 4-pin SPI interface, using SPI mode 3 (CPHA = 1, CPOL = 1). For the A33020, the SPI interface is also used to control entering and leaving of the low power and transport modes.

The sensor responds to commands received on the MOSI (Controller-Out Peripheral-In), SCLK (Serial Clock), and  $\overline{CS}$  (Chip Select) pins, and outputs data on the MISO (Controller-In Peripheral-Out) pin. SPI may operate at either 3.3 or 5 V, depending on the interface voltage specified for the part number.



Figure 25: SPI Interface Programming Setup

#### Table 8: SPI Interface Timings Output [1]

## TIMING

The interface timing parameters from Table 8 are displayed in Figure 26 and Figure 27 below.







Figure 27: SPI Interface Timings Output

| Characteristics                | Symbol               | Test Conditions                                                   | Min. | Тур. | Max. | Unit |
|--------------------------------|----------------------|-------------------------------------------------------------------|------|------|------|------|
| SPI Message Length             | SPILENGTH            |                                                                   | 32   | -    | 32   | bits |
| SDI Clock Frequency            | f                    | MISO pins, $C_L \le 20 \text{ pF}$                                | 0.1  | -    | 10   | MHz  |
| SPI Clock Frequency            | f <sub>SCLK</sub>    | MISO pins, C <sub>L</sub> ≤ 50 pF                                 | 0.1  | -    | 1    | MHz  |
| SPI Clock Duty Cycle           | D <sub>fSCLK</sub>   | SPI <sub>CLKDC</sub>                                              | 40   | -    | 60   | %    |
| SPI Frame Rate                 | t <sub>SPI</sub>     | SPI message is 32 bits                                            | 3    | -    | 289  | kHz  |
| Chip Select to First SCLK Edge | t <sub>CS</sub>      | Time from CS going low to SCLK falling edge                       | 50   | -    | -    | ns   |
| Chip Select Idle Time          | t <sub>CS_IDLE</sub> | Time CS must be high between SPI message frames                   | 200  | _    | _    | ns   |
| Data Output Valid Time         | t <sub>DAV</sub>     | Data output valid after SCLK falling edge, C <sub>L</sub> = 20 pF | _    | _    | 50   | ns   |
| MOSI Setup Time                | t <sub>SU</sub>      | Input setup time before SCLK rising edge                          | 25   | -    | -    | ns   |
| MOSI Hold Time                 | t <sub>HD</sub>      | Input hold time after SCLK rising edge                            | 40   | -    | -    | ns   |
| SCLK to CS Hold Time           | t <sub>CHD</sub>     | Hold SCLK high time before CS rising edge                         | 5    | -    | -    | ns   |

<sup>[1]</sup> Parameter is not measured at final test. Limits based on design simulations.



## **MESSAGE FRAME**

The SPI interface uses a 32-bit packet and is designed to provide a high level of confidence for data for data integrity. There are three possible SPI transactions: Write Cycle, Read Request (from the controller), and Read Response (from the peripheral).

| Bit # | 31   | 30 2       | 9 28      | 8 27     | 26        | 25       | 24     | 23     | 22 | 21    | 20    | 19    | 18    | 17    | 16    | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5  | 4     | 3     | 2     | 1       | 0    |   |
|-------|------|------------|-----------|----------|-----------|----------|--------|--------|----|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|----|-------|-------|-------|---------|------|---|
| CSN   |      |            |           |          |           |          |        |        |    |       |       |       |       |       |       |      |      |      |      |      |      |      |      |      |      |    |       |       |       |         |      |   |
| SCLK  |      | 2          | 3         | 4 !      | 6         | 7        | 8      | 9      | 10 | 11    | 12    | 13    | 14    | 15    | 16    | 17   | 18   | 19   | 20   | 21   | 22   | 23   | 24   | 25   | 26   | 27 | 28    | 29    | 30    | 31      | 32   | — |
| MOSI  | 0 W  | -1 R-0 A   | 4 A:      | 3 A2     | A1        | A0       | -      |        |    | DI-15 | DI-14 | DI-13 | DI-12 | DI-11 | DI-10 | DI-9 | DI-8 | DI-7 | DI-6 | DI-5 | DI-4 | DI-3 | DI-2 | DI-1 | DI-0 |    | CRC-4 | CRC-3 | CRC-2 | CRC-1 C | RC-0 |   |
| MISO  | 1 Pr | ev-A4 Prev | v-A3 Prev | -A2 Prev | A1 Prev-A | 0 Count2 | Count1 | Count0 | S1 | D-15  | D-14  | D-13  | D-12  | D-11  | D-10  | D-9  | D-8  | D-7  | D-6  | D-5  | D-4  | D-3  | D-2  | D-1  | D-0  | S0 | CRC-4 | CRC-3 | CRC-2 | CRC-1 C | RC-0 |   |

#### Figure 28: 32-Bit SPI Frame

#### Write Cycle or Read Request Cycle

The write cycle and read request frame structure is shown in Figure 29 and Figure 30. The frames consist of the following:

- Start Bit [31]: Static bit with a logic value of 0. This bit is not used in the CRC calculation.
- R/W[30]: Read/Write bit set to a logic value of 1 to signify a

- write cycle and 0 to signify a read request.
- Address [29:25]: Address bits for accessing primary registers
- Data [21:6]: Data bit for writing primary registers. Considered immaterial for a read request.
- CRC [4:0]: CRC bits calculated on the frame bits [30:5].
- Immaterial bits [24:22, 5]: Value can be 1 or 0.

|   | Bit  | 31 | 30 | 29 | 28  | 27      | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6      | 5  | 4 | 3 | 2 | 1 | 0 |
|---|------|----|----|----|-----|---------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|--------|----|---|---|---|---|---|
| N | NOSI | 0  | 1  |    | Add | lress [ | 4:0] |    |    | _  |    |    |    |    |    |    |    |    |    |    |    |    |    | - |   | CI | RC [4: | 0] |   |   |   |   |   |

#### Figure 29: Write Cycle SPI Frame

| Bit  | 31 | 30 | 29 | 28  | 27      | 26   | 25 | 24 | 23 | 22 | 21                                          | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7      | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|-----|---------|------|----|----|----|----|---------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|----|---|---|---|---|---|---|
| MOSI | 0  | 0  |    | Add | lress [ | 4:0] |    |    | _  |    | Data [15:0] (immaterial for a read request) |    |    |    |    |    |    |    |    |    |    | —  |   | CI | RC [4: | 0] |   |   |   |   |   |   |

Figure 30: Read Request Cycle Frame

#### **Read Response Cycle**

The read response cycle frame, sent from the IC, as shown in Figure 31. The frame consists of the following:

- Start Bit [31]: Start bit is set to a value of 1. This bit is not used in the CRC calculation.
- Previous Address [30:26]: Register address corresponding to the read request data.
- Frame Count [25:23]: Frame counter, increments with each SPI frame.
- S1 [22]: Status/Error Flag
  - Logical OR of all unmasked error flags. Set to 1 if any

unmasked error flag is asserted. Will clear once presented on the SPI bus following a read, assuming error condition has cleared.

- ABI and SLR reported via S1.
- S0 [5]: Status/Error Flag
  - Logical OR of all unmasked error flags. Set to 1 if any unmasked error flag is asserted. Will clear once presented on the SPI bus following a read, assuming error condition has cleared.
- Data [21:6]: Data contents from primary register.
- CRC [4:0]: CRC bits calculated over the frame [30:5]

| Bit  | 31 | 30  | 29     | 28   | 27     | 26  | 25   | 24     | 23      | 22 | 21             | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6      | 5  | 4 | 3 | 2 | 1 | 0 |
|------|----|-----|--------|------|--------|-----|------|--------|---------|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|--------|----|---|---|---|---|---|
| MISO | 1  | Pre | evious | Addr | ess [4 | :0] | Fram | e Coun | t [2:0] | S1 | 51 Data [15:0] |    |    |    |    |    |    |    |    |    |    |    | S0 |   | CF | RC [4: | 0] |   |   |   |   |   |

#### Figure 31: Read Response Cycle Frame



# A33020

## CRC

Each SPI frame includes a 5-bit CRC, calculated using the polynomial:  $x^5 + x^2 + 1$  with a seed value of  $11111_2$ .



Figure 32: CRC Calculation with Left Shift Register

The outgoing CRC is calculated by the A33020 and transmitted on the MISO pin. The incoming CRC must be calculated by the Controller and included on the MOSI pin. The A33020 checks the CRC on every incoming frame, an invalid frame is ignored. The CRC achieves a hamming distance of 3 for secure data transmission. The CRC may be calculated with the following C code:

```
#include <stdio.h>
#include <stdint.h>
#include <stdbool.h>
/**
 * Computes a 5-bit CRC using the polynomial X^5 + x^2 + 1
*
```

\* This function calculates a 5-bit Cyclic Redundancy Check (CRC)

\* for a given SPI Frame.

\* It utilizes the specified polynomial (X^5 + x^2 + 1) for computation.

 $\ast$  @param data The input data for which the CRC is to be calculated.

\* @param numberOfBits The number of bits to consider for the CRC calculation.

 $\ast$  % Should be set to 26, MSB of SPI frame is not included in CRC calc.

 $\ast$  @return The computed 5-bit CRC value as a 16-bit unsigned integer. The CRC

\* is based on the provided polynomial and the specified
number of bits
\* from the input data

\* from the input data
\*/

uint16\_t SPI\_CRC5(uint64\_t data, uint16\_t numberOfBits) {

```
bool C0 = false:
       bool C1 = false;
       bool C2 = false;
       bool C3 = false;
       bool C4 = false;
       bool COp = true;
       bool C1p = true;
       bool C2p = true;
       bool C3p = true;
       bool C4p = true;
       bool newBit = false;
       uint64_t bitMask = 1;
       bitMask <<= numberOfBits - 1;</pre>
       for (; bitMask != 0; bitMask >>=1) {
                 newBit = ((data & bitMask) != 0);
                 C4 = C3p;
                 C3 = C2p;
                 C2 = C1p ^ C4p ^ newBit;
                 C1 = C0p;
                 C0 = C4p \land newBit;
                 C0p = C0;
                 C1p = C1;
                 C2p = C2;
                 C3p = C3;
                 C4p = C4;
       return (C4? 16U: 0U) + (C3? 8U: 0U) + (C2? 4U: 0U) + (C1?
2U: 0U) + (C0? 1U: 0U);
}
```



# A33020

The CRC may be calculated with the following Python code: def spi\_crc(data\_frame):

```
SPI CRC: Takes 27 bit input and generates 5 bit CRC.
Polynomial = x^5 + x^2 + 1
Initial CRC value set to all 1s
Input:
   data_frame: a string representing 27 bit binary data
ແກກ
crc = list('11111') #CRC seed = 11111
# MSB of SPI frame is not used during CRC calculation.
for j in range(1, 27):
   old_crc = crc
   aux_crc_1 = crc[1]
   aux\_crc\_4 = crc[4]
   crc[4] = int(old_crc[3])
crc[3] = int(old_crc[2])
    crc[2] = int(aux_crc_1) ^ int(aux_crc_4) ^ int(data_frame[j])
    crc[1] = int(old_crc[0])
    crc[0] = int(aux_crc_4) ^ int(data_frame[j])
#flips calculated CRC around to obtain value in proper order
crc = crc[::-1]
```

```
return crc
```

A MATLAB implementation of the CRC is:

```
function [output_binary_word,CRC]=Allegro_CRC_x5_x2(input_
binary word)
%% Initialization
CRC=ones(5,1);
%% CRC calculation
for i=1:length(input_binary_word)
    old CRC=CRC;
    aux_CRC2=CRC(2);
    aux_CRC5=CRC(5);
    CRC(5)=old_CRC(4);
    CRC(4)=old_CRC(3);
    aux=xor(aux_CRC2,aux_CRC5);
    CRC(3)=xor(aux,str2num(input_binary_word(i)));
    CRC(2)=old_CRC(1);
    CRC(1)=xor(aux_CRC5,str2num(input_binary_word(i)));
end
%% Outputs
```

CRC=[num2str(CRC(5)) num2str(CRC(4)) num2str(CRC(3)) num2str(CRC(2)) num2str(CRC(1))]; output\_binary\_word=[input\_binary\_word CRC];



#### MISO RESPONSE ON RECEIPT OF BAD CRC

Following receipt of a bad CRC the IC will return a special SPI packet to indicate to the Controller a problem has occurred. Changes to the MISO packet are:

- Previous Address [30:26]: Set to 0x11.
- Data[21:6]: Contains the contents of the error register (primary: 0xF).
  - Note: The IER flag is not set on the first SPI packet; however, a read of the error register (address 0xF) will show the IER flag asserted.

This packet is shown in Figure 32.

#### **MISO RESPONSE FOLLOWING A WRITE**

Following a write operation, the MISO packet will contain predetermined values within the Previous Address and Data Fields.

- Previous Address [30:26]: Set 0x10.
- Data [21:6]: Primary Angle Value (ANGLE\_OUT\_MAIN from primary 0xE).

This packet is shown in Figure 33.

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23    | 22 | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14   | 13   | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5 | 4 | 3  | 2      | 1  | 0 |
|------|----|----|----|----|----|----|-------|-------|-------|----|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|-----|-----|-----|-----|-----|---|---|----|--------|----|---|
| MISO | 1  | 1  | 0  | 0  | 0  | 1  | Frame | Count | [2:0] | 0  | IER | XEE | BSY | SME | EUE | ESE | POR | OVCC | UVCC | MSH | MSL | SMM | OFE | SAT | TSE | VCF | 0 |   | CF | RC [4: | D] |   |

#### Figure 33: MISO Response Following Bad CRC

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24     | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14    | 13    | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3  | 2      | 1  | 0 |
|------|----|----|----|----|----|----|-------|--------|---------|----|----|----|----|----|----|----|----|-------|-------|-----|----|----|---|---|---|---|----|---|----|--------|----|---|
| MISO | 1  | 1  | 0  | 0  | 0  | 0  | Frame | e Coun | t [2:0] | S1 |    |    |    |    |    |    | AN | GLE_C | UT_MA | AIN |    |    |   |   |   |   | S0 |   | CI | RC [4: | 0] |   |

Figure 34: MISO Response Following a Write Operation

#### **SPI POWER ON RESPONSE**

After a power cycle or returning from Low Power Mode, S1 and S0 are set to logic = 1 until the ANGLE\_RDY (primary: 0xC [0]) bit is set and no other errors are locked. This is an indication to the controller that the signal chain has stabilized and the angle is valid. In addition, transitioning S1 and S0 from logic = 1 to logic = 0 allows for the detection of a stuck diagnostic bit.

The full content of the first SPI return packet following a poweron is 0x80400021. This response only occurs following a full power-cycle or return from Low Power Mode. The SPI logic does not reset following a full or soft reset initiate via the CTRL register (Address 0x0D).

| Bit         | 31                          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| Description | 1 Address Frame Cnt S1 Data |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | S0 |    |    | CRC |    |   |   |   |   |   |   |   |   |   |   |
| Binary      | 1                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |

Figure 35: Initial SPI Response Frame Following Power-On or Return from Low Power Mode



# **Manchester Interface**

To facilitate addressable device programming when using the unidirectional PWM, ABI, or UVW protocols, without requiring four additional SPI connections, the A33020 incorporates an additional serial communication using the PWM line.

This interface allows an external controller to read and write registers in the A33020 EEPROM and volatile memory. The point-to-point communication protocol is based on Manchester encoding per G.E. Thomas (a rising edge indicates a 0 and a falling edge indicates a 1), with address and data transmitted MSB first.

The setup for communication using the Manchester interface is given in Figure 35.



### Figure 36: Manchester Programming Interface Setup

The Manchester interface allows programming and readout with a minimal number of pins involved. A valid auxiliary request command recognized by the sensor places the device into communications mode. In this mode, serial data is transmitted or

received on the PWM pin. In the absence of a clock signal, Manchester encoding is used, allowing the sensor to determine the bit rate requested by the controller. The high and low logic level for the Manchester serial data is determined by the Manchester High and Low Voltage parameters. The PWM output consists of an open drain type circuit. A sufficient pull-up resistor and external supply voltage are required.

# ENTERING MANCHESTER COMMUNICATION MODE

The A33020 continuously monitors the PWM line for a valid Auxiliary command. The Auxiliary command, shown in Figure 34, is initiated by the main controller pulling the PWM output line low for at least two PWM periods. When the controller releases the PWM line, there is a limited time window to start transmission of the Manchester Access Code ( $t_{msgRX}$ ). Once a valid Access code is received, the A33020 enters programming mode, and customer EEPROM/Shadow memory may be read/ written. The communication enable, MANCH\_COMM\_E, bit (extended: 0xA6 [15]) controls the state of the PWM output. When set to a logic 1 the PWM output is disabled, allowing Manchester communication on the PWM line. Setting MANCH\_COMM\_E to 0 re-enables the PWM output, disabling Manchester communication.

| Table 9: Auxiliary | Command | Parameters |
|--------------------|---------|------------|
|--------------------|---------|------------|

| Parameter          | Mode                         | Min.                  | Max. | Units |
|--------------------|------------------------------|-----------------------|------|-------|
| t <sub>hold</sub>  | PWM,<br>Auxiliary<br>Command | $2 \times PWM$ period | _    | μs    |
| t <sub>gate</sub>  | -                            | 0.7                   | -    | μs    |
| t <sub>msgRX</sub> | -                            | 1.4                   | 300  | μs    |

#### **Table 10: Programming Characteristics**

| Parameter                  | Description           | Min. | Тур. | Max.            | Units |
|----------------------------|-----------------------|------|------|-----------------|-------|
| Bit Rate                   | Communication<br>rate | 4    | _    | 100             | kbps  |
| Manchester<br>High Voltage | Data pulses on<br>PWM | 2.8  | -    | V <sub>CC</sub> | V     |
| Manchester<br>Low Voltage  | _                     | 0    | _    | 1.2             | V     |



### Figure 37: Auxiliary Interrupt Pulse Waveform

# TRANSACTION TYPES

The A33020 receives all Manchester communication commands and responds with data on the PWM pin. Each transaction is initiated by a command from the controller; the sensor does not initiate any transactions. Two commands are recognized: Write and Read.



# A33020

### Manchester Command Frame General Format

The general format of a Manchester command message frame is shown in Figure 37. Serial binary data is encoded using a Manchester encoding scheme, where a bit value of 1 is indicated by a falling edge within the bit boundary, and a bit value of zero is indicated by a rising edge within the bit boundary. The time period for the bit boundary is determined by the baud rate initiated by the external controller. The A33020 read acknowledge is transmitted at the same rate as the command message frame. The bits are described in Table 11.



Figure 38: Manchester Message Format

| Table | 11: | A33020 | Manchester | Message | Structure |
|-------|-----|--------|------------|---------|-----------|
| TUDIC |     | ACCOLO | manenester | message | onacture  |

| Quantity of |                 | _       |                                                                                                      |
|-------------|-----------------|---------|------------------------------------------------------------------------------------------------------|
| Bits        | Name            | Values  | Description                                                                                          |
| 2           | Synchronization | 0       | Used to identify the<br>beginning of a serial<br>interface command<br>and communication<br>bit time. |
| 1           | Read/Write      | 0       | [As required] Write<br>operation                                                                     |
| 1           | Read/Wille      | 1       | [As required] Read<br>operation                                                                      |
| 5           | Address         | 0x-0x1F | [Read/Write] Register<br>address (of primary<br>serial interface)                                    |
| 16          | Data            | 0/1     | Only for writes: 16 bits<br>write data. Omit for<br>read commands.                                   |
| 3           | CRC             | 0/1     | Bits to check the validity of frame.                                                                 |

### **READ COMMAND**

The Read command is 11 bits in length, composed of 2 synchronization bits, 1 R/W bit, 5 memory address bits, and 3 CRC bits.



#### Figure 39: Manchester Read Request Command

#### **READ ACKNOWLEDGE**

The Read Acknowledge frame is composed of the synchronization bits, 16 data bits, and 3 CRC bits.



#### Figure 40: Manchester Read Acknowledge Command

#### WRITE COMMAND

The Write command is 27 bits in length, composed of 2 synchronization bits, 1 R/W bit, 5 memory address bits, 16 data bits, and 3 CRC bits.



#### Figure 41: Manchester Write Command

The 5-bit memory address corresponds to the serial register address to which the 16 bits will be written.



A33020

{

}

#### **Manchester Communication CRC**

The Manchester serial interface uses a cyclic redundancy check (CRC) for data-bit error checking (synchronization bits are ignored by the check). The CRC algorithm is based on the following polynomial and the calculation is represented graphically in Figure 41. The trailing 3 bits of a message frame comprise the CRC token. The CRC is initialized at 0b111.





Figure 42: Manchester CRC Calculation

The 3-bit Manchester CRC can be calculated using the following C code:

// command: the Manchester command, right justified, does not include the space for the CRC // numberOfBits: number of bits in the command not including the 2 zero sync bits at the start of the command and the three CRC bits // Returns: The three bit CRC

// This code can be tested at http://codepad.org/yqTKnfmD

uint16\_t ManchesterCRC(uint64\_t data, uint16\_t numberOfBits)

```
bool C0 = false;
bool C1 = false;
bool C2 = false;
bool C0p = true;
bool C1p = true;
bool C2p = true;
uint64 t bitMask = 1;
bitMask <<= numberOfBits - 1;</pre>
// Calculate the state machine
for (; bitMask != 0; bitMask >>= 1)
{
       C2 = C1p;
       C0 = C2p ^ ((data & bitMask) != 0);
       C1 = C0 \wedge C0p;
       COp = CO;
       C1p = C1;
       C2p = C2;
}
return (C2 ? 4U : 0U) + (C1 ? 2U : 0U) + (C0 ? 1U : 0U);
```



# EEPROM AND SHADOW MEMORY USAGE

The A33020 device features include integrated EEPROM to permanently store configuration parameters for operation. EEPROM is customer programmable and retains data, or parameter values, to configure the device for the application requirements. After a reset, or EEPROM write operation, parameter data is copied from EEPROM to shadow (volatile) memory. Parameter data in shadow memory, can be overwritten by performing an extended write to the shadow addresses. Access of device parameters through shadow memory is faster than access through EEPROM. In situations where it is desired to test many parameters quickly before permanently programming, use of shadow memory is recommended. The shadow memory registers have the same format as EEPROM and are accessed at extended addresses 0x40 higher than the equivalent EEPROM address. Some bits do not impact device operation and are not copied into shadow memory. Shadow registers do not contain the ECC bits and may have read or write protection restrictions similar to EEPROM.

# **Enabling EEPROM Access**

Reads and writes to indirect memory, EEPROM, and shadow memory are restricted and require an unlock code. The unlock code is written to the primary serial register ACCESS (primary: 0x1E [15:0]). This involves two write commands, which should be executed after each other:

For SPI communication:

Write 0xC418 to register primary 0x1E [15:0] Write 0x0E80 to register primary 0x1E [15:0]

For Manchester communication:

Write 0xC418 to register primary 0x1E [15:0] Write 0x0E81 to register primary 0x1E [15:0]

Writing the communication enable bit, MANCH\_COMM\_E (extended 0xA6 [15]) to a value of 0 or a reset event disables the communications mode.

The access status is indicated by the direct serial register ACCESS. A read of primary 0x1E [1], set to a value of 1 indicates the customer unlock code is set.

The customer unlock code is not required for write and read operations to all the direct serial registers.

Following an EEPROM write, EEPROM margin checking should be performed. The device must be unlocked when performing margin checks.

# **EEPROM and Shadow Access Protections**

The A33020 contains features to protect against unwanted EEPROM access.

- Setting the EEPROM parameter MEM-LOCK (extended: 0x24 [21:18]) to a value of 0xC (1100 binary) restricts write access to prevent changes the EEPROM registers. Temporary changes to device configuration settings are still possible by writing to the indirect volatile and shadow memory. Note, any changes to the indirect volatile memory are reset after a device reset event. Read access of the EEPROM is still possible.
- Setting the EEPROM parameter MEM-LOCK (extended: 0x24 [21:18]) to a value of 0x3 (0011 binary) restricts write access to prevent changes to EEPROM, indirect volatile, and shadow memory. Once set the parameter settings in indirect memory are read only. Read access is still possible.
- Writes to the MEM-LOCK parameter with the above values are one time access only and are not erasable through subsequent write commands.

# Write Transactions to Extended Memory: EEPROM, Shadow, and Volatile

Invoking an extended write access is a three-step process:

- 1. Write the target extended address to the primary register INDIRECT\_WR\_ADDRESS (primary: 0x1 [7:0]).
- Write the desired data, for the target extended register, to the primary registers INDIRECT\_WR\_DATA\_MSB (primary: 0x2 [15:0]) and INDIRECT\_WR\_DATA\_LSB (primary: 0x3 [15:0]). The register INDIRECT\_WR\_DATA\_LSB corresponds to the data bits [15:0] of the target extended memory address. The register INDIRECT\_WR\_DATA\_MSB corresponds to the data bits [31:16] of the target extended memory address.
- 3. Execute the extended memory write by setting the extended memory execute write bit, EXW (primary: 0x4 [15]), to a value of 1.
  - a. EEPROM writes require  $\approx 6.5$  ms to complete

When the bit exw is set the 32 bits of data contained in INDI-RECT\_WR\_DATA\_LSB and INDIRECT\_WR\_DATA\_LSB are written to the indirect memory address specified by INDI-RECT\_WR\_ADDRESS. The status of the write may be interrogated by polling the primary register INDIRECT\_WR\_STA-TUS (primary: 0x4). The bit WIP (primary: 0x4 [8]), when set, indicates write transaction in progress. The bit WDN (primary: 0x4 [0]), when set, indicates write transaction done, or complete. The error status bit XEE (primary: 0x11 [15]), when set, indicates an error occurred when executing the write. For example, if a write is attempted without the proper access enabled the XEE bits indicates an error.



# Read Transaction from EEPROM and Other Extended Locations

Extended access is provided to additional memory space via the direct registers. This access includes the EEPROM and EEPROM shadow registers. All extended registers are up to 32 bits wide. Invoking an extended read access is a three-step process:

- 1. Write the extended address to be read into the INDI-RECT\_RD\_ADDRESS (primary: 0x5) register (using SPI or Manchester direct access). INDIRECT\_RD\_ADDRESS is the 8-bit extended address that determines which extended memory address will be accessed.
- 2. Invoke the extended access by writing the EXR bit (primary: 0x6 [15] with a value of 1. The address specified in INDI-RECT\_RD\_ADDRESS is then read, and the data is loaded into the INDIRECT\_RD\_DATA\_MSB (primary: 0x7) and INDIRECT\_RD\_DATA\_LSB (primary: 0x8) registers.
- 3. Read the INDIRECT\_RD\_DATA\_MSB and INDIRECT\_ RD\_DATA\_LSB registers (using SPI or Manchester direct access) to get the full data contents of the extended read address. The register INDIRECT\_RD\_DATA\_LSB corresponds to the data bits [15:0] of the target extended memory address. The register INDIRECT\_RD\_DATA\_MSB corresponds to the data bits [31:16] of the target extended memory address.

EEPROM read accesses may take up to 2  $\mu$ s to complete. The RDN (primary: 0x6 [0]) bit can be polled to determine if the read access is complete before reading the data. Shadow register reads complete in one system clock cycle after synchronization. Do not attempt to read the INDIRECT\_RD\_DATA\_MSB and INDIRECT\_RD\_DATA\_LSB) registers if the read access is in process (RIP primary: 0x6 [8] = 1), as it could change during the serial access and the data will be inconsistent. It is also possible that an SPI CRC error will be detected if the data changes during the serial read via the SPI interface.

# **Shadow Memory Read and Write Transactions**

Shadow memory Read and Write transactions are identical to those for EEPROM. Instead of addressing to the EEPROM extended address, one must address to the Shadow Extended addresses, which are located at an offset of 0x40 above the EEPROM. Refer to the EEPROM Table 12, Table 13, and Table 14 for all addresses.

# EEPROM Margin Check

The A33020 contains a test mode, EEPROM Margining, to check the logic levels of the EEPROM bits. The EEPROM margining is accessible with customer access. The EEPROM margining is selectable to check all logic 1, logic 0, or both. The results of the test are reported back in extended memory registers 0x85, 0x83, and 0x82. Note that a fail of the margin test does not force the outputs to a diagnostic state or trigger a diagnostic error flag. The following is a step-by-step procedure to verify EEPROM programming:

- 1. Enable EEPROM access by sending the unlock code to primary address 0x1E.
- 2. Write a '1' to the MARGIN\_START field (volatile 0x85 [0])
  - a. Once started the device will automatically check high/low thresholds for all EEPROM addresses.
- 3. Read MARGIN\_STATUS (volatile 0x85 [4:3]).
  - 0 = No result from margin testing (margin testing not run).
  - 1 =Pass. Margin checking completed with no errors.
  - 2 = Failure detected during margin testing.
  - 3 = Running. Margin testing is still running.
- 4. If a margin failure is detected additional information can be retrieved.
  - MARGIN\_MIN\_MAX\_FAIL (volatile 0x85 [5]).
  - 0 = Margin low threshold failure.
  - 1 = Margin high threshold failure.
  - EE\_ADDR (volatile 0x82 [12:7]) contains the failing address.
- 5. EEPROM should not be considered valid unless margin testing passes. If the margin failure occurs on a previously modified address space, EEPROM can be rewritten and margin checking repeated in an attempt to clear the issue.

See section Extended Memory Table 12 addresses 0x82, 0x83, and 0x85 for more information on EEPROM margining. Time required to verify margin levels across all EEPROM is  $\approx$ 100 µs.



# PRIMARY SERIAL INTERFACE REGISTER REFERENCE

Table 12: Direct Serial Interface Registers Bits Map

| Address |                      |        | Primary Addresse Byte (MSB) |                |             |             |          |               |                           |                               |                            |             | Prin          | nary Addres | ssed Byte ( | LSB)     |          |         |
|---------|----------------------|--------|-----------------------------|----------------|-------------|-------------|----------|---------------|---------------------------|-------------------------------|----------------------------|-------------|---------------|-------------|-------------|----------|----------|---------|
| (0x00)  | Register Symbol      | Access | 15                          | 14             | 13          | 12          | 11       | 10            | 9                         | 8                             | 7                          | 6           | 5             | 4           | 3           | 2        | 1        | 0       |
| 0x0     | NULL_REG             | RO     | 0                           | 0              | 0           | 0           | 0        | 0             | 0                         | 0                             | 0                          | 0           | 0             | 0           | 0           | 0        | 0        | 0       |
| 0x1     | INDIRECT_WR_ADDRESS  | RW     | 0                           | 0              | 0           | 0           | 0        | 0             | 0                         | 0                             |                            |             |               | INDIRECT    | _WR_ADDF    | <br>?    |          |         |
| 0x2     | INDIRECT_WR_DATA_MSB | RW     |                             |                |             | INDIRECT    | WR_DATA_ | 3             |                           |                               |                            |             |               | INDIRECT_   | WR_DATA     | 2        |          |         |
| 0x3     | INDIRECT_WR_DATA_LSB | RW     |                             |                |             | INDIRECT_   | WR_DATA_ | 1             |                           |                               |                            |             |               | INDIRECT_   | WR_DATA_    | 0        |          |         |
| 0x4     | INDIRECT_WR_STATUS   | WO/RO  | EXW                         | 0              | 0           | 0           | 0        | 0             | 0                         | WIP                           | 0                          | 0           | 0             | 0           | 0           | 0        | 0        | WDN     |
| 0x5     | INDIRECT_RD_ADDRESS  | RW     | 0                           | 0              | 0           | 0           | 0        | 0             | 0                         | 0                             |                            |             | 11            | NDIRECT_R   | RD_ADDRE    | SS       |          |         |
| 0x6     | INDIRECT_RD_STATUS   | WO/RO  | EXR                         | 0              | 0           | 0           | 0        | 0             | 0                         | RIP                           | 0                          | 0           | 0             | 0           | 0           | 0        | 0        | RDN     |
| 0x7     | INDIRECT_RD_DATA_MSB | RO     |                             |                |             | INDIRECT_   | RD_DATA_ | 3             |                           |                               |                            |             |               | INDIRECT_   | RD_DATA_    | 2        |          |         |
| 0x8     | INDIRECT_RD_DATA_LSB | RO     |                             |                |             | INDIRECT_   | RD_DATA_ | 1             |                           |                               |                            |             |               | INDIRECT_   | RD_DATA_    | 0        |          |         |
| 0x9     | HP_A_REG             | RO     |                             |                |             |             |          |               |                           | HF                            | P_A                        |             |               |             |             |          |          |         |
| 0xA     | HP_B_REG             | RO     |                             |                |             |             |          |               |                           | HF                            | Р_В                        |             |               |             |             |          |          |         |
| 0xB     | HP_C_REG             | RO     |                             |                |             |             |          |               |                           | HF                            | 2_C                        |             |               |             |             |          |          |         |
| 0xC     | STATUS_REG           | RO/RC  | 0                           | 0              | 0           | 0           | 0        | 0             | ECC_SELF_TEST_FAILED_FLAG | LP_COMP_SELF_TEST_FAILED_FLAG | POKS_SELF_TEST_FAILED_FLAG | MASK_ACTIVE | BACK_FROM_LPM | SLR         | ABI         | ACD      | ROT_H    | ANG_RDY |
| 0xD     | CTRL                 | RW     | 0                           | 0              | 0           | 0           | 0        | 0             | 0                         | 0                             | 0                          | 0           | 0             | 0           | FULL_RST    | SOFT_RST | TC_WR_EN | TCR     |
| 0xE     | MAIN_ANGLE           | RO     |                             |                |             |             |          |               |                           | ANGLE_C                       | DUT_MAIN                   |             |               |             |             |          |          |         |
| 0xF     | ERROR                | RO/RC  | IER                         | XEE            | BSY         | SME         | EUE      | ESE           | POR                       | OVCC                          | UVCC                       | MSH         | MSL           | SMM         | OFE         | SAT      | TSE      | VCF     |
| 0x10    | TEMP12B_P            | RO     | 0                           | 0              | 0           | 0           |          |               |                           |                               |                            | TEMP_       | OUT_P         |             |             |          |          |         |
| 0x11    | TEMP12B_S            | RO     | 0                           | 0              | 0           | 0           |          |               |                           |                               |                            | TEMP_       | OUT_S         |             |             |          |          |         |
| 0x12    | FIELD_REG            | RO     |                             |                |             |             |          |               |                           | FIELD                         | _MAG                       |             |               |             |             |          |          |         |
| 0x13    | TURNS_COUNTER_P      | RO/RC  | TCO_OR_TCW_S                | BFLP_NOT_BFT_P | TCW_ERROR_P | TCO_ERROR_P | 0        | TURNS_COUNT_P |                           |                               |                            |             |               |             |             |          |          |         |
| 0x14    | ANGLE_WITH_HYST      | RO     |                             |                |             |             |          |               |                           | ABI_UVV                       | V_ANGLE                    |             |               |             |             |          |          |         |
| 0x15    | ANGLE_DIAG_AB        | RO     |                             |                |             |             |          |               |                           | ANGLE_                        | OUT_AB                     |             |               |             |             |          |          |         |
| 0x16    | ANGLE_DIAG_BC        | RO     |                             |                |             |             |          |               |                           | ANGLE                         | OUT_BC                     |             |               |             |             |          |          |         |
| 0x17    | ANGLE_DIAG_CA        | RO     |                             |                |             |             |          |               |                           | ANGLE                         | OUT_CA                     |             |               |             |             |          |          |         |
| 0x18    | ANGLE_DIAG_LATCH     | RO     |                             |                |             |             |          |               | A                         | NGLE_OUT                      | DIAG_LAT                   | СН          |               |             |             |          |          |         |

RO: Read only

WO: Write only RW: Read and write RC: Read and clear bit after reading



#### Table 12: Direct Serial Interface Registers Bits Map (continued)

| Address |                       |          |                    |                      | Prin              | nary Addre        | sse Byte (M | ISB)                                 |   |      |       |                 | Prin            | nary Addre | ssed Byte ( | LSB)        |                |   |  |
|---------|-----------------------|----------|--------------------|----------------------|-------------------|-------------------|-------------|--------------------------------------|---|------|-------|-----------------|-----------------|------------|-------------|-------------|----------------|---|--|
| (0x00)  | Register Symbol       | Access   | 15                 | 14                   | 13                | 12                | 11          | 10                                   | 9 | 8    | 7     | 6               | 5               | 4          | 3           | 2           | 1              | 0 |  |
| 0x19    | TURNS_COUNTER_LATCH_P | R0/RC    | TCO_OR_TCW_LATCH_S | BLFP_NOT_BFT_LATCH_P | TCW_ERROR_LATCH_P | TCO_ERROR_LATCH_P | 0           |                                      |   |      |       | TURNS <u>.</u>  | _COUNT_L        | ATCH_P     |             |             |                |   |  |
| 0x1A    | TURNS_COUNTER_S       | RW/RO/RC | TCO_OR_TCW_P       | BLFP_NOT_BFT_S       | TCW_ERROR_S       | TCO_ERROR_S       | 0           | TURNS_COUNT_S                        |   |      |       |                 |                 |            |             |             |                |   |  |
| 0x1B    | TURNS_COUNTER_LATCH_S | RO/RC    | TCO_OR_TCW_LATCH_P | BLFP_NOT_BFT_LATCH_S | TCW_ERROR_LATCH_S | TCO_ERROR_LATCH_S | 0           | TURNS_COUNT_LATCH_S                  |   |      |       |                 |                 |            |             |             |                |   |  |
| 0x1E    | ACCESS                | RO/WO    | ACCES              | SS_KEY               | FREE_REG_LOCK_RD  | FREE_REG_LOCK_WR  | FACT        | CUST_REF_LOCK_RD<br>CUST_REF_LOCK_WR |   | FACT | FACT  | CUST_EE_LOCK_RD | CUST_EE_LOCK_WR | FACT       | FACT        | CUST_ACCESS | FACTORY_ACCESS |   |  |
| 0x1F    | LOOPBACK_REG          | RW       |                    |                      |                   |                   |             |                                      |   | LOOF | PBACK |                 |                 |            |             |             |                |   |  |

RO: Read only WO: Write only RW: Read and write RC: Read and clear bit after reading



#### Address 0x00 (NOP) - Null Register

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Access | RO |

#### Address 0x01 (INDIRECT\_WR\_ADDRESS) Extended Write Address

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |
|--------|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|----|--|
| Name   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | INDIRECT_WR_ADDR |    |    |    |    |    |    |    |  |
| Access | RO | RW               | RW | RW | RW | RW | RW | RW | RW |  |

#### INDIRECT\_WR\_ADDR [7:0]:

Target address to be used for an extended memory write. Address ranges:

- 0x00 through 0x3F: EEPROM (requires ≈6.5 ms following execution of a write)
- 0x40 through 0x7F: Shadow (Volatile)
- 0x80 through 0xAA: Miscellaneous (Volatile)

#### Address 0x02 (INDIRECT\_WR\_DATA\_MSB) Extended Write Data Bytes High

| Bit    | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4      | 3      | 2    | 1  | 0  |
|--------|--------------------|----|----|----|----|----|----|----|----|----|-----|--------|--------|------|----|----|
| Name   | INDIRECT_WR_DATA_3 |    |    |    |    |    |    |    |    |    | IND | IRECT_ | WR_DA1 | TA_2 |    |    |
| Access | RW                 | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW  | RW     | RW     | RW   | RW | RW |

#### INDIRECT\_WR\_DATA\_3 [15:8]:

Upper fourth byte of data for an extended write operation, corresponds to bit [31:24] of the extended write address.

#### INDIRECT\_WR\_DATA\_2 [7:0]:

Third byte of data for an extended write operation, corresponds to bit [23:16] of the extended write address.

#### Address 0x03 (INDIRECT\_WR\_DATA\_LSB) Extended Write Data Bytes Low

| Bit    | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4       | 3      | 2    | 1  | 0  |
|--------|--------------------|----|----|----|----|----|----|----|----|----|-----|---------|--------|------|----|----|
| Name   | INDIRECT_WR_DATA_1 |    |    |    |    |    |    |    |    |    | IND | IRECT_\ | WR_DAT | TA_0 |    |    |
| Access | RW                 | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW  | RW      | RW     | RW   | RW | RW |

#### INDIRECT\_WR\_DATA\_1 [15:8]:

Second byte of data for an extended write operation, corresponds to bit [15:8] of the extended write address.

#### INDIRECT\_WR\_DATA\_0 [7:0]:

Lower first byte of data for an extended write operation, corresponds to bit [7:0] of the extended write address.

#### Address 0x04 (INDIRECT\_WR\_STATUS) Extended Write Control and Status

| -   |      |     |    |    | _  |    |    |    |     |    |    |    |    |    |    |    |     |
|-----|------|-----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|-----|
| E   | Bit  | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Na  | ame  | EXW | 0  | 0  | 0  | 0  | 0  | 0  | WIP | 0  | 0  | 0  | 0  | 0  | 0  | 0  | WDN |
| Aco | cess | WO  | RO  | RO | RO | RO | RO | RO | RO | RO | RO  |

WDN [0]:

#### EXW [15]:

Initial extended write by writing 1. Sets WIP, clears WDN. Writeonly, always reads back 0. Write operation complete when to a value of 1, clears when EXW is set to 1.

#### WIP [8]:

Indicates write in progress when set to 1.



### Address 0x05 (INDIRECT RD ADDRESS) Extended Read Address

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|----|--------------------|----|----|----|----|----|----|----|
| Name   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | ) INDIRECT_RD_ADDR |    |    |    |    |    |    |    |
| Access | RO | RW                 | RW | RW | RW | RW | RW | RW | RW |

### **INDIRECT RD ADDR [7:0]:**

Address to be used for an extended read. Address ranges:

- 0x00 through 0x3F: EEPROM (requires  $\approx 2 \,\mu s$ )
- 0x40 through 0x7F: Shadow (Volatile)
- 0x80 through 0xAA: Miscellaneous (Volatile)

# Address 0x06 (INDIRECT\_RD\_STATUS) Extended Read Control and Status

| Bit    | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
|--------|-----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|-----|
| Name   | EXR | 0  | 0  | 0  | 0  | 0  | 0  | RIP | 0  | 0  | 0  | 0  | 0  | 0  | 0  | RDN |
| Access | WO  | RO  | RO | RO | RO | RO | RO | RO | RO | RO  |

#### EXR [15]:

Initial extended read by writing 1. Sets RIP, clears RDN. Write-only, always reads back 0.

### **RIP** [8]:

Indicates read in progress when set to 1.

### Address 0x07 (INDIRECT\_RD\_DATA\_MSB) Extended Read Data Bytes High

| Bit    | 15                               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  |
|--------|----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|
| Name   | INDIRECT_RD_DATA_3 INDIRECT_RD_D |    |    |    |    |    |    |    |    |    |    |    |    | A_2 |    |    |
| Access | RO                               | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO  | RO | RO |

### INDIRECT\_RD\_DATA\_3 [15:8]:

Upper fourth byte of data for an extended read operation, corresponds to bit [31:24] of the extended read address after execution of a read operation.

### INDIRECT\_RD\_DATA\_2 [7:0]:

Third byte of data for an extended read operation, corresponds to bit [23:16] of the extended read address after execution of a read operation.

### Address 0x08 (INDIRECT\_RD\_DATA\_LSB) Extended Read Data Bytes Low

| Bit    | 15 | 14 | 13  | 12     | 11     | 10  | 9  | 8  | 7  | 6  | 5   | 4      | 3      | 2    | 1  | 0  |
|--------|----|----|-----|--------|--------|-----|----|----|----|----|-----|--------|--------|------|----|----|
| Name   |    |    | IND | IRECT_ | RD_DAT | A_1 |    |    |    |    | IND | IRECT_ | RD_DAT | -A_0 |    |    |
| Access | RO | RO | RO  | RO     | RO     | RO  | RO | RO | RO | RO | RO  | RO     | RO     | RO   | RO | RO |

Contains the lower 16 bits of data following an indirect read operation (such as an EEPROM read). Also stores previous contents of the error register (0x0F) following a read of that register.

#### INDIRECT\_RD\_DATA\_1 [15:8]:

Second byte of data for an extended read operation, corresponds to bit [15:8] of the extended read address after execution of a read operation.

# INDIRECT\_RD\_DATA\_0 [7:0]:

Lower first byte of data for an extended read operation, corresponds to bit [7:0] of the extended read address after execution of a read operation.



# RDN [0]:

Read operation complete when to a value of 1, clears when EXR is set to 1.

### Address 0x09 (HP\_A\_REG) Channel A Reading

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    |    |    |    |    |    |    | HP | _A |    |    |    |    |    |    |    |
| Access | RO |

### HP\_A [15:0]:

Channel A  $CH_A$  = HP1-HP4 reading. Value is a 16-bit signed integer.

Differential Field (G) = Channel\_Reading/S

where S = 23 LSB/G for part numbers with suffix 300 and S = 15.5 for part numbers with suffix 600.

The full differential field (in gauss) seen by the channel can be calculated as:

The returned gauss value is indicative only.

### Address 0x0A (HP\_B\_REG) Channel B Reading

| Bit    | 15 | 14   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    | HP_B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RO   | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

### HP\_B [15:0]:

Channel B  $CH_B = HP2$ -HP5 reading. Value is a 16-bit signed integer.

The full differential field (in gauss) seen by the channel can be calculated as:

Differential Field (G) = Channel\_Reading/S

where S = 23 LSB/G for part numbers with suffix 300 and S = 15.5 for part numbers with suffix 600.

The returned gauss value is indicative only.

### Address 0x0B (HP\_C\_REG) Channel C Reading

| Bit    | 15 | 14   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    | HP_C |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RO   | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

#### HP\_C [15:0]:

calculated as:

Channel C  $CH_C = HP3-HP6$  reading. Value is a 16-bit signed integer.

The full differential field (in gauss) seen by the channel can be

Differential Field (G) = Channel\_Reading/S

where S = 23 LSB/G for part numbers with suffix 300 and S = 15.5 for part numbers with suffix 600.

The returned gauss value is indicative only.



#### Address 0x0C (STATUS\_REG) Device Status Flags

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9                         | 8                             | 7                          | 6           | 5             | 4   | 3   | 2   | 1     | 0       |
|--------|----|----|----|----|----|----|---------------------------|-------------------------------|----------------------------|-------------|---------------|-----|-----|-----|-------|---------|
| Name   | 0  | 0  | 0  | 0  | 0  | 0  | ECC_SELF_TEST_FAILED_FLAG | LP_COMP_SELF_TEST_FAILED_FLAG | POKS_SELF_TEST_FAILED_FLAG | MASK_ACTIVE | BACK_FROM_LPM | SLR | ABI | ACD | ROT_H | ANG_RDY |
| Access | RO                        | RO                            | RO                         | RO          | RC            | RC  | RC  | RC  | RO    | RO      |

### ECC\_SELF\_TEST\_FAILED\_FLAG [9]:

Indicates ECC (Error Corrector Code) self-test failed. ECC self-test checks the ECC mechanism of the EEPROM memory system.

### LP\_COMP\_SELF\_TEST\_FAILED\_FLAG [8]:

Indicates that LP (Low Power) comparators self-test failed.

#### POKS\_SELF\_TEST\_FAILED\_FLAG [7]:

Indicates POK/IOKs (Power OK / Current OK) self-test failed.

#### MASK\_ACTIVE [6]:

Indicates that at least one fault masking bit is active.

#### BACK\_FROM\_LPM [5]:

Back from Low Power Mode report bit.

#### SLR [4]:

ABI slew rate warning. An ABI warning pulse is emitted every time the slew rate is used to track the angle.

#### ABI [3]:

It reflects an ABI integrity error (only if ABI\_SLEW\_RATE = 0). An abi error pulse is emitted every time the angle cannot be tracked.

### ACD [2]:

ABI count-up done. If no slew rate limit is provided (SLEW\_ RATE = 0), the count-up feature is disabled. The ABI output will increment, from 0, following power-up. To reduce the time needed for the counting-up process, the ABI will increment in either CW or CCW direction, whichever is shortest, towards the current angle position. For example, if the current angle position is 270 degrees, the ABI will increment in the CW direction (effectively counting down from 360 degrees) towards this value. When this process is done this flag is set. If EEPROM bit ABI\_SR\_DLY\_EN is set, ABI count-up done will be disabled although SLEW\_RATE limit is provided. Note that the count-up feature occurs at start-up or after a fault clear.

# ROT\_H [1]:

Current rotation direction value. It reflects a magnet rotation direction calculated in main path: it will depend on the ROT\_DIR\_P (extended: 0x3E [0]) configuration bit (0 is counterclock-wise).

ROT\_H calculation is enabled according to the table below:

| ABI_UVW_ENABLE | INTERPOLATOR_<br>BYPASS | ROT_H calculation       |
|----------------|-------------------------|-------------------------|
| 0              | 0                       | No (default value is 0) |
| 0              | 1                       | Yes                     |
| 1              | 0                       | Yes                     |
| 1              | 1                       | Yes                     |

#### ANG\_RDY [0]:

Angle ready informational flag: this flag is set when the first angle calculated in the MAIN, AB, BC, and CA paths are ready.



#### Address 0x0D (CTRL) Control register

| Bit  | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3        | 2        | 1        | 0   |
|------|------------|----|----|----|----|----|----|----|----|----|----|----|----------|----------|----------|-----|
| Nam  | <b>e</b> 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | FULL_RST | SOFT_RST | TC_WE_EN | TCR |
| Acce | ss RO      | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RW       | RW       | RW       | RW  |

### FULL\_RST [3]:

Full Reset. Writing at value of one to this bit triggers a full reset of the device logic, including a full load of the EEPROM, reset of all the status and error registers, reset of the signal processing, reset of the outputs and communications protocols (with the exception of SPI), and a reset of the main controller. This includes all functions performed in a SOFT\_RST. After the reset is complete the POR flag (primary: 0xF [9]) is asserted. A full reset will not reset the status of the access code (If the device has been unlocked, the unlock code is not required to be sent following a full reset).

### SOFT\_RST [2]:

Soft Reset. Writing at value of one to this bit triggers a full reset of the device logic, reset of all the status and error registers, reset of the signal processing, and reset of the outputs and communications protocols (with the exception of SPI). After the reset is complete the POR flag (primary: 0xF [9]) is asserted.

### TC\_WR\_EN [1]:

Turns Count Write Enable. If set to 1, this bit allows for write access to the registers TURNS\_COUNT\_P (primary: 0x13 [10:0]) and TURNS\_COUNT\_S (primary: 0x1A [10:0]). This allows the external controller to overwrite the Turns Count value.

To perform this, set the value on the TURNS\_COUNT\_P register and then set the TC\_WR\_EN bit. It must also be noticed that the TC\_WR\_EN bit will be cleared after a turns count write is performed.

Note, the TURNS\_COUNT\_P and TURN\_COUNT\_S must be set to the equivalent value to avoid a Turns Count warning error flag.

#### TCR [0]:

Turns Count Reset. Writing a value of one to this bit triggers a reset of the internal turns counters, primary and secondary channel. The counters reset to values dependent on the status of TURNS\_CNT\_INIT\_P (extended: 0x3E [1]) and TURNS\_ CNT\_INIT\_S (extended: 0x3F [1]).

#### Address 0x0E (MAIN\_ANGLE) Main Angle Output

| Bit    | 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    | ANGLE_OUT_MAIN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RO             | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

#### ANGLE\_OUT\_MAIN [15:0]:

Register indicates the calculated angle from the three differential channels  $\delta_{MAIN}$ . The parameter is a 16-bit unsigned integer with value of ANGLE\_OUT\_MAIN  $\times$  360/2<sup>16</sup> in degrees. A read of

this register latches the data in ANGLE\_OUT\_DIAG\_LATCH (primary: 0x18 [15:0]), TURNS\_COUNT\_LATCH\_P (primary: 0x19 [10:0]), TURNS\_COUNT\_LATCH\_S (primary: 0x1B [10:0]).



#### Address 0x0F (ERROR) Device Error Flags

| Bit    | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8    | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|-----|-----|-----|-----|-----|
| Name   | IER | XEE | BSY | SME | EUE | ESE | POR | OVCC | UVCC | MSH | MSL | SMM | OFE | SAT | TSE | VCF |
| Access | RC  | RC  | RC  | RO  | RC  | RC  | RC  | RC   | RC   | RC  | RC  | RC  | RC  | RC  | RC  | RC  |

Error register, flags clear on read. All flags latch, meaning they remain high until cleared. Following a read, previous contents of the error register are stored in address 0x08 (INDIRECT\_RD\_DATA\_LSB). This allows data to be retrieved if lost during transmission.

### IER [15]:

Interface error. Invalid SPI packet detected. Packet was discarded. Also indicates an error in the Manchester communication.

| Value | Description        |
|-------|--------------------|
| 0     | No interface error |
| 1     | Interface error    |

#### XEE [14]:

Extended execute error. A command initiated by an extended write failed. Write failed due to access error (not unlocked) or EEPROM write failure.

| Value | Description                |
|-------|----------------------------|
| 0     | No incoming extended error |
| 1     | Extended execute error     |

### BSY [13]:

Extended access overflow.

An extended write or extended read was initiated before previous operation is complete.

| Value | Description              |
|-------|--------------------------|
| 0     | No extended access error |
| 1     | Extended access error    |

#### SME [12]:

Shadow memory error. Indicates detection of a MISR (multiple input signature request) error in the shadow memory. This error requires a reset to clear.

| Value | Description            |
|-------|------------------------|
| 0     | No Shadow memory error |
| 1     | Shadow memory error    |

#### EUE [11]:

EEPROM uncorrectable error. A multi-bit EEPROM read error occurred. EEPROM bit errors are only checked on EEPROM load (i.e., power-on or reset). This error requires a reset to clear and the condition no longer persists.

| Value | Description               |
|-------|---------------------------|
| 0     | No multi-bit EEPROM error |
| 1     | Multi-bit EEPROM error    |

#### ESE [10]:

EEPROM soft error. A correctable (single-bit) EEPROM read occurred. EEPROM bit errors are only checked on EEPROM load (power-on or reset). Single bit error are detected and corrected in shadow memory by hamming ECC.

| Value | Description                |
|-------|----------------------------|
| 0     | No single bit EEPROM error |
| 1     | EEPROM single bit error    |

#### POR [9]:

Reset condition. Indicates a reset event has occurred or a EEPROM load has occurred.

| Value | Description                                                   |
|-------|---------------------------------------------------------------|
| 0     | No reset                                                      |
| 1     | Device has been reset. Volatile registers are re-initialized. |

#### OVCC [8]:

VCC Overvoltage condition. Indicates an overvoltage condition on the supply pin VCC. Will continue to assert until fault condition is removed (and the register is cleared).

| Value | Description              |
|-------|--------------------------|
| 0     | No VCC Overvoltage error |
| 1     | VCC Overvoltage error    |

#### UVCC [7]:

VCC Undervoltage condition. Indicates an undervoltage condition on the supply pin VCC. Will continue to assert until fault condition is removed (and the register is cleared).

| Value | Description               |
|-------|---------------------------|
| 0     | No VCC Undervoltage error |
| 1     | VCC Undervoltage error    |

#### MSH [6]:

Magnetic signal high fault. Indicates the magnitude of the mag-



netic input signal sensed is above the high limit threshold. The high limit threshold is set via EEPROM parameter MSH\_THR (extended: 0x24 [2:0]).

The MSH\_THR is compared to FIELD\_MAG (primary: 0x12 [15:0]).

Will continue to assert until the fault condition is removed (and the register is cleared).

| Value | Description                                      |
|-------|--------------------------------------------------|
| 0     | No magnetic field high fault                     |
| 1     | Magnetic field above the high threshold, MSH_THR |

### MSL [5]:

Magnetic signal low fault. Indicates the magnitude of the magnetic input signal sensed is below the low limit threshold. The low limit threshold is set via EEPROM parameter MSL\_THR (extended: 0x24 [5:3]).

The msl\_thr is compared to FIELD\_MAG (primary: 0x12 [15:0]).

Will continue to assert until the fault condition is removed (and the register is cleared).

| Value | Description                                    |
|-------|------------------------------------------------|
| 0     | No magnetic field low fault                    |
| 1     | Magnetic field below the low threshold MSL_THR |

#### SMM [4]:

Signal mismatch error. Indicates a mismatch between ANGLE\_ OUT\_MAIN  $\delta_{MAIN}$  and any of the diagnostic angles (ANGLE\_ OUT\_AB  $\delta_{AB}$  or ANGLE\_OUT\_BC  $\delta_{BC}$  or ANGLE\_OUT\_CA  $\delta_{CA}$ ). The angle mismatch threshold is set via EEPROM parameter ANGLE\_MISMATCH (extended 0x24 [7:6]).

An error detected by this monitor will continue to assert until the fault condition is removed (and the register is cleared).

SMM also reports a BIST error. During power on for the A33020 only, every low power mode to normal operating mode transition, all error inputs are checked for a stuck at zero condition to confirm the error condition may assert the appropriate indicator bit. An error detected by this monitor requires a reset to clear.

| Value | Description                                               |
|-------|-----------------------------------------------------------|
| 0     | No angle mismatch or error register BIST failure detected |
| 1     | Angle mismatch or error register BIST failure detected    |

### OFE [3]:

Oscillator frequency error. One of the oscillator watchdogs circuits, monitoring the high frequency and low frequency oscillators has detected a fault. Will continue to assert until the fault condition is removed (and the register is cleared).

| Value | Description               |
|-------|---------------------------|
| 0     | No oscillator error       |
| 1     | Oscillator watchdog error |

### SAT [2]:

Channel saturation flag. Indicates internal signal have saturated, including the inputs of the ADCs, prior to the angle calculation. May indicate the magnetic input is outside of the specified range. Will continue to assert until the fault condition is removed (and the register is cleared).

| Value | Description                                                   |
|-------|---------------------------------------------------------------|
| 0     | No saturation detected in the signal path                     |
| 1     | Saturation conditions detected within the channel signal path |

### TSE [1]:

Temperature sensor error. The primary or secondary temperature sensor calculated output is below  $-60^{\circ}$ C or above 170°C. Also reports when the calculated temperature output of the primary and secondary temperature sensors differs by more than 20°C. Will continue to assert until the fault condition is removed (and the register is cleared).

| Value | Description                                                                                                                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Primary and secondary temperature sensors within range                                                                                                                                                                                           |
| 1     | Primary or secondary temperature sensor calculated<br>output below -60°C or above 170°C or the primary<br>temperature sensor calculated output differs more<br>than 20°C when compared to the secondary<br>temperature sensor calculated output. |

### VCF [0]:

Voltage check fault. Indicates a failure of an internal reference voltage. Will continue to assert until the fault condition is removed (and the register is cleared).



#### Address 0x10 (TEMP12B\_P) Primary Channel Temperature Sensor Reading

| Bit    | 15 | 14 | 13 | 12 | 11                               | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |  |
|--------|----|----|----|----|----------------------------------|----|---|---|---|---|---|---|---|----|---|---|--|
| Name   | 0  | 0  | 0  | 0  | TEMP_OUT_P                       |    |   |   |   |   |   |   |   |    |   |   |  |
| Access | RW | RW | RW | RW | RW |    |   |   |   |   |   |   |   | RW |   |   |  |

### TEMP\_OUT\_P [11:0]:

Current ambient temperature from the primary channel internal temperature sensor. Value is a 12-bit signed integer, where: temperature [°C]  $\approx$  (TEMP\_OUT\_P / 8) + 25.

#### Address 0x11 (TEMP12B\_S) Secondary Channel Temperature Sensor Reading

| Bit    | 15 | 14 | 13 | 12 | 11         | 10                               | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |  |
|--------|----|----|----|----|------------|----------------------------------|---|---|---|---|---|---|---|---|---|----|--|
| Name   | 0  | 0  | 0  | 0  | TEMP_OUT_S |                                  |   |   |   |   |   |   |   |   |   |    |  |
| Access | RW | RW | RW | RW | RW         | RW |   |   |   |   |   |   |   |   |   | RW |  |

### TEMP\_OUT\_S [11:0]:

Current ambient temperature from the secondary channel internal temperature sensor. Value is a 12-bit signed integer, where: temperature [°C]  $\approx$  (TEMP\_OUT\_P / 8) + 25.

#### Address 0x12 (FIELD\_REG) FIELD\_MAG

| Bit    | 15 | 14        | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    | FIELD_MAG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RO        | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

#### FIELD\_MAG [15:0]:

Indicates the amplitude of the input magnetic flux density  $B_{IN}$ . Value is a 16-bit unsigned integer.

The LSB read value is converted to gauss with  $B_{IN}(G) = FIELD\_MAG (LSB) / (S \times 1.304 \times 3)$ , with S = 23 LSB/G for part variant 300 and S = 15.5 LSB/G for part variant 600. The returned gauss value is indicative only.



### Address 0x13 (TURNS\_COUNTER\_P) Primary Turns Counter

| Bit    | 15           | 14             | 13          | 12          | 11 | 10 | 9  | 8  | 7  | 6    | 5     | 4     | 3  | 2  | 1  | 0  |
|--------|--------------|----------------|-------------|-------------|----|----|----|----|----|------|-------|-------|----|----|----|----|
| Name   | TC0_OR_TCW_S | BFLP_NOT_BFT_P | TCW_ERROR_P | TCO_ERROR_P | 0  |    |    |    |    | TURN | s_coi | JNT_P |    |    |    |    |
| Access | RO           | RC             | RO          | RO          | RO | RW | RW | RW | RW | RW   | RW    | RW    | RW | RW | RW | RW |

### TCO\_OR\_TCW\_S [15]:

Or between TCO\_ERROR\_S and TCW\_ERROR\_S field in TURNS\_COUNT\_S register.

### BFLP\_NOT\_BFT\_P [14]:

Bit is set when coming back from Low Power Mode and transport mode is disabled.

### TCW\_ERROR\_P [13]:

Primary channel Turns counter warning. The bit is set on any condition that may compromise the accuracy of the primary turns count value. If any of the error bits, VCF, OFE, and UVCC are set, but not limited to, TCW\_ERROR\_P is set. For the A33020 the bit is also set on a condition that may compromise the accuracy of the turns count value during low power operation.

TCW\_ERROR\_P also reports a BIST error on registers TURNS\_COUNTER\_P (primary: 0x13) and TURNS\_ COUNTER\_S (primary 0x1A). During power on, and for the A33020, every low power mode to normal operating mode transition, all TURNS\_COUNTER\_P and TURNS\_COUNTER\_S inputs are checked for a stuck at zero condition to confirm the error condition may assert the appropriate indicator bit. An error detected by this monitor requires a reset to clear.

TCW\_ERROR\_P also reports overspeed errors.

| Value | Description                                        |
|-------|----------------------------------------------------|
| 0     | No turns count warning                             |
| 1     | Warning primary turns count value may be incorrect |

### TCO\_ERROR\_P [12]:

Primary Turns Counter Overflow Error. Indicates the turns counter surpassed its allowable range of -1024 to 1023 (approximately  $\pm 256$  rotations). Must be cleared with a turns-count reset (See TCR in the CTRL register description, primary: 0xD [0]).

# TURNS\_COUNT\_P [11:0]:

Primary turns count. Value represents the primary channel turns count. Indicates total number of turns relative to initial value at power-on. The parameter has a resolution of 90° and is represented as an 11-bit signed integer. A turn actually represents 90° of magnet rotation. It uses the main channel in Full Power Mode.

| Decimal value | Binary value  | Turns count 90° resolu-<br>tion (actual mechanical<br>full rotations) |
|---------------|---------------|-----------------------------------------------------------------------|
| 0             | 000 0000 0000 | 0 (0)                                                                 |
| 1             | 000 0000 0001 | +1 (+0.25)                                                            |
| 511           | 001 1111 1111 | +511 (+127.75)                                                        |
| 512           | 010 0000 0000 | +512 (+128)                                                           |
| 1023          | 011 1111 1111 | +1023 (+255.75)                                                       |
| -1            | 111 1111 1111 | -1 (-0.25)                                                            |
| -512          | 110 0000 0000 | -512 (-128)                                                           |
| -1024         | 100 0000 0000 | -1024 (-256)                                                          |



### Address 0x14 (ANGLE\_WITH\_HYST) Hysteresis Angle Value (16 bits)

| Bit    | 15            | 14                                       | 13 | 12 | 15         14         13         12         11         10         9         8         7         6         5         4         3         2         1         0 |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---------------|------------------------------------------|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| Name   | ABI_UVW_ANGLE |                                          |    |    |                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |
| Access | RO            | RO R |    |    |                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |

### ABI\_UVW\_ANGLE [15:0]:

Angle output from main channel, after hysteresis processing. The hysteresis configuration is set using the parameter ANGLE\_ HYST (extended: 0x25 [22:20]). The parameter is a 16-bit unsigned integer with value of ABI\_UVW\_ANGLE  $\times$  360/2<sup>16</sup> in degrees.

### Address 0x15 (ANGLE\_DIAG\_AB) Diagnostic AB Channel Angle Value (16 bits)

| Bit    | 15                                       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
|--------|------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|----|---|---|
| Name   | e ANGLE_OUT_AB                           |    |    |    |    |    |   |   |   |   |   |   |   |    |   |   |
| Access | s RO |    |    |    |    |    |   |   |   |   |   |   |   | RO |   |   |

### ANGLE\_OUT\_AB [15:0]:

Angle output from channel AB  $\delta_{AB}$ .

The parameter is a 16-bit unsigned integer with value of ANGLE\_OUT\_AB  $\times$  360/216 in degrees.

### Address 0x16 (ANGLE\_DIAG\_BC) Diagnostic BC Channel Angle Value (16 bits)

| Bit    | 15           | 15         14         13         12         11         10         9         8         7         6         5         4         3         2         1         0 |  |  |  |  |  |  |  |  |  |  |  |  | 0 |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|---|
| Name   | ANGLE_OUT_BC |                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |   |
| Access | RO           |                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |   |

### ANGLE\_OUT\_BC [15:0]:

Angle output from channel BC  $\delta_{BC}$ .

The parameter is a 16-bit unsigned integer with value of ANGLE\_OUT\_BC  $\times$  360/2<sup>16</sup> in degrees.

### Address 0x17 (ANGLE\_DIAG\_CA) Diagnostic CA Channel Angle Value (16 bits)

| Bit    | 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    | ANGLE_OUT_CA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RO           | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

#### ANGLE\_OUT\_CA [15:0]:

Angle output from channel CA  $\delta_{CA}$ .

The parameter is a 16-bit unsigned integer with value of ANGLE\_OUT\_CA  $\times$  360/2<sup>16</sup> in degrees.

#### Address 0x18 (ANGLE\_DIAG\_LATCH) Latched Main Angle (16 bits)

|        |    | 15     14     13     12     11     10     9     8     7     6     5     4     3     2     1     0       ANGLE_OUT_DIAG_LATCH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|----|------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 15 | 14                                                                                                                           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  |    | 4  | 3  | 2  | 1  | 0  |
| Name   |    |                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RO                                                                                                                           | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

### ANGLE\_OUT\_DIAG\_LATCH [15:0]:

Latched angle output from the selected redundant channel (AB, BC, or CA). Selectable channel with DIAG\_CHANNEL\_SEL (Extended 0x3F [19:18]).

The parameter is a 16-bit unsigned integer with value of ANGLE\_OUT\_DIAG\_LATCH  $\times$  360/2<sup>16</sup> in degrees.



### Address 0x19 (TURNS\_COUNTER\_LATCH\_P) Primary Turns Counter

| Bit    | 15                         | 14                         | 13                        | 12                     | 11 | 10 | 9  | 8  | 7   | 6     | 5             | 4      | 3   | 2  | 1  | 0  |
|--------|----------------------------|----------------------------|---------------------------|------------------------|----|----|----|----|-----|-------|---------------|--------|-----|----|----|----|
| Name   | TCO_OR_<br>TCW_<br>LATCH_S | BFLP<br>NOT_BFT<br>LATCH_P | TCW_<br>ERROR_<br>LATCH_P | TCO<br>ERROR<br>LATCHP | 0  |    |    |    | TUF | RNS_C | OUNT <u>.</u> | _LATCI | H_P |    |    |    |
| Access | RO                         | RC                         | RO                        | RO                     | RO | RO | RO | RO | RO  | RO    | RO            | RO     | RO  | RO | RO | RO |

# TCO\_OR\_TCW\_LATCH\_S [15]:

Latched or between TCO\_ERROR\_S and TCW\_ERROR\_S field in TURNS\_COUNT\_S register. The bit has the same definition as TCO\_OR\_TCW\_S (primary 0x13 [15]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

### BFLP\_NOT\_BFT\_LATCH\_P [14]:

Latched bit set when coming back from Low Power Mode and transport mode is disabled. The bit has the same definition as BFLP\_NOT\_BFT\_P (primary 0x13 [14]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

### TCW\_ERROR\_LATCH\_P [13]:

Latched primary turns counter warning. The bit has the same def-

inition as TCW\_ERROR\_P (primary 0x13 [13]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

### TCO\_LATCH\_ERROR\_P [12]:

Latched primary turns counter overflow error. The bit has the same definition as TCO\_ERROR\_P (primary 0x13 [12]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

### TURNS\_COUNT\_LATCH\_P [11:0]:

Latched primary turns count. The parameter has the same definition as TURNS\_COUNT\_P (primary: 0x13 [10:0]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).



### Address 0x1A (TURNS\_COUNTER\_S) Secondary Turns Counter

| Bit    | 15           | 14             | 13          | 12          | 11 | 10 | 9  | 8  | 7  | 6    | 5     | 4     | 3  | 2  | 1  | 0  |
|--------|--------------|----------------|-------------|-------------|----|----|----|----|----|------|-------|-------|----|----|----|----|
| Name   | TCO_OR_TCW_P | BFLP_NOT_BFT_S | TCW_ERROR_S | TCO_ERROR_S | 0  |    |    |    |    | TURN | s_coi | JNT_S |    |    |    |    |
| Access | RO           | RC             | RO          | RO          | RO | RO | RO | RO | RO | RO   | RO    | RO    | RO | RO | RO | RO |

### TCO\_OR\_TCW\_P [15]:

Or between TCO\_ERROR\_P and TCW\_ERROR\_P field in TURNS\_COUNT\_P register.

### BFLP\_NOT\_BFT\_S [14]:

Bit is set when coming back from Low Power Mode and transport mode is disabled.

### TCW\_ERROR\_S [13]:

Secondary channel Turns counter warning. The bit is set on any condition that may compromise the accuracy of the secondary turns count value. If any of the error bits, VCF, OFE, and UVCC are set, but not limited to, TCW\_ERROR\_S is set. For the A33020 the bit is also set on a condition that may compromise the accuracy of the turns count value during low power operation.

TCW\_ERROR\_S also reports a BIST error on registers TURNS\_COUNTER\_P (primary: 0x13) and TURNS\_ COUNTER\_S (primary 0x1A). During power on, and for the A33020, every low power mode to normal operating mode transition, all TURNS\_COUNTER\_P and TURNS\_COUNTER\_S inputs are checked for a stuck at zero condition to confirm the error condition may assert the appropriate indicator bit. An error detected by this monitor requires a reset to clear.

TCW\_ERROR\_S also reports overspeed errors.

An error detected by this monitor requires a reset to clear.

TCW\_ERROR\_S also reports overspeed errors.

| Value | Description                                          |
|-------|------------------------------------------------------|
| 0     | No turns count warning                               |
| 1     | Warning secondary turns count value may be incorrect |

### TCO\_ERROR\_S [12]:

Secondary Turns Counter Overflow Error. Indicates the turns counter surpassed its allowable range of -1024 to 1023 (approximately  $\pm 256$  rotations). Must be cleared with a turns-count reset (See TCR in the CTRL register description, primary: 0xD [0]).

### TURNS\_COUNT\_S [11:0]:

Secondary turns count. Value represents the secondary channel turns count. Indicates total number of turns relative to initial value at power-on. The parameter has a resolution of 90° and is represented as an 11-bit signed integer. A turn actually represents 90° of magnet rotation. It uses the redundant channel specified in DIAG\_CHANNEL\_SEL (extended: 0x3F [19:18]), in Full Power Mode.

| Decimal value | Binary value  | Turns count 90°<br>resolution<br>(Actual mechanical<br>full rotations) |
|---------------|---------------|------------------------------------------------------------------------|
| 0             | 000 0000 0000 | 0 (0)                                                                  |
| 1             | 000 0000 0001 | +1 (+0.25)                                                             |
| 511           | 001 1111 1111 | +511 (+127.75)                                                         |
| 512           | 010 0000 0000 | +512 (+128)                                                            |
| 1023          | 011 1111 1111 | +1023 (+255.75)                                                        |
| -1            | 111 1111 1111 | -1 (-0.25)                                                             |
| -512          | 110 0000 0000 | -512 (-128)                                                            |
| -1024         | 100 0000 0000 | -1024 (-256)                                                           |



|        |                    |                 | S S S S S HOLLES<br>S HOLLES<br>S HOLLES<br>S HOLLES<br>S HOLLES<br>S S S S S S S S S S S S S S S S S S S |              |    |    |    |    |     |       |      |       |     |    |    |    |
|--------|--------------------|-----------------|-----------------------------------------------------------------------------------------------------------|--------------|----|----|----|----|-----|-------|------|-------|-----|----|----|----|
| Bit    | 15                 | 14              | 13                                                                                                        | 12           | 11 | 10 | 9  | 8  | 7   | 6     | 5    | 4     | 3   | 2  | 1  | 0  |
| Name   | TCO_OR_TCW_LATCH_P | _NOT_BFT_LATCH_ | W_ERROR_LATCH_                                                                                            | ERROR_LATCH_ | 0  |    |    |    | TUF | RNS_C | OUNT | _LATC | H_S |    |    |    |
| Access | RO                 | RC              | RO                                                                                                        | RO           | RO | RO | RO | RO | RO  | RO    | RO   | RO    | RO  | RO | RO | RO |

### Address 0x1B (TURNS\_COUNTER\_LATCH\_S) Secondary Turns Counter

### TCO\_OR\_TCW\_LATCH\_P [15]:

Latched or between TCO\_ERROR\_P and TCW\_ERROR\_P field in TURNS\_COUNT\_P register. The bit has the same definition as TCO\_OR\_TCW\_P (primary 0x1A [15]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

#### BFLP\_NOT\_BFT\_LATCH\_S [14]:

Latched bit set when coming back from Low Power Mode and transport mode is disabled. The bit has the same definition as BFLP\_NOT\_BFT\_S (primary 0x1A [14]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

#### TCW\_ERROR\_LATCH\_S [13]:

Latched secondary turns counter warning. The bit has the same definition as TCW\_ERROR\_S (primary 0x1A [13]) and is

latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

### TCO\_LATCH\_ERROR\_S [12]:

Latched secondary turns counter overflow error. The bit has the same definition as TCO\_ERROR\_S (primary 0x1A [12]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).

#### TURNS\_COUNT\_LATCH\_S [11:0]:

Latched secondary turns count. The parameter has the same definition as TURNS\_COUNT\_S (primary: 0x1A [10:0]) and is latched on the read of ANGLE\_OUT\_MAIN (primary: 0xE [15:0]).



#### Address 0x1E (ACCESS) Access Register

Writing to register 0x1E is special command to enable access to the extended memory space, EEPROM and Volatile. See section Enabling EEPROM Access for more information.

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8        | 7  | 6  | 5  | 4  | 3  | 2  | 1               | 0              |
|--------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|-----------------|----------------|
| Name   |    |    |    |    |    |    |    | reserved |    |    |    |    |    |    | CUSTOMER_ACCESS | FACTORY_ACCESS |
| Access | WO | WO | RO | RO | RO | RO | RO | RO       | RO | RO | RO | RO | RO | RO | RO              | RO             |

### CUSTOMER\_ACCESS [1]:

Bit indicates access to customer registers within the extended memory space. A logic value of one indicates access to the customer registers within the extended memory space is enabled.

#### FACTORY\_ACCESS [0]:

Bit indicates access to factory registers within the extended memory space. A logic value of one indicates access to the factory registers within the extended memory space is enabled.

#### Address 0x1F (LOOPBACK\_REG) Loopback Register

| Bit    | 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    | LOOPBACK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RW | RW       | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |

#### LOOPBACK [15:0]:

Customer loopback register. The registers allow the external controller to perform a loopback test of the SPI communication between the controller and the peripheral A33020.



# **EXTENDED MEMORY TABLE:**

### EEPROM (NONVOLATILE), SHADOW (VOLATILE), AND MISCELLANEOUS (VOLATILE)

The EEPROM/Shadow register bitmap is shown below. All EEPROM and shadow contents can be read by the user, without unlocking. Writing requires a device unlock. The shadow memory is a copy of the EEPROM in the address range 0x40-0x7F.

#### Table 13: EEPROM/Shadow Memory Map

| W si              | s s               |       |    |         |                         |    |         |           |                 |               |                           |                        |                   | Bits      |        |          |        |           |              |   |                |           |          |           |         |                           |             |
|-------------------|-------------------|-------|----|---------|-------------------------|----|---------|-----------|-----------------|---------------|---------------------------|------------------------|-------------------|-----------|--------|----------|--------|-----------|--------------|---|----------------|-----------|----------|-----------|---------|---------------------------|-------------|
| EEPROM<br>Address | Shadow<br>Address | 31:26 | 25 | 24      | 23                      | 22 | 21      | 20        | 19 18           | 17            | 16                        | 15                     | 14                | 13        | 12     | 11       | 10     | 9         | 8            | 7 | 6              | 5         | 4        | 3         | 2       | 1                         | 0           |
| 0x00              | N/A               | ECC   |    | factory | reserved                |    |         |           |                 |               |                           |                        | ACTOR             | Y_DIE_I   | D      |          |        |           |              |   |                |           |          | factory i | eserved |                           |             |
| 0x01              | N/A               | ECC   |    | factory | reserved                |    |         |           |                 |               |                           |                        | FACTO             | RY_LOT    |        |          |        |           |              |   |                |           | F        | ACTOR     | /_WAFE  | R                         |             |
| 0x02              | N/A               | ECC   |    |         |                         |    |         |           | C               | AS_ID         |                           |                        |                   |           |        |          |        |           |              |   | f              | factory r | erserved |           |         |                           |             |
| 0x03              | N/A               | ECC   |    |         |                         |    |         |           |                 |               |                           |                        |                   | CUSTO     | MER_ID |          |        |           |              |   |                |           |          |           |         |                           |             |
| 0x04 to<br>0x23   | N/A               |       |    |         |                         |    |         |           |                 |               |                           |                        | fac               | tory rese | ved    |          |        |           |              |   |                |           |          |           |         |                           |             |
| 0x24              | 0x64              | ECC   |    |         |                         |    |         | MEM_L     | оск             |               | BLOCK_VOLATILE_<br>OUTPUT | MAKE_ERRORS_<br>HIGH_Z | MASK_4            | MASK_3    | MASK_2 | MASK_1   | MASK_0 | LPM_DIS_C | TRANSPORT_EN |   | ANGLE_MISMALCH | 1         | MSL_TH   | R         | N       | ISH_TH                    | R           |
| 0x25              | 0x65              | ECC   |    |         | INTERPOLATOR_<br>BYPASS | AN | GLE_HYS | л         | ABLERR_RPT_MODE | ABL_SR_DLY_EN | ABI_COUNT_UP_<br>RPT_EN   | ABL_UVW_ENABLE         | INTERPOLATOR_RATE |           |        |          |        | ABI_SLE   | W_RATI       | E |                | ABI       | _UVW_R   | ESOLU     | ΓΙΟΝ    | ABI_UVW_INVERT_<br>OUT_EN | ABI_0_UVW_1 |
| 0x26              | 0x66              | ECC   |    |         |                         |    | AB_L    | INEARI    | ZATION_2        |               |                           |                        | 1                 | AB        | LINEAF | RIZATIO  | N_1    |           |              |   |                | AB        | LINEAR   | RIZATIO   | N_0     |                           |             |
| 0x27              | 0x67              | ECC   |    |         |                         |    | AB_L    | INEARI    | ZATION_5        |               |                           |                        |                   | AB        | LINEAF | RIZATIO  | N_4    |           |              |   |                | AB        | _LINEAF  | RIZATIO   | N_3     |                           |             |
| 0x28              | 0x68              | ECC   |    |         |                         |    | AB_L    | INEARI    | ZATION_8        |               |                           |                        |                   | AB        | LINEAF | RIZATIO  | N_7    |           |              |   |                | AB        | _LINEAF  | RIZATIO   | N_6     |                           |             |
| 0x29              | 0x69              | ECC   |    |         |                         |    | AB_LI   | INEARIZ   | ATION_11        |               |                           |                        |                   | AB        | LINEAR | IZATION  | N_10   |           |              |   |                | AB        | _LINEAF  | RIZATIO   | V_9     |                           |             |
| 0x2A              | 0x6A              | ECC   |    |         |                         |    | AB_LI   | INEARIZ   | ATION_14        |               |                           |                        |                   | AB        | LINEAR | IZATION  | N_13   |           |              |   |                | AB        | LINEAR   | ZATION    | I_12    |                           |             |
| 0x2B              | 0x6B              | ECC   |    |         |                         |    |         | AB_LIN_EN |                 |               |                           | CU                     | ST_ANG            | ILE_OFF   | SET    |          |        |           |              |   |                | AB_       | LINEAR   | IZATION   | I_15    |                           |             |
| 0x2C              | 0x6C              | ECC   |    |         |                         |    | BC_L    | INEARI    | ZATION_2        |               |                           |                        |                   | BC        | LINEAF | RIZATIO  | N_1    |           |              |   |                | BC        | LINEAF   | RIZATIO   | N_0     |                           |             |
| 0x2D              | 0x6D              | ECC   |    |         |                         |    | BC_L    | INEARI    | ZATION_5        |               |                           |                        |                   | BC        | LINEAF | RIZATIO  | N_4    |           |              |   |                | BC        | LINEAF   | RIZATIO   | N_3     |                           |             |
| 0x2E              | 0x6E              | ECC   |    |         |                         |    | BC_L    | INEARI    | ZATION_8        |               |                           |                        |                   | BC        | LINEAF | RIZATIO  | N_7    |           |              |   |                | BC        | LINEAF   | RIZATIO   | N_6     |                           |             |
| 0x2F              | 0x6F              | ECC   |    |         |                         |    | BC_LI   | INEARIZ   | ATION_11        |               |                           |                        |                   | BC_       | LINEAR | RIZATION | N_10   |           |              |   |                | BC        | LINEAF   | RIZATIO   | N_9     |                           |             |
| 0x30              | 0x70              | ECC   |    |         |                         |    | BC_LI   | INEARIZ   | ATION_14        |               |                           |                        |                   | BC_       | LINEAR | RIZATION | N_13   |           |              |   |                | BC        |          | ZATION    | I_12    |                           |             |
| 0x31              | 0x71              | ECC   |    |         |                         |    |         |           |                 |               |                           |                        |                   |           |        |          |        |           | BC_LIN_EN    |   |                | BC.       | LINEAR   | RIZATION  | l_15    |                           |             |
| 0x32              | 0x72              | ECC   |    |         |                         |    | CA_L    | INEARI    | ZATION_2        |               |                           |                        |                   | CA        | LINEAR | RIZATIO  | N_1    |           |              |   |                | CA        | _LINEAF  | RIZATIO   | N_0     |                           |             |
| 0x33              | 0x73              | ECC   |    |         |                         |    | CA_L    | INEARI    | ZATION_5        |               |                           |                        |                   | CA        | LINEAF | RIZATIO  | N_4    |           |              |   |                | CA        | _LINEAF  | RIZATIO   | N_3     |                           |             |
| 0x34              | 0x74              | ECC   |    |         |                         |    | CA_L    | INEARI    | ZATION_8        |               |                           |                        |                   | CA        | LINEA  | RIZATIO  | N_7    |           |              |   |                | CA        | _LINEA   | RIZATIO   | N_6     |                           |             |
| 0x35              | 0x75              | ECC   |    |         |                         |    | CA_LI   | INEARIZ   | ZATION_11       |               |                           |                        |                   | CA        | LINEAR | RIZATION | N_10   |           |              |   |                | CA        | _LINEAF  | RIZATIO   | N_9     |                           |             |
| 0x36              | 0x76              | ECC   |    |         |                         |    | CA_LI   | INEARIZ   | ATION_14        |               |                           |                        |                   | CA        | LINEAR | RIZATION | N_13   |           |              |   |                | CA        | LINEAR   | ZATION    | I_12    |                           |             |

Continued on next page ...



| 5                 |                   |       |    |    |    |    |      |         |          |      |            |    |        |     | Bits |         |         |      |       |             |   |               |        |         |         |        |                  |           |
|-------------------|-------------------|-------|----|----|----|----|------|---------|----------|------|------------|----|--------|-----|------|---------|---------|------|-------|-------------|---|---------------|--------|---------|---------|--------|------------------|-----------|
| EEPROM<br>Address | Shadow<br>Address | 31:26 | 25 | 24 | 23 | 22 | 21   | 20      | 19       | 18   | 17         | 16 | 15     | 14  | 13   | 12      | 11      | 10   | 9     | 8           | 7 | 6             | 5      | 4       | 3       | 2      | 1                | 0         |
| 0x37              | 0x77              | ECC   |    |    |    |    |      |         |          |      |            |    |        |     |      |         |         |      |       | CA_LIN_EN   |   |               | CA_    | LINEAR  | IZATION | l_15   |                  |           |
| 0x38              | 0x78              | ECC   |    |    |    |    | MAII | N_LINEA | RIZATIO  | DN_2 |            |    |        |     | MAI  | I_LINEA | RIZATIO | DN_1 |       |             |   |               | MAI    | N_LINEA | RIZATIC | DN_0   |                  |           |
| 0x39              | 0x79              | ECC   |    |    |    |    | MAI  | N_LINEA | RIZATIO  | DN_5 |            |    |        |     | MAI  | LINEA   | RIZATIO | DN_4 |       |             |   |               | MAI    | N_LINEA | RIZATIC | DN_3   |                  |           |
| 0x3A              | 0x7A              | ECC   |    |    |    |    | MAI  | N_LINEA | ARIZATIO | DN_8 |            |    |        |     | MAI  | LINEA   | RIZATIO | DN_7 |       |             |   |               | MAI    | N_LINEA | RIZATIC | DN_6   |                  |           |
| 0x3B              | 0x7B              | ECC   |    |    |    |    | MAIN | I_LINEA | RIZATIO  | N_11 |            |    |        |     | MAIN | _LINEA  | RIZATIO | N_10 |       |             |   |               | MAI    | N_LINEA | RIZATIC | DN_9   |                  |           |
| 0x3C              | 0x7C              | ECC   |    |    |    |    | MAIN | I_LINEA | RIZATIO  | N_14 |            |    |        |     | MAIN | _LINEA  | RIZATIO | N_13 |       |             |   |               | MAIN   | I_LINEA | RIZATIO | N_12   |                  |           |
| 0x3D              | 0x7D              | ECC   |    |    |    |    |      |         |          |      |            |    |        |     |      |         |         |      |       | MAIN_LIN_EN |   |               | MAIN   | I_LINEA | RIZATIO | N_15   |                  |           |
| 0x3E              | 0x7E              | ECC   |    |    |    |    |      |         |          |      |            |    |        |     |      |         |         |      |       |             |   | TC_HYST_DIS_P | IIR_B\ | N_SEL   | SPARE   | E_CUST | TURNS_CNT_INIT_P | ROT_DIR_P |
| 0x3F              | 0x7F              | ECC   |    |    |    |    |      |         |          |      | PWM_ENABLE | PW | M_SLW_ | SEL | PWM_ | PORCH   | I_SEL   |      | PWM_F | PERIOD      |   | TC_HYST_DIS_S | L      | PM_SLE  | EP_TIM  | IE     | TURNS_CNT_INIT_S | ROT_DIR_S |

### Table 13: EEPROM/Shadow Memory Map (continued)



# EEPROM

#### Address 0x0

| Bit    | 25  | 24      | 23     | 22 | 21 | 20             | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4       | 3     | 2   | 1  | 0  |
|--------|-----|---------|--------|----|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---------|-------|-----|----|----|
| Name   | fac | ctory r | reserv | ed |    | FACTORY_DIE_ID |    |    |    |    |    |    |    |    |    |    |    |    |    |    | fac | ctory r | eserv | red |    |    |
| Access | RO  | RO      | RO     | RO | RO | RO             | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO  | RO      | RO    | RO  | RO | RO |

### FACTORY\_ID [21:6]:

Identification number. When used in combination with FACTORY\_LOT and FACTORY\_WAFER create a unique identification for device traceability. The register access is customer read only.

#### Address 0x1

| Bit    | 25  | 24      | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13   | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3    | 2    | 1   | 0  |
|--------|-----|---------|--------|-----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|-----|------|------|-----|----|
| Name   | fac | ctory r | reserv | red |    |    |    |    |    |    | FA | СТОР | RY_L | ОТ |    |    |    |    |    |    |    | FAC | TORY | /_WA | FER |    |
| Access | RO  | RO      | RO     | RO  | RO | RO | RO | RO | RO | RO | RO | RO   | RO   | RO | RO | RO | RO | RO | RO | RO | RO | RO  | RO   | RO   | RO  | RO |

### FACTORY\_LOT [21:6]:

Identification number. When used in combination with FAC-TORY\_ID and FACTORY\_WAFER create a unique identification for device traceability. The register access is customer read only.

### FACTORY\_WAFER [5:0]:

Identification number. When used in combination with FAC-TORY\_ID and FACTORY\_LOT create a unique identification for device traceability. The register access is customer read only.

#### Address 0x2

| Bit    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5       | 4     | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|-----|---------|-------|----|----|----|----|
| Name   |    |    |    |    |    |    |    | CAS | 5_ID |    |    |    |    |    |    |    |    |    |    | fac | ctory r | eserv | ed |    |    |    |
| Access | RO  | RO   | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO  | RO      | RO    | RO | RO | RO | RO |

### CAS\_ID [25:10]:

Type identification number. May contain an identification number to distinguish a specific device configuration. The register access is customer read only.

#### Address 0x3

| Bit    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    |    |    |    |    |    |    |    |    |    |    | CU | STO | MER_ | ID |    |    |    |    |    |    |    |    |    |    |    |
| Access | RW  | RW   | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |

### CUSTOMER\_ID [25:0]:

Customer identification number. The register space is open for customer write access. The contents of the register have no effect on the device operating modes. A common use for the register is to store a unique identification number written by the customer. The register access is customer read and write.



#### Address 0x24

| Bit     | 25 | 24  | 23  | 22 | 21 | 20   | 19   | 18 | 17 | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9    | 8  | 7  | 6  | 5  | 4   | 3  | 2  | 1   | 0  |
|---------|----|-----|-----|----|----|------|------|----|----|-----|-----|----|----|----|----|----|------|----|----|----|----|-----|----|----|-----|----|
| Name    |    | UNU | SED |    | Ν  | IEM_ | LOCI | <  | R  | BVO | MEH | M4 | M3 | M2 | M1 | M0 | LPMD | ТМ | ٨N | /M |    | MSL |    |    | MSH |    |
| Default | 0  | 0   | 0   | 0  | 0  | 0    | 0    | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 1  | 0  | 0   | 1  | 0  | 0   | 1  |
| Access  | RW | RW  | RW  | RW | RW | RW   | RW   | RW | RW | RW  | RW  | RW | RW | RW | RW | RW | RW   | RW | RW | RW | RW | RW  | RW | RW | RW  | RW |

### MEM\_LOCK [21:18]:

Memory lock bits.

| Value             | Description                             |
|-------------------|-----------------------------------------|
| 1100 <sub>b</sub> | Writing to EEPROM is locked.            |
| 0011 <sub>b</sub> | Writing to EEPROM and Shadow is locked. |
| All others        | No Lock.                                |

#### Reserved [17]

Reserved bits. No function.

### BLOCK\_VOLATILE\_OUTPUT [16]:

Prevents test modes within volatile memory space from affecting the output.

| Value | Description                                                                        |
|-------|------------------------------------------------------------------------------------|
| 0     | Volatile bits allowed to function normally.                                        |
| 1     | Prevents operation of volatile bits, 0x80 through 0xAA, that may impact the output |

### MAKE\_ERRORS\_HIGH\_Z [15]:

Controls PWM error reporting. See "Error Reporting Through PWM" for additional details.

| Value | Description                                                                           |
|-------|---------------------------------------------------------------------------------------|
| 0     | PWM outputs at half frequency and at a fixed duty cycle in response to an error flag. |
| 1     | PWM output goes to a high-impedance state in response to an error flag.               |

#### MASK\_4 [14]:

Bit to mask error flags reporting on the PWM, ABI, and S0/S1 SPI bits. Setting this bit to a logic value of 1 masks the ABI (Primary: 0xC [3]) or SLR (Primary: 0xC [4]) error flags.

#### MASK\_3 [13]:

Bit to mask error flags reporting on the PWM, ABI, and S0/S1 SPI bits. Setting this bit to a logic value of 1 masks the SMM (Primary: 0xF [4]) error flag.

### MASK\_2 [12]:

Bit to mask error flags reporting on the PWM, ABI, and S0/ S1 SPI bits. Setting this bit to a logic value of 1 masks the SAT (Primary: 0xF [2]) error flag.

### MASK\_1 [11]:

Bit to mask error flags reporting on the PWM, ABI, and S0/ S1 SPI bits. Setting this bit to a logic value of 1 masks the TSE (Primary: 0xF [1]) error flag.

# MASK\_0 [10]:

Bit to mask error flags reporting on the PWM, ABI, and S0/ S1 SPI bits. Setting this bit to a logic value of 1 masks the VCF (Primary: 0xF [0]), UVCC (Primary: 0xF [7]), OVCC (Primary: 0xF [8]), and OFE (Primary: 0xF [3]) error flags.

## LPM\_DIS\_C [9]:

Setting this bit to a logic value of 1 disables the Low Power Mode feature.

### LPM\_DIS\_C [8]:

Enables the transport mode feature. When TRANSPORT\_EN is set to a logic value of 1 the A33020 operates in transport mode after entering low power mode.

### ANGLE\_MISMATCH [7:6]:

Angle mismatch. Sets the threshold for the allowable mismatch between the main and redundant angle outputs. If the main and redundant angle outputs differ more than the threshold the SMM flag is set.

| Value       | Description: Signal path mismatch threshold in degrees |
|-------------|--------------------------------------------------------|
| 0           | 3                                                      |
| 1 (default) | 5                                                      |
| 2           | 8                                                      |
| 3           | 12                                                     |



#### MSL\_THR [5:3]:

Magnetic threshold low value. Sets the low threshold of the input magnetic flux density,  $B_{IN}$ . If FIELD\_MAG is below the threshold, the MSL flag will be set. When MSL\_THR is set to 0, the low threshold comparison is disabled.

Note: The FIELD\_MAG value is converted to Gauss using:

$$B_{IN}(G) = (FIELD_MAG_{LSB})/(S \times 3.912),$$

where:

S = 23 for part numbers with suffix 300, and S = 15.5 for part numbers with suffix 600.

#### Example:

To set the low field threshold to 100 G, first find the corresponding value in codes by rearranging the equation shown above.

For part numbers with suffix 300, 100 G corresponds to a FIELD\_MAG of 8,998 codes. The threshold setting closest to this value is Code 1.

| Value       | Threshold<br>Value in Digital<br>Codes | Approx. Field in<br>G (Part Numbers<br>with Suffix 300) | Approx. Field in<br>G (Part Numbers<br>with Suffix 600) |
|-------------|----------------------------------------|---------------------------------------------------------|---------------------------------------------------------|
| 0           | 0                                      | Disabled                                                | Disabled                                                |
| 1 (default) | 9,830                                  | 109                                                     | 162                                                     |
| 2           | 13,107                                 | 146                                                     | 216                                                     |
| 3           | 19,661                                 | 219                                                     | 324                                                     |
| 4           | 22,938                                 | 255                                                     | 378                                                     |
| 5           | 26,214                                 | 291                                                     | 432                                                     |
| 6           | 29,491                                 | 328                                                     | 486                                                     |
| 7           | 32,768                                 | 364                                                     | 540                                                     |

#### MSH\_THR [2:0]:

Magnetic threshold high value. Sets the high threshold of the input magnetic flux density,  $B_{IN}$ . If FIELD\_MAG is above the threshold, the MSH flag will be set. When logic = 0, high-threshold comparison is disabled.

Note: The FIELD\_MAG value is converted to gauss using:

$$B_{IN}(G) = (FIELD_MAG_{LSB})/(S \times 3.912),$$

where:

S = 23 for part numbers with suffix 300, and S = 15.5 for part numbers with suffix 600.

#### Example:

To set the high field threshold to 400 G, first find the corresponding value in codes by rearranging the equation shown above.

For part numbers with suffix 300, 400 G corresponds to a FIELD\_MAG of 35,990 codes. The threshold setting closest to this is logic = 4.

| Logic<br>Value | Threshold Value<br>in Digital Codes | Approx. Field in<br>G (part numbers<br>with suffix 300) | Approx. Field in<br>G (part numbers<br>with suffix 600) |
|----------------|-------------------------------------|---------------------------------------------------------|---------------------------------------------------------|
| 0              | 65,535                              | Disabled                                                | Disabled                                                |
| 1 (default)    | 52,429                              | 583                                                     | 865                                                     |
| 2              | 45,875                              | 510                                                     | 757                                                     |
| 3              | 39,322                              | 437                                                     | 648                                                     |
| 4              | 36,045                              | 401                                                     | 594                                                     |
| 5              | 32,768                              | 364                                                     | 540                                                     |
| 6              | 29,491                              | 328                                                     | 486                                                     |
| 7              | 26,214                              | 291                                                     | 432                                                     |



#### Address 0x25

| Bit     | 25  | 24  | 23   | 22 | 21   | 20  | 19  | 18 | 17   | 16   | 15  | 14   | 13  | 12  | 11 | 10  | 9   | 8   | 7   | 6  | 5  | 4    | 3   | 2  | 1    | 0   |
|---------|-----|-----|------|----|------|-----|-----|----|------|------|-----|------|-----|-----|----|-----|-----|-----|-----|----|----|------|-----|----|------|-----|
| Name    | UNU | SED | IN_B | AN | G_H\ | ′ST | ABI | ER | SL_D | CU_R | ABI | INTR | ABI | _IN |    | ABI | SLE | W_R | ATE |    | AB | I_UV | W_R | ES | AB_I | A_U |
| Default | 0   | 0   | 0    | 0  | 0    | 0   | 1   | 0  | 0    | 0    | 0   | 1    | 0   | 0   | 0  | 0   | 0   | 0   | 1   | 1  | 0  | 1    | 0   | 1  | 0    | 0   |
| Access  | RW  | RW  | RW   | RW | RW   | RW  | RW  | RW | RW   | RW   | RW  | RW   | RW  | RW  | RW | RW  | RW  | RW  | RW  | RW | RW | RW   | RW  | RW | RW   | RW  |

### INTERPOLATOR\_BYPASS [23]:

Interpolator bypass. See INTERPOLATOR\_RATE for more information.

#### ANGLE\_HYST [22:20]:

Angle ABI hysteresis. Angle Hysteresis threshold applied to the angle for ABI calculation. Value is 16-bit resolution. Provides  $\approx 0.01$  to  $1.41^{\circ}$  of hysteresis.

#### hysteresis = $360 \times 2^{(-16)} \times 2^{(\text{ANGLE}_HYST+1)}$

| Value | Description         |
|-------|---------------------|
| 0     | 0.01° of hysteresis |
| 1     | 0.02° of hysteresis |
| 2     | 0.04° of hysteresis |
| 3     | 0.09° of hysteresis |
| 4     | 0.18° of hysteresis |
| 5     | 0.35° of hysteresis |
| 6     | 0.70° of hysteresis |
| 7     | 1.41° of hysteresis |

#### ABI\_ERR\_RPT\_MODE [19:18]:

ABI error flag report mode.

ABI fault report strongly depends on PWM report logic.

Errors are reported through ABI in two different ways: in-phase error reporting or high-Z. ABI\_ERR\_RPT\_MODE controls which of these two methods is used.

With in-phase reporting, when an error occurs, the A and B outputs are in-phase with PWM (A and B pins mirror the PWM signal). The I pin is set to high impedance. See MAKE\_ERRORS\_ HIGH\_Z (EEPROM 0x3 bit 15) for PWM error reporting configurations. In-phase error reporting is not recommended if PWM is disabled.

With high-Z report method, A, B, and I are set to high impedance if an error occurs.

| Value       | Description                  |
|-------------|------------------------------|
| 0           | ABI high-z report mode       |
| 1           | ABI in-phase report mode     |
| 2 (default) | ABI Error reporting disabled |
| 3           | Same as 1                    |

### ABI\_SR\_DLY\_EN [17]:

ABI Slew Rate Delay Enable.

Disables the ABI count-up following power-on. If set, ABI pins will jump to the magnetic angle following initial poweron sequence. The ABI integrity error will not assert during this transition.

Disabling of count-up only applies if error reporting is enabled. If ABI error reporting is disabled (ABI\_ERR\_RPT\_MODE = 2) ABI count-up will still occur following power-on or reset.

| Value | Description                                                                                |
|-------|--------------------------------------------------------------------------------------------|
| 0     | ABI count-up occurs following power-on or reset (if ABI_SLEW_RATE is non-zero)             |
| 1     | ABI count-up will not occur following power-on or reset, if ABI error reporting is enabled |

#### ABI\_COUNT\_UP\_RPT\_EN [16]:

ABI count up feature report enable. When set to a logic 1 PWM indicates the completion of ABI count-up by outputting the ACD flag. See Table 17 for details on ACD reporting. If set to 0, the ACD flag is not communicated via PWM..

Note: The count up feature is disable when ABI\_SLEW\_RATE (extended: 0x25 [11:6]) is set to a value of zero.

Note: ABI conducts the count-up procedure when returning from an error state, unless ABI diagnostics are disabled (ABI\_ERR\_RPT\_MODE = 2).

#### ABI\_UVW\_ENABLE [15]:

ABI or UVW output enable. Setting this bit to a logic value of one enables the ABI or UVW outputs.



#### **INTERPOLATOR\_RATE [14]:**

Applies a 2nd order interpolator to the output angle to obtain an upsampled angle signal with a configurable update rate.

The interpolator only applies if the INTERPOLATOR\_BYPASS is set to a logic 0.

| INTERPOLATOR_<br>RATE<br>Value | INTERPOLATOR_<br>BYPASS<br>Value | ABI angle output<br>rate (μs) |
|--------------------------------|----------------------------------|-------------------------------|
| Х                              | 1                                | 2                             |
| 1                              | 0                                | 0.5                           |
| 0                              | 0                                | 0.25                          |

### ABI\_INDEX\_MODE [13:12]

Defines the width and placement of the I pulse in ABI.

| Value | Description                       |
|-------|-----------------------------------|
| 0     | I pulse is set only at 0° to +R   |
| 1     | I pulse is set only at –R to +R   |
| 2     | I pulse is set only at –R to +2R  |
| 3     | I pulse is set only at –2R to +2R |

#### R indicates the ABI quadrature resolution



#### ABI\_SLEW\_RATE [11:6]

ABI slew time rate. 0 disables slew limiting.

Minimum edged-to-edge time for ABI output is defined by:

(N+1) × 125 ns

where N is the value of ABI\_SLEW\_RATE.

This limits the maximum ABI velocity. Reducing the ABI resolution can be used to counteract this. Setting to a non-zero value enables the ABI count-up feature.

| Value | Description            |
|-------|------------------------|
| 0     | Slew limiting disable  |
| 1     | 250 ns of slew control |
|       |                        |
| 63    | 8 µs of slew control   |

#### ABI\_UVW\_RESOLUTION [5:2]

Defines resolution of ABI/UVW outputs.

In ABI mode, cycle resolution =  $2^{(14-n)}$  where n is the ABI\_UVW RESOLUTION value.

In UVW mode, the number of pole pairs is n + 1. See Table 4 for a more expansive list of options.

| Value | Cycles per<br>revolution (A or B) | UVW pole pairs |
|-------|-----------------------------------|----------------|
| 0     | 2 <sup>14c</sup> = 16384          | 1              |
| 1     | 2 <sup>13</sup> = 8192            | 2              |
| 2     | 2 <sup>12</sup> = 4096            | 3              |
| 3     | 2 <sup>11</sup> = 2048            | 4              |
|       |                                   |                |
| 14    | 2 <sup>0</sup> = 1                | 15             |
| 15    | N/A                               | 16             |



#### ABI\_UVW\_INVERT\_OUT\_EN [1]

Invert ABI/UVW signals.

| Value |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Description |                                  |  |  |  |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------|--|--|--|--|--|--|--|--|
|       | ABI/UVW signals behave as shown below for an increasing angle value. Q1 through Q4 represent changes in angle at ABI resolution.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |                                  |  |  |  |  |  |  |  |  |
|       | State Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Α           | В                                |  |  |  |  |  |  |  |  |
| 0     | Q1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           | 0                                |  |  |  |  |  |  |  |  |
|       | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           | 1                                |  |  |  |  |  |  |  |  |
|       | Q3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1           | 1                                |  |  |  |  |  |  |  |  |
|       | Q4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1           | 0                                |  |  |  |  |  |  |  |  |
|       | ABI/UVW signals are inverted and beha represent changes in angle at ABI resolution of the second sec |             | asing angle value. Q1 through Q4 |  |  |  |  |  |  |  |  |
|       | State Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Α           | В                                |  |  |  |  |  |  |  |  |
| 1     | Q1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1           | 1                                |  |  |  |  |  |  |  |  |
|       | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1           | 0                                |  |  |  |  |  |  |  |  |
|       | Q3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           | 0                                |  |  |  |  |  |  |  |  |
|       | Q4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           | 1                                |  |  |  |  |  |  |  |  |

#### ABI\_0\_UVW\_1 [0]

Defines behavior of the ABI/UVW pins.

| Value | Description                 |
|-------|-----------------------------|
| 0     | ABI output mode is selected |
| 1     | UVW output mode is selected |



#### Address 0x26 through 0x2A

The AB channel linearization fields. Each address space contains three linearization fields, each 8 bits in size. A total of 16 linearization fields are provided for the AB angle channel.

| Bit     | 25 | 24 | 23  | 22   | 21   | 20   | 19  | 18     | 17     | 16  | 15  | 14   | 13   | 12   | 11  | 10     | 9      | 8   | 7  | 6    | 5     | 4     | 3   | 2      | 1     | 0   |
|---------|----|----|-----|------|------|------|-----|--------|--------|-----|-----|------|------|------|-----|--------|--------|-----|----|------|-------|-------|-----|--------|-------|-----|
| Name    | -  |    | AB_ | LINE | ARIZ | ATIO | N_N | (2, 5, | 8, 11, | 14) | AB_ | LINE | ARIZ | ATIO | N_N | (1, 4, | 7, 10, | 13) | AB | LINE | EARIZ | ZATIC | N_N | (0, 3, | 6, 9, | 12) |
| Default | 0  | 0  | 0   | 0    | 0    | 0    | 0   | 0      | 0      | 0   | 0   | 0    | 0    | 0    | 0   | 0      | 0      | 0   | 0  | 0    | 0     | 0     | 0   | 0      | 0     | 0   |
| Access  | -  | -  | RW  | RW   | RW   | RW   | RW  | RW     | RW     | RW  | RW  | RW   | RW   | RW   | RW  | RW     | RW     | RW  | RW | RW   | RW    | RW    | RW  | RW     | RW    | RW  |

#### AB\_LINEARIZATION\_N:

Linearization field for angle channel AB. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the (N × 22.5)° angle position.

#### Example:

The AB\_LINEARIZATION\_12 field applies correction to the measured value of  $(12 \times 22.5^{\circ}) = 270^{\circ}$ .

| Value<br>(Binary) | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
| 0000 0000         | $0^{\circ}$ compensation at the (N × 22.5)° position.                             |
| 0000 0001         | ≈ 0.088° is added to the reading at the $(N \times 22.5)^{\circ}$ position.       |
|                   |                                                                                   |
| 0111 1111         | ≈ 11.16° is added to the reading at the (N × 22.5)° position.                     |
| 1000 0000         | $-11.25^{\circ}$ is added to the reading at the (N × 22.5) <sup>o</sup> position. |
|                   |                                                                                   |
| 1111 1111         | ≈ $-0.088^{\circ}$ is added to the reading at the (N × 22.5)° position.           |



#### Address 0x2B

Additional AB channel linearization fields and customer angle offset field.

| Bit     | 25 | 24 | 23 | 22 | 21 | 20   | 19 | 18                | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10                  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---------|----|----|----|----|----|------|----|-------------------|----|----|----|----|----|----|----|---------------------|----|----|----|----|----|----|----|----|----|----|
| Name    | _  | _  | -  | -  | -  | AB_L |    | CUST_ANGLE_OFFSET |    |    |    |    |    |    |    | AB_LINEARIZATION_15 |    |    |    |    |    |    |    |    |    |    |
| Default | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Access  | _  | _  | -  | -  | -  | RW   | RW | RW                | RW | RW | RW | RW | RW | RW | RW | RW                  | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |

### AB\_LIN\_ENABLE [20]:

AB channel linearization enable. Enables segmented linearization on AB angle channel.

| Value | Description                                  |
|-------|----------------------------------------------|
| 0     | No linearization is applied to the AB angle. |
| 1     | Linearization is applied to the AB channel.  |

### AB\_LINEARIZATION\_15 [7:0]:

Linearization field for angle channel AB. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the 337° angle position.

| Value<br>(Binary) | Description                                             |
|-------------------|---------------------------------------------------------|
| 0000 0000         | 0° compensation at the 337° position.                   |
| 0000 0001         | ≈ 0.088° is added to the reading at the 337° position.  |
|                   |                                                         |
| 0111 1111         | ≈ 11.16° is added to the reading at the 337° position.  |
| 1000 0000         | -11.25° is added to the reading at the 337° position.   |
|                   |                                                         |
| 1111 1111         | ≈ –0.088° is added to the reading at the 337° position. |

### CUST\_ANGLE\_OFFSET [19:8]:

Angle offset (zero position) adjustment. Offsets the reported angle value to relocate the 0° reference point. Applied *before* linearization to *all channels* (AB, BC, CA, and main). This value is added to the computed angle. 12-bit field with 12-bit resolution ( $\approx 0.088^\circ$ ).



#### Address 0x2C through 0x30

BC channel linearization fields. Each address space contains three linearization fields, each 8 bits in size. A total of 16 linearization fields are provided for the BC angle channel.

| Bit     | 25 | 24 | 23                                   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13   | 12   | 11  | 10     | 9      | 8   | 7  | 6    | 5     | 4     | 3   | 2      | 1     | 0   |
|---------|----|----|--------------------------------------|----|----|----|----|----|----|----|----|------|------|------|-----|--------|--------|-----|----|------|-------|-------|-----|--------|-------|-----|
| Name    | _  | -  | BC_LINEARIZATION_N (2, 5, 8, 11, 14) |    |    |    |    |    |    |    |    | LINE | ARIZ | ATIO | N_N | (1, 4, | 7, 10, | 13) | BC | LINE | EARIZ | ZATIC | N_N | (0, 3, | 6, 9, | 12) |
| Default | 0  | 0  | 0                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0   | 0      | 0      | 0   | 0  | 0    | 0     | 0     | 0   | 0      | 0     | 0   |
| Access  | -  | -  | RW                                   | RW | RW | RW | RW | RW | RW | RW | RW | RW   | RW   | RW   | RW  | RW     | RW     | RW  | RW | RW   | RW    | RW    | RW  | RW     | RW    | RW  |

### **BC\_LINEARIZATION\_N:**

Linearization field for angle channel BC. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the (N × 22.5)° angle position.

### Example:

The BC\_LINEARIZATION\_12 field applies correction to the measured value of  $(12 \times 22.5^{\circ}) = 270^{\circ}$ .

| Value<br>(Binary) | Description                                                             |
|-------------------|-------------------------------------------------------------------------|
| 0000 0000         | $0^{\circ}$ compensation at the (N × 22.5)° position.                   |
| 0000 0001         | ≈ 0.088° is added to the reading at the (N × 22.5)° position.           |
|                   |                                                                         |
| 0111 1111         | ≈ 11.16° is added to the reading at the (N × 22.5)° position.           |
| 1000 0000         | $-11.25^{\circ}$ is added to the reading at the (N × 22.5)° position.   |
|                   |                                                                         |
| 1111 1111         | ≈ $-0.088^{\circ}$ is added to the reading at the (N × 22.5)° position. |



### Address 0x31

Final BC channel linearization field. BC channel linearization enable.

| Bit     | 25 | 24     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6  | 5     | 4    | 3     | 2   | 1  | 0  |
|---------|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|-------|------|-------|-----|----|----|
| Name    |    | UNUSED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BC_L |    | BC | C_LIN | IEAR | IZATI | ON_ | 15 |    |
| Default | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0     | 0    | 0     | 0   | 0  | 0  |
| Access  | RW | RW     | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW   | RW | RW | RW    | RW   | RW    | RW  | RW | RW |

# BC\_LIN\_ENABLE [8]:

BC channel linearization enable. Enables segmented linearization on BC angle channel.

| Value | Description                                  |
|-------|----------------------------------------------|
| 0     | No linearization is applied to the BC angle. |
| 1     | Linearization is applied to the BC channel.  |

### BC\_LINEARIZATION\_15 [7:0]:

Linearization field for angle channel BC. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the 337° angle position.

| Value<br>(Binary) | Description                                             |
|-------------------|---------------------------------------------------------|
| 0000 0000         | 0° compensation at the 337° position.                   |
| 0000 0001         | ≈ 0.088° is added to the reading at the 337° position.  |
|                   |                                                         |
| 0111 1111         | ≈ 11.16° is added to the reading at the 337° position.  |
| 1000 0000         | -11.25° is added to the reading at the 337° position.   |
|                   |                                                         |
| 1111 1111         | ≈ –0.088° is added to the reading at the 337° position. |



### Address 0x32 through 0x36

CA channel linearization fields. Each address space contains 3 linearization fields, each 8 bits in size. A total of 16 linearization fields are provided for the CA angle channel.

| Bit     | 25  | 24  | 23  | 22 | 21   | 20   | 19  | 18     | 17     | 16  | 15  | 14 | 13   | 12   | 11  | 10     | 9      | 8   | 7  | 6    | 5     | 4     | 3   | 2      | 1     | 0   |
|---------|-----|-----|-----|----|------|------|-----|--------|--------|-----|-----|----|------|------|-----|--------|--------|-----|----|------|-------|-------|-----|--------|-------|-----|
| Name    | UNU | SED | CA_ |    | ARIZ | ATIO | N_N | (2, 5, | 8, 11, | 14) | CA_ |    | ARIZ | ATIO | N_N | (1, 4, | 7, 10, | 13) | CA | LINE | EARIZ | ZATIC | N_N | (0, 3, | 6, 9, | 12) |
| Default | 0   | 0   | 0   | 0  | 0    | 0    | 0   | 0      | 0      | 0   | 0   | 0  | 0    | 0    | 0   | 0      | 0      | 0   | 0  | 0    | 0     | 0     | 0   | 0      | 0     | 0   |
| Access  | RW  | RW  | RW  | RW | RW   | RW   | RW  | RW     | RW     | RW  | RW  | RW | RW   | RW   | RW  | RW     | RW     | RW  | RW | RW   | RW    | RW    | RW  | RW     | RW    | RW  |

# CA\_LINEARIZATION\_N:

Linearization field for angle channel CA. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the (N × 22.5)° angle position. Example: the CA\_LINEARIZATION\_12 field applies correction to the measured value of  $(12 \times 22.5^{\circ}) = 270^{\circ}$ .

| Value<br>(Binary) | Description                                                           |
|-------------------|-----------------------------------------------------------------------|
| 0000 0000         | $0^{\circ}$ compensation at the (N × 22.5)° position.                 |
| 0000 0001         | ≈ 0.088° is added to the reading at the (N × 22.5)° position.         |
|                   |                                                                       |
| 0111 1111         | ≈ 11.16° is added to the reading at the (N × 22.5)° position.         |
| 1000 0000         | $-11.25^{\circ}$ is added to the reading at the (N × 22.5)° position. |
|                   |                                                                       |
| 1111 1111         | ≈ –0.088° is added to the reading at the (N × 22.5)° position.        |



### Address 0x37

CA channel linearization enable, and final CA channel linearization coefficient field.

| Bit     | 25 | 24     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8  | 7  | 6     | 5    | 4     | 3   | 2  | 1  | 0  |
|---------|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|-------|------|-------|-----|----|----|----|
| Name    |    | UNUSED |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CA_L |    | C/ | A_LIN | IEAR | IZATI | ON_ | 15 |    |    |
| Default | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0     | 0    | 0     | 0   | 0  | 0  | 0  |
| Access  | RW | RW     | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW   | RW | RW | RW    | RW   | RW    | RW  | RW | RW | RW |

### CA\_LIN\_ENABLE [8]:

CA channel linearization enable. Enables segmented linearization on CA angle channel.

| Value | Description                                  |
|-------|----------------------------------------------|
| 0     | No linearization is applied to the CA angle. |
| 1     | Linearization is applied to the CA channel.  |

Value is determined by design. Not measured at final test.

### CA\_LINEARIZATION\_15 [7:0]:

Linearization field for angle channel CA. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the 337° angle position.

| Value<br>(Binary) | Description                                                  |
|-------------------|--------------------------------------------------------------|
| 0000 0000         | 0° compensation at the 337° position.                        |
| 0000 0001         | ≈ 0.088° is added to the reading at the 337° position.       |
|                   |                                                              |
| 0111 1111         | ≈ 11.16° is added to the reading at the 337° position.       |
| 1000 0000         | $-11.25^\circ$ is added to the reading at the 337° position. |
|                   |                                                              |
| 1111 1111         | ≈ –0.088° is added to the reading at the 337° position.      |



#### Address 0x38 through 0x3C

Main channel linearization fields. Each address space contains three linearization fields, each 8 bits in size. A total of 16 linearization fields are provided for the main angle channel.

| Bit     | 25                                        | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14     | 13    | 12      | 11     | 10      | 9        | 8  | 7  | 6      | 5     | 4      | 3    | 2        | 1        | 0  |
|---------|-------------------------------------------|----|----|----|----|----|----|----|----|----|----|--------|-------|---------|--------|---------|----------|----|----|--------|-------|--------|------|----------|----------|----|
| Name    | UNUSED MAIN_LINEARIZATION_N (2, 5, 8, 11, |    |    |    |    |    |    |    |    |    | Ν  | 1AIN_L | INEAF | RIZATIO | DN_N ( | 1, 4, 7 | , 10, 13 | 3) | ١  | /AIN_I | INEAF | RIZATI | ON_N | (0, 3, 6 | 6, 9, 12 | )  |
| Default | 0                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0     | 0       | 0      | 0       | 0        | 0  | 0  | 0      | 0     | 0      | 0    | 0        | 0        | 0  |
| Access  | RW                                        | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW     | RW    | RW      | RW     | RW      | RW       | RW | RW | RW     | RW    | RW     | RW   | RW       | RW       | RW |

### MAIN\_LINEARIZATION\_N:

Linearization field for the main angle channel. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the (N × 22.5)° angle position.

### Example:

The MAIN\_LINEARIZATION\_12 field applies correction to the measured value of  $(12 \times 22.5^{\circ}) = 270^{\circ}$ .

| Value<br>(Binary) | Description                                                             |
|-------------------|-------------------------------------------------------------------------|
| 0000 0000         | $0^{\circ}$ compensation at the (N × 22.5)° position.                   |
| 0000 0001         | ≈ 0.088° is added to the reading at the (N × 22.5)° position.           |
|                   |                                                                         |
| 0111 1111         | ≈ 11.16° is added to the reading at the (N × 22.5)° position.           |
| 1000 0000         | $-11.25^{\circ}$ is added to the reading at the (N × 22.5)° position.   |
|                   |                                                                         |
| 1111 1111         | ≈ $-0.088^{\circ}$ is added to the reading at the (N × 22.5)° position. |



#### Address 0x3D

Final linearization field for the main angle channel. Main channel linearization enable.

| Bit     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5    | 4    | 3    | 2    | 1   | 0  |
|---------|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|-----|----|----|------|------|------|------|-----|----|
| Name    |    |    |    |    |    |    |    | UI | NUSE | D  |    |    |    |    |    |    |    | M_L |    | MA | IN_L | INEA | RIZA | ΓΙΟΝ | _15 |    |
| Default | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0    | 0    | 0    | 0    | 0   | 0  |
| Access  | RW   | RW | RW | RW | RW | RW | RW | RW | RW | RW  | RW | RW | RW   | RW   | RW   | RW   | RW  | RW |

#### MAIN\_LIN\_ENABLE [8]:

Main channel linearization enable. Enables segmented linearization on the main angle channel.

| Value | Description                                    |
|-------|------------------------------------------------|
| 0     | No linearization is applied to the main angle. |
| 1     | Linearization is applied to the main channel.  |

#### BC\_LINEARIZATION\_15 [7:0]:

Linearization field for the main angle channel. 8-bit signed value with 12-bit angle resolution ( $\approx 0.088^{\circ}$  step size). Compensation value applied to the 337° angle position.

| Value<br>(Binary) | Description                                             |
|-------------------|---------------------------------------------------------|
| 0000 0000         | 0° compensation at the 337° position.                   |
| 0000 0001         | ≈ 0.088° is added to the reading at the 337° position.  |
|                   |                                                         |
| 0111 1111         | ≈ 11.16° is added to the reading at the 337° position.  |
| 1000 0000         | -11.25° is added to the reading at the 337° position.   |
|                   |                                                         |
| 1111 1111         | ≈ –0.088° is added to the reading at the 337° position. |



#### Address 0x3E

| Bit     | 25 | 24     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13   | 12 | 11  | 10 | 9    | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---------|----|--------|----|----|----|----|----|----|----|----|----|------|------|----|-----|----|------|------|----|----|----|----|----|----|----|----|
| Name    |    | UNUSED |    |    |    |    |    |    |    |    |    | тснр | IIR_ | BW | SPA | RE | TCIP | RO_P |    |    |    |    |    |    |    |    |
| Default | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0   | 0  | 0    | 0    | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  |
| Access  | RW | RW     | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW   | RW   | RW | RW  | RW | RW   | RW   | RW | RW | RW | RW | RW | RW | RW | RW |

#### TC\_HYST\_DIS\_P [6]

Disables primary channel turns count hysteresis. A hysteresis of approximately 11.25 degrees applies to the angle for the turns count calculation. There is a  $\pm 5.625^{\circ}$  area on the turns count boundaries (90, 180, 270, 360 degrees) where the turns count is not updated.

| Value | Description                                          |
|-------|------------------------------------------------------|
| 0     | Hysteresis applied to primary channel turns count    |
| 1     | No hysteresis applied to primary channel turns count |

#### IIR\_BW\_SEL [5:4]

Differential channel filter bandwidth. Primary effect is on response time.

| Value | Bandwidth (kHz) | Typical Response<br>Time (µs) |
|-------|-----------------|-------------------------------|
| 0     | 6.25            | 45                            |
| 1     | 12.5            | 25                            |
| 2     | 25              | 20                            |
| 3     | 50              | 15                            |

#### SPARE\_CUST [3:2]

Spare customer bits. Spare EEPROM bits for miscellaneous customer purpose. The value of these bits have no effect on the outputs.

#### TURNS\_CNT\_INIT\_P [1]

Primary turns count initialization selection. Defines the initial value of the turns count after a power reset event. Must be equal to the value set for TURNS\_CNT\_INIT\_S (extended: 0x3F [1])

| Value | Description                                                                                                                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Turns count initialize to a value of 0                                                                                                                                                                                          |
| 1     | Turns count initialize to a value based on the<br>initial angle reading<br>$0 \le angle < 90 \rightarrow 0$<br>$90 \le angle < 180 \rightarrow 1$<br>$180 \le angle < 270 \rightarrow 2$<br>$270 \le angle < 360 \rightarrow 3$ |

#### ROT\_DIR\_P [0]

Primary channel rotation direction. Must be set to the same value as ROT\_DIR\_S (extended: 0x3F [0]).

| Value | Description                                                                                    |
|-------|------------------------------------------------------------------------------------------------|
| 0     | Increasing angle rotation direction is counterclockwise, when orientated as shown in Figure 3. |
| 1     | Increasing angle rotation direction is<br>clockwise, when orientated as shown in<br>Figure 3.  |



#### Address 0x3F

| Bit     | 25 | 24 | 23  | 22  | 21 | 20 | 19   | 18   | 17  | 16 | 15   | 14 | 13  | 12    | 11  | 10 | 9    | 8    | 7  | 6    | 5   | 4     | 3    | 2   | 1    | 0    |
|---------|----|----|-----|-----|----|----|------|------|-----|----|------|----|-----|-------|-----|----|------|------|----|------|-----|-------|------|-----|------|------|
| Name    |    |    | UNU | SED |    |    | DIAC | G_CH | PWM | ΡW | /M_S | LR | PWI | M_POF | RCH | ΡW | /M_F | PERI | OD | тснѕ | LPI | M_SLE | EP_T | IME | TCIS | RO_S |
| Default | 0  | 0  | 0   | 0   | 0  | 0  | 0    | 0    | 0   | 0  | 0    | 0  | 0   | 0     | 0   | 0  | 0    | 0    | 0  | 0    | 0   | 0     | 0    | 0   | 0    | 0    |
| Access  | RW | RW | RW  | RW  | RW | RW | RW   | RW   | RW  | RW | RW   | RW | RW  | RW    | RW  | RW | RW   | RW   | RW | RW   | RW  | RW    | RW   | RW  | RW   | RW   |

#### DIAG\_CHANNEL\_SEL [19:18]

Diagnostic channel selector. Defines the redundant channel angle output latched in ANGLE\_OUT\_DIAG\_LATCH (primary: 0x18 [15:0]) and defines the redundant channel used for TURNS\_COUNT\_S in Full Power Mode.

| Value | Description: Selected redundant channel |
|-------|-----------------------------------------|
| 0     | AB                                      |
| 1     | AB                                      |
| 2     | BC                                      |
| 3     | CA                                      |

#### **PWM\_ENABLE** [17]

PWM output enable. Setting this bit to a logic value of one enables the PWM output.

#### PWM\_SLW\_SEL [16:14]

PWM fall time control. Controls the fall time of the PWM output. A value of zero sets the PWM output fall time to the fastest rate, a value of seven sets the PWM output fall time to the slowest rate.

| Value | Fall time,<br>C <sub>OUT</sub> = 100 pF (μs) | Fall time,<br>C <sub>OUT</sub> = 1 nF (μs) |
|-------|----------------------------------------------|--------------------------------------------|
| 0     | 0.04                                         | 0.12                                       |
| 1     | 0.10                                         | 0.17                                       |
| 2     | 0.18                                         | 0.25                                       |
| 3     | 0.26                                         | 0.33                                       |
| 4     | 0.67                                         | 0.70                                       |
| 5     | 1.35                                         | 1.29                                       |
| 6     | 2.80                                         | 2.58                                       |
| 7     | 4.02                                         | 3.73                                       |

#### PWM\_PORCH\_SEL [13:11]

PWM output fixed low and high time selection. This parameter configures the fixed low and high time of the PWM output.

| Value | PWM Low Clamp<br>(% Duty Cycle) | PWM High Clamp<br>(% Duty Cycle) |
|-------|---------------------------------|----------------------------------|
| 0     | 2                               | 98                               |
| 1     | 3                               | 97                               |
| 2     | 4                               | 96                               |
| 3     | 5                               | 95                               |
| 4     | 6                               | 94                               |
| 5     | 7                               | 93                               |
| 6     | 8                               | 92                               |
| 7     | 0                               | 100                              |

#### PWM\_PERIOD [10:7]

PWM output period. Controls the period, or frequency, of the PWM output.

| Value | Frequency (Hz) |
|-------|----------------|
| 0     | 125            |
| 1     | 167            |
| 2     | 250            |
| 3     | 333            |
| 4     | 500            |
| 5     | 667            |
| 6     | 800            |
| 7     | 1000           |
| 8     | 1333           |
| 9     | 1600           |
| 10    | 2000           |
| 11    | 2667           |
| 12    | 4000           |
| 13    | 5333           |
| 14    | 8000           |
| 15    | 16000          |



#### TC\_HYST\_DIS\_S [6]

Disables secondary channel turns count hysteresis. A hysteresis of approximately 11.25 degrees applies to the angle for the turns count calculation. There is a  $\pm 5.625^{\circ}$  area on the turns count boundaries (90, 180, 270, 360 degrees) where the turns count is not updated.

| Value | Description                                            |
|-------|--------------------------------------------------------|
| 0     | Hysteresis applied to secondary channel turns<br>count |
| 1     | No hysteresis applied to secondary channel turns count |

#### LPM\_SLEEP\_TIME [5:2]

Low power mode sleep time selection. Sets the sleep time during low power mode for the turns count tracking. See section Low Power Mode for more information.

#### TURNS\_CNT\_INIT\_S [1]

Secondary turns count initialization selection. Defines the initial value of the turns count after a power reset event. Must be equal to the value set for TURNS\_CNT\_INIT\_P (extended: 0x3E [1])

| Value | Description                                                                                                                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Turns count initialize to a value of 0                                                                                                                                                                                                      |
| 1     | Turns count initialize to a value based on the<br>initial angle reading<br>$0 \le $ angle $< 90 \rightarrow 0$<br>$90 \le $ angle $< 180 \rightarrow 1$<br>$180 \le $ angle $< 270 \rightarrow 2$<br>$270 \le $ angle $< 360 \rightarrow 3$ |

#### ROT\_DIR\_S [0]

Secondary channel rotation direction. Must be set to the same value as ROT\_DIR\_P (extended: 0x3E [0]).

| Value | Description                                                                                          |
|-------|------------------------------------------------------------------------------------------------------|
| 0     | Increasing angle rotation direction is<br>counterclockwise, when orientated as shown in<br>Figure 3. |
| 1     | Increasing angle rotation direction is clockwise, when orientated as shown in Figure 3.              |



#### Table 14: Volatile Memory Map

| EEPROM  |       |    |    |    |    |    |             |             | -  |    |     |              |          | Bits      |         |     |        |        |   |        |                  |                     |        |               |               |                   |                 |
|---------|-------|----|----|----|----|----|-------------|-------------|----|----|-----|--------------|----------|-----------|---------|-----|--------|--------|---|--------|------------------|---------------------|--------|---------------|---------------|-------------------|-----------------|
| Address | 31:26 | 25 | 24 | 23 | 22 | 21 | 20          | 19          | 18 | 17 | 16  | 15           | 14       | 13        | 12      | 11  | 10     | 9      | 8 | 7      | 6                | 5                   | 4      | 3             | 2             | 1                 | 0               |
| 0x80    |       |    |    |    |    |    |             |             |    |    |     | R            | ead only | . Factory | Reserve | ed. |        |        |   |        |                  |                     |        |               |               |                   |                 |
| 0x81    |       |    |    |    |    |    |             |             |    |    |     | R            | ead only | . Factory | Reserve | ed. |        |        |   |        |                  |                     |        |               |               |                   |                 |
| 0x82    |       |    |    |    |    |    | EE_DBE_FLAG | EE_SBE_FLAG |    |    | EE_ | ECC          |          |           |         |     | EE_/   | ADDR   |   |        |                  | EE_I                | ERR_ST | ATUS          |               | CP_ERR            | EE_ERR          |
| 0x83    |       |    |    |    |    |    |             |             |    |    |     |              |          | EE_       | DATA    |     |        |        |   |        |                  |                     |        |               |               |                   |                 |
| 0x84    |       |    |    |    |    |    |             |             |    |    |     | R            | ead only | . Factory | Reserve | ed. |        |        |   |        |                  |                     |        |               |               |                   |                 |
| 0x85    |       |    |    |    |    |    |             |             |    |    |     |              |          | EE_LOOP   |         |     | EE_TES | T_ADDF | 2 |        | EE_USE_TEST_ADDR | MARGIN_MIN_MAX_FAIL |        | MARGIN_STATUS | MARGIN_NO_MIN | MARGIN_NO_MAX     | MARGIN_START    |
| 0xA6    |       |    |    |    |    |    |             |             |    |    |     | MANCH_COMM_E |          |           |         |     |        |        | R | ESERVI | ED               |                     |        |               |               |                   |                 |
| 0xAA    |       |    |    |    |    |    |             |             |    |    |     |              |          |           |         |     |        |        |   |        |                  |                     |        |               |               | POKS_TEST_RUNNING | POKS_TEST_START |



#### Address 0x82

| Bit    | 25 | 24 | 23 | 22 | 21 | 20              | 19              | 18 | 17 | 16   | 15  | 14 | 13 | 12 | 11 | 10   | 9   | 8  | 7  | 6  | 5    | 4      | 3     | 2  | 1          | 0          |
|--------|----|----|----|----|----|-----------------|-----------------|----|----|------|-----|----|----|----|----|------|-----|----|----|----|------|--------|-------|----|------------|------------|
| Name   | 0  | 0  | 0  | 0  | 0  | EE_DBE_<br>FLAG | EE_SBE_<br>FLAG |    |    | EE_E | ECC |    |    |    |    | EE_A | DDR |    |    |    | EE_I | ERR_S1 | TATUS |    | CP_<br>ERR | EE_<br>ERR |
| Access | RO | RO | RO | RO | RO | RO              | RO              | RO | RO | RO   | RO  | RO | RO | RO | RO | RO   | RO  | RO | RO | RO | RO   | RO     | RO    | RO | RC         | RC         |

#### EE\_DBE\_FLAG [20]:

Error flag indicates detection of an EEPROM dual-bit error. The EEPROM ECC logic detects an address with a dual-bit error. This check runs after a reset event or EEPROM load event.

| Value | Description                       |
|-------|-----------------------------------|
| 0     | No EEPROM dual bit error detected |
| 1     | EEPROM dual bit error detected    |

#### EE\_SBE\_FLAG [20]:

Error flag indicates detection of an EEPROM single-bit error. The EEPROM ECC logic detects an address with a single-bit error. The ECC logic automatically corrects the faulty bit in the volatile region of memory. This check runs after a reset event or EEPROM load event.

| Value | Description                         |
|-------|-------------------------------------|
| 0     | No EEPROM single-bit error detected |
| 1     | EEPROM single-bit error detected    |

#### EE\_ECC [18:13]:

EEPROM ECC data. After the internal margin test is complete, this parameter contains the ECC data bits of the first fault address found during the margin test. Data in this parameter is only valid if the margin test reports a failure. See MARGIN\_STATUS (extended: 0x85 [4:3]) for margin results information.

#### EE\_ADDR [12:7]:

EEPROM address data. After the internal margin test is complete, this parameter contains the address of the first fault address found during the margin test. Data in this parameter is only valid if the margin test reports a failure. See MARGIN\_STATUS (extended: 0x85 [4:3]) for margin results information.

#### EE\_ERR\_STATUS [6:2]:

Indicates the error status of the last EEPROM write. If logic > 0, an error was detected during the last EEPROM write.

#### CP\_ERR [1]:

Indicates the error status of the EEPROM write charge pump during the last EEPROM write. If logic = 1, an error is detected, and the error is set in EE\_ERR\_STATUS (extended: 0x82 [6:2]).

#### EE\_ERR [0]:

Indicates detection of an EEPROM write error. If logic = 1, an EEPROM write error is detected. The bit clears after read.

#### Address 0x83

| Bit    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12  | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   |    |    |    |    |    |    |    |    |    |    |    |    | EE_C | ATA |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO   | RO  | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO | RO |

#### EE\_DATA [25:0]:

EEPROM field data. After the internal margin test is complete, this parameter contains information from the data fields of the first fault address found during the margin test. Data in this parameter is only valid if the margin test reports a failure. See MARGIN\_STATUS (extended: 0x85 [4:3]) for margin results information.



#### Address 0x85

| Bit   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13      | 12 | 11 | 10    | 9      | 8  | 7  | 6                | 5                       | 4  | 3             | 2            | 1                 | 0            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|-------|--------|----|----|------------------|-------------------------|----|---------------|--------------|-------------------|--------------|
| Name  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | EE_LOOP |    | E  | E_TES | T_ADDF | 2  |    | EE_USE_TEST_ADDR | MARGIN_MIN_MAX_<br>FAIL |    | MARGIN_STATUS | MARGIN_NOMIN | MARGIN_NO_<br>MAX | MARGIN_START |
| Acces | RO | RW      | RW | RW | RW    | RW     | RW | RW | RW               | RO                      | RO | RO            | RW           | RW                | RW           |

#### EE\_LOOP [13]:

Continuously loops the margin test. When bit logic = 1, the margin test loops continuously. If an error is detected or if MAR-GIN\_START (extended: 0x85 [0]) is cleared, the margin test stops.

| Value | Description                                               |
|-------|-----------------------------------------------------------|
| 0     | Margin test runs once                                     |
| 1     | Margin test loops continuously until an error is detected |

#### EE\_TEST\_ADDR [12:7]:

Optional start address for margin test. Defines the starting address for the margin test when  $EE\_USE\_TEST\_ADDR$  (extended: 0x85 [6]) is set to logic = 1.

#### EE\_USE\_TEST\_ADDR [6]:

When set to logic = 1, the margin test starts at the address defined by EE\_TEST\_ADDR (extended: 0x85 [12:7]).

| Value | Description                                           |
|-------|-------------------------------------------------------|
| 0     | Margin test starts at address 0x0                     |
| 1     | Margin test starts at address defined by EE_TEST_ADDR |

#### MARGIN\_MIN\_MAX\_FAIL [5]:

If a margin failure is detected, this bit indicates if the failure was detected at the minimum or maximum reference level.

| Value | Description                                       |
|-------|---------------------------------------------------|
| 0     | Margin test failure detected at minimum threshold |
| 1     | Margin test failure detected at maximum threshold |

#### MARGIN\_STATUS [4:3]:

Indicates the status of the margin test. The bits clear after a read or reset event.

| Value | Description                                 |
|-------|---------------------------------------------|
| 0     | Reset condition: No result from margin test |
| 1     | Pass: No errors detected during margin test |
| 2     | Fail: Error detected during margin test     |
| 3     | In progress: Margin test still running      |

#### MARGIN\_NO\_MIN [2]:

Disables the minimum reference level during margin test. When set to logic = 1, the margin test does not check for errors at the low reference level.

| Value | Description                                                   |
|-------|---------------------------------------------------------------|
| 0     | Margin test includes check at the low reference level         |
| 1     | Margin test does not include check at the low reference level |

#### MARGIN\_NO\_MAX [1]:

Disables the maximum reference level during margin test. When set to logic = 1, the margin test does not check for errors at the high reference level.

| Value | Description                                                    |
|-------|----------------------------------------------------------------|
| 0     | Margin test includes check at the high reference level         |
| 1     | Margin test does not include check at the high reference level |

#### MARGIN\_START [0]:

Triggers start of margin test. When set to LOGIC = 1, the margin test begins. The bit clears when the margin test completes and  $EE\_LOOP$  (extended: 0x85 [13]) = 0; if  $EE\_LOOP = 1$ , the margin test runs until MARGIN\_START = 0. If the margin test detects an error, the MARGIN\_START bit clears.



#### Address 0xA6

| Bit    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15           | 14 | 13       | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|--------|----|----|----|----|----|----|----|----|----|----|--------------|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | MANCH_COMM_E |    | reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Access | RO | RW           | RW | RW       | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW | RW |

#### MANCH\_COMM\_E [15]:

Enables Manchester communications mode on the PWM output pin. When LOGIC = 1, the PWM output stops and the pin becomes an input/output pin for Manchester communication. This bit is set directly with a write operation or indirectly using the access code. To exit Manchester communications mode, MANCH\_COMM\_E is set to LOGIC = 0.

#### Address 0xAA

| Bit    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                     | 0                   |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|---------------------|
| Name   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | POKS_TEST_<br>RUNNING | POKS_TEST_<br>START |
| Access | RO                    | RW                  |

#### POKS\_TEST\_RUNNING [1]:

POKs/IOKs startup test is running.

| Value | Description                            |
|-------|----------------------------------------|
| 0     | POKs/IOKs startup test is not running. |
| 1     | POKs/IOKs startup test is running.     |

#### POKS\_TEST\_START [0]:

When set to LOGIC = 1, runs the POKs/IOKs self-test. If an error occurs, it is reported in POKS\_SELF\_TEST\_FAILED\_FLAG (primary: 0xC [7]).



# SAFETY AND DIAGNOSTICS

The A33020 was developed in accordance with the ASIL design flow (ISO 26262) and incorporates several internal diagnostics as well as error/warning/status flags enabling the host microcontroller to assess the operational status of the die.

A short summary of the diagnostics is provided below. A complete listing and discussion of the A33020 safety features may be found in the Safety Manual.

#### Status, Error, and Warning Flags

The A33020 features include several status, error, and warning flags. These flags allow the external controller to act in response of detected fault condition. Table 15 provides a summary list of the flags. More information is also found in the Primary Serial Interface Register Reference.

All flags may be read through the primary serial registers (primary: 0xF) via SPI or Manchester communication. These error flags remain set until the register is read or reset, and the condition is removed.

#### Table 15: Status and Error Flags

| Status and<br>Error Flag | Description                                                           | Flag Response                                                                                                                                                                       |
|--------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VCF                      | Voltage Check Failure                                                 | VCF = 1 (primary: 0xF [0])                                                                                                                                                          |
| TSE                      | Temperature Sensor Error                                              | TSE = 1 (primary: 0xF [1])                                                                                                                                                          |
| SAT                      | Saturation Error                                                      | SAT = 1 (primary: 0xF [2])                                                                                                                                                          |
| OFE                      | Oscillator Frequency Discrepancy Error                                | OFE = 1 (primary: 0xF [3])                                                                                                                                                          |
| SMM                      | Signal Path (primary channel versus secondary channel) Mismatch Error | SMM = 1 (primary: 0xF [4])                                                                                                                                                          |
| MSL                      | Magnet Sense Low (input condition below low threshold) Error          | MSL = 1 (primary: 0xF [5])                                                                                                                                                          |
| MSH                      | Magnet Sense High (input condition above high threshold) Error        | MSL = 1 (primary: 0xF [6])                                                                                                                                                          |
| UVCC                     | Undervoltage Error                                                    | UVCC = 1 (primary: 0xF [7])                                                                                                                                                         |
| OVCC                     | Overvoltage Error                                                     | OVCC = 1 (primary: 0xF [8])                                                                                                                                                         |
| POR                      | Power On Reset Event                                                  | POR = 1 (primary: 0xF [9])                                                                                                                                                          |
| ESE                      | Single Bit EEPROM Error (correctable)                                 | ESE = 1 (primary: 0xF [10])                                                                                                                                                         |
| EUE                      | Multi-Bit EEPROM Error (uncorrectable)                                | EUE = 1 (primary: 0xF [11])                                                                                                                                                         |
| SME                      | Shadow Memory Error. (Multiple Input Shift Register signature error)  | SME = 1 (primary: 0xF [12] )                                                                                                                                                        |
| BSY                      | Extended Access Busy Condition                                        | BSY = 1 (primary: 0xF [13])                                                                                                                                                         |
| XEE                      | Extended Execute Error Condition                                      | EXE = 1 (primary: 0xF [14])                                                                                                                                                         |
| IER                      | Interface Error Condition                                             | IER = 1 (primary: 0xF [15])                                                                                                                                                         |
| ABI                      | ABI Integrity Fault                                                   | ABI = 1 (primary: 0x0C [3])                                                                                                                                                         |
| SLR                      | ABI Slew Rate Warning                                                 | SLR = 1 (primary: 0x0C [4])                                                                                                                                                         |
| TCW_ERROR                | Turns Count Warning and Error                                         | TCW_ERROR_P = 1 (primary: 0x13 [13])<br>TCW_ERROR_LATCH_P = 1 (primary: 0x19 [13])<br>TCW_ERROR_S = 1 (primary: 0x1A [13])<br>TCW_ERROR_LATCH_S = 1 (primary: 0x1B [13])            |
| TCO_ERROR                | Turns Count Overflow Error                                            | TCO_ERROR_P = 1 (primary: 0x13 [12])<br>TCO_ERROR_LATCH_P = 1 (primary: 0x19 [12])<br>TCO_ERROR_S = 1 (primary: 0x1A [12])<br>TCO_ERROR_LATCH_S = 1 (primary: 0x1B [12])            |
| TCO_OR_TCW               | Turns Count Warning and Error or Turns Count Overflow Error           | TCO_OR_TCW_S = 1 (primary: 0x13 [15])<br>TCO_OR_TCW_LATCH_S = 1 (primary: 0x19 [15])<br>TCO_OR_TCW_P = 1 (primary: 0x1A [15])<br>TCO_OR_TCW_LATCH_P = 1 (primary: 0x1B [15])        |
| BFLP                     | Back from low power mode, not from transport mode                     | BFLP_NOT_BFT_P = 1 (primary: 0x13 [14])<br>BFLP_NOT_BFT_LATCH_P= 1 (primary: 0x19 [14])<br>BFLP_NOT_BFT_S = 1 (primary: 0x1A [14])<br>BFLP_NOT_BFT_LATCH_S = 1 (primary: 0x1B [14]) |



# **Error Reporting Through SPI**

There are two error reporting bits, S0 and S1, within the A33020 SPI frame. The value of S0 and S1 represent the logical "or" of the bits within the error register. ABI and SLR related flags are only reported by S1. The S0 and S1 bits clear after a SPI read transaction and the condition for the flag no longer exists. Note, S0 and S1 are set to a value of one after a power-cycle or after returning to normal operating mode from Low Power Mode. If an error flag is masked the result of this flag is not reported by S0 and S1.

### **Information Flags**

The A33020 features a dedicated status register (Primary 0xC), providing informational flags to the external controller. These flags may be useful for the external controller to monitor operation. Table 16 provides a summary list of the information status flags. More information is also found in the Primary Serial Interface Register Reference.

#### Table 16: Status Register Contents (Primary 0xC)

| Bit Position | Status Flag                   | Description                     |
|--------------|-------------------------------|---------------------------------|
| 0            | ANG_RDY                       | Angle Ready                     |
| 1            | ROT_H                         | Rotation Direction              |
| 2            | ACD                           | ABI count-up procedure complete |
| 3            | ABI                           | ABI integrity error detected    |
| 4            | SLR                           | Slew rate warning               |
| 5            | BACK_FROM_LPM                 | Back from low power mode        |
| 6            | MASK_ACTIVE                   | Mask active                     |
| 7            | POKS_SELF_TEST_FAILED_FLAG    | POK/IOK self-test               |
| 8            | LP_COMP_SELF_TEST_FAILED_FLAG | Low power mode self-test        |
| 9            | ECC_SELF _TEST_ FAILED_ FLAG  | Error Correction Code self-test |



## **Error Reporting Through PWM**

The PWM output is configurable to report flags using a special frequency and duty cycle or by going to a high impedance state. The parameter MAKE\_ERRORS\_HIGH\_Z (extended: 0x24 [15]) configures the PWM error reporting function. When set to a value one the error flags result in a PWM at high impedance state for a minimum of two periods. When MAKE\_ERRORS\_HIGH\_Z is set to a value of zero the PWM reports the error flags at a defined duty cycle, shown in Table 3, and at 1/2 the frequency defined by PWM\_PERIOD (extended: 0x3F [10:7]).

In the event of multiple error flags, when MAKE\_ERRORS\_ HIGH\_Z equals zero, the PWM output reports the error condition according to priority. Table 18 lists the error flags in the order of priority from highest to lowest. The highest priority error dictates the PWM duty cycle. Error flags OFE, SME, and EUE are the highest priority flags and report through the PWM output by a high-impedance state (100% duty cycle).

The parameter PWM\_PORCH\_SEL (extended: 0x3F [13:11]) configures the PWM minimum and maximum duty cycle, and also sets the duty cycle used for error reporting.

#### Table 17: PWM Error Flag Duty Cycle

| PWM_PO     | RCH_SEL  | 0     | 1     | 2     | 3      | 4        | 5     | 6     | 7     |
|------------|----------|-------|-------|-------|--------|----------|-------|-------|-------|
| Error      | Priority |       |       |       | Duty C | ycle [%] |       |       |       |
| OFE        | Highest  | 100   | 100   | 100   | 100    | 100      | 100   | 100   | 100   |
| SME        | Highest  | 100   | 100   | 100   | 100    | 100      | 100   | 100   | 100   |
| EUE        | Highest  | 100   | 100   | 100   | 100    | 100      | 100   | 100   | 100   |
| POR+ESE    | 1        | 78.05 | 78.05 | 77.96 | 78.06  | 78.13    | 78.16 | 78.16 | 79.22 |
| POR        | 2        | 16.31 | 16.27 | 16.27 | 16.29  | 16.35    | 16.44 | 16.24 | 14.90 |
| UVCC       | 3        | 38.89 | 38.76 | 38.64 | 38.88  | 38.78    | 38.70 | 38.64 | 38.43 |
| VCF        | 4        | 33.25 | 33.23 | 33.22 | 33.24  | 33.26    | 32.97 | 33.04 | 32.55 |
| OVCC       | 5        | 72.40 | 72.67 | 72.55 | 72.41  | 72.60    | 72.43 | 72.56 | 73.33 |
| TSE        | 6        | 66.75 | 66.77 | 66.78 | 66.76  | 66.74    | 67.03 | 66.96 | 67.45 |
| MSH        | 7        | 61.11 | 61.24 | 61.36 | 61.12  | 61.22    | 61.30 | 61.36 | 61.57 |
| SAT        | 8        | 56.59 | 56.45 | 56.67 | 56.73  | 56.73    | 56.58 | 56.75 | 56.86 |
| MSL        | 9        | 44.54 | 44.29 | 44.41 | 44.53  | 44.31    | 44.44 | 44.24 | 44.31 |
| SMM        | 10       | 21.95 | 21.80 | 22.04 | 21.94  | 21.87    | 21.84 | 21.84 | 20.78 |
| ABI or SLR | 11       | 27.60 | 27.33 | 27.45 | 27.59  | 27.40    | 27.57 | 27.44 | 26.67 |
| ACD        | 12       | 84.07 | 84.10 | 84.09 | 84.06  | 83.99    | 83.89 | 84.09 | 85.49 |
| ESE        | 13       | 78.05 | 78.20 | 77.96 | 78.06  | 78.13    | 78.16 | 78.16 | 79.22 |

### Error Reporting in ABI/UVW

Error reporting when using ABI/UVW requires the transmission of angle information to be interrupted. When using ABI/UVW, it is recommended to use an additional output (PWM or SPI).

For more information on ABI / UVW error reporting, contact Allegro MicroSystems.



# A33020, Turns Count and Low Power Mode Error Checking

The A33020 monitors and keeps track of Turns Counts during normal operation and Low Power Mode (LPM). The turns count value, as reported in normal power model, is also included in the A33020 Safety Analysis for ASIL D operation. Note, the LPM and Turns Count features report using the SPI or Manchester interface.

The A33020 features diagnostic on the turns count during normal operating and LPM. Status and error conditions of the turns count report using two bits, turns count warning (TCW\_ERROR) and

turns count overflow (TCO\_ERROR). The flags are reported in the registers that include the turns count value. A list is shown in Table 19 below.

The TCW\_ERROR or TCO\_ERROR flags set in normal operation are latched and saved in LPM until cleared. The error flags set during LPM remain, after returning to normal operation, until cleared. The TCW\_ERROR and TCO\_ERROR flags only clear after a reset of the Turns Count. The external controller may execute a reset of the Turns Count using the CTRL register (primary: 0x0D). More information is available in the Primary Serial Interface Register Reference.

#### Table 18: Turns Count

| Turns Count Flag  | Description                               | Primary Memory Location |
|-------------------|-------------------------------------------|-------------------------|
| TCW_ERROR_P       | Turns Count Warning<br>Primary Channel    | 0x13 [13]               |
| TCO_ERROR_P       | Turns Count Overflow<br>Primary Channel   | 0x13 [12]               |
| TCW_ERROR_S       | Turns Count Warning<br>Secondary Channel  | 0x1A [13]               |
| TCO_ERROR_S       | Turns Count Overflow<br>Secondary Channel | 0x1A [12]               |
| TCW_ERROR_LATCH_P | Turns Count Warning<br>Primary Channel    | 0x19 [13]               |
| TCO_ERROR_LATCH_P | Turns Count Overflow<br>Primary Channel   | 0x19 [12]               |
| TCW_ERROR_LATCH_S | Turns Count Warning<br>Secondary Channel  | 0x1B [13]               |
| TCO_ERROR_LATCH_S | Turns Count Overflow<br>Secondary Channel | 0x1B [12]               |



### **APPLICATION INFORMATION**

Once the device is powered on, the rate of change of  $V_{CC}$  for any magnitude larger than 1 V should be limited to less than 1 V/ $\mu$ s. Note: It is recommended to leave the ABI pins floating if the ABI output is not used.



Figure 43: Typical A33020 configuration using SPI interface and with PWM enabled



Figure 44: Typical A33020 configuration using SPI interface and with PWM disabled

<sup>[1]</sup> If using Low Power Mode, Allegro recommends populating pull-downs on all SPI input pins (CS, MOSI, SCLK). This ensures Low Power Mode is maintained while the microcontroller is de-energized.





Figure 45: Typical A33020 configuration with PWM enabled and SPI not connected.



Figure 46: Typical A33020 configuration with PWM disabled and SPI not connected





**I/O STRUCTURES** 



# Stray-Field Immune, Precision, Hall-Effect Angle Sensor IC

#### PACKAGE OUTLINE DRAWINGS



Figure 47: LE Package, 14-Pin TSSOP



# Stray-Field Immune, Precision, Hall-Effect Angle Sensor IC



Figure 48: LP Package, 24-Pin eTSSOP



#### **Revision History**

| Number | Date              | Description                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _      | December 14, 2023 | Initial release                                                                                                                                                                                                                                                                                                                              |
| 1      | January 18, 2024  | Updated Selection Guide table (page 3), Supply Current, Transport Mode Supply Current, Low-<br>Power Mode Sleep Current, Low-Power Mode Wake Current, Low-Power Mode Average Supply<br>Current test conditions (page 6), and EEPROM Margin Check section (page 40).                                                                          |
| 2      | June 14, 2024     | Updated selection guide (page 3), Operating Characteristics (page 9), figure 2 (page 13), Turns Counting and Low Power Mode ection (page 27), CRC section (page 34),SPI Power On Response section and figure 34 (page 35), MSH_THR [5:3] section (page 61), figure 46 (page 87) and figure 47 (page 88), minor editorial updates throughout. |
| 3      | November 4, 2024  | Updated ASIL status (page 2), pinout (page 5), and sleep time graphs and table (page 28).                                                                                                                                                                                                                                                    |
| 4      | January 31, 2025  | Updated Package LE 14-pin TSSOP Pinout Drawing (page 4), CRC section (page 34), Address 0x08 section (page 45), Address 0x0F section (page 49), and Address 0x24 Magnetic Threshold High register section (page 62)                                                                                                                          |
| 5      | March 18, 2025    | Updated SPI Power on Response (page 36), MSH_THR [2:0]:section (page 62), Error Reporting Through SPI section (page 82), and A33020, Turns Count and Low Power Mode Error Checking (page 84)                                                                                                                                                 |

Copyright 2025, Allegro MicroSystems.

Allegro MicroSystems reserves the right to make, from time to time, such departures from the detail specifications as may be required to permit improvements in the performance, reliability, or manufacturability of its products. Before placing an order, the user is cautioned to verify that the information being relied upon is current.

Allegro's products are not to be used in any devices or systems, including but not limited to life support devices or systems, in which a failure of Allegro's product can reasonably be expected to cause bodily harm.

The information included herein is believed to be accurate and reliable. However, Allegro MicroSystems assumes no responsibility for its use; nor for any infringement of patents or other rights of third parties which may result from its use.

Copies of this document are considered uncontrolled documents.



### APPENDIX

```
MATLAB Function to compute the A33020 Linearization Coefficients
function [lin_coef,gap]=A33020_calc_lin_coef(angle_mech,angle_meas)
%
% This function computes the linearization coefficients for the A33020.
% Linearization is 16 segments with fixed pivot points (0°, 360^{\circ}/16, 2*360^{\circ}/16,..., 15\times360^{\circ}/16).
% The coefficients corresponds to the angle error between the measured angle at the pivot points
and the actual magnet position.
%
% Inputs:
%
    - angle_mech: n×1 vector: actual magnet position: must be between 0° and 360° and monotically
increasing [°]
    - angle meas: n×1 vector: A33020 measured position at each angle mech position (direct output
of A33020) [°]
%
% Outputs:
%
    - lin coef: 16×1 vector: contains the linearization coefficients [LSB]
%
        o lin_coef(1) corresponds to XXX_linearization_0, lin_coef(2) corresponds to XXX_linear-
ization_1, ..., lin_coef(16) corresponds to XXX_linearization_15
%
        o coefficients must be converted to 8 bits signed
%
    - gap: 16×1 vector: angle error between actual mechanical position and measured position
%% Inspect inputs
% Re-arrange data if necessary
if size(angle_mech,2)>1
    angle_mech=angle_mech';
end
% Only 360° max input range is acceptable
if max(angle mech)-min(angle mech)>360
    error('Linearization range must be <=360°')</pre>
end
% angle_mech must be increasing
```



```
if sum(diff(angle_mech)<0)>0
    error('angle_mech must be increasing')
end
% Avoid issues with 360° exact rotation
if wrapTo360(min(angle_mech))==wrapTo360(max(angle_mech))-360
    angle_mech=angle_mech(1:end-1);
    angle_meas=angle_meas(1:end-1);
end
```

%% Compute the angle error between measurements and actual position

#### % Re-arrange measured angle

angle\_meas\_temp=unwrap(wrapTo360(angle\_meas)\*2\*pi/360)\*360/2/pi; angle\_meas\_temp=unique([angle\_meas\_temp-360;angle\_meas\_temp;angle\_meas\_temp+360],'stable');

#### % Re-arrange actual position

```
angle_mech_temp=unwrap(wrapTo360(angle_mech)*2*pi/360)*360/2/pi;
angle_mech_temp=unique([angle_mech_temp-360;angle_mech_temp;angle_mech_temp+360]);
```

# % Interpolate actual position at linearization pivot positions

```
pivot=[0:360/16:360-360/16]';
mech_pos=interp1(angle_meas_temp,angle_mech_temp,pivot,'spline','extrap');
```

% Angle error between measurements and actual position gap=wrapTo180(pivot-mech\_pos);

%% Compute the linearization coefficients

```
% Select only the measurements inside the range
index=zeros(length(pivot),1);
for i=1:length(pivot)
```

if min(abs(wrapTo360(angle\_meas)-pivot(i)))<=360/16</pre>



index(i)=1;

```
end
```

end

```
index=logical(index);
```

% Compute the coefficient (remove the mean offset) lin\_coef=round((gap-mean(gap(index)))/(2\*11.25/2^8));

% Bound the linearization coefficients lin\_coef(isnan(lin\_coef))=0; lin\_coef(lin\_coef>2^7-1)=2^7-1; lin\_coef(lin\_coef<-2^7)=-2^7;</pre>

