

### **FEATURES AND BENEFITS**

- Contactless 0° to 360° angle sensor IC, for angular position, rotational speed, and direction measurement
  - □ Capable of sensing magnet rotational speeds targeting 12.5-bit effective resolution with 300 G field; higher effective resolution possible at higher field strengths
  - ☐ Circular vertical Hall (CVH) technology provides a single-channel sensor system, with air gap independence
- On-chip 32-segment linearization to improve angle accuracy
  - ☐ Reduces impact of magnet to sensor misalignment
  - ☐ Reduces impact of imperfect magnetization of target magnet
- Developed as a Safety Element out of Context (SEooC) in accordance with ISO 26262 requirements for hardware product development for use in safety-critical applications (pending assessment)
  - ☐ Single-die version designed to meet ASIL B requirements when integrated and used in conjunction with the appropriate system-level control, in the manner prescribed in the AAS33051 Safety Manual
  - □ Dual-die version designed to meet ASIL D requirements when integrated and used in conjunction with the appropriate system-level control, in the manner prescribed in the AAS33051 Safety Manual

Continued on next page...

### **PACKAGES**

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



Not to scale

## **DESCRIPTION**

The AAS33051 is a 360° angle sensor IC that provides contactless high-resolution angular position data based on magnetic circular vertical Hall (CVH) technology. It has a system-on-chip (SoC) architecture that includes: a CVH front end, digital signal processing to calculate the angular position data, and multiple output formats: serial protocol (SPI), pulse-width modulation (PWM), and either motor commutation (UVW) or encoder outputs (A, B, I). It also includes on-chip EEPROM technology, capable of supporting up to 100 read/write cycles, for flexible programming of calibration parameters. The AAS33051 is ideal for automotive applications requiring 0° to 360° angle measurements, such as electronic power steering (EPS), electronic power braking (EPB or IDB), transmission actuators, and brushless DC (BLDC) pumps.

The AAS33051 includes on-chip 32-segment linearization. This can be used to calibrate out errors due to misalignment between the magnet and the sensor or imperfect magnetization of the target magnet (which can present itself as a misalignment of the magnet to the sensor).

The AAS33051 supports customer integration into safety-critical applications.

The AAS33051 is available in a dual-die 24-pin eTSSOP and a single-die 14-pin TSSOP package. The packages are lead (Pb) free with 100% matte tin leadframe plating. The 1 mm thin package reduces the minimum air gap between the CVH transducer and the target magnet. The AAS33051 device is pin-compatible with the A1339 to enable easy migration.



Figure 1: AAS33051 Magnetic Circuit and IC Diagram

## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **FEATURES AND BENEFITS (continued)**

- High diagnostic coverage
  - ☐ On-chip diagnostics include logic built-in self-test (LBIST), signal-path diagnostics, and watchdogs to support safety-critical (ASIL) applications
  - □ 4-bit CRC on SPI
- On-chip EEPROM for storing factory and customer calibration parameters
  - ☐ Single-bit error correction; dual-bit error detection, error correction control (ECC)
- Supports operating in harsh conditions required for automotive and industrial applications, including direct connection to 12 V battery
  - □ Operating temperature range from –40°C to 150°C
  - □ Operating supply voltage range from 3.7 to 18 V, absolute maximum of 28 V continuous
    - ♦ Can support ISO 7637-2 Pulse 5b up to 39 V
- Low-power mode and turns-counter feature to keep track of motor position in automotive applications when the vehicle is turned off
  - □ Loss of power is indicated by reset flag
  - ☐ Externally stored positions can be written back to the turnscounter

- Multiple output formats supported for ease of system integration
  - ☐ ABI and UVW interfaces provide high-resolution and lowest-latency angle data
  - □ PWM interface provides initial position for ABI/UVW interfaces
  - □ 10 MHz SPI for low-latency angle and diagnostic data; enables multiple independent ICs to be connected to the same bus
    - ♦ 5 V SPI can be supported
  - ☐ Output resolution on ABI and UVW are selectable
- Multiple programming/configuration formats supported
  - ☐ The system can be completely controlled and programmed over SPI, including EEPROM writes
  - □ For systems with limited pins available, writing and reading can be performed over the VCC and PWM pins. This allows the EEPROM of a device that has only the ABI/UVW and PWM pins connected to be programmed in the production line.
- 1 mm thin surface-mount TSSOP packages for both singleand dual-die versions to minimize air gap from target magnet to CVH transducer for improved field strength
  - □ Pin-compatible to single- and dual-die A1339 devices
  - ☐ Stacked dual-die construction to improve channel-tochannel matching for systems that require redundant sensors

#### **Table of Contents**

| Features and Benefits.  Description | 1<br>1 |
|-------------------------------------|--------|
| Selection Guide                     |        |
| Absolute Maximum Ratings            |        |
| Thermal Characteristics             |        |
| Pinout Diagrams and Terminal List   |        |
| Operating Characteristics           |        |
| Typical Performance                 |        |
| Functional Description              | 9      |
| Overview                            |        |
| Angle Measurement                   | 9      |
| System Level Timing                 |        |
| Power-Up                            | 9      |
| PWM Output                          |        |
| Linearization                       | . 14   |
| Incremental Output Interface (ABI)  | . 14   |
| Brushless DC Motor Commutation      | . 20   |
| ABI Behavior at Power-Up            | . 22   |
| Angle Hysteresis                    | . 23   |
| Low Power Mode                      |        |
| Turns Counting and Low Power Mode   | . 28   |
| Setting the Turns Count Value       | . 30   |
| Transport Mode                      | . 30   |
|                                     |        |

| Device Programming Interface Interface Structure SPI Interface Manchester Interface EEPROM and Shadow Memory Usage | 31<br>32<br>36 |
|--------------------------------------------------------------------------------------------------------------------|----------------|
| Enabling EEPROM Access                                                                                             | 42             |
| EEPROM Write Lock                                                                                                  | 42             |
| EEPROM Access and Write Lock Exceptions                                                                            |                |
| Write Transaction                                                                                                  |                |
| Read Transaction                                                                                                   |                |
| Shadow Memory Read and Write Transactions                                                                          |                |
| Serial Interface Table                                                                                             |                |
| Primary Serial Interface Registers Reference                                                                       |                |
| EEPROM and Shadow Register Table                                                                                   |                |
| EEPROM Reference                                                                                                   |                |
| Safety and Diagnostics                                                                                             |                |
| Alive Counter                                                                                                      |                |
| Oscillator Watchdogs                                                                                               | . 60           |
| Logic Built-In Self-Test (LBIST)                                                                                   |                |
| Application Information                                                                                            |                |
| Magnetic Target Requirements                                                                                       |                |
| Typical SPI and ABI/UVW Applications                                                                               |                |
| I/O Structures                                                                                                     |                |
| Package Outline Drawings                                                                                           |                |
| . aonago Camilo Diamiligo                                                                                          |                |



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **SELECTION GUIDE \***

| Part Number         | System Die | Interface Voltage (V) | Package       | Packing                      |
|---------------------|------------|-----------------------|---------------|------------------------------|
| AAS33051LLPBTR-DD   | Dual       | 3.3                   | 24-pin eTSSOP | 4000 pieces per 13-inch reel |
| AAS33051LLEATR      | Single     | 3.3                   | 14-pin TSSOP  | 4000 pieces per 13-inch reel |
| AAS33051LLPBTR-5-DD | Dual       | 5.0                   | 24-pin eTSSOP | 4000 pieces per 13-inch reel |
| AAS33051LLEATR-5    | Single     | 5.0                   | 14-pin TSSOP  | 4000 pieces per 13-inch reel |

### **ABSOLUTE MAXIMUM RATINGS**

| Characteristic                 | Symbol               | Notes                                            | Rating     | Unit |
|--------------------------------|----------------------|--------------------------------------------------|------------|------|
| Forward Supply Voltage         | V <sub>CC</sub>      | Sampling angles, respecting T <sub>J</sub> (max) | 28         | V    |
| Reverse Supply Voltage         | V <sub>RCC</sub>     | Not sampling angles                              | -18        | V    |
| All Other Pins Forward Voltage | V <sub>IN</sub>      |                                                  | 5.5        | V    |
| All Other Pins Reverse Voltage | V <sub>R</sub>       |                                                  | -0.5       | V    |
| Operating Ambient Temperature  | T <sub>A</sub>       | L range                                          | -40 to 150 | °C   |
| Maximum Junction Temperature   | T <sub>J</sub> (max) |                                                  | 170        | °C   |
| Storage Temperature            | T <sub>stg</sub>     |                                                  | -65 to 170 | °C   |

### THERMAL CHARACTERISTICS: May require derating at maximum conditions

| Characteristic                              | Characteristic Symbol Test Conditions* |                                                                               |    | Unit |
|---------------------------------------------|----------------------------------------|-------------------------------------------------------------------------------|----|------|
| Dackage Thermal Desistance                  | Б                                      | LP-24 package with exposed thermal pad; measured on JEDEC JESD51-7 2s2p board | 69 | °C/W |
| Package Thermal Resistance R <sub>0JA</sub> |                                        | LE-14 package; measured on JEDEC JESD51-7 2s2p board                          | 82 | °C/W |



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### PINOUT DIAGRAMS AND TERMINAL LIST TABLE

## Pinout Diagrams LP 24-Pin eTSSOP

| CS_1 1    | 0       | 24 BYP_2   |
|-----------|---------|------------|
| SCLK_1 2  |         | 23 VCC_2   |
| MOSI_1 3  |         | 22 WAKE_2  |
| MISO_1 4  |         | 21 PWM_2   |
| A_1/U_1 5 | li i    | 20 GND_2   |
| B_1/V_1 6 | i PAD i | 19 I_2/W_2 |
| I_1/W_1 7 | i i i   | 18 B_2/V_2 |
| GND_1 8   |         | 17 A_2/U_2 |
| PWM_1 9   | ij      | 16 MISO_2  |
| WAKE_1 10 |         | 15 MOSI_2  |
| VCC_1 11  |         | 14 SCLK_2  |
| BYP_1 12  |         | 13 CS_2    |

### **LE 14-Pin TSSOP**

| BYP_1 1  | 0 | 14 I_1/W_1 |
|----------|---|------------|
| VCC_1 2  |   | 13 B_1/V_1 |
| WAKE_1 3 |   | 12 A_1/U_1 |
| PWM_1 4  |   | 11 MISO_1  |
| GND 5    |   | 10 MOSI_1  |
| GND 6    |   | 9 SCLK_1   |
| GND 7    |   | 8 CS_1     |
|          |   |            |

### **Terminal List Table**

| Pin     | Pin N   | umber | Europhia a                                                                                          |  |
|---------|---------|-------|-----------------------------------------------------------------------------------------------------|--|
| Name    | LE-14   | LP-24 | Function                                                                                            |  |
| PWM_1   | 4       | 9     | PWM angle output (die 1)                                                                            |  |
| BYP_1   | 1       | 12    | External bypass capacitor terminal for internal regulator (die 1)                                   |  |
| A_1/U_1 | 12      | 5     | Option 1: Quadrature A output signal (die 1) Option 2: U (phase 1) output signal (die 1)            |  |
| B_1/V_1 | 13      | 6     | Option 1: Quadrature B output signal (die 1) Option 2: V (phase 2) output signal (die 1)            |  |
| VCC_1   | 2       | 11    | Power supply                                                                                        |  |
| I_1/W_1 | 14      | 7     | Option 1: Quadrature I (index) output signal (die 1) Option 2: W (phase 3) output signal (die 1)    |  |
| VCC_2   | _       | 23    | Power supply                                                                                        |  |
| MISO_2  | _       | 16    | SPI controller-input peripheral-output (die 2)                                                      |  |
| SCLK_2  | -       | 14    | SPI clock terminal input (die 2)                                                                    |  |
| MOSI_2  | -       | 15    | SPI controller-output peripheral-input (die 2); also address selection for Manchester interface     |  |
| CS_2    | -       | 13    | SPI chip-select terminal, active low input (die 2); also addre selection for Manchester interface   |  |
| GND     | 5, 6, 7 | _     | Device ground terminal                                                                              |  |
| GND_1   | _       | 8     | Device ground terminal                                                                              |  |
| GND_2   | _       | 20    | Device ground terminal                                                                              |  |
| PWM_2   | _       | 21    | PWM angle output (die 2)                                                                            |  |
| BYP_2   | _       | 24    | External bypass capacitor terminal for internal regulator (die 2)                                   |  |
| A_2/U_2 | _       | 17    | Option 1: Quadrature A output signal (die 2)<br>Option 2: U (phase 1) output signal (die 2)         |  |
| B_2/V_2 | -       | 18    | Option 1: Quadrature B output signal (die 2)<br>Option 2: V (phase 2) output signal (die 2)         |  |
| I_2/W_2 | -       | 19    | Option 1: Quadrature I (index) output signal (die 1) Option 2: W (phase 3) output signal (die 1)    |  |
| MISO_1  | 11      | 4     | SPI controller-input peripheral-output (die 1)                                                      |  |
| SCLK_1  | 9       | 2     | SPI clock terminal input (die 1)                                                                    |  |
| MOSI_1  | 10      | 3     | SPI controller-output peripheral-input (die 1); also address selection for Manchester interface     |  |
| CS_1    | 8       | 1     | SPI chip-select terminal, active low input (die 1); also address selection for Manchester interface |  |
| WAKE_1  | 3       | 10    | External wake-up signal input (die 1)                                                               |  |
| WAKE_2  | _       | 22    | External wake-up signal input (die 2)                                                               |  |
| PAD     | _       | PAD   | Exposed pad for thermal dissipation                                                                 |  |



## **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

| Characteristics                                    | Symbol                 | Test Conditions                                                                                   | Min. | Typ. [1] | Max. | Unit [2] |
|----------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------|------|----------|------|----------|
| ELECTRICAL CHARACTERISTICS                         |                        |                                                                                                   |      |          |      |          |
| Supply Voltage                                     | V <sub>CC</sub>        |                                                                                                   | 3.7  | -        | 18   | V        |
| Supply Current                                     | I <sub>CC(full)</sub>  | For single die                                                                                    | _    | 15       | 19   | mA       |
| Low-Power Mode Average Supply                      |                        | Single die, target RPM = 0, T <sub>A</sub> = 25°C,<br>V <sub>CC</sub> = 5 V, sleep time = 96 ms   | -    | 76       | -    | μΑ       |
| Current                                            | I <sub>CC(LP)</sub>    | Single die, target RPM = 0, T <sub>A</sub> = 150°C,<br>V <sub>CC</sub> = 16 V, sleep time = 96 ms | -    | _        | 170  | μΑ       |
| Transport Mada Supply Current                      |                        | Single die, T <sub>A</sub> = 25°C, V <sub>CC</sub> = 5 V                                          | _    | 45       | _    | μA       |
| Transport Mode Supply Current                      | I <sub>CC(TRANS)</sub> | Single die, T <sub>A</sub> = 150°C, V <sub>CC</sub> = 16 V                                        | _    | -        | 150  | μΑ       |
| Dower On Boost Threshold Voltage [3][6]            | V <sub>PORHI</sub>     | V <sub>CC</sub> rising, dV/dt = 1 V/ms, T <sub>A</sub> = -40°C to 150°C                           | _    | -        | 3.7  | V        |
| Power-On Reset Threshold Voltage <sup>[3][6]</sup> | V <sub>PORLOW</sub>    | V <sub>CC</sub> falling, dV/dt = 1 V/ms, T <sub>A</sub> = -40°C to 150°C                          | 2.8  | -        | _    | V        |
| Undervoltage Warning Level [6]                     | V <sub>UV</sub>        | T <sub>A</sub> = -40°C to 150°C                                                                   | 3.7  | 3.82     | 4    | V        |
| Supply Zener Clamp Voltage                         | V <sub>ZSUP</sub>      | $I_{CC} = I_{CC(AWAKE)} + 3 \text{ mA}, T_A = 25^{\circ}\text{C}$                                 | 26.5 | -        | _    | V        |
| Reverse Battery Current                            | I <sub>RCC</sub>       | V <sub>RCC</sub> = 18 V, T <sub>A</sub> = 25°C                                                    | _    | -        | 5    | mA       |
| Power-On Time <sup>[4]</sup>                       | t <sub>PO</sub>        | Power-on diagnostics disabled, interface working, but angle not yet settled                       | -    | 300      | _    | μs       |
| Bypass Pin Output Voltage <sup>[5]</sup>           | $V_{BYP}$              | $T_A = 25^{\circ}C, C_{BYP} = 0.1 \mu\text{F}$                                                    | 2.97 | 3.3      | 3.63 | V        |
| SPI AND ABI/UVW INTERFACE SPE                      | CIFICATIO              | NS (for 3.3 V interface)                                                                          |      |          |      |          |
| 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        |
| Output High Voltage                                | V <sub>OH</sub>        | MISO and ABI/UVW pins, C <sub>L</sub> = 20 pF, T <sub>A</sub> = 25°C                              | 2.93 | 3.3      | 3.63 | V        |
| Output Low Voltage                                 | V <sub>OL</sub>        | MISO and ABI/UVW pins, C <sub>L</sub> = 20 pF, T <sub>A</sub> = 25°C                              | _    | 0.3      | _    | V        |
| SPI AND ABI/UVW INTERFACE SPE                      | CIFICATIO              | NS (for 5 V interface)                                                                            |      |          |      |          |
| Digital Input High Voltage                         | V <sub>IH</sub>        | MOSI, SCLK, CS pins                                                                               | 3.75 | -        | 5.5  | V        |
| Digital Input Low Voltage                          | V <sub>IL</sub>        | MOSI, SCLK, CS pins                                                                               | _    | _        | 0.5  | V        |
| Output High Voltage                                | V <sub>OH</sub>        | MISO and ABI/UVW pins, $C_L = 20$ pF, $T_A = 25$ °C; $V_{CC} \ge 5$ V                             | 4    | 5        | 5.5  | V        |
| Output Low Voltage                                 | V <sub>OL</sub>        | MISO and ABI/UVW pins, C <sub>L</sub> = 20 pF, T <sub>A</sub> = 25°C                              | _    | 0.3      | _    | V        |
| SPI INTERFACE SPECIFICATIONS                       |                        | ·                                                                                                 |      |          |      |          |
| SPI Clock Frequency <sup>[6]</sup>                 | f <sub>SCLK</sub>      | MISOx pins, C <sub>L</sub> = 20 pF                                                                | 0.1  | _        | 10   | MHz      |
| SPI Clock Duty Cycle [6]                           | D <sub>fSCLK</sub>     | SPI <sub>CLKDC</sub>                                                                              | 40   | _        | 60   | %        |
| SPI Frame Rate <sup>[6]</sup>                      | t <sub>SPI</sub>       |                                                                                                   | 5.8  | _        | 588  | kHz      |
| Chip Select to First SCLK Edge <sup>[6]</sup>      | t <sub>cs</sub>        | Time from CSx going low to SCLKx falling edge                                                     | 50   | _        | _    | ns       |
| Chip Select Inactive Time [6]                      | t <sub>CSH</sub>       | Time in which $\overline{CS}x$ is held high before the next frame                                 | 150  | -        | -    | ns       |
| Data Output Valid Time <sup>[6]</sup>              | t <sub>DAV</sub>       | Data output valid after SCLKx falling edge                                                        | _    | _        | 50   | ns       |
| MOSI Setup Time [6]                                | t <sub>SU</sub>        | Input setup time before SCLKx rising edge                                                         | 25   | _        | _    | ns       |
| MOSI Hold Time <sup>[6]</sup>                      | t <sub>HD</sub>        | Input hold time after SCLKx rising edge                                                           | 50   | _        | _    | ns       |
| SCLK to CS Hold Time <sup>[6]</sup>                | t <sub>CHD</sub>       | Hold SCLKx high time before CSx rising edge                                                       | 5    | _        | _    | ns       |
| Load Capacitance <sup>[6]</sup>                    | C <sub>L</sub>         | Loading on digital output (MISOx) pin                                                             | _    | _        | 20   | pF       |

Continued on the next page...



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### OPERATING CHARACTERISTICS (continued): Valid over the full operating voltage and ambient temperature ranges, unless otherwise noted

| Characteristics                                         | Symbol                | Test Conditions                                                                                          | Min.                 | Typ. [1] | Max.                 | Unit [2] |
|---------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------|----------------------|----------|----------------------|----------|
| PWM INTERFACE SPECIFICATION                             | S                     |                                                                                                          |                      |          | 3                    |          |
|                                                         |                       | PWM frequency minimum setting, T <sub>A</sub> in specification                                           | _                    | 98       | _                    | Hz       |
| PWM Carrier Frequency                                   | f <sub>PWM</sub>      | PWM programmable options (number of steps)                                                               | _                    | 128      | _                    | steps    |
|                                                         |                       | PWM frequency maximum setting, T <sub>A</sub> in specification                                           | _                    | 3.125    | _                    | kHz      |
| PWM Output Low Clamp                                    | D <sub>PWM(min)</sub> | Corresponding to digital angle of 0x000                                                                  | _                    | 5        | _                    | %        |
| PWM Output High Clamp                                   | D <sub>PWM(max)</sub> | Corresponding to digital angle of 0xFFF                                                                  | -                    | 95       | _                    | %        |
| INCREMENTAL OUTPUT SPECIFIC                             |                       |                                                                                                          |                      |          |                      |          |
| ABI and UVW Output Angular<br>Hysteresis <sup>[6]</sup> | hys <sub>ANG</sub>    | Programmable                                                                                             | 0                    | _        | 1.38                 | degrees  |
| MANCHESTER INTERFACE SPECI                              | FICATIONS             |                                                                                                          | `                    |          |                      |          |
| Manchester High Voltage [6]                             | V <sub>MAN(H)</sub>   | Applied to VCC line                                                                                      | 7.3                  | 8        | V <sub>CC(max)</sub> | V        |
| Manchester Low Voltage [6]                              | V <sub>MAN(L)</sub>   | Applied to VCC line                                                                                      | V <sub>CC(min)</sub> | 5        | 5.7                  | V        |
| Manchester Bitrate [6]                                  | f <sub>MAN</sub>      | Line state changes once or twice per bit;<br>maximum speed is usually limited by VCC line<br>capacitance | 2.2                  | _        | 100                  | kbit/s   |
| BUILT-IN SELF-TEST                                      |                       |                                                                                                          |                      |          |                      |          |
| Logic BIST Time                                         | t <sub>LBIST</sub>    | Configurable to run on power-up or on user request                                                       | _                    | 30       | _                    | ms       |
| Circular Vertical Hall Self-Test Time                   | t <sub>CVHST</sub>    | Configurable to run on power-up or on user request                                                       | _                    | 30       | _                    | ms       |
| MAGNETIC CHARACTERISTICS                                |                       |                                                                                                          |                      |          |                      |          |
| Magnetic Field                                          | В                     | Range of input field                                                                                     |                      | _        | 1200                 | G        |

Continued on the next page...



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

OPERATING CHARACTERISTICS (continued): Valid over the full operating voltage and ambient temperature ranges, unless otherwise noted

| Characteristics                       | Symbol                      | ymbol Test Conditions                                                                   |      | Typ. [1] | Max. | Unit [2] |
|---------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------|------|----------|------|----------|
| ANGLE CHARACTERISTICS                 |                             |                                                                                         |      |          |      |          |
| Output <sup>[7]</sup>                 | RES <sub>ANGLE</sub>        | Both 12- and 15-bit angle values are available via SPI                                  | -    | 12 or 15 | _    | bit      |
| Angle Refresh Rate <sup>[8]</sup>     | t <sub>ANG</sub>            | No averaging                                                                            | _    | 1        | _    | μs       |
| Response Time [6]                     | t <sub>RESPONSE</sub>       | Angular latency; valid for ABI or UVW interface                                         | _    | 10       | _    | μs       |
| Angle Error [9]                       | FDD                         | T <sub>A</sub> = 25°C, ideal magnet alignment, B = 300 G, target rpm = 0                | -1   | ±0.4     | 1    | degrees  |
|                                       | ERR <sub>ANG</sub>          | T <sub>A</sub> = 150°C, ideal magnet alignment, B = 300 G, target rpm = 0               | -1.3 | ±0.7     | 1.3  | degrees  |
| Tamana anakuma Duikk                  | ANGLE                       | T <sub>A</sub> = 150°C, B = 300 G, angle change from 25°C                               | -1.4 | _        | 1.4  | degrees  |
| Temperature Drift                     | ANGLE <sub>DRIFT</sub>      | T <sub>A</sub> = -40°C, B = 300 G, angle change from 25°C                               | _    | 0.9      | _    | degrees  |
| A :- :-   101/111                     | N                           | T <sub>A</sub> = 25°C, B = 300 G, no internal filtering, target rpm = 0, 3-sigma noise  | -    | ±0.22    | _    | degrees  |
| Angle Noise [10][11] N <sub>ANG</sub> |                             | T <sub>A</sub> = 150°C, B = 300 G, no internal filtering, target rpm = 0, 3-sigma noise | -    | ±0.28    | _    | degrees  |
| Effective Resolution [12]             |                             | B = 300 G, T <sub>A</sub> = 25°C                                                        | _    | 12.47    | _    | bits     |
| Angle Drift Over Lifetime [13]        | ANGLE <sub>Drift_Life</sub> | B = 300 G, average maximum drift observed following AEC-Q100 qualification testing      | -    | 0.5      | _    | degrees  |

 $<sup>^{[1]}</sup>$  Typical data is at  $T_A$  = 25°C and  $V_{CC}$  = 5 V, and is for design estimates only.

[6] Parameter is not guaranteed at final test. Determined by design.

[10] Error and noise values are with no further signal processing. Angle noise can be reduced with internal filtering and slower angle-refresh rate value.

[12] Effective resolution is calculated using:

$$\log_2(360) - \log_2\left(\frac{1}{n}\sum_{i=1}^n \sigma_i\right)$$

where  $\sigma$  is the standard deviation based on 30 measurements taken at each of the 32 angular positions, I = 11.25, 22.5, ... 360.

[13] Maximum observed angle drift following AEC-Q100 stress is 1.4 degrees.



<sup>[2] 1</sup> G (gauss) = 0.1 mT (millitesla).

<sup>&</sup>lt;sup>[3]</sup> At power-on, a die does not respond to commands until  $V_{CC}$  rises to greater than  $V_{PORHI}$ . After that, the die performs and responds typically until  $V_{CC}$  reduces to less than  $V_{PORLOW}$ .

<sup>[4]</sup> During the power-on phase, the AAS33051 SPI transactions are not guaranteed.

<sup>[5]</sup> The output voltage and current specifications are 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 that are to be expected during typical operation.

<sup>[7]</sup> RES<sub>ANGLE</sub> represents the number of bits of data available for reading from the die registers.

<sup>[8]</sup> The rate at which a new angle reading become ready.

<sup>[9]</sup> Error value as measured at Allegro final test before any on-chip linearization is applied. Actual raw angle error performance in application can vary with multiple factors (e.g., magnet-to-sensor alignment, etc). Using the on-chip linearization features of the AAS33051 can significantly reduce these errors.

<sup>[11]</sup> This value represents 3-sigma or three times the standard deviation of the measured samples.

### **TYPICAL PERFORMANCE**

Table 1: Typical Power Consumption in Low-Power Mode over Wake-Up Intervals at Different Temperatures

| LPM_CYCLE_TIME |     | 25°C |      | 150°C |      |      |  |
|----------------|-----|------|------|-------|------|------|--|
| [ms]           | 5 V | 12 V | 16 V | 5 V   | 12 V | 16 V |  |
| 8              | 239 | 253  | 264  | 298   | 314  | 329  |  |
| 16             | 151 | 164  | 176  | 208   | 224  | 238  |  |
| 24             | 121 | 134  | 146  | 177   | 193  | 207  |  |
| 32             | 106 | 119  | 130  | 162   | 178  | 192  |  |
| 40             | 97  | 110  | 121  | 153   | 168  | 182  |  |
| 48             | 91  | 104  | 115  | 147   | 162  | 176  |  |
| 56             | 87  | 100  | 111  | 142   | 158  | 172  |  |
| 64             | 84  | 96   | 108  | 139   | 154  | 168  |  |
| 72             | 81  | 94   | 105  | 136   | 152  | 166  |  |
| 80             | 79  | 92   | 103  | 134   | 150  | 164  |  |
| 88             | 78  | 90   | 101  | 133   | 148  | 162  |  |
| 96             | 76  | 89   | 100  | 131   | 147  | 160  |  |
| 104            | 75  | 88   | 99   | 130   | 145  | 159  |  |
|                |     |      |      |       |      |      |  |
| 152            | 71  | 83   | 94   | 126   | 141  | 155  |  |
|                |     |      |      |       |      |      |  |
| 200            | 68  | 81   | 92   | 123   | 138  | 152  |  |
|                |     |      |      |       |      |      |  |
| 248            | 67  | 79   | 91   | 122   | 137  | 151  |  |
|                |     |      |      |       |      |      |  |
| 296            | 66  | 78   | 90   | 121   | 136  | 150  |  |
|                |     |      |      |       |      |      |  |
| 400            | 65  | 77   | 88   | 120   | 135  | 149  |  |
|                |     |      |      |       |      |      |  |
| 512            | 64  | 76   | 88   | 119   | 134  | 148  |  |



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **FUNCTIONAL DESCRIPTION**

### Overview

The AAS33051 is a rotary-position Hall-sensor-based device. It incorporates one or two electrically independent Hall sensor dies in the same surface-mount package to provide solid-state consistency and reliability, and to support a wide variety of automotive applications. Each Hall-sensor-based die measures the direction of the magnetic field vector through 360° in the x-y plane (parallel to the branded face of the device) and computes an angle measurement based on the actual physical reading, as well as any internal parameters that have been set by the user. The output of each die is used by the host microcontroller to provide a single channel of target data.

This device is an advanced, programmable system-on-chip (SoC). Each integrated circuit includes a circular vertical Hall (CVH) analog front end, a high-speed sampling analog-to-digital converter (ADC), digital filtering, digital signal processing, a digital control SPI interface, motor commutation outputs (UVW), and encoder outputs (A, B, I).

Advanced offset, gain, and linearization adjustment options are available in the AAS33051. These options can be configured in onboard EEPROM, providing a wide range of sensing solutions in the same device.

### **Angle Measurement**

The AAS33051 can monitor the angular position of a rotating magnet at speeds ranging from 0 to more than 15,000 rpm. The AAS33051 has a typical output refresh rate of 1  $\mu$ s.

Readout in SPI is possible with 12-bit resolution with error flags included in the same word, or in 15-bit resolution without included error flags. Reading out the angle takes 16 SPI clock cycles. For details about SPI usage, see the SPI Interface section.

PWM output is always resolved to a 12-bit angle resolution.

ABI/UVW resolution can be set to the level desired by the customer.

The sensor readout is processed and linearized in various steps. These are detailed in Figure 3.

### **System-Level Timing**

Internal registers are updated with a new angle value every  $t_{\rm ANG}$ . Due to signal-path delay, the angle is  $t_{\rm RESPONSE}$  old at each update. In other words,  $t_{\rm RESPONSE}$  is the delay from the time of magnet sampling until generation of a processed angle value. The streaming protocols ABI and UVW, which do not require external trigger,

update every  $t_{ANG}$  (if an angle change has occurred). SPI, which is asynchronously clocked, results in a varying latency depending on sampling frequency and SCLK speed. The values that are presented to the user are copied from the data path to the output registers between 0 and 125 ns after the SPI falling chip-select edge. If the SPI clock is 10 MHz, the data are clocked-out after 1.6  $\mu$ s. Because the data are sampled in at the first clock edge at an age of maximum  $t_{RESPONSE}$ , the age of the data after the SPI transaction finishes is between 1.6 and 1.6 +  $t_{RESPONSE}$   $\mu$ s.

The update rate and the signal delay of the different angle-output paths depending on the sensor settings are shown in Figure 2.

The value of the ANGLE\_ZCD register is updated approximately every 32  $\mu$ s. The value of the register GAUSS is update approximately every 128  $\mu$ s.

### Power-Up

Upon applying power to the AAS33051, the device automatically runs through an initialization routine. The purpose of this initialization is to ensure that the device comes up in the same predictable operating condition every power cycle. This initialization routine takes a finite amount of time to complete, which is referred to as power-on time, t<sub>PO</sub>. Regardless of the state of the device before a power cycle, the device re-powers with EEPROM shadow bits copied from the EEPROM anew, and serial registers in their default states. For example, on every power-up, the device powers with the ZERO\_OFFSET stored in the EEPROM. The extended write access field WRITE\_ADR is set back to its default value, zero.

### **PWM Output**

The AAS33051 provides a pulse-width-modulated output with duty cycle proportional to measured angle. The PWM duty cycle is clamped at 5% and 95% DC for diagnostic purposes. 5% DC corresponds to 0 degrees of angle; 95% DC corresponds to 360° of angle. The 0% and 100% (pulled low and pulled high) states are reserved for error condition notifications. The rising edges of the output are always at the same points in time, while the falling edge moves from 5% to 95% over angles of 0 to 360 degrees.

In case of errors:

- If PEO = 1, errors affect the PWM pin.
- If PES = 0, the PWM pin is tristated, i.e., put it in a high-Z state. A power cycle is needed to relieve the high-Z condition, even if the error that caused the condition no longer persists.
- If PES = 1, the output frequency is halved in case of errors.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

As soon as the condition that caused the error no longer persists, the PWM output returns to typical behavior. Errors that appeared and disappeared within one PWM cycle remain stored and output once for the next PWM cycle. This way, very brief errors continue to be reported. In case of errors, the duty cycle is fixed to the levels in Table 2.

**Table 2: PWM Output Errors** 

| Error | Priority    | Duty Cycle % | Description / Persistence                                                                                |  |  |  |
|-------|-------------|--------------|----------------------------------------------------------------------------------------------------------|--|--|--|
| WDE   | 1 (highest) | 5            | Watchdog error. Permanent error until restart.                                                           |  |  |  |
| EUE   | 2           | 10.625       | EEPROM uncorrectable error. Permanent error until restart.                                               |  |  |  |
| STF   | 3           | 16.25        | Self-test failure. Permanent error until restart.                                                        |  |  |  |
| PLK   | 4           | 21.875       | PLL not locked. Persists until PLL locks.                                                                |  |  |  |
| ZIE   | 5           | 27.5         | Zero-crossing integrity error. Persists as long as the issue exists.                                     |  |  |  |
| AVG   | 6           | 33.125       | Angle averaging error. Outputs once, then clears.                                                        |  |  |  |
| UV    | 7           | 38.75        | Undervoltage (UVA and/or UVCC dependent on serial error masks). Persists until no unmasked undervoltage. |  |  |  |
| MSL   | 8           | 44.375       | Persists until field strength exceeds the low threshold.                                                 |  |  |  |
| ESE   | 9           | 50           | EEPROM correctable error. Outputs once, then clears.                                                     |  |  |  |
| SAT   | 10          | 55.625       | Saturation error. Persists as long as the issue exists.                                                  |  |  |  |
| MSH   | 11          | 61.25        | Persists until field strength is less than the high threshold.                                           |  |  |  |
| TR    | 12          | 66.875       | Persists until temperature within range.                                                                 |  |  |  |
| TOV   | 13 (lowest) | 72.5         | Turns counter overflow. Persists until cleared via CTRL register.                                        |  |  |  |



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

The duty cycle of the pin can be configured using the PWM\_BAND and the PWM\_FREQ fields, yielding the frequencies shown in Table 3.

Table 3: PWM Frequency Table (Hz)

|          | ,  | PWM_BAND |      |      |      |      |     |     |     |
|----------|----|----------|------|------|------|------|-----|-----|-----|
|          |    | 0        | 1    | 2    | 3    | 4    | 5   | 6   | 7   |
|          | 0  | 3125     | 2778 | 2273 | 1667 | 1087 | 641 | 352 | 185 |
|          | 1  | 3101     | 2740 | 2222 | 1613 | 1042 | 610 | 333 | 175 |
|          | 2  | 3077     | 2703 | 2174 | 1563 | 1000 | 581 | 316 | 166 |
|          | 3  | 3053     | 2667 | 2128 | 1515 | 962  | 556 | 301 | 157 |
|          | 4  | 3030     | 2632 | 2083 | 1471 | 926  | 532 | 287 | 150 |
| PWM_FREQ | 5  | 3008     | 2597 | 2041 | 1429 | 893  | 510 | 275 | 143 |
|          | 6  | 2985     | 2564 | 2000 | 1389 | 862  | 490 | 263 | 137 |
|          | 7  | 2963     | 2532 | 1961 | 1351 | 833  | 472 | 253 | 131 |
|          | 8  | 2941     | 2500 | 1923 | 1316 | 806  | 455 | 243 | 126 |
|          | 9  | 2920     | 2469 | 1887 | 1282 | 781  | 439 | 234 | 121 |
|          | 10 | 2899     | 2439 | 1852 | 1250 | 758  | 424 | 225 | 116 |
|          | 11 | 2878     | 2410 | 1818 | 1220 | 735  | 410 | 217 | 112 |
|          | 12 | 2857     | 2381 | 1786 | 1190 | 714  | 397 | 210 | 108 |
|          | 13 | 2837     | 2353 | 1754 | 1163 | 694  | 385 | 203 | 105 |
|          | 14 | 2817     | 2326 | 1724 | 1136 | 676  | 373 | 197 | 101 |
|          | 15 | 2797     | 2299 | 1695 | 1111 | 658  | 362 | 191 | 98  |





Figure 2: Update Rate and Signal Delay



Figure 3: Angle Data Flow Chart
Text in all capitals denotes registers that affect their containing block.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### Linearization

The AAS33051 contains linearization functionality. Linearization allows for conversion of the initially sensor-measured magnetic field data into customer-desired linear output. This can be used to correct minor imperfections in the encoder signal.

Linearization converts the electrical angles (the angle as measured by the sensor front end) into mechanical angles (the actual angle of the encoder signal).

To use the linearization feature, it is most convenient to use the Allegro AAS33051 Samples Programmer Graphical User Interface (GUI). It allows the user to measure points along the mechanical rotation, calculate all parameters that need to be written into the sensor, and write these values into the sensor. To use this function, the user must be able to read and control the mechanical angle.

The sensor performs linearization by taking the measured electrical angles and, depending on the angle measured, subtracting a linearization coefficient stored in EEPROM. There are 32 of these linearization coefficients in the EEPROM. The angle value at a sensor angle reading of 0.00, 11.25, 22.50, ... 348.75 electrical degrees are to be modified by the values in EEPROM fields LIN0, LIN1, LIN2, ... LIN31. The EEPROM LIN values are subtracted from the electrical sensor angles, as shown in Table 4.

The LIN fields are 12-bit signed values. Each LIN coefficient has a range of -2048 through 2047 LSB, which corresponds to a correction of the electrical angle by 22.50 through -22.49 degrees (EEPROM field LS = 0) or by 45.00 through -44.98 degrees (EEPROM field LS = 1). When the electrical angle is between two of the linearization points, the sensor calculates the appropriate correction value for this angle by linear interpolation between the two coefficients next to the value. For example, if the sensor measures an angle of  $5.625^{\circ}$ , the output is 5.625 - (LIN0 + LIN1) / 2.

An example showing a nonlinear curve that is corrected by the sensor is provided in Figure 4. In this example, the values of LIN0, LIN1, LIN2, and LIN3 are negative numbers, while LIN4 is a positive number. The linearized output angle in the example is close to the mechanical angle, but not perfect. This was done deliberately for the purpose of showing a more-realistic example.

The output delay of the AAS33051 is not affected by enabling or disabling linearization. If linearization is disabled, the EEPROM LIN fields can be used for other customer purposes.

The data path employed to track rotation of the field in the low-power mode is not linearized. In low-power mode, the sensor automatically wakes up at a programmable angle change rate.

With default settings, it stays in the wake mode at speeds exceeding 100 rpm. Because the angle used to determine the wake-up event is not linearized, the sensor wake-up behavior is determined by the change of the nonlinearized electrical angle, not by the change of the linearized angle or the mechanical angle.

**Table 4: Linearization Coefficients** 

| Electrical<br>Angle (°)<br>Measured By<br>Sensor | Correction<br>Value<br>Written In<br>EEPROM | Output<br>Angle<br>Visible<br>On Sensor Output |  |  |
|--------------------------------------------------|---------------------------------------------|------------------------------------------------|--|--|
| 0.00                                             | LIN0                                        | Output = 0.00 – LIN0                           |  |  |
| 11.25                                            | LIN1                                        | Output = 11.25 – LIN1                          |  |  |
| 22.50                                            | LIN2                                        | Output = 22.50 – LIN2                          |  |  |
| 33.75                                            | LIN3                                        | Output = 33.75 – LIN3                          |  |  |
| 45.00                                            | LIN4                                        | Output = 45.00 - LIN4                          |  |  |
| 56.25                                            | LIN5                                        | Output = 56.25 – LIN5                          |  |  |
| 67.50                                            | LIN6                                        | Output = 67.50 – LIN6                          |  |  |
| 78.75                                            | LIN7                                        | Output = 78.75 – LIN7                          |  |  |
| 90.00                                            | LIN8                                        | Output = 90.00 - LIN8                          |  |  |
| 101.25                                           | LIN9                                        | Output = 101.25 - LIN9                         |  |  |
| 112.50                                           | LIN10                                       | Output = 112.50 - LIN10                        |  |  |
| 123.75                                           | LIN11                                       | Output = 123.75 – LIN11                        |  |  |
| 135.00                                           | LIN12                                       | Output = 135.00 - LIN12                        |  |  |
| 146.25                                           | LIN13                                       | Output = 146.25 – LIN13                        |  |  |
| 157.50                                           | LIN14                                       | Output = 157.50 - LIN14                        |  |  |
| 168.75                                           | LIN15                                       | Output = 168.75 – LIN15                        |  |  |
| 180.00                                           | LIN16                                       | Output = 180.00 - LIN16                        |  |  |
| 191.25                                           | LIN17                                       | Output = 191.25 – LIN17                        |  |  |
| 202.50                                           | LIN18                                       | Output = 202.50 - LIN18                        |  |  |
| 213.75                                           | LIN19                                       | Output = 213.75 – LIN19                        |  |  |
| 225.00                                           | LIN20                                       | Output = 225.00 - LIN20                        |  |  |
| 236.25                                           | LIN21                                       | Output = 236.25 - LIN21                        |  |  |
| 247.50                                           | LIN22                                       | Output = 247.50 - LIN22                        |  |  |
| 258.75                                           | LIN23                                       | Output = 258.75 – LIN23                        |  |  |
| 270.00                                           | LIN24                                       | Output = 270.00 - LIN24                        |  |  |
| 281.25                                           | LIN25                                       | Output = 281.25 – LIN25                        |  |  |
| 292.50                                           | LIN26                                       | Output = 292.50 - LIN26                        |  |  |
| 303.75                                           | LIN27                                       | Output = 303.75 – LIN27                        |  |  |
| 315.00                                           | LIN28                                       | Output = 315.00 - LIN28                        |  |  |
| 326.25                                           | LIN29                                       | Output = 326.25 – LIN29                        |  |  |
| 337.50                                           | LIN30                                       | Output = 337.50 - LIN30                        |  |  |
| 348.75                                           | LIN31                                       | Output = 348.75 – LIN31                        |  |  |





Figure 4: Linearization Example

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

The AAS33051 offers an incremental output mode in the form of quadrature A/B and index (I) 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 2N cycles per magnetic revolution, giving a cycle resolution of  $(360 / 2^N)$  degrees per cycle. B is offset from A by  $\frac{1}{4}$  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 5.

Because A and B are offset by 1/4 of a cycle, they are in quadrature and together have four unique states per cycle. Each state represents  $R = [360 / (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:

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

Note that the A/B progression is a grey 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$  Q3  $\rightarrow$  Q2  $\rightarrow$  Q1

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 ter-



Figure 5: One Full Revolution



# **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

minology used to express variance from perfect signal behavior. Ideally, the A and B cycle are as shown in Figure 6 for a constant velocity.

In reality, the edge rate of the A and B signals, and the switching threshold of the receiver inputs/outputs (I/Os), affect the quadrature periods (see Figure 7).



Figure 6: Electrical Cycle



Figure 7: Electrical Cycle



# **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

### **RESOLUTION**

The AAS33051 supports the following ABI output resolutions.

This is set via the RESOLUTION\_PAIRS field in EEPROM.

Table 5: ABI Output Resolution

| EEPROM<br>Resolution<br>Field | Cycle<br>Resolution<br>(Bits = N) | Quadrature<br>Resolution<br>(Bits = 4 × N) | Cycles per<br>Revolution<br>(A or B) | Quadrature<br>States per<br>Revolution | Cycle Resolution<br>(Degrees) | Quadrature<br>Resolution (R)<br>(Degrees) |  |  |
|-------------------------------|-----------------------------------|--------------------------------------------|--------------------------------------|----------------------------------------|-------------------------------|-------------------------------------------|--|--|
| 0                             | Factory Use Only                  |                                            |                                      |                                        |                               |                                           |  |  |
| 1                             |                                   | Factory Use Only                           |                                      |                                        |                               |                                           |  |  |
| 2                             |                                   |                                            | Factory                              | Use Only                               |                               |                                           |  |  |
| 3                             | 11                                | 13                                         | 2048                                 | 8192                                   | 0.176                         | 0.044                                     |  |  |
| 4                             | 10                                | 12                                         | 1024                                 | 4096                                   | 0.352                         | 0.088                                     |  |  |
| 5                             | 9                                 | 11                                         | 512                                  | 2048                                   | 0.703                         | 0.176                                     |  |  |
| 6                             | 8                                 | 10                                         | 256                                  | 1024                                   | 1.406                         | 0.352                                     |  |  |
| 7                             | 7                                 | 9                                          | 128                                  | 512                                    | 2.813                         | 0.703                                     |  |  |
| 8                             | 6                                 | 8                                          | 64                                   | 256                                    | 5.625                         | 1.406                                     |  |  |
| 9                             | 5                                 | 7                                          | 32                                   | 128                                    | 11.250                        | 2.813                                     |  |  |
| 10                            | 4                                 | 6                                          | 16                                   | 64                                     | 22.500                        | 5.625                                     |  |  |
| 11                            | 3                                 | 5                                          | 8                                    | 32                                     | 45.000                        | 11.250                                    |  |  |
| 12                            | 2                                 | 4                                          | 4                                    | 16                                     | 90.000                        | 22.5                                      |  |  |
| 13                            | 1                                 | 3                                          | 2                                    | 8                                      | 180.0                         | 45.0                                      |  |  |
| 14                            | 0                                 | 2                                          | 1                                    | 4                                      | 360.0                         | 90.0                                      |  |  |
| 15                            | n/a                               | n/a                                        | n/a                                  | n/a                                    | n/a                           | n/a                                       |  |  |



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### **SLEW-RATE LIMITING**

Slew-rate limiting is enabled when the ABI.ABI\_SLEW\_TIME field is non-zero. This option separates the sample update rate 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
- typical sample rate output resumes. This skipping is most likely to 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 1 µs. The slew limit time can be set greater than the nominal angle-sample update period, providing the velocity of the angle rotation does not, on average, require ABI transitions greater than the angle-sample rate.



Figure 8: Slew Rate Limiting



# **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

#### **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 position, 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 in Figure 9.



Figure 9: Index Pulse



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

The AAS33051 offers U, V, and W signals for stator commutation of brushless DC (BLDC) motors. The device is mode-selectable 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 the angle sensor. The U, V, and W outputs

switch when the measured mechanical angle crosses the value where a change should occur. If hysteresis is used, the output update method is different. The output behavior when hysteresis is enabled is described in the Angle Hysteresis section. The UVW waveforms for three- and five-pole-pair BLDC motors are shown in Figure 10 and Figure 11.



Figure 10: U, V, W Outputs for Three-Pole-Pair BLDC Motor



Figure 11: U, V, W Outputs for Five-Pole-Pair BLDC Motor



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

| Quantity of Poles  | Quantity of Pole-Pairs | Conversion from Electrical<br>Degrees to Mechanical Degrees |                |  |  |
|--------------------|------------------------|-------------------------------------------------------------|----------------|--|--|
| (RESOLUTION_PAIRS) | Pole-Pairs             | Electrical (°)                                              | Mechanical (°) |  |  |
| 0000               | 1                      | 90                                                          | 90             |  |  |
| 0001               | 2                      | 90                                                          | 45             |  |  |
| 0010               | 3                      | 90                                                          | 30             |  |  |
| 0011               | 4                      | 90                                                          | 22.5           |  |  |
| 0100               | 5                      | 90                                                          | 18             |  |  |
| 0101               | 6                      | 90                                                          | 15             |  |  |
| 0110               | 7                      | 90                                                          | 12.857         |  |  |
| 0111               | 8                      | 90                                                          | 11.25          |  |  |
| 1000               | 9                      | 90                                                          | 10             |  |  |
| 1001               | 10                     | 90                                                          | 9              |  |  |
| 1010               | 11                     | 90                                                          | 8.1818         |  |  |
| 1011               | 12                     | 90                                                          | 7.5            |  |  |
| 1100               | 13                     | 90                                                          | 6.9231         |  |  |
| 1101               | 14                     | 90                                                          | 6.4286         |  |  |
| 1110               | 15                     | 90                                                          | 6              |  |  |
| 1111               | 16                     | 90                                                          | 5.625          |  |  |



### **ABI Behavior at Power-Up**

At power-up, the AAS33051 ABI interface communicates the current position. This means that reading the angle through the PWM output is not needed to find the current position when using the ABI interface. The behavior at start-up is the following:

- During tpO, the state of the interface is undefined
- During a delay phase, the output displays a  $0^{\circ}$  angle. With default settings, the  $0^{\circ}$  angle is indicated by A = B = low and I = high.
- The interface catches 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_{SETTLE(MAX)} = \frac{180^{\circ}}{R} \times ABI\_slew\_time$$

where R is the quadrature resolution.

 After catching up, with the output angle is complete, the sensor operates as typical.

If ABI\_SLEW\_TIME is set to 0, there is no catch-up phase. The output jumps to the final position immediately, e.g., with A = high and B = low. With ABI\_SLEW\_TIME set to 0, the user cannot determine the position at startup from the ABI interface.



Figure 20: ABI Startup Behavior



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **Angle Hysteresis**

Hysteresis can be applied to the compensated angle to moderate jitter in the angle output due to noise or mechanical vibration. In the AAS33051, the hysteresis field (ANG.HYSTERESIS) defines the width of an angle window at 14-bit resolution. Mathematically, the width of this window is:

ANG.HYSTERESIS × (360 / 16384) degrees

giving a range of 0 to 1.384 degrees.

The hysteresis-compensated angle can be routed to the ABI or UVW interface by setting the ABI.AHE bit to 1. On the SPI or Manchester interface, the hysteresis-compensated angle can be read via an alternate register (HANG.ANGLE\_HYS) at 12-bit resolution.

The effect of the hysteresis is shown in Figure 12. 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 output angle is the sensor angle, minimizing latency. If the sensor angle reverses direction, the output 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 viewable via the STA.ROT bit, where 0 is in the increasing-angle direction and 1 is in the decreasing-angle direction.

This behavior has the following consequences:

- If the hysteresis window is greater than the output resolution, the output angle skips consecutive incremental steps. If the hysteresis-compensated angle is selected for the ABI output, this results in an integrity failure due to skipped quadrature states. To avoid this, it is recommended that the slew-rate limiting be enabled on the ABI interface if hysteresis is used.
- 2. If there is jitter due to noise or mechanical vibration, especially at a static angle position or very slow rotation, the angle tends 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.



### **Electrical Angle**



Figure 12: Effect of Hysteresis

Note: The rotation direction resets to 0, or increasing-angle direction. At power-up or exiting low-power mode, or after LBIST, the hysteresis window always lags behind the initial angle position; therefore, if hysteresis is enabled, a decreasing-angle direction of rotation is not registered until the hysteresis window has passed.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **Low-Power Mode**

Low-power mode is an automatic duty-cycling between a reduced-power angle-sampling wake state and a minimal-power sleep state. Low-power mode is only entered if a set of conditions is met:

- The WAKE pin must be low, AND
- The SPI pins must be low, AND
- The change of the magnetic-field direction must be less than the programmed threshold, AND
- The command to enter the low-power mode must have been provided.

When keeping WAKE and SPI pins low, the AAS33051 leaves and re-enters low-power mode repeatedly based on comparing the angle change to the maximum permitted angle change. This allows tracking the angular position with high speed (when needed) and minimized power consumption (when possible) without user commands to enter/leave the low-power mode.

In the sleep state, the sensor counts the time until it needs to wake up again, but does not sample angles. No output is provided as to whether the sensor is currently sampling or sleeping. However, the alive-count serial register is incremented at each wake/sleep cycle. Reading the alive-count allows the user to verify that the system was still operating and sampling angles while it was in low-power mode.

In case the change of angle between successive samples is larger than a set threshold, or in case a high voltage on the wake pin was detected, low-power mode is left automatically and the sensor transitions to full-power mode.

#### STATE TRANSITIONS WITHIN LOW-POWER MODE

The SPI input pins are used as the primary arbiter of low-power mode. When the inputs of all three pins (MOSI, SCLK, CSN) are pulled low for at least  $64~\mu s$ , the sensor enters a semi-low-power state in which the PLL and some other logic are disabled (including SPI and Manchester), the I/O regulator is turned off, and the ABI and PWM pins are tristated. Only the low-power anglesensing path is enabled in order to update the turns-counter and measure the angular velocity. This state is called the wake state.

In the wake state, the WAKE pin and the velocity are monitored. Once the WAKE pin is low (de-asserted) and the velocity is less than the threshold set in the EEPROM, the sensor enters sleep. The low-frequency oscillator remains on, with a counter for the sleep period (LPM\_CYCLE\_TIME) and logic to detect SPI/WAKE pins going high active. Expiration of the counter, or assertion of the WAKE pin signal, returns the sensor to the wake state to update the turns-counter and measure the velocity based on change in angle from entering the sleep state. If the velocity exceeds the threshold or the WAKE pin is active, the sensor remains awake and continues to update the turns-counter.

The SPI pins must change from the all-zero state to resume the typical operation mode; this is followed by a settle time for the PLL to lock before the angle output and temperature update is resumed.

All determinations about entering the sleep state are made at the end of the LPM\_CYCLE\_TIME, which runs continuously, regardless of sensor state. Therefore, the sensor can enter sleep only on those time boundaries.

The general flow of the low-power mode is diagrammed in Figure 13.





Figure 13: Low-Power Mode Flowchart



# **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

When using the default settings, the diagram can be simplified to the one shown in Figure 14.



Figure 14: Simplified Low-Power Flowchart, Default Settings



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **WAKE PIN**

It is possible for the sensor to enter the wake state using the WAKE pin. This may be connected to a digital output from a microcontroller, or to an analog signal generated from backscatter from the coils of an electric motor. Keep in mind that it remains possible for angle-change processing in low-power mode to trigger automatic wake-up, so use of the WAKE pin is often not

required for automatic wake-up. In applications where sudden ≥180° rotations could occur, the WAKE pin can be employed to remove this risk.

A sample input circuit is given in Figure 15.

The threshold at which the WAKE pin should signal a power-on is programmable in EEPROM using the field WP\_THRES. The hysteresis of the pin can be selected using the field WP\_HYS.



Figure 15: Sample Filtering Circuit



### **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 car 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 AAS33051 includes a circuit that counts the rotational turns of a magnet. When sensor ICs are connected to the car battery, they must also have low-power modes that enable efficient battery usage. The AAS33051 is able to go into a low-power state and still monitor and keep track of rotations. This ensures that the system can accurately and consistently track steering wheel position or seat-belt extension when using the AAS33051 in a key-on or key-off mode. Traditionally, this key-off requirement is achieved by a combination of relatively complex mechanical and electronic components. The AAS33051 can reduce system-level complexity and eliminate many system components by performing both the absolute angle measurement and the tracking of TCs, while maintaining low battery power consumption at vehicle key-off.

In low-power mode, the turns-counter is updated using a low-power signal path. The design minimizes the amount of logic that is drawing power during the low-power awake periods, allowing for efficient turns-count tracking during battery-operated low-power modes. The turns-counter logic tracks the exact accumulated change in angle. Due to its emphasis on low power, the signal path that tracks the total turns does not implement the same angle compensation as the primary signal path. However, after the sensor returns to full-power operation, the source for the turns-counter data changes back to the more-accurate full-power signal path. Because of this, the user does not witness the reduced

accuracy in the low-power signal path. Using the EEPROM setting TCP = 1, the turns-counter uses the full-power high-accuracy path when available. This setting is recommended.

For backward compatibility with the A1339, it is possible to use the low-power signal path as the only turns-counter source by setting the TCP field in EEPROM to 0.



Figure 16: Turns-Counting

To read the total position of the magnetic encoder (angle in 12-bit resolution, as well as additional revolutions in 9 bits, sign-extended to 12 bits), two serial register are provided in TD\_HIGH and TD\_LOW. This 24-bit word accumulates the total changes in angle. When reading TD\_HIGH, the contents of TD\_LOW are locked. This ensures that the values of the two words match. To get a correct reading of the entire turns delta, the customer must read TD\_HIGH then TD\_LOW.

An example for reading TURNS DELTA is given in Figure 17.



Figure 17: Reading TURNS\_DELTA



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

The reads from register 0x36 (TD\_HIGH) and 0x38 (TD\_LOW) return the words 0x7005 and 0x6664. Taking the 12 LSB from each word and combining these gives value 0x005664, which equals 22116, or  $[22116 \times (360 / 4096)] = 1943.78^{\circ}$  of total rotation.

Negative numbers are output in two's complement. The example in Figure 18 shows a read of a negative TURNS DELTA value.



Figure 18: Read of a Negative TURNS\_DELTA Value

Again, taking the last 12 bits of each transaction, the TURNS\_DELTA value is 0xFFE5DB. This value is converted from two's complement by treating the first bit as a negative value and the other 23 bits as positive values. In decimal, the TURNS\_DELTA value equals (0x800000 + 0x7FE5DB) = (-8388608 + 8381915) = -6693. This equals an angle of  $[-6693 \times (360 / 4096)] = -588.25^{\circ}$ .

The initial value of the register (zero, or current angle, or current angle with TURNS\_COUNT zeroed) can be controlled using the EEPROM field TURNS\_INIT, as detailed in Figure 19.



Figure 19: TURNS\_DELTA Value at Startup,
Depending on TURNS\_INIT

If the customer wants to restore the old value of TURNS\_ DELTA after a power-on reset, then TURNS\_INIT should be set to 10.

The serial register TURNS presents the highest value bits of the TURNS\_DELTA. It saturates at 2047 and -2048 in the 45-degree mode and at 511 and -512 in the 180-degree mode. If this happens, the turns-count overflow flag asserts and remains asserted until the turns-counter is reset via the control register (see the Primary Serial Interface Registers Reference section).

During low-power mode, the AAS33051 periodically measures the magnet position and updates the turns-count based on the angular change from the previous angle measurement. If the angle changes by  $\geq 180$  degrees, the direction change is ambiguous and is interpreted as a rotation in the opposite direction. Any sample-to-sample delta greater than 135 degrees sets the turns-count warning flag. This is intended to give some indication of the velocity relative to the low-power-mode cycle time. During the sleep period, the velocity must be sufficiently fast for the angle delta to approach the 180-degree point of ambiguity.



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **Setting the Turns-Count Value**

There are two ways to modify the value of the turns-counter:

- Using the turns-counter reset function
- Writing the TURNS\_DELTA value to register EWD, and loading it into TURNS\_DELTA

### **INVOKING A TURNS-COUNTER RESET**

A reset of the turns-counter is a command invoked using the field CTRL.SPECIAL. For details, refer to the CTRL.SPECIAL field in the Primary Serial Interface Registers Reference section.

## CHANGING OR RESTORING THE TURNS\_DELTA VALUE

It is possible to load a desired value into the turns-counter register. This may be useful if a certain externally stored value becomes set again following a power loss. The turns-counter register itself cannot be written directly. Instead, the writing action is an indirect one using the following steps:

- 1. Writing should only be when the system is stable, as indicated by the STA.AOK bit field.
- 2. Write the desired 21-bit value of TURNS\_DELTA into the serial registers EWDH and EWDL. Example:
  - A. To set TURNS\_DELTA to value  $10441.32^{\circ}$  (29 rotations and  $1.32^{\circ}$  current angle), write  $(10441.32 / 360) \times 4096 = 118799 = 0x01D00F$ .
  - B. Write the lower 16 bits into register EWDL, and the higher 5 bits into EWDH. Put 11 zeros in front of the TURNS\_DELTA value to get a full 16 bits to write. This results in writing 0x0001 to register 0x04:0x05 (EWDH) and writing 0xD00F to register 0x06:0x07 (EWDL).

- 3. Write the value 0x3 to the field CTRL.SPECIAL and write 0x46 to the field CTRL.INITIATE SPECIAL.
- 4. The sensor behavior to process the command depends on the setting of the TURNS INIT EEPROM field:
  - A. When TURNS\_INIT = 00 or 01, the value is copied to TURNS\_DELTA, and subsequent angle changes accumulate on top of this value. Using this is not recommended for scenarios in which one wants to restore a saved value, because small offset changes/noise errors result in an increasing error every time such a write is performed.
  - B. When TURNS\_INIT = 10 or 11, the value is compared to the currently sensed angle. The TURNS\_DELTA field snaps to the closest value matching the sensed angle. Errors in position of <180° are removed this way. This method is recommended for scenarios in which one wants to restore a saved TURNS\_DELTA value. If the angle has drifted a little before writing back, it is corrected by the sensor, and a correct TURNS\_DELTA value remains present, even after many turns-counter restorations.

### **Transport Mode**

Transport mode is effectively low-power mode, but with the low-frequency oscillator disabled and the WAKE pin disabled. To invoke transport mode, the serial CTRL.SPECIAL field is set to 0x6, then when low-power mode is enabled (SPI inputs low for  $> 64 \mu s$ ), transport mode is entered.

As soon as one of the incoming SPI lines is high, the AAS33051 wakes up. Transport mode can be disabled using the customer EEPROM setting TPMD.





### **DEVICE PROGRAMMING INTERFACE**

The AAS33051 can be programmed in two ways:

- Using the *SPI interface* for input and output, while supplying the VCC pin with typical operating voltage
- Using a *Manchester protocol* on the supply pin for input, and the PWM pin for output.

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

All setting fields and all data fields of the sensor can be read and written using both protocols. If EEPROM locking is used (detailed in the EEPROM Write Lock section), write access using either of the protocols is prevented.

A separate setting to completely disable the Manchester interface is available in the DM field of the EEPROM. Using this setting causes the sensor to ignore any commands entered using Manchester protocol. The SPI interface does not become disabled by disabling the Manchester interface.

### **Interface Structure**

The AAS33051 consists of two memory blocks. The primary serial interface registers are used for direct writes and reads by the host controller for frequently required data (for example, angle data, warning flags, field strength, and temperature). All forms of communication (even to the extended locations) operate through the primary registers, whether that be via SPI or Manchester.

The primary serial registers also provide a data and address location for accessing extended memory locations. Accessing these extended locations is performed 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 21.

For writing extended locations, the primary interface offers extended write address, data, and control registers. Refer to the section Write Transaction to EEPROM and Other Extended Locations for details about their usage.

For reading extended locations, the primary interface offers extended read address, data, and control registers. Refer to the section Read Transaction from EEPROM and Other Extended Locations for details about their usage.

EEPROM writing requires additional procedures. For more information about EEPROM and shadow memory read and write access, see EEPROM and Shadow Memory Usage section.

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



Figure 21: Serial Registers Allow Access to Extended Memory (EEPROM and Shadow)



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **SPI Interface**

The AAS33051 provides a full-duplex 4-pin SPI interface for each die, using SPI mode 3 (CPHA = 1, CPOL = 1). All programming can be performed using this interface; all programming can also be performed using the Manchester interface.

In addition to providing a communications interface, the SPI interface is used to control the entering and leaving of the low-power and transport modes. If the SPI interface is not used, do not leave the chip-select line floating; instead, follow the recommendations in the Typical SPI and ABI/UVW Applications section.

The sensor responds to commands received on the controller-output peripherl-input (MOSI), serial clock (SCLK), and chipselect (CSB) pins, and outputs data on the controller-input peripheral-output (MISO) pin. All three input pins are 3.3 V and 5 V SPI compatible, with threshold values determined by factory EEPROM settings. The MISO output voltage level conforms to 3.3 V or 5 V SPI levels, based on factory settings. Regular parts are shipped with 3.3 V interface. Contact Allegro for ordering options of the 5 V variant.

The setup for communication using the SPI interface is given in Figure 22.



Figure 22: Programming Connections for SPI Interface

#### TIMING

The interface timing parameters from the specification table are defined in Figure 23 and Figure 24.



Figure 23: SPI Interface Timings Input



Figure 24: SPI Interface Timings Output



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### **MESSAGE FRAME SIZE**

The SPI interface requires 16-, 17-, or 20-bit packet lengths. An extended 20-bit SPI packet allows 4 bits of CRC to accompany every data packet. A 17-bit packet is only allowed if the EEPROM/shadow bit S17 is set to 1.



Figure 27: 20-Bit SPI Frame

If more clock pulses than expected were detected by the sensor in an SPI transaction, the interface warning WARN.IER activates. This warning does not activate for clean SPI transactions with 16 or 20 bits, or with clean 17-bit transactions when S17 is enabled.

The purpose of the 17-bit SPI option is to allow delayed reading of the MISO line by the host. Some hosts allow sampling of data from the peripheral not on the rising edge, but on the next falling edge of SCLK. This way, in case of long interface delays caused by large line capacitance or very long cables, the permissible clock speed can be increased. However, a 17th falling edge is required to read the 16th bit coming from the sensor. For the sensor to not display an error when this 17th clock is found, the bit S17 must be set.

#### **WRITE CYCLE**

Write cycles consist of 1 low bit, 1 read/write (R/W) bit (write = high), 6 address bits (corresponding to the primary serial register), 8 data bits, and 4 optional CRC bits. To write a full 16-bit serial register, two write commands are required (even and odd byte addresses). MOSI bits are clocked-in on the rising edge of the controller-generated SCLK signal.

#### **READ CYCLE**

Reading data always involves at least two SPI frames. In the first frame, the read command is sent; in the second frame, the result from the first read is received. While receiving data from the last read command, it is possible to send another read command (duplexed read). This way, every frame except the first one contains data from the sensor. This is useful for very fast reading of angle data

When receiving the last frame, the host can transmit a command with MOSI set to all zeros. This represents a read command from register 0x00 and does not change the state of the sensor. Reading from register 0x00 outputs the value 0x0000.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

In frames where a previous read command was not sent, the MISO data output should be ignored.

Because an SPI read command can transmit 16 data bits at one time, and the primary serial registers are built from one even and one odd byte, the entire 16-bit contents of one serial register may be transmitted with one SPI frame. This is accomplished by providing an even serial address value. If an odd value address

is sent, only the contents of the single byte are returned, with the eight most significant bits within the SPI packet set to zero. Example: To read all 16 bits of the error register (0x24:0x25), an SPI read request using address 0x24 should be sent. If only the 8 LSBs are desired, the address 0x25 should be used. Examples of both an SPI write and an SPI read request, using a 16-bit SPI message frame, are shown in Figure 28.



Figure 28: SPI Read and Write Pulse Sequences



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### CRC

If the user wants to check the data coming from the sensor, it is possible to use 20-bit SPI frames. Without additional setting required, a 4-bit CRC is automatically generated and placed on the MISO line if more than 16 bits are read from the sensor.

The four additional CRC bits on the MOSI line coming from the host are ignored by the sensor, unless the PWI.SC bit is set within EEPROM. When the incoming CRC check is enabled, an incoming SPI packet with an incorrect CRC is discarded, and the CRC error flag set in serial register WARN.CRC.

The CRC is based on the polynomial  $x^4 + x + 1$  with the linear feedback shift register preset to all 1s. The 16-bit packet is shifted through, from bit 15 (MSB) to bit 0 (LSB). The CRC logic is shown in Figure 22. Data are fed into the CRC logic with MSB first. Output is sent as C3-C2-C1-C0.



Figure 29: SPI CRC

The CRC output by the sensor on the MISO pin is always calculated correctly. The CRC from the host on the MOSI pin must be correct if the CRC enable bit PWI.SC in the EEPROM is set.

NOTE: If the extended read data (ERD) register is read before the ERCS.ERD bit indicates a read has completed, there is a possibility of a CRC error, because the data could change during the read. Do not read the ERD register until it is known to be stable based on the completed-bit indication or waiting sufficient time.

The CRC can be calculated with the following C code:

```
CalculateCRC
  Take the 16-bit input and generate a 4-bit CRC
* Polynomial = x^4 + x + 1
* LFSR preset to all 1s
uint8_t CalculateCRC(uint16_t input)
 bool CRC0 = true;
 bool CRC1 = true;
 bool CRC2 = true;
 bool CRC3 = true;
 int i;
 bool DoInvert;
 uint16_t mask = 0x8000;
 for (i = 0; i < 16; ++i)
 DoInvert = ((input & mask) != 0) ^ CRC3; // XOR required?
 CRC3 = CRC2;
 CRC2 = CRC1;
 CRC1 = CRC0 ^ DoInvert;
 CRC0 = DoInvert;
 mask >>= 1;
 return (CRC3 ? 8U : 0U) + (CRC2 ? 4U : 0U) + (CRC1 ? 2U :
0U) + (CRC0 ? 1U : 0U);
```

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



## Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **Manchester Interface**

To facilitate addressable device programming when using the unidirectional PWM output mode with no need for additional wiring, the AAS33051 incorporates a serial interface on the VCC line. All programming can be performed using this interface; all programming can also be performed using the SPI interface.

This interface allows an external controller to read and write registers in the AAS33051 EEPROM and volatile memory. The device uses a point-to-point communication protocol, 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 addressable Manchester code implementation uses the logic states of the CSN/MOSI pins to set address values for each die. In this way, individual communication with up to four AAS33051 dies is possible. Using a broadcast Manchester command, any die receiving the command responds. To prevent any undesired programming of the AAS33051, the serial interface can be disabled by setting the disable Manchester bit, PWI.DM, to 1. With this bit set, the sensor ignores any Manchester input on VCC.

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



Figure 30: Manchester Interface Programming Setup

### CONCEPT OF MANCHESTER COMMUNICATION

The Manchester interface allows programming and readout with a minimal number of pins involved. This is beneficial for sensor subassemblies connected to wiring harnesses because fewer connections are needed. The supply level is typically modulated between 5 V and 8 V (V<sub>MAN(H)</sub> and V<sub>MAN(L)</sub>) to produce a low signal and a high signal. In the absence of a clock signal, Manchester encoding is used, allowing the sensor to determine the bit rate that the host is using.

The controller can freely choose any supported Manchester communication frequency for each transaction. The sensor recognizes the transaction speed used by the controller and sends the response at the same data rate.

As Manchester commands are sent on the supply line, the speed is usually limited by capacitances on the supply line. A reduction of the bit rate, or using a stronger line driver, can help to ensure stable communication.

If a correct read command is sent, the sensor responds to the controller using the open-drain output on the PWM line. The high level is determined by the PWM pull-up (usually 3.3 V or 5 V), and the low level is close to GND. The PWM uses an open-drain output, setting the logic levels to GND and logic-level high (see Figure 30). A sufficient pull-up resistor (e.g.,  $4.7 \ \mathrm{k}\Omega$ ) must be used to pull the line to a maximum logic-high level  $V_{\mathrm{IN}}$ .

#### **ENTERING MANCHESTER COMMUNICATION MODE**

Provided the disable Manchester bit is not set in EEPROM, the AAS33051 continuously monitors the VCC line for valid Manchester commands. The part does not take action until a valid Manchester access code is received.

There are two special Manchester code commands used to activate or deactivate the serial interface and to specify the output format used during read operations:

- 1. Manchester Access Code: Enters Manchester communication mode; Manchester code output on the PWM pin. For an example, see the Manchester Access Code section.
- Manchester Exit Code: Returns the PWM pin to typical operation. For an example, see the Manchester Exit Code section.

Once the Manchester communication mode is entered, the PWM output pin ceases to provide angle data, interrupting any data transmission in progress.

### TRANSACTION TYPES

The AAS33051 receives all commands via the VCC pin and responds to read commands via the PWM pin. This implementation of Manchester encoding requires the communication pulses be within a high ( $V_{MAN(H)}$ ) and low ( $V_{MAN(L)}$ ) range of voltages on the VCC line. Each transaction is initiated by a command from the controller; the sensor does not initiate any transactions. Two commands are recognized by the AAS33051: write and read.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### CONTROLLER MANCHESTER MESSAGE STRUCTURE

The general format of a command message frame is shown in Figure 31. Note that, in the Manchester coding used, 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.





Figure 31: Manchester Message Format

A brief description of the bit fields is provided in Table 6.

**Table 6: Manchester Message Bit Fields** 

| Bits | Parameter Name  | Description                                                                                                                                                         |
|------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | Synchronization | Value 00 sent to identify a command start and to synchronize sensor clock                                                                                           |
| 1    | Read/Write      | 0 = write, 1 = read                                                                                                                                                 |
|      | Target ID       | Select the target ID for this transaction. [ID3 ID2 ID1 ID0] are each addressed/ignored by a 1/0 at their address, so that a write to [0011] writes to ID0 and ID1. |
| 4    |                 | Reading from several sensors at the same time results in corrupted outputs if the output pins are tied together.                                                    |
|      |                 | Writing to [0000] is a broadcast write; it is written to all sensor dies.                                                                                           |
| 6    | Address         | Serial address for read/write                                                                                                                                       |
| 16   | Data            | Only for writes: 16 bit write data. Omit for read commands                                                                                                          |
| 3    | CRC             | 3-bit CRC, needed for all commands                                                                                                                                  |

When the AAS33051 is operating in PWM mode, the die ID value is determined by the state of the CSN and MOSI pins, as detailed in Table 7.

Table 7: Pin Values

| MOSI | cs | ID Value |  |  |  |  |
|------|----|----------|--|--|--|--|
| 0    | 0  | ID0      |  |  |  |  |
| 0    | 1  | ID1      |  |  |  |  |
| 1    | 0  | ID2      |  |  |  |  |
| 1    | 1  | ID3      |  |  |  |  |

Using the 4 bits of the chip-select field, die can be selected via their ID value, allowing up to four die to be individually addressed and providing for different group addressing schemes.

Example: If target ID =  $[1\ 0\ 1\ 0]$ , all die with ID3 or ID1 are selected. If target ID is set to  $[0\ 0\ 0\ 0]$ , an ID comparison is not performed, allowing all sensors to be addressed at once. In case of PWM line-sharing for Manchester communication, reading must be performed one die at a time.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### SENSOR MANCHESTER MESSAGE STRUCTURE

If a read command with the desired register number is sent from the controller to the sensor, the device responds with a read response frame using the Manchester protocol over the PWM output.

The following command messages can be exchanged between the device and the external controller:

- Manchester access code (host to sensor)
- Manchester exit code (host to sensor)
- Manchester write command (host to sensor)
- Manchester read command (host to sensor)
- Manchester read response (sensor to host)

In addition to the contents of the requested memory location, a return status field is included with every read response. This field provides the ID used to communicate with the part and any errors that may have occurred during the transaction. These bits are:

- **ID:** ID (CSN/MOSI) unless BC = 1 (ID is 00)
- BC: Broadcast; ID field was zero or SPI mode active
- AE: Abort error; edge-detection failure after synchronization detection
- **OR:** Overrun error; a new Manchester command has been received before the previous request could be completed
- CS: Checksum error; a prior command had a checksum error

For EEPROM address information, refer to the EEPROM and Shadow Register Table. For serial address locations, refer to the Primary Serial Interface Registers Reference section.

## **MANCHESTER ACCESS CODE**

The Manchester access code must be sent before other Manchester commands.

The Manchester access code always operates as a broadcast pulse, meaning the sensor does not look at the target ID field. For example, if two sensors configured with ID0 and ID1 respectively are sharing a common VCC line, a Manchester access code with a target ID value of [0 0 1 0] results in both sensors entering Manchester serial communication mode.

**Table 8: Manchester Access Code** 

| Bits | Parameter Name  | Description                                                        |
|------|-----------------|--------------------------------------------------------------------|
| 2    | Synchronization | 00                                                                 |
| 1    | Read/Write      | 0                                                                  |
| 4    | Target ID       | 0000 (this command is always a broadcast, even if it is addressed) |
| 6    | Address         | 111111 (fixed number for Manchester access message)                |
| 16   | Data            | 0x62D2 (fixed number for Manchester access message)                |
| 3    | CRC             | 3-bit CRC                                                          |

An example is shown in Figure 32 with target ID =  $[0\ 0\ 0\ 1]$ , data = access code = 0x62D2, and CRC = 110.



Figure 32: Target ID = [0 0 0 1], Data = Access Code = 0x62D2, CRC = 110



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### MANCHESTER EXIT CODE

The Manchester exit code can be sent after Manchester access is complete in order to avoid accidental decoding of Manchester commands.

The Manchester exit code always operates as a broadcast pulse, meaning the sensor does not look at the target ID field. For example, if two sensors configured with ID0 and ID1 respectively are sharing a common VCC line, a Manchester access code with a target ID value of [0 0 1 0] results in both sensors exiting Manchester serial communication mode.

Table 9: Manchester Exit Code

| Bits | Parameter Name  | Description                                                              |
|------|-----------------|--------------------------------------------------------------------------|
| 2    | Synchronization | 00                                                                       |
| 1    | Read/Write      | 0                                                                        |
| 4    | Target ID       | 0000 (this command is always a broadcast, even if it is addressed)       |
| 6    | Address         | 111111 (fixed number for Manchester exit message)                        |
| 16   | Data            | 0x0000 (any value except 0x62D2 can be used for Manchester exit message) |
| 3    | CRC             | 3-bit CRC                                                                |

An example is given below, with target ID =  $[0\ 0\ 0\ 1]$ , data = 0x0000, and CRC = 110.



Figure 33: Target ID = [0 0 0 1], Data = 0x0000, CRC = 110

### **MANCHESTER READ COMMAND**

Determines the serial address within the sensor from which the next read response transmits data. The sensor must receive a Manchester access code before responding to a read command.

This command is sent by the controller.

**Table 10: Manchester Read Command** 

| Bits | Parameter Name  | Description                                                             |
|------|-----------------|-------------------------------------------------------------------------|
| 2    | Synchronization | 00                                                                      |
| 1    | Read/Write      | 1                                                                       |
| 4    | Target ID       | Depends on targeted sensor ID, e.g., to target ID0, use 0001            |
| 6    | Address         | Serial register address, e.g., 0x10 for READ_DATA_LO, or 0x20 for ANGLE |
| 3    | CRC             | 3-bit CRC                                                               |

An example is provided in Figure 34 where register 0x20 ANGLE is read from target ID [0 0 0 1] with CRC = 111. The two synchronization pulses from the read response on the PWM return line are also shown.



Figure 34: Target ID = [0 0 0 1], ANGLE = 0x20, CRC = 111

# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### MANCHESTER READ RESPONSE

The read response transmits data from the sensor to the controller after a read command. These data are sent by the sensor on the open-drain PWM pin. A pull-up resistor is needed for this to work.

Read from an even address, returns even byte [15:8] and odd byte [7:0].

Read from an odd address, returns odd byte [7:0] only. Data bits [15:8] are zeroes.

**Table 11: Manchester Read Response** 

| Bits | Parameter Name  | Description                                                                                                                                                                                                                                                                                                           |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | Synchronization | 00                                                                                                                                                                                                                                                                                                                    |
| 2    | ID              | Target ID of the responding sensor die. 00 for ID0, 01 for ID1, 10 for ID2, 11 for ID3.                                                                                                                                                                                                                               |
| 1    | BC flag         | Broadcast: Value set to 1 if read command was a broadcast command (Target-ID set to [0 0 0 0]), 0 if not                                                                                                                                                                                                              |
| 1    | AE flag         | Abort error: Value set to 1 if a previous transaction was aborted and discarded, typically caused by incorrect bit lengths, 0 if there was no problem. The error is stored until it can be transmitted on the next read response and is cleared afterwards.                                                           |
| 1    | OR flag         | Overrun error: If a command is sent to the sensor while the sensor is still sending a read response, and this command is completely transmitted before the read response finishes, an overrun error occurs. This error is then stored until it can be transmitted on the next read response and is cleared afterward. |
| 1    | CS flag         | CRC error: Value set to 1 if a previous transaction had an incorrect CRC, 0 means there was no problem. The error is stored until it can be transmitted on the next read response and is cleared afterward.                                                                                                           |
| 16   | data            | Read from an even address: even byte [15:8] and odd byte [7:0]. Read from an odd address: odd byte [7:0] only. Data bits [15:8] are zeroes.                                                                                                                                                                           |
| 3    | CRC             | 3-bit CRC                                                                                                                                                                                                                                                                                                             |

An example is shown in Figure 35, where register 0x20 ANGLE is read, and the response is ID 00 (ID0), the four flags are all zeros (no errors), the data is 0x5C34, and the CRC is 100.



Figure 35: ID = 00, Error Flag = 0000, Data = 0x5C34, CRC = 100

### MANCHESTER READ RESPONSE DELAY

The Manchester read response starts at the end of the read command. The response may start a ¼-bit time before the CRC finishes transmitting (overlap with last CRC bit) or a ¼-bit time after the CRC finishes transmitting.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### CRC

The serial Manchester interface uses a cyclic redundancy check (CRC) for data-bit error checking of all the bits coming after the two synchronization bits. The synchronization bits are not included in the CRC. The CRC algorithm is based on the polynomial:

$$g(x) = x^3 + x + 1.$$

The calculation is represented graphically in Figure 36. The trailing 3 bits of a message frame comprise the CRC token. The CRC is initialized at 111. Data are fed into the CRC logic with MSB first. Output is sent as C2-C1-C0.



Figure 36: 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 COp = 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 ^ C0p;
 C0p = C0;
 C1p = C1;
 C2p = C2;
return (C2 ? 4U : 0U) + (C1 ? 2U : 0U) + (C0 ? 1U : 0U);
```



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# **EEPROM AND SHADOW MEMORY USAGE**

The device uses EEPROM to permanently store configuration parameters for operation. EEPROM is user-programmable and permanently stores operation parameter values or customer information. The operation parameters are downloaded to shadow (volatile) memory at power-up. Shadow fields are initially loaded from corresponding fields in EEPROM, but can be overwritten, either by performing an extended write to the shadow addresses, or by reprogramming the corresponding EEPROM fields and power cycling the IC. Use of shadow memory is substantially faster than accessing EEPROM. In situations where many parameters need to be tested quickly, shadow memory is recommended for trying parameter values before permanently programming them into EEPROM. The shadow memory registers have the same format as the EEPROM and are accessed at extended addresses 0x40 higher than the equivalent EEPROM address. Unused bits in the EEPROM do not exist in the related shadow register and return 0 when read. Shadow registers do not contain the ECC bits. Shadow registers have the same protection restrictions as the EEPROM. All registers can be read without unlocking. The mapping of bits from register addresses in EEPROM to their corresponding register addresses in shadow memory is shown in the EEPROM and Shadow Register Table.

# **Enabling EEPROM Access**

To enable EEPROM write access after power-on-reset, an unlock code needs to be written to the serial register KEYCODE. This involves five write commands, which should be executed one after the other:

- 1. Write 0x00 to register 0x3C [15:8]
- 2. Write 0x27 to register 0x3C [15:8]
- 3. Write 0x81 to register 0x3C [15:8]
- 4. Write 0x1F to register 0x3C [15:8]
- 5. Write 0x77 to register 0x3C [15:8]

This needs to be performed once after power-on reset if the customer intends to write to the EEPROM.

Writing to serial registers and reading from serial registers does not require a special procedure after power-on.

Reading all EEPROM cells is always possible.

## **EEPROM Write Lock**

It is possible to protect the EEPROM from accidental writes.

- Setting the EEPROM field LOCK to value 0xC (1100 in binary) blocks any writes to the EEPROM, so that permanent changes are not possible anymore. Temporary changes to the setting are still possible by writing to the shadow memory, but these changes are lost after a power cycle.
   This lock is permanent and cannot be reversed. Reading of the settings remains possible.
- Setting the EEPROM field LOCK to value 0x3 (0011 in binary) locks EEPROM writes AND shadow memory writes. This means none of the sensor settings can be changed anymore. This lock is permanent and cannot be reversed. Reading of the settings remains possible.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# **EEPROM Access Exceptions and Write Lock Exceptions**

It is possible to allow writes to the fields CUST and CUST2 without having to enable EEPROM access, and even when the EEPROM write lock is enabled (LOCK = 0xC or LOCK = 0x3).

This is controlled using the EEPROM fields CUD (customer uses disables), DEL (disable EEPROM lock), and DUR (disable unlock requirement). By default, the fields CUD, DEL, and DUR are all set to zero.

These settings control EEPROM access to different fields as shown in Table 12.

Table 12: EEPROM Access Exceptions for CUSTOMER and CUSTOMER2 Fields

| CUD Setting | DUR Setting | DEL Setting | Lock Setting | Writes to CUSTOMER2 (0x17) Possible | Writes to CUSTOMER (0x1F) Possible | Writes to All Other EEPROM Possible |  |  |
|-------------|-------------|-------------|--------------|-------------------------------------|------------------------------------|-------------------------------------|--|--|
| 0           | 0           | 0/1         | 0x0          | after keycode                       | after keycode                      | after keycode                       |  |  |
| 0           | 1           | 0/1         | 0x0          | always                              | after keycode                      | after keycode                       |  |  |
| 0           | 0           | 0           | 0xC/0x3      | never                               | never                              | never                               |  |  |
| 0           | 0           | 1           | 0xC/0x3      | after keycode                       | never                              | never                               |  |  |
| 0           | 1           | 0           | 0xC/0x3      | never                               | never                              | never                               |  |  |
| 0           | 1           | 1           | 0xC/0x3      | always                              | never                              | never                               |  |  |
| 1           | 0           | 0/1         | 0x0          | after keycode                       | after keycode                      | after keycode                       |  |  |
| 1           | 1           | 0/1         | 0x0          | always                              | always                             | after keycode                       |  |  |
| 1           | 0           | 0           | 0xC/0x3      | never                               | never                              | never                               |  |  |
| 1           | 0           | 1           | 0xC/0x3      | after keycode                       | after keycode                      | never                               |  |  |
| 1           | 1           | 0           | 0xC/0x3      | never                               | never                              | never                               |  |  |
| 1           | 1           | 1           | 0xC/0x3      | always                              | always                             | never                               |  |  |

# Write Transaction to EEPROM and Other Extended Locations

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

- Write the extended address into the EWA register (using SPI or Manchester direct access). EWA is the 8-bit extended address that determines which extended memory address is to be accessed.
- Write the data that is to be transferred into the EWD registers (using SPI or Manchester direct access). This requires four SPI writes or two Manchester packets to load all 32 bits of data.

Invoke the extended access by writing the direct EWCS. EXW bit with 1.

The 32 bits of data in EWD are then written to the address specified in EWA.

The bit EWCS.WDN can be polled to determine when the write completes. This is only necessary for EEPROM writes, which can require up to 24 ms to complete. Shadow register writes complete immediately in one system clock cycle after synchronization.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

For example, to write location 0x1F in the EEPROM with 0x00A45678:

• Write 0x1F to the lower 8 bits of the EWA register (0x1F to EWA + 1, address 0x03)



• Write 0x00A45678 to EWD (0x00 to EWD, 0xA4 to EWD + 1, 0x56 to EWD + 2, 0x78 to EWD + 3)



• Write 0x80 to EWCS



• Read EWCS + 1 until bit 0 (WDN) is set, or wait enough time.

In the example, register 0x08 is read, so that the second output byte is from register 0x09, then a waiting period occurs before bit 0 becomes 1, which happens in the last read.



If an access violation occurs (address not unlocked), the transaction terminates, the corresponding RDN or WDN bit becomes set, and the XEE warning bit asserts. If the EEPROM write aborts, the XEE bit in the ERR register also becomes set.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

After writing to the EEPROM, verify that the write was successful by performing an EEPROM margin check.

# **EEPROM Margin Check**

Due to nonidealities in transistors, current slowly leaks into or out of EEPROM cells and can, over time, cause small changes in the stored voltage level. Variances in voltage levels of the charge pump can result in a variety of stored EEPROM cell voltages when programming. If this value is marginally close to the threshold, the small drift over lifetime can cause this value to move across the threshold. This results in a corrupted EEPROM value. Because this drift happens slowly over time, if there is an issue, it may not appear for years. For this reason, it is important to perform margin testing (margining) to verify the internal voltage levels of EEPROM cells after programming and to ensure future issues do not occur.

Margining is performed by Allegro on all registers at final test. Because EEPROM cell voltages are only modified when writing to the cell, it is not necessary to perform margining on registers that have not been modified.

Margining is performed in two steps: the first checks the validity of the voltage stored on digital 1 cells, and the second checks the voltage stored on digital 0 cells. It is important to perform both steps to ensure issues do not occur.

To perform margining, a value of 0b0001 must be written to the SPECIAL field of the CTRL register. This reduces the internal threshold value. Once this value is written, an EEPROM read uses this lower threshold when reading EEPROM values. Perform a read on all EEPROM registers that are being tested, and confirm they read correctly. If a stored voltage is marginal to the typical operating threshold, it appears as a 1 when the value should be 0.

Repeat this test with the value of 0b0010 in the SPECIAL register to raise the threshold value to greater than typical operation. Again, read all EEPROM registers being tested. In this test, any stored high voltage that is marginal to the typical threshold appears as a 0 when the value should be 1.

If, during either test, a bit is read incorrectly, perform another EEPROM write of the desired values to the register and retest the margins.

Unlike other values in the SPECIAL field, these values persist and can be read to confirm the write was successful. As a result, the SPECIAL register must be cleared (or power cycled) to return the threshold value to its typical level.

In Figure 37,  $V_{NOM(H)}$  represents the nominal voltage programmed into EEPROM cells containing a 1, and  $V_{NOM(L)}$  represents the nominal voltage programmed into EEPROM cells containing a 0. The red and blue lines represent the actual voltage levels in the programmed cells for 1 and 0 values respectively. As can be observed, at time 0 when the margin test is run, both the high and low levels still appear to be the correct value when the threshold is moved to the margin testing levels.



Figure 37: Example of Passing Programming Voltages

In Figure 38, the high and low voltage levels at the time of programming are further from their target. The drift over time results in these value crossing  $V_{THRESH}$  and becoming corrupted. At time 0 when the margin test is run, these values fail, and are reported as errors to be reprogrammed.



Figure 38: Example of Failing Programming Voltages



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

Margining is shown below as a list of high-level steps. For details about performing individual steps, see the associated sections.

- 1. Clear the ERR and WARN registers.
  - A. Set the CTRL.CLW and CTRL.CLE bits.
- 2. Enable EEPROM access.
- 3. Write new data to the EEPROM as desired.
- 4. Check the following flags for EEPROM errors: ESE, EUE, XEE, IER, CRC, and BSY.
  - A. If any are asserted, the EEPROM write may have failed.
  - B. A second write attempt is recommended.
- 5. Set CTRL.SPECIAL to 0001b to enable low-voltage margining.
- Read all EEPROM addresses changed in step 3 and verify their contents.
  - A. Verify the ESE and EUE error flags are clear.
- 7. Set CTRL.SPECIAL to 0010b to enable high-voltage margining.
- 8. Read all EEPROM addresses changed in step 3 and verify their contents.
  - A. Verify the ESE and EUE error flags are clear.
- 9. If any EEPROM value read with a low or high threshold differs from the desired EEPROM or if either the ESE or EUE bits are set, EEPROM margining has failed.
  - A. One additional write attempt and margin check should be accomplished. If margin failures persist following a second EEPROM write, the device should be discarded.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# 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:

- Write the extended address to be read into the ERA register (using SPI or Manchester direct access). ERA is the 8-bit extended address that determines which extended memory address is to be accessed.
- 2. Invoke the extended access by writing the direct ERCS.EXT bit with 1. The address specified in ERA is then read, and the data is loaded into the ERD registers.
- 3. Read the ERD registers (using SPI or Manchester direct access) to get the extended data. Obtaining all 32 bits requires multiple packets.

EEPROM read accesses may require up to 2  $\mu$ s to complete. The ERCS.RDN 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 ERD registers if the read access is potentially in process, because it could change during the serial access and cause the data to be inconsistent. It is also possible to cause an SPI CRC error to be detected if the data changes during the serial read via the SPI interface.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

For example, to read location 0x1F in the EEPROM:





• Write 0x80 to ERCS.



• Read ERCS + 1 until bit 0 (RDN) is set, or wait enough time.

In the example, register 0x0C is read, so that the last bit of the second output byte contains the RDN bit.



- Read ERDH (upper 16 bits of read data).
- Read ERDL (lower 16 bits of read data).

In the example below, the result for the data at address 0x1F is 0x58A45678. In this value:

- □ Bits [31:26] are the EEPROM CRC.
- $\square$  Bits [25:24] are unused and zero.
- □ Bits [23:0] are the EEPROM values that can be used. These are the 24 bits containing the data 0xA45678 that was written in the EEPROM write example.



Note that it would have been possible to pipeline transactions in this example, i.e., send a new command while reading return data from the old command. This way, the transaction could have been performed in five SPI frames instead of eight.



# **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

# **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, address the shadow extended addresses, which are located at an offset of 0x40 above the EEPROM. For all addresses, refer to the EEPROM and Shadow Register Table.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# **SERIAL INTERFACE TABLE**

Table 13: Primary Serial Interface Registers Bits Map

| Address [1]                                  | Register | Read/ |     |     | Add           | Iressed | Byte (M            | SB)             |     |        |        |       | Addre  | ssed By | rte + 1 (l | MSB) |     |     | LSB                                          |
|----------------------------------------------|----------|-------|-----|-----|---------------|---------|--------------------|-----------------|-----|--------|--------|-------|--------|---------|------------|------|-----|-----|----------------------------------------------|
| (0x00)                                       | Symbol   | Write | 15  | 14  | 13            | 12      | 11                 | 10              | 9   | 8      | 7      | 6     | 5      | 4       | 3          | 2    | 1   | 0   | Address                                      |
| 0x02                                         | EWA      | RW    | 0   | 0   | 0             | 0       | 0                  | 0               | 0   | 0      |        |       | •      | WRITE   | _ADR       |      |     | ·   | 0x03                                         |
| 0x04                                         | EWDH     | RW    |     |     | WRITE_DATA_HI |         |                    |                 |     |        |        | 0x05  |        |         |            |      |     |     |                                              |
| 0x06                                         | EWDL     | RW    |     |     | WRITE_DATA_LO |         |                    |                 |     |        |        |       |        |         | 0x07       |      |     |     |                                              |
| 80x0                                         | EWCS     | WO/RO | EXW | 0   | 0             | 0       | 0                  | 0               | 0   | WIP    | 0      | 0     | 0      | 0       | 0          | 0    | 0   | WDN | 0x09                                         |
| A0x0                                         | ERA      | RW    | 0   | 0   | 0             | 0       | 0                  | 0               | 0   | 0      |        |       |        | READ_   | _ADR       |      |     |     | 0x0B                                         |
| 0x0C                                         | ERCS     | WO/RO | EXR | 0   | 0             | 0       | 0                  | 0               | 0   | RIP    | 0      | 0     | 0      | 0       | 0          | 0    | 0   | RDN | 0x0D                                         |
| 0x0E                                         | ERDH     | RO    |     |     |               |         |                    | ,               | F   | READ_D | ATA_HI | •     | •      | •       | •          |      | •   |     | 0x0F                                         |
| 0x10                                         | ERDL     | RO    |     |     |               |         |                    |                 | R   | EAD_D  | ATA_LO |       |        |         |            |      |     |     | 0x11                                         |
| 0x12<br>0x14<br>0x16<br>0x18<br>0x1A<br>0x1C | Unused   | RO    | 0   | 0   | 0             | 0       | 0                  | 0               | 0   | 0      | 0      | 0     | 0      | 0       | 0          | 0    | 0   | 0   | 0x13<br>0x15<br>0x17<br>0x19<br>0x1B<br>0x1D |
| 0x1E                                         | CTRL     | RW/WO |     | SPE | CIAL          |         | 0                  | CLS             | CLW | CLE    |        |       | INI    | TIATE_  | SPECIA     | .L   |     |     | 0x1F                                         |
| 0x20                                         | ANG      | RO    | 0   | EF  | UV            | Р       |                    |                 |     |        |        | ANG   | LE     |         |            |      |     |     | 0x21                                         |
| 0x22                                         | STA      | RO    | 1   | 0   | 0             | 0       | 0                  | 0               | DI  | EID    | ROT    | LPSH  | SDN    | BDN     | LBR        | CSTR | BIP | AOK | 0x23                                         |
| 0x24                                         | ERR      | RO    | 1   | 0   | 1             | 0       | WAR                | STF             | AVG | ABI    | PLK    | ZIE   | EUE    | OFE     | UVD        | UVA  | MSL | RST | 0x25                                         |
| 0x26                                         | WARN     | RO    | 1   | 0   | 1             | 1       | IER                | CRC             | 0   | SRW    | XEE    | TR    | ESE    | SAT     | TCW        | BSY  | MSH | TOV | 0x27                                         |
| 0x28                                         | TSEN     | RO    | 1   | 1   | 1             | 1       |                    | •               |     | •      | Т      | EMPER | ATURE  |         |            |      |     | ,   | 0x29                                         |
| 0x2A                                         | FIELD    | RO    | 1   | 1   | 1             | 0       |                    |                 |     |        |        | GAU   | SS     | -       |            |      |     |     | 0x2B                                         |
| 0x2C                                         | TURNS    | RO    | 1   | 1   | TSRC          | Р       |                    |                 |     |        |        | TUR   | NS     |         |            |      |     |     | 0x2D                                         |
| 0x2E                                         | TOFF     | RO    | 1   | LAT | 0             | Р       | 0                  |                 |     |        |        | TURN  | IS_OFF | SET     |            |      |     |     | 0x2F                                         |
| 0x30                                         | HANG     | RO    | 0   | EF  | UV            | Р       |                    |                 |     |        |        | ANGLE | _HYS   |         |            |      |     |     | 0x31                                         |
| 0x32                                         | ANG15    | RO    | 0   |     |               |         |                    |                 |     | A۱     | IGLE_1 | 5     |        |         |            |      |     |     | 0x33                                         |
| 0x34                                         | ZANG     | RO    | 0   | EF  | UV            | Р       |                    |                 |     |        |        | ANGLE | _ZCD   |         |            |      |     |     | 0x35                                         |
| 0x36                                         | TD_HIGH  | RO    | 0   | EF  | TSRC          | Р       | TURNS_DELTA[23:12] |                 |     |        |        | 0x37  |        |         |            |      |     |     |                                              |
| 0x38                                         | TD_LOW   | RO    | 0   | EF  | LAT           | Р       | TURNS_DELTA[11:0]  |                 |     |        |        | 0x39  |        |         |            |      |     |     |                                              |
| 0x3A                                         | PTANG    | RO    | 0   | EF  | UV            | Р       |                    | PLL_TURNS_ANGLE |     |        |        |       | 0x3B   |         |            |      |     |     |                                              |
| 0x3C                                         | KEY      | WO/RO |     |     |               | KEYO    | CODE               |                 |     |        | 0      | 0     | 0      | 0       | 0          | 0    | 0   | CUL | 0x3D                                         |
| 0x3E                                         | Unused   | RO    | 0   | 0   | 0             | 0       | 0                  | 0               | 0   | 0      | 0      | 0     | 0      | 0       | 0          | 0    | 0   | 0   | 0x3F                                         |

<sup>[1]</sup> Addresses that span multiple bytes are addressed by the most significant byte.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# PRIMARY SERIAL INTERFACE REGISTERS REFERENCE

# Location 0x02:0x03 (EWA)

## **EWA.WRITE ADR**

The field WRITE\_ADR is a bit field located at address 0x02 [7:0]. This bit field is part of the location EWA.

8-bit address for extended writes. Writes require unlock.

0x00:0x1F—EEPROM (requires approximately 24 ms) 0x40:0x5F—Shadow

# Location 0x04:0x05 (EWDH)

# EWDH.WRITE\_DATA\_HI

The field WRITE\_DATA\_HI is a bit field located at address 0x04 [15:0]. This bit field is part of the location EWDH.

Upper 16 bits of data for an extended write operation.

# Location 0x06:0x07 (EWDL)

## EWDL.WRITE\_DATA\_LO

The field WRITE\_DATA\_LO is a bit field located at address 0x06 [15:0]. This bit field is part of the location EWDL.

Lower 16 bits of data for an extended write operation.

# Location 0x08:0x09 (EWCS)

### **EWCS.WDN**

The field wdn is a bit located at address 0x08 [0]. This bit is part of the location EWCS.

Write is performed when WDN = 1; WDN clears when EXW is set to 1.

## **EWCS.WIP**

The field WIP is a bit located at address 0x08 [8]. This bit is part of the location EWCS.

Write in progress when 1.

## **EWCS.EXW**

The field EXW is a bit located at address 0x08 [15]. This bit is part of the location EWCS.

Initiate extended write by writing with 1. Sets WIP and clears WDN. Write-only, always reads back 0.

# Location 0x0A:0x0B (ERA)

## **ERA.READ ADR**

The field READ\_ADR is a bit field located at address 0x0A [7:0]. This bit field is part of the location ERA.

8-bit address for extended reads.

0x00:0x1F—EEPROM (takes about 2 μs) 0x40:0x5F—Shadow

NOTE: After LBIST or a reload of EEPROM values, the value of READ ADR is changed.

# Location 0x0C:0x0D (ERCS)

### **ERCS.RDN**

The field RDN is a bit located at address 0x0C [0]. This bit is part of the location ERCS.

Read is performed when 1, clears when EXR set to 1.

### **ERCS.RIP**

The field RIP is a bit located at address 0x0C [8]. This bit is part of the location ERCS.

Read in progress when 1.

## **ERCS.EXR**

The field EXR is a bit located at address 0x0C [15]. This bit is part of the location ERCS.

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

# Location 0x0E:0x0F (ERDH)

## ERDH.READ\_DATA\_HI

The field READ\_DATA\_HI is a bit field located at address 0x0E [15:0]. This bit field is part of the location ERDH.

Upper 16 bits of data from extended read operation, valid when RDN set to 1.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x10:0x11 (ERDL)

# ERDL.READ\_DATA\_LO

The field READ\_DATA\_LO is a bit field located at address 0x10 [15:0]. This bit field is part of the location ERDL.

Lower 16 bits of data from extended read operation, valid when RDN set to 1.

# Location 0x1E:0x1F (CTRL)

# CTRL.INITIATE\_SPECIAL

The field INITIATE\_SPECIAL is a bit field located at address 0x1E [7:0]. This bit field is part of the location CTRL.

For certain actions from SPECIAL bit field, a code must be set to initiate SPECIAL. These are to be written into this bit field.

0xB9 initiates CVH self-test or functional BIST.

0x46 initiates turns-counter reset.

0xA5 initiates EEPROM margin or EEPROM reload.

0x5A initiates hard reset.

Read always returns 0x00.

# CTRL.CLE

The field CLE is a bit located at address 0x1E [8]. This bit is part of the location CTRL.

Clear error register ERR when written with 1. Clears bits previously read from the ERR. Bits that are not yet read are not cleared, so the user needs to read ERR first. Write-only, always returns 0.

# CTRL.CLW

The field CLW is a bit located at address 0x1E [9]. This bit is part of the location CTRL.

Clear warning (WARN) register when set to 1. Clears bits previously read from WARN, so WARN should be read first. Write-only, always returns 0.

## **CTRL.CLS**

The field CLS is a bit located at address 0x1E [10]. This bit is part of the location CTRL.

Clear bits SDN and BDN from the STATUS register when set to 1. Write-only, returns 0 when read.

#### CTRL.SPECIAL

The field SPECIAL is a bit field located at address 0x1E [15:12]. This bit field is part of the location CTRL.

Special actions. Some of the actions are only invoked after the INITIATE\_SPECIAL field is written with the correct value. This field returns 0x00 on completion. Self-tests may be run in parallel.

0000—No action.

0001—Enable EEPROM low-voltage margining.

0010—Enable EEPROM high-voltage margining.

0011—Turns-counter load from EWD. Starts after writing 0x46 to INITIATE SPECIAL.

0100—Turns-counter reset. Starts after writing 0x46 to INITIATE SPECIAL.

0101—Reload EEPROM. Requires unlock of part. Starts after writing 0xA5 to INITIATE SPECIAL.

0110—Enable transport mode on next LPM entry.

0111—Hard reset. Requires unlock of part. Starts after writing 0x5A to INITIATE SPECIAL.

1001—Run CVH self-test. Starts after writing 0xB9 to INITIATE SPECIAL.

1010—Run logic BIST. Starts after writing 0xB9 to INITIATE\_SPECIAL.

 $1011\mbox{--}Run$  CVH self-test and logic-BIST in parallel. Starts after writing 0xB9 to INITIATE\_SPECIAL.

# Location 0x20:0x21 (ANG)

### **ANG.ANGLE**

The field ANGLE is a bit field located at address 0x20 [11:0]. This bit field is part of the location ANG.

ANGLE from PLL after processing. ANGLE in degrees = unsigned 12-bit value  $\times$  (360 / 4096).

#### ANG.P

The field P is a bit located at address 0x20 [12]. This bit is part of the location ANG.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **ANG.UV**

The field UV is a bit located at address 0x20 [13]. This bit is part of the location ANG.

Undervoltage flag (real time). OR of UVA and UVD undervoltage flags. Conditions are real time but are masked by the shadow mask bits.

### **ANG.EF**

The field EF is a bit located at address 0x20 [14]. This bit is part of the location ANG.

Error flag. If any unmasked bit in ERR or WARN is set, value is 1.

# Location 0x22:0x23 (STA)

### STA.AOK

The field AOK is a bit located at address 0x22 [0]. This bit is part of the location STA.

Angle output OK. PLL is in lock.

## STA.BIP

The field BIP is a bit located at address 0x22 [1]. This bit is part of the location STA.

Boot in progress.

### STA.CSTR

The field CSTR is a bit located at address 0x22 [2]. This bit is part of the location STA.

CVH self-test running.

#### STA.LBR

The field LBR is a bit located at address 0x22 [3]. This bit is part of the location STA.

LBIST running.

### STA.BDN

The field BDN is a bit located at address 0x22 [4]. This bit is part of the location STA.

Boot complete. EEPROM loaded and any startup self-tests are complete.

#### STA.SDN

The field SDN is a bit located at address 0x22 [5]. This bit is part of the location STA.

Special access (from CTRL register) is complete. Clears to 0 when SPECIAL triggered, set 1 when complete.

### STA.LPSH

The field LPSH is a bit located at address 0x22 [6]. This bit is part of the location STA.

Cannot enter low-power mode because angular speed is too high.

## STA.ROT

The field ROT is a bit located at address 0x22 [7]. This bit is part of the location STA.

Rotation direction based on hysteresis (0 = increasing angle, 1 = decreasing angle).

### STA.DIEID

The field DIEID is a bit field located at address 0x22 [9:8]. This bit field is part of the location STA.

DIE ID from EEPROM (for multi-die packages).

# Location 0x24:0x25 (ERR)

This is the error register. All errors are latched, meaning any error remains high after a single occurrence. Errors must be read and then cleared in order to remove them. It is important that the user clears errors, so that subsequent errors become visible. This is especially important for the RST error flag (reset), which is always enabled after power on. Not removing it means that an unexpected reset cannot be discovered afterward.

### **ERR.RST**

The field RST is a bit located at address 0x24 [0]. This bit is part of the location ERR.

Reset condition. Sets on power-on reset or on hard reset. Does not set on LBIST.

### **ERR.MSL**

The field MSL is a bit located at address 0x24 [1]. This bit is part of the location ERR.

Magnetic sense low fault. Magnetic sense was below the MAG\_THRES\_LO limit.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **ERR.UVA**

The field UVA is a bit located at address 0x24 [2]. This bit is part of the location ERR.

Undervoltage detector tripped. If the undervoltage situation persists after it is cleared, it becomes set again. Based on analog regulator.

## **ERR.UVD**

The field UVD is a bit located at address 0x24 [3]. This bit is part of the location ERR.

Undervoltage detector tripped. If the undervoltage situation persists after it is cleared, it becomes set again.

#### ERR.OFE

The field OFE is a bit located at address 0x24 [4]. This bit is part of the location ERR.

Oscillator frequency watchdog tripped.

#### **ERR.EUE**

The field EUE is a bit located at address 0x24 [5]. This bit is part of the location ERR.

EEPROM uncorrectable error. A multi-bit EEPROM read occurred.

# **ERR.ZIE**

The field ZIE is a bit located at address 0x24 [6]. This bit is part of the location ERR.

Zero-crossing integrity error—A zero-crossing did not occur within the maximum time expected, likely indicating a missing magnet, an extreme rotation speed, or a sensor defect.

## **ERR.PLK**

The field PLK is a bit located at address 0x24 [7]. This bit is part of the location ERR.

PLL lost lock.

## **ERR.ABI**

The field ABI is a bit located at address 0x24 [8]. This bit is part of the location ERR.

ABI integrity fault. The quadrature integrity of the ABI could not be maintained.

#### **ERR.AVG**

The field AVG is a bit located at address 0x24 [9]. This bit is part of the location ERR.

Angle averaging error. The ORATE is too high for the velocity and the averaging is corrupted.

### **ERR.STF**

The field STF is a bit located at address 0x24 [10]. This bit is part of the location ERR.

Self-test failure.

### **ERR.WAR**

The field WAR is a bit located at address 0x24 [11]. This bit is part of the location ERR.

Warning. Some unmasked error bits are set in the WARN register. If WAR in mask register MSK is set, this bit is forced to 0.

# Location 0x26:0x27 (WARN)

#### **WARN.TOV**

The field TOV is a bit located at address 0x26 [0]. This bit is part of the location WARN.

Turns-counter overflow error. The turns-counter surpassed its maximum value of  $\pm 256$  full rotations. This is not dependent on the resolution of the turns (45 degrees or 180 degrees).

### **WARN.MSH**

The field MSH is a bit located at address 0x26 [1]. This bit is part of the location WARN.

Magnetic sense high fault. Magnetic sense has exceeded the MAG\_THRES\_HI limit.

### **WARN.BSY**

The field BSY is a bit located at address 0x26 [2]. This bit is part of the location WARN.

Extended access overflow. An EXW or EXR was initiated while a previous extended read or write was in progress.

### **WARN.TCW**

The field TCW is a bit located at address 0x26 [3]. This bit is part of the location WARN.

Turns-counter warning (greater than  $\pm 135$ -degree delta).



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### **WARN.SAT**

The field SAT is a bit located at address 0x26 [4]. This bit is part of the location WARN.

Aggregate saturation flag. Shows that any internal signals are saturated; the likely cause is extremely strong or weak fields.

## **WARN.ESE**

The field ESE is a bit located at address 0x26 [5]. This bit is part of the location WARN.

EEPROM soft error. A correctable (single-bit) EEPROM read occurred.

## **WARN.TR**

The field TR is a bit located at address 0x26 [6]. This bit is part of the location WARN.

Temperature out of range. The temperature sensor calculated a temperature below –60°C or above 180°C. Temperature saturates at those limits.

## **WARN.XEE**

The field XEE is a bit located at address 0x26 [7]. This bit is part of the location WARN.

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

## **WARN.SRW**

The field SRW is a bit located at address 0x26 [8]. This bit is part of the location WARN.

Slew-rate warning. This warning asserts if the ABI slew-rate limiting is enabled and a condition occurs that requires the limiting to be applied.

#### WARN.CRC

The field CRC is a bit located at address 0x26 [10]. This bit is part of the location WARN.

Incoming SPI CRC error. Packet was discarded.

#### **WARN.IER**

The field IER is a bit located at address 0x26 [11]. This bit is part of the location WARN.

Interface error. Invalid number of bits in SPI packet, or bit 15 of MOSI data = 1. Packet was discarded.

Also Manchester error.

# Location 0x28:0x29 (TSEN)

## **TSEN.TEMPERATURE**

The field TEMPERATURE is a bit field located at address 0x28 [11:0]. This bit field is part of the location TSEN.

Current junction temperature from internal temperature sensor relative to  $25^{\circ}$ C (signed value). Value is in 1/8 of a degree. Temperature  $^{\circ}$ C = (TSEN.TEMPERATURE / 8) + 25.0.

# Location 0x2A:0x2B (FIELD)

### FIELD.GAUSS

The field GAUSS is a bit field located at address 0x2A [11:0]. This bit field is part of the location FIELD.

Field strength in gauss.

# Location 0x2C:0x2D (TRNS)

## **TRNS.TURNS**

The field TURNS is a bit field located at address 0x2C [11:0]. This bit field is part of the location TRNS.

Turns counter—signed 45-degree or 180-degree increments.

### TRNS.P

The field P is a bit located at address 0x2C [12]. This bit is part of the location TRNS.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

## TRNS.TSRC

The field TSRC is a bit located at address 0x2C [13]. This bit is part of the location TRNS.

Turns source. Set to 1 to use accurate PLL as turns-counter source in the typical power mode (recommended). To use ZCD angle as the turns-counter source for the typical power mode (not recommended), set to 0.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x2E:0x2F (TOFF)

# TOFF.TURNS\_OFFSET

The field TURNS\_OFFSET is a bit field located at address 0x2E [10:0]. This bit field is part of the location TOFF.

This is either the 11 or 9 LSBs of the TURNS\_DELTA register, depending on the 180-degree or 45-degree turns configuration.

### TOFF.P

The field P is a bit located at address 0x2E [12]. This bit is part of the location TOFF.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

# **TOFF.LAT**

The field LAT is a bit located at address 0x2E [14]. This bit is part of the location TOFF.

Indicates that the TURNS\_OFFSET field is latched. If 1, indicates that the word in the TOFF field was latched during a prior read of the turns register and is consistent with that reading. Returns to 0 after reading.

# Location 0x30:0x31 (HANG)

## HANG.ANGLE\_HYS

The field ANGLE\_HYS is a bit field located at address 0x30 [11:0]. This bit field is part of the location HANG.

Angle from PLL after processing. Angle in degrees = unsigned 12-bit value  $\times$  (360 / 4096).

### HANG.P

The field P is a bit located at address 0x30 [12]. This bit is part of the location HANG.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

## **HANG.UV**

The field UV is a bit located at address 0x30 [13]. This bit is part of the location HANG.

Undervoltage flag (real time). OR of analog and digital UV flags. Conditions are real time but are masked by the shadow mask bits.

#### **HANG.EF**

The field EF is a bit located at address 0x30 [14]. This bit is part of the location HANG.

Error flag. If any unmasked bit in ERR or WARN is set, the value of this bit is 1.

# Location 0x32:0x33 (ANG15)

# ANG15.ANGLE\_15

The field ANGLE\_15 is a bit field located at address 0x32 [14:0]. This bit field is part of the location ANG15.

15-bit compensated angle (not rounded).

# Location 0x34:0x35 (ZANG)

## ZANG.ANGLE\_ZCD

The field ANGLE\_ZCD is a bit field located at address 0x34 [11:0]. This bit field is part of the location ZANG.

Angle from zero-crossing detector, which is used to verify that the PLL angle is correct. In low-power mode, this angle is always used for the turns-counter; in typical power mode with TSRC = 0, this angle is used for the turns-counter source. Angle in degrees = unsigned 12-bit value  $\times$  (360 / 4096).

### ZANG.P

The field P is a bit located at address 0x34 [12]. This bit is part of the location ZANG.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

#### **ZANG.UV**

The field UV is a bit located at address 0x34 [13]. This bit is part of the location ZANG.

Undervoltage flag (real time). OR of analog and digital UV flags. Conditions are real time but are masked by the shadow mask bits.

# **ZANG.EF**

The field EF is a bit located at address 0x34 [14]. This bit is part of the location ZANG.

Error flag. If any unmasked bit in ERR or WARN is set, the value of this bit is 1.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x36:0x37 (TD HIGH)

When reading TD\_HIGH, the contents of TD\_LOW are locked. This ensures the values of the two words match. To get a correct reading of the entire turns delta, the customer must read TD\_HIGH, then TD\_LOW.

## TD\_HIGH.TURNS\_DELTA\_HIGH

The field TURNS\_DELTA\_HIGH is a bit field located at address 0x36 [11:0]. This bit field is part of the location TD\_HIGH.

Upper 9 bits (sign extended to 12) of the turns-delta counter.

# TD\_HIGH.P

The field P is a bit located at address 0x36 [12]. This bit is part of the location TD HIGH.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

# TD\_HIGH.TSRC1

The field TSRC1 is a bit located at address 0x36 [13]. This bit is part of the location TD HIGH.

Turns source. Set to 1 to use accurate PLL as turns-counter source in typical power mode (recommended). To use ZCD angle as turns-counter source in typical power mode (not recommended), set to 0.

## TD\_HIGH.EF

The field EF is a bit located at address 0x36 [14]. This bit is part of the location TD\_HIGH.

Error flag. If any unmasked bit in ERR or WARN is set, the value of this bit is 1.

# Location 0x38:0x39 (TD LOW)

# TD\_LOW.TURNS\_DELTA\_LOW

The field TURNS\_DELTA\_LOW is a bit field located at address 0x38 [11:0]. This bit field is part of the location TD LOW.

Lower 12 bits of the turns-delta counter. This is the angle offset at 12-bit resolution.

## TD\_LOW.P

The field P is a bit located at address 0x38 [12]. This bit is part of the location TD LOW.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

# TD\_LOW.LAT1

The field LAT1 is a bit located at address 0x38 [13]. This bit is part of the location TD\_LOW.

Indicates that the TD\_LOW field is latched. If 1, indicates that TD\_LOW was latched on a prior read of the TD\_HIGH register, and is consistent with that reading. Returns to 0 after reading.

## TD\_LOW.EF

The field EF is a bit located at address 0x38 [14]. This bit is part of the location TD LOW.

Error flag. If any unmasked bit in ERR or WARN is set, the value of this bit is 1.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x3A:0x3B (PTANG)

# PTANG.PLL\_TURNS\_ANGLE

The field PLL\_TURNS\_ANGLE is a bit field located at address 0x3A [11:0]. This bit field is part of the location PTANG.

Angle from PLL after processing, as used for the turns-counter.

May have hysteresis based on H2A configuration in EEPROM.

Angle in degrees = unsigned 12-bit value  $\times$  (360 / 4096).

## PTANG.P

The field P is a bit located at address 0x3A [12]. This bit is part of the location PTANG.

Odd parity computed across all bits of this register. Value is chosen in such a way that there should always be an odd number of ones in the 16-bit word.

## **PTANG.UV**

The field UV is a bit located at address 0x3A [13]. This bit is part of the location PTANG.

Undervoltage flag (real time). OR of analog and digital UV flags. Conditions are real time but are masked by the shadow mask bits.

## **PTANG.EF**

The field EF is a bit located at address 0x3A [14]. This bit is part of the location PTANG.

Error flag. If any unmasked bit in ERR or WARN is set, the value of this bit is 1.

# Location 0x3C:0x3D (KEY)

## **KEY.CUL**

The field CUL is a bit located at address 0x3C [0]. This bit is part of the location KEY.

Customer unlocked if 1

### **KEY.KEYCODE**

The field KEYCODE is a bit field located at address 0x3C [15:8]. This bit field is part of the location KEY.

Customer access keycode is entered here, using five subsequent write commands with the numbers: 0x00, 0x27, 0x81, 0x1F, and 0x77.

Always reads back 0.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# **EEPROM AND SHADOW REGISTER TABLE**

The EEPROM register bitmap is shown in Table 14. Addresses that span multiple bytes are addressed by the most significant byte.

All EEPROM content can be read by the user. The EEPROM ECC field in bits [31:26] of each word are not shown here. Bits [25:24] of each EEPROM word are unused and are not shown here but are included in the ECC.

Table 14: EEPROM/Shadow Memory Map

| EEPROM  | Shadow            | Register |      |                                                               |        |                   |          |         |          |         |        |         |      | В     | Bits                      |                        |       |      |         |          |          |         |      |        |          |      |
|---------|-------------------|----------|------|---------------------------------------------------------------|--------|-------------------|----------|---------|----------|---------|--------|---------|------|-------|---------------------------|------------------------|-------|------|---------|----------|----------|---------|------|--------|----------|------|
| Address | Memory<br>Address | Name     | 23   | 22                                                            | 21     | 20                | 19       | 18      | 17       | 16      | 15     | 14      | 13   | 12    | 11                        | 10                     | 9     | 8    | 7       | 6        | 5        | 4       | 3    | 2      | 1        | 0    |
| 0x17    | -                 | CU2      |      |                                                               |        |                   |          |         |          |         |        |         |      | CUST  | STOMER 2                  |                        |       |      |         |          |          |         |      |        |          |      |
| 0x18    | 0x58              | PWE      |      |                                                               |        |                   | ZCD_T    | JRNS_C  | FFSET    |         |        |         |      | TOV   | TR                        | MSH                    | SAT   | ESE  | MSL     | UV       | AVG      | ZIE     | PLK  | STF    | EUE      | OFE  |
| 0x19    | 0x59              | ABI      | -    | -                                                             |        |                   | ABI_SLE  | W_TIME  |          |         | INV    | -       | -    | AHE   | -                         | -                      | INDEX | MODE | WDH     | PLH      | IOE      | UVW     | R    | ESOLUT | ION_PAII | RS   |
| 0x1A    | 0x5A              | MSK      | IERM | CRCM                                                          | -      | SRWM              | XEEM     | TRM     | ESEM     | SATM    | TCWM   | BSYM    | MSHM | TOVM  | WARM                      | STFM                   | AVGM  | ABIM | PLKM    | ZIEM     | EUEM     | OFEM    | UVDM | UVAM   | MSLM     | RSTM |
| 0x1B    | 0x5B              | PWI      | PEN  | PV                                                            | VM_BAN | BAND PWM_FREQ - P |          |         |          | PHE     | PEO    | PES     | ELI  | LS    | WP_                       | HYS                    | ZAL   | W    | /P_THRE | S        | DM       | H2T     | S17  | SC     |          |      |
| 0x1C    | 0x5C              | ANG      |      | ORA                                                           | TE     |                   | RD       | RO      |          |         | HYSTE  | RESIS   |      |       | ZERO_OFFSET               |                        |       |      |         |          |          |         |      |        |          |      |
| 0x1D    | 0x5D              | LPC      | T45  | TCP                                                           | TPMD   | LPMD              | TURNS    | S_INIT  |          | L       | PM_CY0 | CLE_TIM | E    |       | LPT                       | LPT LPM_WAKE_THRESHOLD |       |      |         |          |          |         |      |        |          |      |
| 0x1E    | 0x5E              | COM      |      | LO                                                            | CK     |                   | LBE      | CSE     | DUR      | DEL     | -      | CUD     | DST  | DHR   | MAG_THRES_HI MAG_THRES_LO |                        |       |      |         |          |          |         |      |        |          |      |
| 0x1F    | -                 | CUS      |      |                                                               |        |                   |          |         |          |         |        |         |      | CUST  | TOMER                     |                        |       |      |         |          |          |         |      |        |          |      |
| 0x20    | 0x60              | LIN00    |      |                                                               |        |                   | Lineariz | ation E | rror Seg | gment 1 |        |         |      |       |                           |                        |       |      | Lineari | zation E | Error Se | gment 0 | )    |        |          |      |
| 0x21    | 0x61              | LIN01    |      |                                                               |        |                   | Lineariz | ation E | rror Seg | gment 3 |        |         |      |       |                           |                        |       |      | Lineari | zation E | Error Se | gment 2 | !    |        |          |      |
|         |                   |          |      | –                                                             |        |                   |          |         |          |         |        |         |      |       |                           |                        |       |      |         |          |          |         |      |        |          |      |
| 0x2E    | 0x6E              | LIN14    |      | Linearization Error Segment 29 Linearization Error Segment 28 |        |                   |          |         |          |         |        |         |      |       |                           |                        |       |      |         |          |          |         |      |        |          |      |
| 0x2F    | 0x6F              | LIN15    |      | Linearization Error Segment 31 Linearization Error Segment 30 |        |                   |          |         |          |         |        |         |      |       |                           |                        |       |      |         |          |          |         |      |        |          |      |
| _       | 0x80              | ALV      |      |                                                               |        |                   |          |         |          |         |        |         |      | Alive | counte                    | r                      |       |      |         |          |          |         |      |        |          |      |



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

## **EEPROM REFERENCE**

# Location 0x17 (CU2)

Customer-usable field, intended for storing data or turns counter.

This word can be written even if EEPROM is locked. Write may be allowed without the unlock code based on COM.DUR and COM.DEL settings (see word 0x1E).

### **CU2.CUSTOMER 2**

The field CUSTOMER 2 is a bit field located at address 0x17 [23:0]. This bit field is part of the location CU2.

Customer-usable field, intended for storing data or turns counter.

Depending on COM.DUR and COM.DEL settings, this word can be written even if EEPROM is locked. Details are given in the EEPROM Write Lock section.

# Location 0x18 (PWE)

#### PWE.OFE

The field OFE is a bit located at address 0x18 [0]. This bit is part of the location PWE.

PWM oscillator frequency watchdog error enable. Duty cycle output 5% at half the selected PWM frequency.

# **PWE.EUE**

The field EUE is a bit located at address 0x18 [1]. This bit is part of the location PWE.

PWM EEPROM uncorrectable error enable. Duty cycle 10.625% at half the selected PWM frequency.

## **PWE.STF**

The field STF is a bit located at address 0x18 [2]. This bit is part of the location PWE.

PWM self-test failure error enable. Duty cycle 16.25% at half the selected PWM frequency.

## **PWE.PLK**

The field PLK is a bit located at address 0x18 [3]. This bit is part of the location PWE.

PWM PLL lost lock error enable. Duty cycle 21.875% at half the selected PWM frequency.

### PWE.ZIE

The field ZIE is a bit located at address 0x18 [4]. This bit is part of the location PWE.

PWM zero-crossing integrity error enable. Duty cycle 27.5% at half the selected PWM frequency.

### **PWE.AVG**

The field AVG is a bit located at address 0x18 [5]. This bit is part of the location PWE.

PWM angle averaging error enable. Duty cycle is 33.125% at half the selected PWM frequency.

#### PWE.UV

The field UV is a bit located at address 0x18 [6]. This bit is part of the location PWE.

PWM undervoltage fault enable (analog or digital). Duty cycle 38.75% at half the selected PWM frequency.

### PWE.MSL

The field MSL is a bit located at address 0x18 [7]. This bit is part of the location PWE.

PWM magnetic sense low fault enable. Duty cycle 44.375% at half the selected PWM frequency.

### **PWE.ESE**

The field ESE is a bit located at address 0x18 [8]. This bit is part of the location PWE.

PWM EEPROM soft error enable. Duty cycle 50% at half the selected PWM frequency.

### **PWE.SAT**

The field SAT is a bit located at address 0x18 [9]. This bit is part of the location PWE.

PWM saturation warning enable. Duty cycle 55.625% at half the selected PWM frequency.

## PWE.MSH

The field MSH is a bit located at address 0x18 [10]. This bit is part of the location PWE.

PWM magnetic sense high fault enable. Duty cycle 61.25% at half the selected PWM frequency.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **PWE.TR**

The field TR is a bit located at address 0x18 [11]. This bit is part of the location PWE.

PWM temperature sensor out of range error enable. Duty cycle 66.875% at half the selected PWM frequency.

### **PWE.TOV**

The field TOV is a bit located at address 0x18 [12]. This bit is part of the location PWE.

PWM turns-counter overflow error enable. Duty cycle 72.5% at half the selected PWM frequency.

# PWE.ZCD\_TURNS\_OFFSET

The field ZCD\_TURNS\_OFFSET is a bit field located at address 0x18 [23:13]. This bit field is part of the location PWE.

Offset to ZCD angle for purposes of aligning for turns-counting. This is 11-bit angle resolution and is added to the ZCD angle for turns purposes. If the turns configuration uses the PLL (TCP = 1), it is important to use this to align the ZCD close to the PLL angle.

The value is already calibrated at the Allegro factory. However, if ZERO\_OFFSET is changed, linearization is used, and RD or RO is changed; recalibration of this value may be needed.

To recalibrate the ZCD\_TURNS\_OFFSET value, read the output registers ANGLE and ANGLE\_ZCD, and take the 12 LSB from these registers. Calculate the new value of ZCD\_TURNS\_OFFSET using these two measurements as follows:

 $ZCD\_TURNS\_OFFSET = mod( ( (mod((ANGLE - ANGLE ZCD), 4096) / 2) + ZCD TURNS OFFSET), 2048)$ 

In the formula above, the division by two is included to compensate for the fact that the angle resolution is 12 bits, while the ZCD\_TURNS\_OFFSET resolution is 11 bits.

A completely perfect alignment is not necessary and is not possible when using linearization. However, gross misalignments of  $>180^{\circ}$  cause turns-counting errors in combination with low-power mode if TCP = 1.

# Location 0x19 (ABI)

# ABI.RESOLUTION\_PAIRS

The field RESOLUTION\_PAIRS is a bit field located at address 0x19 [3:0]. This bit field is part of the location ABI.

ABI or UVW resolution.

If ABI selected, this selects AB cycle counts per rotation. Cycle count =  $2^{(14-n)}$  where n is the selected code.

If UVW is selected, this is the number of pole pairs minus 1.

### **ABI.UVW**

The field UVW is a bit located at address 0x19 [4]. This bit is part of the location ABI.

Incremental outputs UVW (1), ABI (0).

### ABI.IOE

The field IOE is a bit located at address 0x19 [5]. This bit is part of the location ABI.

Incremental output pins enable (see UVW).

### **ABI.PLH**

The field PLH is a bit located at address 0x19 [6]. This bit is part of the location ABI.

Enable ABI all high (before inversions) as error mode if PLL is unlocked.

## **ABI.WDH**

The field WDH is a bit located at address 0x19 [7]. This bit is part of the location ABI.

Enable ABI all high (before inversions) as error mode if high-frequency watchdog trips.

## ABI.INDEX\_MODE

The field INDEX\_MODE is a bit field located at address 0x19 [9:8]. This bit field is part of the location ABI.

ABI index mode, defines the width and placement of the index pulse.

Mode 0: Angle = 0 Mode 1: Angle = -R or 0 Mode 2: Angle = -R, 0 or +RMode 3: Angle = -2R, -R, 0 or +R



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

#### ABI.AHE

The field AHE is a bit located at address 0x19 [12]. This bit is part of the location ABI.

ABI hysteresis enable. If 1, use hysteresis on angle going to ABI.

## **ABI.INV**

The field INV is a bit located at address 0x19 [15]. This bit is part of the location ABI.

Invert ABI or UVW signals.

# ABI.ABI\_SLEW\_TIME

The field ABI\_SLEW\_TIME is a bit field located at address 0x19 [21:16]. This bit field is part of the location ABI.

ABI slew-rate limit. If 0, the slew-rate limiter is disabled. Otherwise,  $(N+1) \times 125$  ns (nominal) is the minimum edge-to-edge time for the ABI output. This limits the maximum ABI velocity. Reducing the ABI output resolution may be useful to counteract this effect.

# Location 0x1A (MSK)

## MSK.RSTM

The field RSTM is a bit located at address 0x1A [0]. This bit is part of the location MSK.

Reset mask. If set to 1, the corresponding error does not affect the error flag EF.

## MSK.MSLM

The field MSLM is a bit located at address 0x1A [1]. This bit is part of the location MSK.

Magnetic sense low fault mask. If set to 1, the corresponding error does not affect the error flag EF.

## MSK.UVAM

The field UVAM is a bit located at address 0x1A [2]. This bit is part of the location MSK.

Analog undervoltage fault mask. If set to 1, the corresponding error does not affect the error flag EF.

### MSK.UVDM

The field UVDM is a bit located at address 0x1A [3]. This bit is part of the location MSK.

Digital undervoltage fault mask. If set to 1, the corresponding error does not affect the error flag EF.

### MSK.OFEM

The field OFEM is a bit located at address 0x1A [4]. This bit is part of the location MSK.

Oscillator frequency watchdog error mask. If set to 1, the corresponding error does not affect the error flag EF.

### MSK.EUEM

The field EUEM is a bit located at address 0x1A [5]. This bit is part of the location MSK.

EEPROM uncorrectable error mask. If set to 1, the corresponding error doesnot affect the error flag EF.

### **MSK.ZIEM**

The field ZIEM is a bit located at address 0x1A [6]. This bit is part of the location MSK.

Zero-crossing integrity error mask. If set to 1, the corresponding error does not affect the error flag EF.

### MSK.PLKM

The field PLKM is a bit located at address 0x1A [7]. This bit is part of the location MSK.

PLL lost lock error mask. If set to 1, the corresponding error does not affect the error flag EF.

### **MSK.ABIM**

The field ABIM is a bit located at address 0x1A [8]. This bit is part of the location MSK.

ABI integrity fault mask. If set to 1, the corresponding error does not affect the error flag EF.

## MSK.AVGM

The field AVGM is a bit located at address 0x1A [9]. This bit is part of the location MSK.

Angle averaging fault mask. If set to 1, the corresponding error does not affect the error flag EF.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

### **MSK.STFM**

The field STFM is a bit located at address 0x1A [10]. This bit is part of the location MSK.

Self-test failure error mask. If set to 1, the corresponding error does not affect the error flag EF.

### MSK.WARM

The field WARM is a bit located at address 0x1A [11]. This bit is part of the location MSK.

If set to 1, does not set WAR bit in the ERR register when unmasked warnings are present.

### **MSK.TOVM**

The field TOVM is a bit located at address 0x1A [12]. This bit is part of the location MSK.

Turns-counter overflow error mask. If set to 1, the corresponding error does not affect the error flag EF.

### MSK.MSHM

The field MSHM is a bit located at address 0x1A [13]. This bit is part of the location MSK.

Magnetic sense high fault mask. If set to 1, the corresponding error does not affect the error flag EF.

# MSK.BSYM

The field BSYM is a bit located at address 0x1A [14]. This bit is part of the location MSK.

Indirect access busy error mask. If set to 1, the corresponding error will not affect the error flag EF.

# MSK.TCWM

The field TCWM is a bit located at address 0x1A [15]. This bit is part of the location MSK.

Turns-counter warning mask. If set to 1, the corresponding error does not affect the error flag EF.

### **MSK.SATM**

The field SATM is a bit located at address 0x1A [16]. This bit is part of the location MSK.

Aggregate saturation flag mask. If set to 1, the corresponding error does not affect the error flag EF.

#### MSK.ESEM

The field ESEM is a bit located at address 0x1A [17]. This bit is part of the location MSK.

EEPROM soft error mask. If set to 1, the corresponding error does not affect the error flag EF.

# MSK.TRM

The field TRM is a bit located at address 0x1A [18]. This bit is part of the location MSK.

Temperature sensor out of range error mask. If set to 1, the corresponding error does not affect the error flag EF.

#### MSK.XEEM

The field XEEM is a bit located at address 0x1A [19]. This bit is part of the location MSK.

Execute error mask. If set to 1, the corresponding error does not affect the error flag EF.

### **MSK.SRWM**

The field SRWM is a bit located at address 0x1A [20]. This bit is part of the location MSK.

Slew-rate warning mask. If set to 1, the corresponding error does not affect the error flag EF.

# MSK.CRCM

The field CRCM is a bit located at address 0x1A [22]. This bit is part of the location MSK.

CRC error mask (SPI). If set to 1, the corresponding error does not affect the error flag EF.

### **MSK.IERM**

The field IERM is a bit located at address 0x1A [23]. This bit is part of the location MSK.

Interface error mask. If set to 1, the corresponding error does not affect the error flag EF.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x1B (PWI)

### **PWI.SC**

The field SC is a bit located at address 0x1B [0]. This bit is part of the location PWI.

SPI CRC (incoming) validated if SC = 1, ignored if SC = 0.

### **PWI.S17**

The field S17 is a bit located at address 0x1B [1]. This bit is part of the location PWI.

SPI ignore 17th clock to allow negative-edge host sampling.

# PWI.H2T

The field H2T is a bit located at address 0x1B [2]. This bit is part of the location PWI. Turns uses hysteresis if 1.

- 0 =Use nonhysteresis angle for turns-counter
- 1 = Use hysteresis angle for turns-counter

This affects serial register TANG (0x3A).

## PWI.DM

The field DM is a bit located at address 0x1B [3]. This bit is part of the location PWI.

Disable Manchester interface. If 1, any Manchester input on VCC is ignored.

# PWI.WP\_THRES

The field WP\_THRES is a bit field located at address 0x1B [6:4]. This bit field is part of the location PWI.

WAKE pin voltage threshold.

### **PWI.ZAL**

The field ZAL is a bit located at address 0x1B [7]. This bit is part of the location PWI.

Zero offset after linearization:

- 0 =Before linearization and rotation
- 1 = After linearization

# PWI.WP\_HYS

The field WP\_HYS is a bit field located at address 0x1B [9:8]. This bit field is part of the location PWI.

WAKE pin hysteresis.

#### **PWI.LS**

The field LS is a bit located at address 0x1B [10]. This bit is part of the location PWI.

Linearization scale:

 $0 = \pm 22.5$  degrees

 $1 = \pm 45$  degrees

### **PWI.ELI**

The field ELI is a bit located at address 0x1B [11]. This bit is part of the location PWI.

Enable linearization:

0 = Disabled

1 = Enabled

Note: If ZERO\_OFFSET is changed, linearization is used, and RD or RO is changed; recalibration of ZCD\_TURNS\_OFFSET may be needed. For further information, see the ZCD\_TURNS\_OFFSET description.

### **PWI.PES**

The field PES is a bit located at address 0x1B [12]. This bit is part of the location PWI.

PWM error select (if PEO = 1).

0 = PWM tristated, must reset (or set PEO back to 0 in shadow) to release the PWM output.

1 = PWM carrier frequency is halved, and the highest-priority error is output on PWM as the selected duty cycle. See PWM Output section for more details.

### **PWI.PEO**

The field PEO is a bit located at address 0x1B [13]. This bit is part of the location PWI.

PWM error output enable. If 1, PES selects the response to an enabled error (see ABE word).

## **PWI.PHE**

The field PHE is a bit located at address 0x1B [14]. This bit is part of the location PWI.

PWM hysteresis enable. If 1, use hysteresis on the angle going to PWM.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

## PWI.PWM\_FREQ

The field PWM\_FREQ is a bit field located at address 0x1B [19:16]. This bit field is part of the location PWI.

PWM frequency select. See PWM Output section for more details.

# PWI.PWM\_BAND

The field PWM\_BAND is a bit field located at address 0x1B [22:20]. This bit field is part of the location PWI.

PWM frequency band. See PWM Output section for more details.

### **PWI.PEN**

The field PEN is a bit located at address 0x1B [23]. This bit is part of the location PWI.

PWM enable = 1.

If 0, PWM is tristate.

# Location 0x1C (ANG)

# ANG.ZERO\_OFFSET

The field ZERO\_OFFSET is a bit field located at address 0x1C [11:0]. This bit field is part of the location ANG.

Post-compensation zero offset (or DC adjust) at angle resolution. This value is subtracted from the measured angle.

Note: If ZERO\_OFFSET is changed, linearization is used, and RD or RO is changed; recalibration of ZCD\_TURNS\_OFFSET may be needed. For further information, see the ZCD\_TURNS\_OFFSET description.

### **ANG.HYSTERESIS**

The field HYSTERESIS is a bit field located at address 0x1C [17:12]. This bit field is part of the location ANG.

Angle hysteresis threshold, angle resolution  $\times$  4 (14 bit). Range is approximately 0 degrees to 1.384 degrees.

#### ANG.RO

The field RO is a bit located at address 0x1C [18]. This bit is part of the location ANG.

Rotation direction (post-linearization). If set to 0, increasing angle movement is in the clockwise direction when looking down on the top of the die. If set to 1, increasing angle movement is in the counterclockwise direction.

Note: If ZERO\_OFFSET is changed, linearization is used, and RD or RO is changed; recalibration of ZCD\_TURNS\_OFFSET may be needed. For further information, see the ZCD\_TURNS\_OFFSET description.

### ANG.RD

The field RD is a bit located at address 0x1C [19]. This bit is part of the location ANG.

Rotate die. Rotates final angle by 180 degrees. This is the last step in the angle processing algorithm. The sensor is Allegro factory-calibrated to deliver identical field directions for both dies. If the user wants the two outputs to be 180° offset from each other, this setting is a convenient way to do so.

Note: If ZERO\_OFFSET is changed, linearisation is used, and RD or RO is changed; recalibration of ZCD\_TURNS\_OFFSET may be needed. For further information, see the ZCD\_TURNS\_OFFSET description.

# ANG.ORATE

The field ORATE is a bit field located at address 0x1C [23:20]. This bit field is part of the location ANG.

Reduces the output rate by averaging samples. 2<sup>ORATE</sup> samples are averaged. ORATE values greater than 12 are reduced to 12 in the logic, meaning that up to 4096 samples = 4 ms can be selected as the averaging time.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x1D (LPC)

# LPC.LPM\_WAKE\_THRESHOLD

The field LPM\_WAKE\_THRESHOLD is a bit field located at address 0x1D [10:0]. This bit field is part of the location LPC.

Minimum sample-to-sample angle difference in low-power mode to force a switch to typical power mode. Also used as maximum angle difference in typical power mode to determine if the device can enter low-power mode. In both cases, the angle difference is calculated over the time given in LPM\_CYCLE\_TIME. Resolution is 11 bits, for values of 0 degrees to 180 degrees, with resolution of (360/4096) degrees per LSB. Setting values close to 180 degrees can result in dangerous ambiguity and is not recommended.

## LPC.TCP

The field TCP is a bit located at address 0x1D [11]. This bit is part of the location LPC.

Turns-counter PLL:

0 = Turns uses ZCD angle.

1 = Turns uses PLL except during LPM and if PLL lock is lost. Ensure the ZCD\_TURNS\_OFFSET aligns the ZCD angle close to the PLL angle.

## LPC.LPT

The field LPT is a bit located at address 0x1D [11]. This bit is part of the location LPC.

Low-power transport:

0 = Low-power mode requires CTRL to enable transport mode.

1 = Low-power mode (SPI pins low) automatically enters transport mode.

# LPC.LPM\_CYCLE\_TIME

The field LPM\_CYCLE\_TIME is a bit field located at address 0x1D [17:12]. This bit field is part of the location LPC.

Low-power cycle time in 8.192 ms increments with cycle time =  $[(N + 1) \times 8.192$  ms]. Also determines the alive-counter increment rate.

## LPC.TURNS\_INIT

The field TURNS\_INIT is a bit field located at address 0x1D [19:18]. This bit field is part of the location LPC.

Turns initialization at power-up.

00, 01 = Turns-counter zeroed at power-up.

10 = Turns-counter set to full settled angle (turns register may be non-zero).

11 = Turns-counter set to settled angle offset from 180-degree or 45-degree configuration (MSB 10 or 12 bits zeroed), turns register starts at zero.

### LPC.LPMD

The field LPMD is a bit located at address 0x1D [20]. This bit is part of the location LPC.

Disable low-power mode if 1.

## LPC.TPMD

The field TPMD is a bit located at address 0x1D [21]. This bit is part of the location LPC.

Disable transport mode if 1.

### LPC.T45

The field T45 is a bit located at address 0x1D [23]. This bit is part of the location LPC.

Turns-counter steps at 45-degree boundaries if 1, and at 180-degree boundaries if 0.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x1E (COM) COM.MAG\_THRES\_LO

The field MAG\_THRES\_LO is a bit field located at address 0x1E [5:0]. This bit field is part of the location COM.

Magnetic field low comparator value, field value equals low field error threshold in gauss divided by 16.

If set to 0, low threshold is disabled.

00 0000: Low-field flag disabled 00 0001: 16 gauss 00 0010: 32 gauss ... 00 1101: 208 gauss (factory setting) ... 11 1111: 1108 gauss

# COM.MAG\_THRES\_HI

The field MAG\_THRES\_HI is a bit field located at address 0x1E [11:6]. This bit field is part of the location COM.

Magnetic field high comparator value, field value equals maximum field threshold in gauss divided by 32. If set to 0, high threshold is disabled.

00 0000: High-field flag disabled 00 0001: 32 gauss 00 0010: 64 gauss ... 10 0101: 1184 gauss (factory setting) ... 11 1111: 2016 gauss

### COM.DHR

The field DHR is a bit located at address 0x1E [12]. This bit is part of the location COM.

Disable hard reset in serial CTRL register special if 1.

## COM.DST

The field DST is a bit located at address 0x1E [13]. This bit is part of the location COM.

Disable self-test initiation in serial CTRL register SPECIAL if 1.

### COM.CUD

The field CUD is a bit located at address 0x1E [14]. This bit is part of the location COM.

If 1, the customer word 0x1F uses the DUR and DEL configuration in addition to the CUSTOMER2 word 0x17.

## COM.DEL

The field DEL is a bit located at address 0x1E [16]. This bit is part of the location COM.

Disable EEPROM lock for CUST2 (EEPROM word 0x17) and, if CUD = 1, CUST word 0x1F. EEPROM lock does not affect writeability of word 0x17 (and 0x1F if enabled). Intended for turns-counter savings.

### COM.DUR

The field DUR is a bit located at address 0x1E [17]. This bit is part of the location COM.

Disable unlock requirement for CUST2 (EEPROM word 0x17) and if CUD = 1, CUST word 0x1F.

### COM.CSE

The field CSE is a bit located at address 0x1E [18]. This bit is part of the location COM.

Enable CVH self-test at power-up.

# COM.LBE

The field LBE is a bit located at address 0x1E [19]. This bit is part of the location COM.

Power-up logic BIST enable.

### **COM.LOCK**

The field LOCK is a bit field located at address 0x1E [23:20]. This bit field is part of the location COM.

Lock options:

1100 = Lock EEPROM writes.

0011 = Lock EEPROM writes AND indirect register writes.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

# Location 0x1F (CUS)

### **CUS.CUSTOMER**

The field CUSTOMER is a bit field located at address 0x1F [23:0]. This bit field is part of the location CUS.

Customer-usable field, intended for storing data.

With certain settings, this word can be written even if EEPROM is locked. Details are given in the EEPROM Write Lock section.

If COM.CUD = 1, then, depending on COM.DUR and COM. DEL settings, this word can be written even if EEPROM is locked. Details are given in the EEPROM Write Lock section.

# Location 0x20 (LIN00)

## **LIN00.LINEARIZATION ERROR SEGMENT 0**

The field LINEARIZATION ERROR SEGMENT 0 is a bit field located at address 0x20 [11:0]. This bit field is part of the location LIN00.

Correction value at segment boundary. Signed, resolution is based on LS bit. Is subtracted from sensor angle to produce linearized angle.

For LS = 0, range is  $\pm 22.5$  degrees. For LS = 1, range is  $\pm 45$  degrees.

## **LIN00.LINEARIZATION ERROR SEGMENT 1**

The field LINEARIZATION ERROR SEGMENT 1 is a bit field located at address 0x20 [23:12]. This bit field is part of the location LIN00.

Correction value at segment boundary. Signed, resolution is based on LS bit. Is subtracted from sensor angle to produce linearized angle.

For LS = 0, range is  $\pm 22.5$  degrees. For LS = 1, range is  $\pm 45$  degrees.

NOTE: linearization segments 2 through 29 have been omitted from the datasheet for reasons of brevity.

# Location 0x2F (LIN15)

## **LIN15.LINEARIZATION ERROR SEGMENT 30**

The field LINEARIZATION ERROR SEGMENT 30 is a bit field located at address 0x2F [11:0]. This bit field is part of the location LIN15.

Correction value at segment boundary. Signed, resolution is based on LS bit. Is subtracted from sensor angle to produce linearized angle.

For LS = 0, range is  $\pm 22.5$  degrees. For LS = 1, range is  $\pm 45$  degrees.

### **LIN15.LINEARIZATION ERROR SEGMENT 31**

The field LINEARIZATION ERROR SEGMENT 31 is a bit field located at address 0x2F [23:12]. This bit field is part of the location LIN15.

Correction value at segment boundary. Signed, resolution is based on LS bit. Is subtracted from sensor angle to produce linearized angle.

For LS = 0, range is  $\pm 22.5$  degrees. For LS = 1, range is  $\pm 45$  degrees.

# Location 0x80 (ALV)

#### **ALV.ALIVE COUNTER**

The field ALIVE COUNTER is a bit field located at address 0x80 [31:0]. This bit field is part of the location ALV.

ALIVE COUNTER is a 32-bit counter, which increments periodically from zero after power-on or hard reset. The alive increment period is based on the EEPROM LPM\_CYCLE\_TIME, which has a resolution of 8.192 ms. The ALIVE COUNTER can overflow. The overflow period of the counter is  $[2^{32} \times 8.192 \times (LPM\_CYCLE\_TIME + 1)]$  milliseconds. At CYCLE\_TIME = 0, this period is approximately 400 days.



# Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization

## SAFETY AND DIAGNOSTICS

The AAS33051 was developed in accordance with the ASIL design flow. It incorporates several diagnostics.

## **Alive Counter**

A 32-bit counter increments periodically from zero after power-on or hard reset. It is read via an extended read at address 0x80. The alive increment period is based on the EEPROM LPM\_CYCLE\_TIME, which has a resolution of 8.192 ms.

The alive counter can overflow. The overflow period of the counter is  $[2^{32} \times 8.192 \times (LPM\_CYCLE\_TIME + 1)]$  milliseconds. At LPM\_CYCLE\_TIME = 0, this period is approximately 400 days.

# **Oscillator Watchdogs**

The watchdogs run constantly when in full power or wake mode. They are disabled during sleep mode and are reset when waking up to ensure there is not a false positive due to a partial clock count. These watchdogs are intended to detect gross failures of either oscillator. Logic running on clocks based on each oscillator effectively counts clock periods produced in the other clock domain and compares the counts to the expected limits.

# Logic Built-In Self-Test (LBIST)

Logic BIST is implemented to verify the integrity of the AAS33051 logic. It can be executed in parallel with the CVH self-test. LBIST is effectively a form of auto-driven scan. The logic to be tested is divided into 31 scan chains. The chains are fed in parallel by a 31-bit linear-feedback shift register (LFSR)

to generate pseudo-random data. The output of the scan chains is fed back into a multiple-input shift register (MISR) that accumulates the shifted bits into a 31-bit signature. Verification of LBIST typically takes 30 ms.

## **CVH Self-Test**

CVH self-test is a method of verifying the operation of the CVH transducer without applying an external magnetic field. This feature is useful for both manufacturing test and for integration debug. The CVH self-test is implemented by changing the switch configuration from the typical operating mode into a test configuration, allowing a test current to drive the CVH in place of the magnetic field. By changing the direction of the test current and by changing the elements in the CVH that are driven, the self-test circuit emulates a changing angle of magnetic field. The measured angle is monitored to determine a passing or failing device.

Verification of CVH self-test typically takes 30 ms.

Self-test can be run on power-up, by setting the EEPROM field SHA.COM.CSE = 1

Self-test can also be invoked via the serial control register by issuing the corresponding special command.

The test is complete when either:

- STA.SDN = 1 (special done) or
- STA.CSTR = 0 (CVH self-test not running).

Failure is indicated by:

• ERR.STF = 1 (assuming it was cleared before test was run).



# **APPLICATION INFORMATION**

# **Magnetic Target Requirements**

The AAS33051 is designed to operate with magnets constructed with a variety of magnetic materials, geometries, and field strengths. For a list of common magnet dimensions, see Table 15.

The AAS33051 actively measures and adapts to its magnetic environment. This allows operation throughout a large range of field strengths (recommended range is 300 to 1000 G; however, operation beyond this range does not result in long-term damage). Due to the greater signal-to-noise ratio provided at higher field strengths, performance inherently increases with increasing field strength.

**Table 15: Target Magnet Parameters** 

| Magnetic Material        | Diameter<br>(mm) | Thickness<br>(mm) |  |  |  |
|--------------------------|------------------|-------------------|--|--|--|
| Neodymium (Sintered) [1] | 10               | 2.5               |  |  |  |
| Neodymium (Sintered)     | 8                | 3                 |  |  |  |
| Neodymium/SmCo           | 6                | 2.5               |  |  |  |
| Thickness                | Diameter         |                   |  |  |  |

<sup>[1]</sup> A sintered neodymium magnet with 10 mm (or greater) diameter and 2.5 mm thickness is the recommended magnet for redundant applications.



Figure 39: Magnetic Field versus Air Gap for a Magnet 6 mm in Diameter and 2.5 mm Thick

Allegro can provide similar curves for customer application magnets upon request. Allegro recommends larger magnets for applications that require optimized accuracy performance.

# Typical SPI and ABI/UVW Applications

Typical application diagrams for SPI and ABI/UVW are shown in Figure 40 and Figure 41. Programming and controlling are possible using the SPI interface and the Manchester interface. The

Manchester programming interface is useful for low-pin-count applications (e.g., ABI). For details about programming with this interface, see the Manchester Interface section.



Figure 40: Typical SPI Application Diagram

## Notes:

- PWM and ABI/UVW can be used in parallel to the SPI interface.
- Entering and exiting low-power mode is controlled using the SPI lines.
- The WAKE pin does not have to be used but should be grounded if unused.





Figure 41: Typical ABI/UVW Application Diagram

## Notes:

- Entering and exiting low-power mode is controlled using the CSB, MOSI, and SCLK line. It is possible to connect CSB, MOSI, and SCLK together and connect them to the microcontroller on one line to control entering/exiting low-power mode, if required.
- PWM output can be left floating, if not required. The absolute position is transferred through ABI pins after power-on, so that PWM data is not needed to find the start position. The AAS33051 is different from the A1339 in this regard.
- For programming the sensor, CSB and MOSI determine the peripheral address. For more details, refer to the Manchester Interface section.
- If not needed by the host, any of the ABI outputs can be left floating. For example:
  - $\hfill\Box$  If only rotational frequency is needed, it is possible to use only pin A.
  - □ If frequency and position is needed, but direction is always the same, it is possible to use only pin B and pin I.



# I/O STRUCTURES











# PACKAGE OUTLINE DRAWINGS



Figure 42: Package LP, 24-Pin TSSOP with Exposed Thermal Pad





Figure 43: Package LE, 14-Pin TSSOP



# **Precision Angle Sensor IC with Incremental and Motor Commutation Outputs and On-Chip Linearization**

## **Revision History**

| Number | Date              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _      | March 27, 2018    | Initial release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1      | April 18, 2018    | Corrected selection guide part numbers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2      | August 29, 2018   | Updated Terminal List table (page 4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3      | July 14, 2020     | Updated LE-14 and LP-24 package drawing Hall element tolerances (p. 74-75) and minor editorial updates.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4      | October 27, 2020  | Added 5 V variant (pages 3, 5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5      | October 24, 2022  | Updated package drawings (pages 74-75) and minor editorial updates                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6      | November 27, 2023 | Reformatted register notation throughout document to current standard                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7      | January 25, 2024  | Updated Table 2 (page 10), Linearization section (page 14), Figure 8 (page 18), Table 14 (page 59).                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 8      | May 14, 2024      | Corrected reverse voltage rating (page 3), updated EEPROM margin test (page 46) and made minor editorial corrections throughout (all pages) including: removal of archaic language (master changed to controller, slave changed to peripheral, and normal changed to typical), removal of future tense ("will") wherever possible, minimization of use of title case (except for headings and captions), removal of trailing zeros to the right of decimal points, and addition of hyperlinks for cross-referenced sections. |

Copyright 2024, 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.

For the latest version of this document, visit our website:

www.allegromicro.com



# **Mouser Electronics**

**Authorized Distributor** 

Click to View Pricing, Inventory, Delivery & Lifecycle Information:

Allegro MicroSystems:

AAS33051LLEATR AAS33051LLPBTR-DD