

# **MA600A**

High-Accuracy, <0.6° (<0.1°) INL, High-Bandwidth, Configurable Digital Magnetic Angle Sensor

# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# DESCRIPTION

The MA600A is a precision, high-bandwidth magnetic angle sensor that detects the absolute angular position of a permanent magnet, typically a diametrically magnetized cylinder on a rotating shaft. Integrated with a precision tunnel magnetoresistance (TMR) sensor, the MA600A achieves high-bandwidth and high accuracy (INL), making it an ideal solution for position control and robotics.

The MA600A supports a wide range of magnetic field strengths and mounting configurations: end-of-shaft (on-axis) and side-shaft (off-axis).

On-chip non-volatile memory (NVM) provides storage for configuration parameters, including the reference zero-angle position, ABZ, UVW, and PWM settings.

The MA600A is factory-calibrated to achieve an error (INL) below 0.6° across its operating temperature range. Furthermore, a final system calibration is available through a 32-point user configurable correction table. The resulting error (INL) after user calibration can be smaller than 0.1°.

Communication with the MA600A can be done via serial peripheral interface (SPI) and synchronous serial interface (SSI).

Daisy Chain configuration is supported. It allows sequential SPI angle readout of multiple sensors minimizing the number of I/O pins used by the controller device.

The MA600A is available in a small QFN-16 (3mmx3mm) package.

# **FEATURES**

- <0.6° Error (INL)</li>
- <0.1° Error (INL) After User Calibration with On-Chip 32-Point Lookup Table
- Configurable 12-Bit to 15-Bit Absolute Angle Encoder
- High Bandwidth (e.g. 12kHz at 12.5-Bit Resolution)
- No Latency
- Wide 10mT to 100mT Magnetic Field Range
- Serial Peripheral Interface (SPI) for Digital Angle Readout and Chip Configuration
- SPI Angle Readout in Daisy Chain Configuration Supported
- Synchronous Serial Interface (SSI) for Digital Angle Readout
- Incremental ABZ Quadrature Encoder Interface with Configurable Pulses per Turn (1 to 4096)
- Incremental UVW Encoder Output
- Pulse-Width Modulation (PWM) Absolute Output
- Multi-Turn or Speed Output Option
- 3.3V Supply
- 7.5mA Quiescent Current (I<sub>AVDD</sub> + I<sub>DVDD</sub>)
- -40°C to +125°C Operating Temperature
- Available in a Small QFN-16 (3mmx3mm) Package

# **APPLICATIONS**

- Robotics
- Multi-Turn Encoders
- Position Control
- Speed Control

All MPS parts are lead-free, halogen-free, and adhere to the RoHS directive. For MPS green status, please visit the MPS website under Quality Assurance. "MPS", the MPS logo, and "Simple, Easy Solutions" are trademarks of Monolithic Power Systems, Inc., or its subsidiaries.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# TYPICAL APPLICATION



# **Configurable Filter Window** to Optimize Resolution vs. Bandwidth (BW)

| Digital<br>Filter<br>Window<br>FW | Noise-Free<br>Resolution<br>(Bits) | Latency<br>Cancellation<br>at Constant<br>Speed | Bandwidth<br>(kHz) |
|-----------------------------------|------------------------------------|-------------------------------------------------|--------------------|
| 0                                 | 12.3                               | No                                              | 17                 |
| 5 (default)                       | 12.5                               | Yes                                             | 12                 |
| 6                                 | 13                                 | Yes                                             | 5.8                |
| 7                                 | 13.5                               | Yes                                             | 2.7                |
| 8                                 | 14                                 | Yes                                             | 1.3                |
| 9                                 | 14.3                               | Yes                                             | 0.63               |
| 10                                | 14.6                               | Yes                                             | 0.31               |
| 11                                | 14.8                               | Yes                                             | 0.15               |
| 12                                | 15                                 | Yes                                             | 0.075              |



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

### ORDERING INFORMATION

| Part Number*          | Package          | Top Marking | MSL Rating |
|-----------------------|------------------|-------------|------------|
| MA600AGQE-0000        | OEN 16 (2mmy2mm) | See Below   | 1          |
| MA600AGQE-xxxx**      | QFN-16 (3mmx3mm) | See Delow   | ı          |
| TBMA600A-Q-LT         | Test Board       | N/A         | N/A        |
| EVKT-MagAlpha-MagDiff | Evaluation kit   | N/A         | N/A        |

<sup>\*</sup> For Tape & Reel, add suffix -Z (e.g.: MA600AGQE-xxxx-Z).

# TOP MARKING

**CLGY** LLLL

CLG: MPS product code of MA600AGQE-xxxx

Y: Year code LLLL: Lot number

### **EVALUATION KIT EVKT-MAGALPHA-MAGDIFF**

EVKT-MagAlpha-MagDiff kit contents (items below can be ordered separately):

| # | Part Number        | Item                                                     |   |
|---|--------------------|----------------------------------------------------------|---|
| 1 | EVKT-MA-RP-PICO-V2 | MagAlpha and MagDiff evaluation board with MCU.          | 1 |
| 2 | Ribbon cable       | 8 conductors, flat ribbon cable.                         | 2 |
| 3 | USB cable          | USB cable, A Male to Micro B Male.                       | 1 |
| 4 | Online resources   | Include GUI, python library, and supplementary documents | - |

Order directly from MonolithicPower.com or our distributors.



Figure 1: EVKT-MagAlpha-MagDiff Evaluation Kit Set-Up

<sup>\*\* &</sup>quot;xxxx" is the configuration code identifier for the register settings. The first four digits of the suffix ("xxxx") can be a hexadecimal value between 0 and F. Work with an MPS FAE to create this unique number for the nondefault function option. "0000" is the factory default code.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# PACKAGE REFERENCE





# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **PIN FUNCTIONS**

| Pin#  | Name  | Description                                                                                                                                                                                                |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIII# | Name  | •                                                                                                                                                                                                          |
| 1     | IO1   | <b>Digital input/output (I/O) 1.</b> The IO1 pin is bidirectional and configured as push-pull by default. (1) Float IO1 if not used.                                                                       |
| 2     | 102   | <b>Digital I/O 2.</b> The IO2 pin is bidirectional and configured as push-pull by default. (1) Float IO2 if not used.                                                                                      |
| 3     | IO3   | <b>Digital I/O 3.</b> The IO3 pin is bidirectional and configured as push-pull by default. (1) Float IO3 if not used.                                                                                      |
| 4     | COPI  | <b>Serial peripheral interface (SPI) data in.</b> The COPI pin is pulled down internally. <sup>(2)</sup> Connect COPI to GND if not used.                                                                  |
| 5     | /CS   | SPI chip selection. The /CS pin is pulled up internally. (2) Connect /CS to DVDD if not used.                                                                                                              |
| 6     | 104   | <b>Digital I/O 4.</b> The IO4 pin is bidirectional and configured as push-pull by default. (1) Float IO4 if not used.                                                                                      |
| 7     | CIPO  | <b>SPI data out.</b> The CIPO pin is configured as push-pull when the SPI is active. CIPO is configured as pull-down when the SPI is idle. Float CIPO if not used.                                         |
| 8     | GND   | Supply ground.                                                                                                                                                                                             |
| 9     | IO5   | <b>Digital I/O 5.</b> The IO5 pin is bidirectional and configured as push-pull by default. (1) Float IO5 if not used.                                                                                      |
| 10    | TEST  | Test. Connect the TEST pin to GND.                                                                                                                                                                         |
| 11    | CK100 | <b>Clock output reference for speed calculation.</b> Float the CK100 pin if not used. Pin is internally pulled down to GND when CK100 bit in register IF is 0.                                             |
| 12    | SCLK  | SPI clock. The SCLK pin is pulled down internally. (2) Connect SCLK to GND if not used.                                                                                                                    |
| 13    | DVDD  | <b>Digital supply 3.3V.</b> Bypass the DVDD pin to GND with a 0.1µF, low ESR capacitor. See the Electrical Mounting and Power Supply Decoupling section on page 41 for details on the layout reference.    |
| 14    | AVDD  | <b>Analog supply 3.3V.</b> Bypass the AVDD pin to GND with a $1\mu F$ , low ESR capacitor. See the Electrical Mounting and Power Supply Decoupling section on page 41 for details on the layout reference. |
| 15    | IO6   | <b>Digital I/O 6.</b> The IO6 pin is bidirectional and configured as push-pull by default. (1) Float IO6 if not used.                                                                                      |
| 16    | NC    | Do not connect. Pin is internally pulled down to GND.                                                                                                                                                      |
| 17    | E-PAD | E-pad. No connection. Float the E-PAD pin.                                                                                                                                                                 |

#### Notes:

- 1) Can be configured as open drain with the OD615 and OD243 parameters.
- 2) Can be configured to high impedance with the SPULLIN parameter.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

| ABSOLUTE MAXIMUM                                                                                                                                                          | RATINGS (3)                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| Supply voltage (V <sub>AVDD</sub> , V <sub>DVDD</sub> )<br>Input pin voltage (V <sub>I</sub> )<br>Output pin voltage (V <sub>O</sub> )<br>Continuous power dissipation (7 | 0.5V to +6\<br>0.5V to +6\ |
|                                                                                                                                                                           | 2W                         |
| Lead temperature  Operating temperature  Maximum magnetic field                                                                                                           | 260°C<br>-40°C to +125°C   |
| ESD Ratings                                                                                                                                                               |                            |
| Human body model (HBM)                                                                                                                                                    | ±2k\                       |

Charged-device model (CDM).....±2kV

| Recommended Operating Conditions (5)      |                |  |  |  |
|-------------------------------------------|----------------|--|--|--|
| V <sub>AVDD</sub> , V <sub>DVDD</sub>     | 3V to 3.6V     |  |  |  |
| Operating junction temp (T <sub>J</sub> ) | 40°C to +125°C |  |  |  |

#### Notes:

- 3) Exceeding these ratings may damage the device.
- 4) The maximum allowable power dissipation is a function of the maximum junction temperature, T<sub>J</sub> (MAX), the junction-to-ambient thermal resistance, θ<sub>JA</sub>, and the ambient temperature, T<sub>A</sub>. The maximum allowable continuous power dissipation at any ambient temperature is calculated by P<sub>D</sub> (MAX) = (T<sub>J</sub> (MAX) T<sub>A</sub>) / θ<sub>JA</sub>. Exceeding the maximum allowable power dissipation can produce an excessive die temperature, which may cause the regulator to go into thermal shutdown. Internal thermal shutdown circuitry protects the device from permanent damage.
- The device is not guaranteed to function outside of its operating conditions.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **ELECTRICAL CHARACTERISTICS**

 $V_{AVDD} = V_{DVDD} = 3.3V$ ,  $T_A = -40$ °C to +125°C, typical values at  $T_A = 25$ °C, unless otherwise noted.

| Parameter                                              | Symbol                                | Condition                                                     | Min  | Тур   | Max  | Units |
|--------------------------------------------------------|---------------------------------------|---------------------------------------------------------------|------|-------|------|-------|
| Power Supply                                           | •                                     | •                                                             | •    |       |      |       |
| Cumply valtage                                         | V <sub>AVDD</sub>                     |                                                               | 3    | 3.3   | 3.6  | V     |
| Supply voltage                                         | $V_{DVDD}$                            |                                                               | 3    | 3.3   | 3.6  | V     |
| V <sub>DD</sub> under-voltage lockout (UVLO) threshold | V <sub>DD_UVLO</sub>                  | V <sub>DD</sub> rising, V <sub>AVDD</sub> = V <sub>DVDD</sub> |      |       | 2.95 | V     |
| V <sub>DD</sub> UVLO hysteresis                        | V <sub>DD_UVLO_</sub>                 | V <sub>AVDD</sub> = V <sub>DVDD</sub>                         | 30   |       |      | mV    |
| Supply current                                         | I <sub>AVDD</sub> + I <sub>DVDD</sub> | T <sub>A</sub> = 25°C                                         | 5.5  | 7.5   | 9.5  | mA    |
| Supply current drift                                   |                                       | $T_A = -40^{\circ}\text{C to } +125^{\circ}\text{C}$          |      | 0.006 |      | mA/°C |
| Digital Input/Output (I/O)                             |                                       |                                                               |      |       |      |       |
| Input high voltage                                     | ViH                                   |                                                               | 2.5  |       | 5.5  | V     |
| Input low voltage                                      | VIL                                   |                                                               | -0.3 |       | +0.8 | V     |
| Push-Pull Option                                       |                                       |                                                               |      |       |      |       |
| Output low voltage                                     | V <sub>OL_PP</sub>                    | I <sub>OL</sub> = 12mA                                        |      |       | 0.4  | V     |
| Output high voltage                                    | V <sub>OH_PP</sub>                    | I <sub>OH</sub> = 12mA                                        | 2.4  |       |      | V     |
| Pull-up resistor                                       | R <sub>PU</sub>                       | $V_{I} = GND$                                                 |      | 80    |      | kΩ    |
| Pull-down resistor                                     | R <sub>PD</sub>                       | $V_I = DVDD$                                                  |      | 30    |      | kΩ    |
| Rising edge slew rate                                  | T <sub>R</sub>                        | C <sub>LOAD</sub> = 50pF                                      |      | 0.7   |      | V/ns  |
| Falling edge slew rate                                 | T <sub>F</sub>                        | C <sub>LOAD</sub> = 50pF                                      |      | 0.7   |      | V/ns  |
| Open-Drain Option                                      | •                                     |                                                               |      |       |      |       |
| Output low voltage                                     | V <sub>OL_OD</sub>                    | I <sub>OL</sub> = 12mA                                        |      |       | 0.4  | V     |
| Output high voltage (6)                                | V <sub>OH_OD</sub>                    | Supplied by external pull-up resistor                         |      |       | 5.5  | V     |
| Open-drain leakage current                             |                                       |                                                               |      | 100   |      | nA    |



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **GENERAL CHARACTERISTICS**

 $V_{\text{AVDD}} = V_{\text{DVDD}} = 3.3 \text{V}$ , 20mT < B < 80mT,  $T_{\text{A}} = -40 ^{\circ}\text{C}$  to +125°C, typical values at  $T_{\text{A}} = 25 ^{\circ}\text{C}$  and B = 45mT, unless otherwise noted.

| Parameter                   | Symbol           | Condition                                                                       | Min   | Тур    | Max    | Units  |
|-----------------------------|------------------|---------------------------------------------------------------------------------|-------|--------|--------|--------|
| Operating temperature       | T <sub>OP</sub>  |                                                                                 | -40   |        | +125   | °C     |
| Applied we are at a field   | Б                | Optimal linearity                                                               | 20    |        | 80     | mT     |
| Applied magnetic field      | В                | Functional                                                                      | 10    |        | 150    | mT     |
| Absolute Output (Serial)    |                  |                                                                                 |       |        |        |        |
| Resolution (6)              |                  | ±3σ noise deviation                                                             | 12    |        | 15     | bit    |
| Noise RMS (6)               |                  |                                                                                 | 0.002 |        | 0.015  | deg    |
| Refresh rate                | frefresh         | $T_A = 25^{\circ}C$                                                             | 780   | 800    | 820    | kHz    |
| Oscillator drift            |                  | $T_A = -40 \text{ to } +85^{\circ}\text{C}$                                     |       | -30    |        | ppm/°C |
| Oscillator drift            |                  | T <sub>A</sub> = 85 to 125°C                                                    |       | -100   |        | ppm/°C |
| Data output length          |                  |                                                                                 |       | 16     |        | bit    |
| Response Time               |                  |                                                                                 |       |        |        |        |
| Start-up time (6)           |                  | FW = 0, T <sub>A</sub> = 25°C                                                   |       |        | 250    | μs     |
| Latency (added time beyond  | L                | FW = 0                                                                          |       | 32     |        | μs     |
| refresh time) (6)           | L                | FW = 5 to 12                                                                    | -0.5  |        | 0.5    | μs     |
| Cutoff frequency            | fcutoff          | FW = 0                                                                          |       | 17     |        | kHz    |
| Accuracy                    |                  |                                                                                 |       |        |        |        |
|                             |                  | $T_A = 25^{\circ}C, B = 45mT$                                                   |       | 0.2    | 0.6    | deg    |
| Integral non-linearity (6)  | INL              | After user calibration with on-<br>chip 32-point lookup table,<br>$T_A = 25$ °C |       | 0.06   | 0.1    | deg    |
| Output Drift                | ·                |                                                                                 |       | 1      | •      | •      |
| T                           |                  | T <sub>A</sub> = -40 to +85°C                                                   |       | 0.0015 | 0.0045 | deg/°C |
| Temperature induced (6)     |                  | T <sub>A</sub> = 85 to 125°C                                                    |       | 0.005  | 0.02   | deg/°C |
| Magnetic field induced (6)  |                  | T <sub>A</sub> = 25°C                                                           |       | 0.004  | 0.007  | deg/mT |
| Voltage supply induced (6)  |                  | B = 45mT, T <sub>A</sub> = 25°C                                                 |       | 0.1    | 0.3    | deg/V  |
| Functional Test Mode        |                  |                                                                                 |       |        |        |        |
| Functional test accuracy    |                  |                                                                                 |       | 2      |        | deg    |
| Absolute Output (PWM)       |                  |                                                                                 |       |        |        |        |
| Pulse-width modulation      | 4                | $PWMF = 1, T_A = 25^{\circ}C$                                                   | 243   | 250    | 257    | Hz     |
| (PWM) frequency             | f <sub>PWM</sub> | PWMF = 0, T <sub>A</sub> = 25°C                                                 | 0.975 | 1      | 1.025  | kHz    |
| PWM resolution              |                  |                                                                                 |       | 12     |        | bit    |
| Incremental Output (ABZ)    |                  |                                                                                 |       |        |        |        |
| ABZ update rate             |                  | $T_A = 25^{\circ}C$                                                             | 12    | 12.8   |        | MHz    |
| Edges per turn resolution   |                  | Configurable                                                                    | 4     |        | 16384  |        |
| Pulses per channel per turn | PPT + 1          | Configurable                                                                    | 1     |        | 4096   |        |
| Differential nonlinearity   | DNL              |                                                                                 |       | 1.7    |        | %      |
| Overall ABZ jitter (3σ)     |                  | PPT = 511, speed = 1krpm                                                        |       | 0.06   |        | deg    |
| Overali ADZ jiller (30)     |                  | PPT = 2047, speed = 10krpm                                                      |       | 0.02   |        | deg    |



 ${\rm MA600A-HIGH\text{-}ACCURACY, <0.6^{\circ}\ (<0.1^{\circ})\ INL,\ DIGITAL\ MAGNETIC\ SENSOR}$ 

# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **GENERAL CHARACTERISTICS** (continued)

 $V_{\text{AVDD}} = V_{\text{DVDD}} = 3.3 \text{V}$ , 20mT < B < 80mT,  $T_{\text{A}} = -40 ^{\circ}\text{C}$  to +125°C, typical values at  $T_{\text{A}} = 25 ^{\circ}\text{C}$  and B = 45mT unless otherwise noted.

| Parameter               | Symbol                   | Condition                   | Min | Тур   | Max | Units   |  |
|-------------------------|--------------------------|-----------------------------|-----|-------|-----|---------|--|
| Incremental Output (UVW | Incremental Output (UVW) |                             |     |       |     |         |  |
| Cycle per turn          | NPP + 1                  | Configurable                | 1   |       | 8   |         |  |
| UVW jitter (3σ)         |                          | NPP = 0, speed = 5krpm      |     | 0.4   |     | deg     |  |
| Speed Output            | Speed Output             |                             |     |       |     |         |  |
| Speed scale             | SSPEED                   | f <sub>CK100</sub> = 100kHz |     | 5.722 |     | rpm/LSB |  |
| CK100 clock frequency   |                          | T <sub>A</sub> = 25°C       | 98  | 100   | 102 | kHz     |  |

#### Note:

6) Guaranteed by design or characterization.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# TYPICAL CHARACTERISTICS

 $V_{AVDD} = V_{DVDD} = 3.3V$ , 20mT < B < 80mT,  $T_A = 25$ °C, unless otherwise noted.













10



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# TYPICAL CHARACTERISTICS (continued)

 $V_{AVDD} = V_{DVDD} = 3.3V$ , 20mT < B < 80mT,  $T_A = 25$ °C, unless otherwise noted.







7) See "Appendix B: Definitions" for INL & Harmonics definitions.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **FUNCTIONAL BLOCK DIAGRAM**



Figure 2: Functional Block Diagram



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **OPERATION**

### **Sensor Front End**

The magnetic field is detected with the tunneling magnetoresistance (TMR) bridges located in the center of the package. The angle is measured using the Spinaxis<sup>TM</sup> method, which directly digitizes the direction of the field without complex arctangent computation or feedback loop-based circuits (interpolators).

The Spinaxis<sup>™</sup> method is based on phase detection, and this method generates a sinusoidal signal with a phase that represents the angle of the magnetic field. The angle is then obtained by a time-to-digital converter, which measures the time between the zero crossing of the sinusoidal signal and the edge of a constant waveform (see Figure 3). The time-to-digital is output from the front end to the digital conditioning block.



Top: Sine Waveform

Bottom: Clock for Time-to-Digital Converter

Figure 3: Phase Detection Method

The front-end output delivers a digital number that is proportional to the angle of the magnetic field (at a rate of 800kHz) in a straightforward and open-loop manner.

### **Sensor (Magnet Mounting)**

The sensitive volume of the MA600A is confined to a region less than 400µm wide. This area contains multiple TMR bridges. The volume is located horizontally within 50µm of the center of the package. Vertically, the sensitive volume is centered at approximately 300µm under the surface. The sensor detects the angle of the magnetic field projected in a plane parallel to the package's upper surface. This means that the only relevant magnetic field is the in-plane component (X and Y components) within the sensitive volume (see Figure 4).



Figure 4: Space Coordinates (Field is Sensed on the XY Plane)

By default, when looking at the top of the package, the angle increases when the magnetic field rotates clockwise. Figure 5 shows the zero angle of a sensor that has not been configured, where the cross indicates the sensitive point. Both the rotation direction and the zero angle can be configured.



Figure 5: Detection Point and Default Positive Direction

This type of detection provides flexibility for the angular encoder design. The sensor requires the magnetic vector to remain within the sensor plane with an amplitude within the recommended operating range.

The most straightforward mounting method is to place the MA600A sensor on the rotation axis of a permanent magnet, such as a diametrically magnetized cylinder (see Figure 6 on page 12).

Consider a Neodymium alloy (N35) cylinder magnet with Ø5x2.5mm dimensions inserted into an aluminum shaft, with a 2mm air gap between the magnet and the sensor (surface of the package). For optimal linearity, the sensor is positioned on the magnet's rotation axis with a 5% precision of the magnet's outer diameter.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

For more information about the sensor and magnet placement, refer to the related application note on the MPS website (Selecting the Right Magnet for the MagAlpha in End-of-Shaft Mounting).



Figure 6: End-of-Shaft Mounting

If the end-of-shaft position is not available, the sensor can be positioned away from the rotation axis of a cylinder or ring magnet (see Figure 7).



Figure 7: Side-Shaft Mounting

In this case, the magnetic field angle is no longer directly proportional to the mechanical angle. The MA600A can be adjusted to compensate for this effect, and to recover the linear relation between the mechanical angle and the sensor output. With multiple pole pair magnets, the MA600A indicates multiple rotations for each mechanical turn.

#### **Serial Interface**

The sensor supports the serial peripheral interface (SPI) for angle reading and register configuration. Alternatively, the synchronous serial interface (SSI) protocol can be used for angle reading. Configuration through the SSI is not supported.

# Serial Peripheral Interface (SPI)

The SPI is a four-wire, synchronous, serial communication interface. The MA600A supports SPI mode 3 and mode 0. Table 1 shows the SPI specifications.

**Table 1: SPI Specifications** 

|                   | Mode 0                   | Mode 3 |  |
|-------------------|--------------------------|--------|--|
| SCLK Idle State   | Low                      | High   |  |
| Data Capture      | On the SCLK rising edge  |        |  |
| Data Transmission | On the SCLK falling edge |        |  |
| /CS Idle State    | High                     |        |  |
| Data Order        | MSB first                |        |  |

The SPI mode (0 or 3) is detected automatically by the sensor and does not require additional action from the user. The maximum SPI clock frequency supported by MA600A is 25MHz. There is no minimum clock rate. Real maximum data rates depend on the PCB layout quality and signal trace length.

Table 2 shows the standard SPI values.

Table 2: SPI Standard

|                   | Mode 0        | Mode 3 |
|-------------------|---------------|--------|
| CPOL              | 0             | 1      |
| CPHA              | 0             | 1      |
| Data Order (DORD) | 0 (MSB first) |        |

All commands to the MA600A (whether for writing or reading register content) must be transferred through the SPI COPI pin. See the SPI Communication section on page 15 for details.

Figure 8 shows the SPI timing diagram for mode 3 and mode 0, where COPI is the controller output peripheral input, and CIPO is the controller input peripheral output. Figure 9 on page 14 shows the minimum idle time, and Table 3 shows the SPI timing.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE





Figure 8: SPI Timing Diagram





### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

**Table 3: SPI Timing** 

| Parameter (8)           | Description                                               | Min | Max | Unit |
|-------------------------|-----------------------------------------------------------|-----|-----|------|
| tidle_command           | Idle time between transmissions                           | 120 | •   | ns   |
| tstore_reg_block        | Time required to store a register block to the NVM        | 600 | •   | ms   |
| trestore_all_reg_blocks | Time required to restore all register blocks from the NVM | 240 | -   | μs   |
| tcsL                    | Time between /CS falling edge and SCLK falling edge       | 20  | •   | ns   |
| tsclk                   | SCLK period                                               | 40  | •   | ns   |
| tsclkl                  | Low level of the SCLK signal                              | 20  | •   | ns   |
| tsclкн                  | High level of the SCLK signal                             | 20  | •   | ns   |
| tcsн                    | Time between the SCLK rising edge and /CS rising edge     | 20  | •   | ns   |
| tcipo                   | SCLK setting edge to data output valid                    | -   | 15  | ns   |
| <b>t</b> copi           | Data input valid to SCLK rising edge                      | 15  | -   | ns   |

#### Note:

8) All values are guaranteed by design.

The MA600A resolution may be affected by the sampling frequency (/CS frequency) (see Figure 10).



Figure 10: Resolution and Sampling Frequency In some frequency ranges (e.g. between 90kHz and 110kHz), the resolution drop can be visible at certain angles. A smaller drop can also be visible between 40kHz and 60kHz.

### **SPI Communication**

The sensor supports eight types of SPI operation:

- Read angle
- Read multi-turn
- Read speed
- Read register
- Write register
- Store a single register block to the NVM
- Restore all register blocks from the NVM

### Clear error flags

Each operation has a specific frame structure described below and is summarized in Table 5 on page 19.

### SPI Read Angle

The refresh period is 1/f<sub>REFRESH</sub>. New data is transferred into the output buffer each refresh period. The controller device triggers the reading by pulling /CS low.

When a trigger event is detected, the data remains in the output buffer until the /CS signal is de-asserted (see Table 4).

**Table 4: Sensor Data Timing** 

| Event            | Action                                     |
|------------------|--------------------------------------------|
| /CS falling edge | Start reading and freeze the output buffer |
| /CS rising edge  | Release the output buffer                  |

A full angle reading requires 16 clock pulses. The angle output value is read with the most significant bit (MSB) first. Figure 11 shows a diagram of a full SPI angle reading.



Figure 11: Diagram of a Full 16-Bit SPI Angle Reading

The angle in degrees can be calculated with Equation (1):

angle (deg) = 
$$\frac{\text{angle (dec)}}{2^{16}} \times 360$$
 (1)

16



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

If less resolution is sufficient, the angle can be read by sending fewer clock counts since the MSB is first. Figure 12 shows a diagram of a partial 8-bit SPI angle reading.



Figure 12: Diagram of a Partial 8-Bit SPI Angle Reading

If there are very fast reading cycles, the MA600A continues sending the same data until the data

refreshes. See the General Characteristics section on page 7 for the refresh rate.

# SPI Read Multi-Turn or Speed

By sending 32 clock pulses in one frame, the user can obtain the multi-turn or speed information.

The first 16 bits returned on the CIPO line contain the angle value. When MTSP in register PRT is set to 0 (default setting), the second 16 bits contain the multi-turn count; when MTSP is set to 1, the second 16 bits contain the speed (see Figure 13).

See the Multi-Turn Output section on page 37 for more details on multi-turn.

See the Speed Output and Calculation section on page 37 for more details of speed.



Figure 13: 32-Bit Frame "Read Multi-Turn or Speed" Operation

# SPI Read Register

A "Read Register" operation consists of two 16-bit frames. The first frame sends a read request which contains the 8-bit read command followed by the 8-bit register address. The second frame returns the 8-bit angle value (MSB byte) with the requested 8-bit register value (LSB byte).

The first 16-bit SPI frame (read request) is:



The second 16-bit SPI frame (response) is:

|      | Angle |              |                | Reg. Value |       |       |                |       |                |                |
|------|-------|--------------|----------------|------------|-------|-------|----------------|-------|----------------|----------------|
| CIPO | -     | Angle (15:8) | V <sub>7</sub> | $V_6$      | $V_5$ | $V_4$ | V <sub>3</sub> | $V_2$ | V <sub>1</sub> | V <sub>0</sub> |
|      | MSB   |              |                |            |       |       |                |       |                | LSB            |
| COPI |       | (            | )              |            |       |       |                |       |                |                |

Figure 14 shows a complete transmission.



Figure 14: Overview of a "Read Register" Operation with Two 16-Bit Frames

### SPI Write Register

A "Write Register" operation consists of three 16bit frames. The first frame sends a write request, that contains the 16-bit write command. The second frame sends the 8-bit register address and the 8-bit value (MSB first). The third frame



#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

returns the newly written register value with an 8-bit angle value.

The first 16-bit SPI frame (write request) is:



The second 16-bit SPI frame (address and value) is:



The third 16-bit SPI frame (response) is:

|      | Angle        | Reg. Value                                                                                                              |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------|
| CIPO | Angle (15:8) | V <sub>7</sub> V <sub>6</sub> V <sub>5</sub> V <sub>4</sub> V <sub>3</sub> V <sub>2</sub> V <sub>1</sub> V <sub>0</sub> |
|      | MSB          | LSB                                                                                                                     |
| COPI |              | 0                                                                                                                       |

The readback register content can be used to verify the register configurations.

For example, to set the value of the output rotation direction (RD) to counterclockwise (RD bit = 1), write register DIR by sending the following first and second frames:



Then send the third frame. If the register is written correctly, the reply is:



Figure 15 shows a complete transmission.



Figure 15: Overview of a "Write Register" Operation with Three 16-Bit Frames

# Non-Volatile Memory (NVM) Operation

The sensor contains a non-volatile memory (NVM) that is divided into two separate memory blocks. Each block contains 32 registers. Block 0 contains registers ZERO0 to RMAPID, and block 1 contains registers CORR0 to CORR31. The values stored in the NVM are automatically loaded into the sensor's registers during start-up.

By using the "Store a Single Register Block to the NVM" SPI command, the register values in the block are copied to NVM.

If the user wants to change the value of register N in NVM, the right order is:

- 1. Write the target value to register N by "Write Register" command
- Check the block number B to which register N belongs
- 3. Use the "Store a Single Register Block to the NVM" command to store block B

It is possible to manually force the restoration of the NVM values to the registers by using the "Restore All Register Blocks" SPI command.

When the sensor receives a NVM command ("Store a Single Register Block to the NVM" or "Restore All Register Blocks"), the NVM will be busy for the time required to execute the command.

If another NVM command is sent while the NVM is busy, the command is ignored and the ERRMEM bit is set to 1.

### SPI Store a Single Register Block to the NVM

A "Store a Single Register Block" operation consists of two 16-bit frames, see Figure 16. The third frame is to illustrate that other commands need to be sent after at least tstore\_reg\_block (See Table 3 on page 15).



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE



Figure 16: Overview of "Store a Single Register Block to the NVM" Operation with Three 16-Bit Frames (B=0 for Block 0, B=1 for Block 1)

# SPI Restore All Register Blocks from the NVM

A "Restore All Register Blocks" operation consists of one 16-bit frame. This command restores all register blocks from the NVM (see Figure 17).

The second frame in Figure 17 is to illustrate that other commands need to be sent after at least trestore all reg blocks.

This operation is done automatically (without user intervention) at each start-up.



Figure 17: Overview of "Restore All Register Blocks from the NVM" Operation with Two 16-Bit Frames

### SPI Clear Error Flags

A "Clear Error Flags" operation consists of one 16-bit frame. This command clears all error flags in register STATUS, including NVMB, ERRCRC,

ERRMEM, and ERRPAR (see Figure 18). Other commands should be sent after tidle\_command.



Figure 18: Overview of Clear Error Flags Operation with Two 16-Bit Frames

Table 5 shows a summary of all SPI commands.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

**Table 5: SPI Commands List Overview** 

| Command Function                            | Transaction<br>Length | C           | Command                                                                 | Returned Value on<br>Last Command     |  |
|---------------------------------------------|-----------------------|-------------|-------------------------------------------------------------------------|---------------------------------------|--|
| Read Angle                                  | 1 x 16-bit            |             | 0x0000                                                                  | 16-bit angle                          |  |
| Read Multi-Turn                             | 1 x 32-bit            | 0>          | k00000000                                                               | 16-bit angle +<br>16-bit multi-turn   |  |
| Read Speed                                  | 1 x 32-bit            | 0>          | k00000000                                                               | 16-bit angle +<br>16-bit speed        |  |
| Read Register                               | 2 x 16-bit            | 1st command | 0xd2 <sup>(9)</sup> +<br>8-bit reg. address                             | 8-bit angle MSB +<br>8-bit reg. value |  |
|                                             |                       | 2nd command | 0x0000                                                                  | o-bit reg. value                      |  |
|                                             | 3 x 16-bit            | 1st command | 0xea54 <sup>(9)</sup>                                                   |                                       |  |
| Write Register                              |                       | 2nd command | 8-bit reg. address +<br>8-bit reg. value                                | 8-bit angle MSB +<br>8-bit reg. value |  |
|                                             |                       | 3rd command | 0x0000                                                                  |                                       |  |
| Store a Single Beginter                     |                       | 1st command | 0xea55 <sup>(9)</sup>                                                   |                                       |  |
| Store a Single Register Block to the NVM    | 2 x 16-bit            | 2nd command | 0xea00 <sup>(9)</sup> for block 0,<br>0xea01 <sup>(9)</sup> for block 1 | 16-bit angle                          |  |
| Restore All Register<br>Blocks from the NVM | 1 x 16-bit            | (           | 0xea56 <sup>(9)</sup>                                                   | 16-bit angle                          |  |
| Clear Error Flags                           | 1 x16-bit             | (           | 0xd700 <sup>(9)</sup>                                                   | 16-bit angle                          |  |

#### Note:

# **SPI Parity Check**

SPI parity check is enabled by setting PRT bit in register PRT to 1. The parity sign is determined by PRTS, where the sign is even by default (PRTS = 0) and can be changed to odd by setting PRTS to 1. When parity check is enabled, changing the PRTS value leads to the ERRPAR flag becoming active.

When SPI parity check is enabled, the controller must send one parity bit after the 16-bit command. The MA600A also returns one parity bit after the 16-bit data. Figure 19 shows the SPI read angle with parity check.



Figure 19: SPI Read Angle When SPI Parity
Check is Enabled

If the parity bit sent by controller is wrong, the error bit (ERRPAR) in register STATUS is set to 1. See the ERRPAR section on page 38 for more details.

Table 6 shows a summary of SPI commands with parity check.

**Table 6: SPI Commands with Parity Check Overview** 

| Command Function            | Command Sent by<br>Controller                | Returned Value                                                         | Action when Parity<br>Sent by Controller<br>Is Wrong |  |
|-----------------------------|----------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------|--|
| Read Angle                  | 0x0000 + parity bit                          | 16-bit angle + parity bit                                              | ERRPAR = 1                                           |  |
| Read Multi-Turn or<br>Speed | 0x0000 + parity bit +<br>0x0000 + parity bit | 16-bit angle + parity bit<br>+ 16-bit multi-turn/speed<br>+ parity bit | ERRPAR = 1                                           |  |
| Read/Write Register         | Several 17-bit commands,                     | Several 17-bit replies,                                                | ERRPAR = 1, the                                      |  |
| Store/Restore NVM           | where each command is a                      | where each reply is a 16-bit                                           | command is                                           |  |
| Clear Error Flags           | 16-bit command + parity bit                  | reply + parity bit                                                     | discarded                                            |  |

<sup>9)</sup> These values are in hexadecimal format. For example, 0xd2 indicates 1101 0010 in binary format.



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **SPI Angle Parity Check on CIPO**

SPI angle parity check can be enabled by setting APRT bit in register PRT to 1.

If APRT = 1, the least significant bit (LSB) of the 16-bit angle output on CIPO is replaced by the angle parity bit. Figure 20 shows an example of angle reading with the angle parity bit, where AP stands for the angle parity bit.



Figure 20: Angle Output with Parity Bit when APRT = 1

When APRT = 1, SPI angle parity check is applied to all SPI CIPO replies containing a 16-bit angle.

The angle parity bit sign is controlled by PRTS bit in register PRT.

SPI parity check and angle parity check can be enabled at the same time. Figure 21 shows an example of angle reading with both the angle parity bit and SPI parity bit, where P stands for the parity bit of the previous 16-bit data.



Figure 21: Angle Output with Parity Bit when PRT = 1 and APRT = 1

# Synchronous Serial Interface (SSI)

The SSI is a 2-wire, synchronous, serial interface, and the sensor operates as a peripheral to the external SSI controller.

Only angle reading can be done by the SSI. It is not possible to read or write registers using the SSI.

The maximum SSI clock frequency supported by the MA600A is 5MHz. Real maximum data rates depend on the PCB layout quality and signal trace length.

Figure 22 on page 20 shows the SSI timing for mode A and mode B, and Table 7 shows the timing of SSI communication.



Figure 22: SSI Timing for Mode A and Mode B (Both Modes are Supported)



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

**Table 7: SSI Timing** 

| Parameter     | Description                                         | Min | Max | Unit |
|---------------|-----------------------------------------------------|-----|-----|------|
| tssp          |                                                     |     | 81  | ns   |
| <b>t</b> ssck | SSCK period                                         | 0.2 | 16  | μs   |
| tssckl        | Low level of the SSCK signal                        | 0.1 | 8   | μs   |
| tsscкн        | High level of the SSCK signal                       | 0.1 | 8   | μs   |
| t⋈            | Transfer timeout (monoflop time)                    | 25  | -   | μs   |
| t₽            | Dead time: SSCK high time for the next data reading | 40  | -   | μs   |

### **SSI Read Angle**

The MSBs are transmitted first. Every refresh period, new data is transferred into the output buffer.

The first clock count is a dummy clock to start the transmission. The first MSB data is then transmitted on the second clock count. The controller device triggers the reading by driving SSCK high.

The MA600A's data length is 16 bits long. meaning a full reading requires one dummy clock and 16 clock counts (see Figure 23 on page 20). The reading can also be performed with fewer than 17 clock counts. For example, if an application requires only 12-bit angle information, it is sufficient to send the first dummy clock to start the transmission as well as 12 additional clock cycles to read the angle data.

When a trigger event is detected, the data remains in the output buffer until the transfer timeout passes (see Table 8).

Figure 24 shows the timing for consecutive angle readings.

**Table 8: Sensor Data Timing** 

| Trigger Event          | Release of the Output Buffer                         |
|------------------------|------------------------------------------------------|
| First SSCK rising edge | Last SSCK falling edge +                             |
| after dummy clock      | timeout (t <sub>M</sub> ) (see Figure 22 on page 20) |





SSI Mode B

Figure 23: Diagram of a Full 16-Bit SSI Angle Reading (with First Dummy Clock)



Figure 24: Two Consecutive 16-Bit SSI Angle Readings (with Required Dead Time Between the Frames)

### SSI Parity Check

The SSI parity check is enabled by default. To obtain the parity bit, the user must send one dummy clock and 17 clock counts. The parity bit follows the LSB of the angle data (see Figure 25). The parity sign is even parity by default and



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

can be configured to odd parity by setting PRTS to 1 in register PRT with an SPI command.



Figure 25: 17-Bit SSI Angle Reading with Parity Check (with First Dummy Clock)



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **REGISTER MAP**

Table 9: Register Map (10)

| #   | Block | Hex  | Bit[7]<br>(MSB) | Bit[6]   | Bit[5]          | Bit[4] | Bit[3]    | Bit[2] | Bit[1] | Bit[0]<br>(LSB) |
|-----|-------|------|-----------------|----------|-----------------|--------|-----------|--------|--------|-----------------|
| 0   |       | 0x00 |                 | Z[7:0]   |                 |        |           |        |        |                 |
| 1   |       | 0x01 |                 | Z[15:8]  |                 |        |           |        |        |                 |
| 2   |       | 0x02 |                 |          | BCT             |        |           |        |        |                 |
| 3   |       | 0x03 |                 | - ETY    |                 |        |           |        |        | ETX             |
| 4   |       | 0x04 |                 | PPT[2:0] |                 |        | IL        | .IP    |        | PPT[11]         |
| 5   |       | 0x05 |                 |          |                 | PPT    | [10:3]    |        |        |                 |
| 7   |       | 0x07 |                 | NPP      |                 |        |           | -      |        |                 |
| 8   |       | 80x0 | PWMM            | PWMF     |                 |        |           | -      |        |                 |
| 9   |       | 0x09 | RD              |          | -               |        |           |        |        |                 |
| 10  | 0     | 0x0A | DAISY           |          | -               |        |           |        |        | RWM             |
| 11  |       | 0x0B | OD615           | OD243    | OD243 SPULLIN - |        |           |        |        |                 |
| 12  |       | 0x0C |                 |          |                 | Н      | YS        |        |        |                 |
| 13  |       | 0x0D |                 |          | -               |        |           | F      | W      |                 |
| 14  |       | 0x0E |                 | INTF_SEL |                 | -      | ı         | DAZ    | -      | CK100           |
| 18  |       | 0x12 |                 |          |                 | MTOFF  | SET[7:0]  |        |        |                 |
| 19  |       | 0x13 |                 |          |                 | MTOFFS | SET[15:8] |        |        |                 |
| 26  |       | 0x1A | NVMB            |          |                 | -      |           | ERRCRC | ERRMEM | ERRPAR          |
| 28  |       | 0x1C | MTSP            | -        | PRT             | PRTS   | APRT      | FT     | A      | FTM             |
| 31  |       | 0x1F |                 |          |                 | SUF    | FIXID     |        |        |                 |
| 32  |       | 0x20 |                 |          |                 | CO     | RR0       |        |        |                 |
| 33  |       | 0x21 |                 | CORR1    |                 |        |           |        |        |                 |
|     | 1     |      |                 |          |                 |        |           |        |        |                 |
| 62  |       | 0x3E |                 | CORR30   |                 |        |           |        |        |                 |
| 63  |       | 0x3F |                 |          |                 | COF    | RR31      |        |        |                 |
| 132 | 4     | 0x84 |                 |          |                 | -      |           |        |        | UR10            |

### Notes:

<sup>10) &</sup>quot;-" indicates bits that are not accessible by the user.



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# REGISTERS DESCRIPTION

# **ZERO0 (0x00)**

Set the zero position (see Zero Setting section).

| Bi | its | Access | Bit Name | Default | Description                                         |
|----|-----|--------|----------|---------|-----------------------------------------------------|
| 7: | :0  | R/W    | Z[7:0]   | 0       | 8 least significant bits (LSB) of the zero setting. |

# **ZERO1 (0x01)**

Set the zero position (see Zero Setting section).

| Bits | Access | Bit Name | Default | Description                                        |
|------|--------|----------|---------|----------------------------------------------------|
| 7:0  | R/W    | Z[15:8]  | 0       | 8 most significant bits (MSB) of the zero setting. |

# BCT0 (0x02)

For side-shaft configuration: Trims the bias current of the X or Y direction TMR bridge (see Bias Current Trimming Settings section).

| Bits | Access | Bit Name | Default | Description                                                            |
|------|--------|----------|---------|------------------------------------------------------------------------|
| 7:0  | R/W    | ВСТ      | 0       | Reduces the bias current of the TMR bridge selected via BCT1 register. |

# BCT1 (0x03)

For side-shaft configuration: Determines in which direction (X or Y) the TMR bridge bias current is trimmed (see Bias Current Trimming Settings section).

| Bits | Access | Bit Name | Default | Description                                                                   |
|------|--------|----------|---------|-------------------------------------------------------------------------------|
| 7:2  | N/A    | -        | N/A     | Reserved.                                                                     |
| 1    | R/W    | ETY      | 0       | Bias current trimming in the Y direction TMR bridge.  0: Disabled  1: Enabled |
| 0    | R/W    | ETX      | 0       | Bias current trimming in the X direction TMR bridge.  0: Disabled 1: Enabled  |

# ABZ0 (0x04)

For ABZ configuration: Determines ABZ index parameterization and number of pulses per turn (see ABZ Incremental Encoder Output section).

| Bits | Access | Bit Name | Default | Description                                                                                        |
|------|--------|----------|---------|----------------------------------------------------------------------------------------------------|
| 7:5  | R/W    | PPT[2:0] | 0b111   | 3 least significant bits (LSB) of PPT (see Table 17): Number of pulses per turn of the ABZ output. |
| 4:1  | R/W    | ILIP     | 0       | Parametrization of the ABZ index pulse (see Figure 36).                                            |
| 0    | R/W    | PPT[11]  | 0       | Most significant bit (MSB) of PPT (see Table 17): Number of pulses per turn of the ABZ output.     |

# ABZ1 (0x05)

For ABZ configuration: Determines pulses per turn (see ABZ Incremental Encoder Output section).

| Bits | Access | Bit Name  | Default | Description                                                                       |
|------|--------|-----------|---------|-----------------------------------------------------------------------------------|
| 7:0  | R/W    | PPT[10:3] | 0x3F    | 7 middle bits of PPT (see Table 17): Number of pulses per turn of the ABZ output. |



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# UVW (0x07)

For UWV configuration: Determines number of pole pairs (see UVW Incremental Encoder Output section).

| Bits | Access | Bit Name | Default | Description                                            |
|------|--------|----------|---------|--------------------------------------------------------|
| 7:5  | R/W    | NPP      | 0       | Number of pole pairs of the UVW output (see Table 21). |
| 4:0  | N/A    | -        | N/A     | Reserved.                                              |

# PWM (0x08)

For PWM configuration: Determines PWM frequency and mode (see Absolute Output section).

| Bits | Access | Bit Name | Default | Description                                                                                                   |
|------|--------|----------|---------|---------------------------------------------------------------------------------------------------------------|
|      |        |          |         | Adds error detection to the PWM frame.                                                                        |
| 7    | R/W    | PWMM     | 1       | 0: Disabled<br>1: Enabled                                                                                     |
|      |        |          |         | When PWMM=1, if ERRCRC, ERRMEM or ERRPAR are detected, the PWM error and data bands are zero (see Figure 41). |
|      |        |          |         | Sets pulse-width modulated output frequency.                                                                  |
| 6    | R/W    | PWMF     | 1       | 0: 1 kHz<br>1: 250 Hz                                                                                         |
| 5:0  | N/A    | -        | N/A     | Reserved.                                                                                                     |

# DIR (0x09)

Determines sensor positive direction (see Rotation Direction section).

| Bits | Access | Bit Name | Default | Description                                 |
|------|--------|----------|---------|---------------------------------------------|
| 7    | R/W    | RD       | 0       | 0: Clockwise (CW) 1: Counterclockwise (CCW) |
| 6:0  | N/A    | -        | N/A     | Reserved.                                   |

# IO0 (0x0A)

For IO configuration: Determines state of Reduced Wire Mode (RWM) and Daisy Chain (see Special Interfaces section).

| Bits | Access | Bit Name | Default | Description                                                                                |
|------|--------|----------|---------|--------------------------------------------------------------------------------------------|
| 7    | R/W    | DAISY    | 0       | Enables Daisy Chain Mode. This bit can only be written if UR10 = 1.  0: Disable 1: Enable  |
| 6:1  | N/A    | -        | N/A     | Reserved.                                                                                  |
| 0    | R/W    | RWM      | 0       | Enables Reduced Wire Mode. This bit can only be written if UR10 = 1.  0: Disable 1: Enable |



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# IO1 (0x0B)

For IO configuration: Determines the internal circuit of various IO pins (see Digital I/O Pin Circuit section).

| Bits | Access | Bit Name | Default | Description                                                                                                               |
|------|--------|----------|---------|---------------------------------------------------------------------------------------------------------------------------|
| 7    | R/W    | OD615    | 0       | Determines the output circuits of pins IO6, IO1 and IO5.  0: Push-Pull 1: Open-Drain                                      |
| 6    | R/W    | OD243    | 0       | Determines the output circuits of pins IO2, IO4, IO3.  0: Push-Pull 1: Open-Drain                                         |
| 5    | R/W    | SPULLIN  | 1       | Determines the input circuits of /CS, SCLK and COPI pins.  0: Hi-Z.  1: Pull-up (for /CS) and Pull-down (for SCLK, COPI). |
| 4:0  | N/A    | -        | N/A     | Reserved.                                                                                                                 |

# HYST (0x0C)

Hysteresis of the ABZ output (see ABZ Hysteresis section).

| Bits | Access | Bit Name | Default | Description                                  |
|------|--------|----------|---------|----------------------------------------------|
| 7:0  | R/W    | HYS      | 16      | Configurable hysteresis used for ABZ output. |

# FILT (0x0D)

For filter window configuration: Determines the window size of the digital filter (see Digital Filter Configuration section).

| Bits | Access | Bit Name | Default | Description                                |
|------|--------|----------|---------|--------------------------------------------|
| 7:4  | N/A    | -        | N/A     | Reserved.                                  |
| 3:0  | R/W    | FW       | 5       | Digital filter window size (see Table 10). |

# IF (0x0E)

Interface selection register (see I/O Matrix section).

| Bits | Access | Bit Name | Default | Description                                                                                           |
|------|--------|----------|---------|-------------------------------------------------------------------------------------------------------|
| 7:5  | R/W    | INTF_SEL | 0       | Choice of the function of pins IO1 to IO6 (see Table 27).                                             |
| 4:3  | N/A    | -        | N/A     | Reserved.                                                                                             |
|      |        |          |         | For Incremental Encoder Output: Enable DAZ interface.                                                 |
| 2    | R/W    | DAZ      | 0       | 0: Disable<br>1: Enable                                                                               |
|      |        |          |         | If enabled, D signal indicates rotation direction (CW or CCW), both A and Z signals remain unchanged. |
| 1    | N/A    | -        | N/A     | Reserved.                                                                                             |
|      |        |          |         | If enabled, the 100 kHz system clock is available at CK100 pin.                                       |
| 0    | R/W    | CK100    | 0       | 0: Disable<br>1: Enabled                                                                              |

# MT0 (0x12)

Multi-turn offset value (see Multi-Turn Output section).

| Bits | Access   | Bit Name      | Default | Description                                                    |
|------|----------|---------------|---------|----------------------------------------------------------------|
| 7:0  | R/W*(11) | MTOFFSET[7:0] | 0       | 8 least significant bits (LSB) of the multi-turn offset value. |

MA600A Rev. 0.8

12/23/2024



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# MT1 (0X13)

Multi-turn offset value.

| Bits | Access   | Bit Name       | Default | Description                                                   |
|------|----------|----------------|---------|---------------------------------------------------------------|
| 7:0  | R/W*(11) | MTOFFSET[15:8] | 0       | 8 most significant bits (MSB) of the multi-turn offset value. |

# STATUS (0x1A)

Register containing error flags. Can be cleared by sending the Clear Error Flags command (see Status Byte section).

| Bits | Access       | Bit Name | Default                                | Description                                                  |
|------|--------------|----------|----------------------------------------|--------------------------------------------------------------|
|      |              |          |                                        | Indicates if NVM is busy                                     |
| 7    | R            | NVMB     | 0                                      | 0: No Error detected<br>1: Error detected                    |
| 6:3  | N/A          | -        | N/A                                    | Reserved.                                                    |
|      |              |          |                                        | CRC error detected during NVM restoration.                   |
| 2    | 2 R ERRCRC C | 0        | 0: No Error detected 1: Error detected |                                                              |
|      |              |          |                                        | Rises when an "SPI write" is performed when the NVM is busy. |
| 1    | R            | ERRMEM   | 0                                      | 0: No Error detected 1: Error detected                       |
|      |              |          |                                        | Parity error detected on the COPI line, ignores SPI command. |
| 0    | R            | ERRPAR   | 0                                      | 0: No Error detected<br>1: Error detected                    |



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **PRT (0x1C)**

For parity check (see SPI Parity Check subsection) and test angle configuration (see Functional Test section).

| Bits | Access                         | Bit Name                   | Default                                                                                                                                   | Description                                                                      |
|------|--------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 7    | R/W* <sup>(11)</sup>           | MTSP                       | 0                                                                                                                                         | Determines the data returned by SPI "Read Multi-Turn or Speed" operation.        |
| ,    | TQ VV · /                      | WTO                        | 0                                                                                                                                         | 0: Multiturn<br>1: Speed                                                         |
| 6    | N/A                            | -                          | N/A                                                                                                                                       | Reserved.                                                                        |
|      |                                |                            |                                                                                                                                           | Enables SPI Parity Check.                                                        |
| 5    | R/W* <sup>(11)</sup>           | PRT                        | 0                                                                                                                                         | 0: Disable<br>1: Enable                                                          |
|      | 4 R/W*(11) PRTS 0              |                            |                                                                                                                                           | Determines the sign of parity bit (Even/Odd).                                    |
| 4    |                                |                            | 0                                                                                                                                         | 0: Even<br>1: Odd                                                                |
|      |                                |                            |                                                                                                                                           | 16th bit of the SPI angle data is replaced by the parity bit.                    |
| 3    | 3 R/W* <sup>(11)</sup> APRT 0  |                            | 0                                                                                                                                         | 0: Disabled<br>1: Enabled                                                        |
|      | 2:1 R/W* <sup>(11)</sup> FTA 0 |                            |                                                                                                                                           | Functional test angle. Selects the angle output in Functional Test Mode (FTM=1): |
| 2:1  |                                |                            | 0                                                                                                                                         | 0b00: 0°<br>0b01: 90°<br>0b10: 180°<br>0b11: 270°                                |
| 0    | R/W*(11)                       | R/W* <sup>(11)</sup> FTM 0 | Functional test mode enable. When enabled, a reference signal replaces the TMR front-end output as input of the signal treatment circuit. |                                                                                  |
|      |                                |                            |                                                                                                                                           | 0: Disabled.<br>1: Enabled.                                                      |

# RMAPID (0x1F)

Register map identification number.

|   | Bits | Access | Bit Name | Default | Description                                 |
|---|------|--------|----------|---------|---------------------------------------------|
| Ī | 7:0  | R      | SUFFIXID | 0       | Suffix for custom register setting version. |

# CORR0-CORR31 (0x20 - 0x3F)

For User Output Calibration (see User Output Calibration section).

| Bits | Access | Bit Name    | Default | Description                                                   |
|------|--------|-------------|---------|---------------------------------------------------------------|
|      |        | CORR0       |         |                                                               |
| 7:0  | R/W    | -<br>CORR31 | 0       | User correction table (32 x 8 bits) for linear interpolation. |



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# UR10 (0x84)

Unlock write access to register IO0.

| Bits | Access   | Bit Name | Default | Description                                                        |  |
|------|----------|----------|---------|--------------------------------------------------------------------|--|
| 7:1  | N/A      | -        | N/A     | Reserved.                                                          |  |
| 0    | R/W*(11) | UR10     | 0       | O: Register 10 is write-locked.  1: Register 10 is write-unlocked. |  |

#### Note:

11) R/W\* indicates write access to the register only. Values are not stored in the NVM.

# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# REGISTER SETTINGS

# **Digital Filter Configuration**

The filter window (FW) setting controls the sensor's resolution of the angle output (defined as the  $\pm 3\sigma$  noise interval), the latency, and the cutoff frequency ( $f_{\text{CUTOFF}}$ ).

Table 10 provides the filter setting options and resulting performance. It is not recommended to use FW 1 to 4 and 13 to 15.

**Table 10: Filter Settings** 

| FW             | τ<br>(μs) | Resolution<br>(bits) | Latency<br>Cancellation<br>at Constant<br>Speed | <b>f</b> сито <b>гг (kHz)</b> (12) |
|----------------|-----------|----------------------|-------------------------------------------------|------------------------------------|
| 0              | 0         | 12.3                 | No                                              | 17                                 |
| 5<br>(default) | 40        | 12.5                 | Yes                                             | 12                                 |
| 6              | 80        | 13                   | Yes                                             | 5.8                                |
| 7              | 160       | 13.5                 | Yes                                             | 2.7                                |
| 8              | 320       | 14                   | Yes                                             | 1.3                                |
| 9              | 640       | 14.3                 | Yes                                             | 0.63                               |
| 10             | 1280      | 14.6                 | Yes                                             | 0.31                               |
| 11             | 2560      | 14.8                 | Yes                                             | 0.15                               |
| 12             | 5120      | 15                   | Yes                                             | 0.075                              |

#### Note:

12) f<sub>CUTOFF</sub> is defined as -3dB frequency on the spectrum.

The cutoff frequency is 17kHz when FW = 0. With this setting, the digital filter and latency cancellation are disabled.

See the Typical Characteristics section on page 9 for more details on the spectrum and phase for different FW settings.

To accurately model the system and analyze the control loop stability, the front-end signal's transfer function (H<sub>FE</sub>) can be calculated with Equation (2):

$$H_{FE} = \frac{1}{(1+T_{FE}s)^2}$$
 (2)

The digital filter transfer function (H<sub>FILTER</sub>) can be calculated with Equation (3):

$$H_{\text{FILTER}} = \frac{1 + (2 + \delta)\tau s}{(1 + \tau s)^2}$$
 (3)

The sensor transfer function (H) can then be calculated with Equation (4):

$$H = H_{FF} \times H_{FII TFR} \tag{4}$$

where  $\tau_{FE} = 5.3 \mu s$  and  $\delta = \frac{L}{\tau}$ . The time constant ( $\tau$ ) can be determined based on Table 10; L, the latency without digital filter, is given in General Characteristics section on page 7.

Figure 26 shows a simplified block diagram of the transfer function of the system.



Figure 26: Simplified Block Diagram

### **Zero Setting**

The zero position ( $a_0$ ) of the MA600A can be configured with 16 bits of resolution. The angle outputted by the MA600A ( $a_{OUT}$ ) can be calculated by Equation (5):

$$a_{OUT} = a_{RAW} - a_0 \tag{5}$$

Where  $a_{RAW}$  is the raw angle provided by the MagAlpha front end.

The Z parameter is 0 by default and is the zeroangle position. a<sub>0</sub> can be calculated in decimals with Equation (6):

$$a_0 = \frac{Z}{2^{16}} \times 360 \tag{6}$$

Table 11 shows the zero-setting parameter.

 Table 11: Zero-Setting Parameter

 Z
 Zero Position a<sub>0</sub> (deg)

 0
 0

 1
 0.005

 2
 0.011

 ...
 ...

 65534
 359.989

 65535
 359.995

# Zero Position Example

To set the zero position to 20 degrees, the Z parameter can be calculated with Equation (7):

$$Z = \frac{20^{\circ}}{360^{\circ}} \times 2^{16} = 3641 \tag{7}$$

In binary, it is written as 0000 1110 0011 1001.

### **Rotation Direction**

By default, when looking at the top of the package, the angle increases when the magnetic



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

field rotates clockwise (CW) (see Figure 27 on page 30).



Figure 27: Positive Rotation Direction of the Magnetic Field

**Table 12** shows the rotation direction parameter.

**Table 12: Rotation Direction Parameter** 

| RD | Positive Direction     |  |  |  |
|----|------------------------|--|--|--|
| 0  | Clockwise (CW)         |  |  |  |
| 1  | Counterclockwise (CCW) |  |  |  |

# Bias Current Trimming (BCT) Settings Side-Shaft

When the MA600A is mounted on the side of the magnet, the relationship between the field angle and the mechanical angle is no longer directly linear. This effect is related to the fact that the tangential magnetic field is typically smaller than the radial field. The field ratio (k) can be calculated with Equation (8):

$$k = \frac{B_{RAD}}{B_{TAN}}$$
 (8)

Where  $B_{RAD}$  is the maximum radial magnetic field, and  $B_{TAN}$  is the maximum tangential magnetic field (see Figure 28).



Figure 28: Side-Shaft Field

The k ratio depends on the magnet geometry and distance to the sensor. If the k ratio does not equal 1, the sensor output response is nonlinear with respect to the mechanical angle. The error curve has the shape of a double sinewave (see Figure 30). E is the amplitude of this error.

The bias current of the X or Y TMR bridge can be reduced to recover linearity. The direction in which the bias current is reduced corresponds to the direction where the field amplitude is the largest. The ETX and ETY parameters control this direction. The current reduction is set by the bias current trimming parameter (BCT), which is an integer from 0 to 255. If BCT exceeds 200, the compensation result can be affected by the temperature.

In side-shaft configuration (when the sensor's center is located beyond the magnet's outer diameter), the k ratio exceeds 1. For optimal compensation, the radial axis current should be reduced by setting BCT, which can be calculated with Equation (9):

BCT = 258 x 
$$\left(1 - \frac{1}{k}\right)$$
 (9)

Equation (9) is plotted in Figure 29 and Table 13.



Figure 29: Relation Between the k Ratio and the Optimal BCT to Recover Linearity

Table 13: Example of BCT Settings

| E (deg) | Magnet Ratio (k) | ВСТ |
|---------|------------------|-----|
| 0       | 1                | 0   |
| 11.5    | 1.5              | 86  |
| 19.5    | 2                | 129 |
| 25.4    | 2.5              | 155 |
| 30      | 3                | 172 |
| 33.7    | 3.5              | 184 |
| 36.9    | 4                | 194 |
| 39.5    | 4.5              | 201 |
| 41.8    | 5                | 207 |

#### Determining the *k Ratio*

It is possible to deduce the k ratio from the error curve obtained with the default BCT setting (BCT



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

= 0). Rotate the magnet one revolution and record the MA600A's output.

Next, plot the error curve (the difference between the MA600A's output and the real mechanical position vs. the real mechanical position) and extract two parameters: the maximum error (E), and the position of the maximum with respect to a zero crossing ( $\alpha_M$ ) (see Figure 30). The k ratio can be calculated with Equation (10):

$$k = \frac{\tan (E + \alpha_m)}{\tan (\alpha_m)}$$
 (10)

Figure 30 shows the error curve.



Figure 30: Error Curve in Side-Shaft Configuration with BCT = 0

Table 13 on page 31 shows examples of BCT settings. Figure 31 shows an alternative approach to obtain the *k* parameter.



Figure 31: Relationship between the Error Measured with BCT = 0 and the Magnet Ratio k

#### **Sensor Orientation**

The dot marked on the package indicates whether the radial field is aligned with the sensor coordinate X or Y (see Figure 32).



Figure 32: Package Top View with the X and Y Axes

Determine which axis should be reduced based on the qualitative field distribution around a ring (see Figure 28 on page 31).

For example, Figure 28 shows that the field along the sensor's Y-direction is tangential and weaker. This means that the X-axis should be reduced (ETX = 1 and ETY = 0).

If both ETX and ETY are set to 1, the current bias is reduced in both directions the same way (e.g. the linearity is the same as BCT = 0).

**Table 14: Trimming Direction Parameters** 

| ETX          | <b>Enable Trimming of the X-Axis</b>   |
|--------------|----------------------------------------|
| 0            | Disabled                               |
| 1            | Enabled                                |
|              |                                        |
| ETY          | <b>Enable Trimming of the Y-Axis</b>   |
| <b>ETY</b> 0 | Enable Trimming of the Y-Axis Disabled |

#### **Factory Output Linearization**

The sensor is factory-calibrated with the precision (see the General Characteristics section on page 7) at the nominal magnetic field and room temperature.

### **User Output Calibration**

The MA600A contains a 32 point lookup table for in-system calibration. This enables removal of errors induced by the magnetic configuration (misalignments and magnet defaults) as well as the intrinsic MA600A error. The user calibration consists of storing  $corr_i$  angle correction values in the NVM for 32 equidistant positions of the MagAlpha output, which are referred as  $out_i$  ( $out_i = 0^\circ$ , 11.25°, 22.5°, etc., where i = 0,...,31).

During operation, the sensor makes a linear interpolation using the two  $out_i$  surrounding the



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

present output to determine the correct compensation to apply (see Figure 33).



Figure 33: Linear Interpolation for On-Chip Calibration

Figure 34 shows an example comparing error before and after calibration.



Figure 34: Error Before and After Calibration

Note: out<sub>i</sub> refer to the sensor output with the default zero setting, not the user-configured zero setting. Therefore, calibration should be performed prior to zero setting.

#### **Correction Values Calculation**

The 32 correction values, *corr<sub>i</sub>*, are the negative value of the measured error:

$$corr_i = -err_i$$
 (11)

The measured errors, erri, are the difference between the sensor output and the ideal output:

$$err_i = out_i - ref_i$$
 (12)

where out; is the MA600A output in degrees and ref; is the real mechanical angle in degrees, measured by a reference, e.g. a precise encoder. If the zero of the reference encoder is far from the MA600A zero, then all errors *err*; will be large, in other word they will have a large common mode component. In this case *err*; can be offset by a constant value, without affecting the linearity after correction:

$$err_{i} = err_{i} - mean(err_{i})$$
 (13)

Once the correction values *corr<sub>i</sub>* in degrees, *corr<sub>i</sub>*(*deg*), are obtained, they need to be transformed into an integer number, *corr<sub>i</sub>*(*int*), to be stored to the memory.

Calibration allows to correct with an accuracy of 0.09°. To save memory space, the correction values *corr<sub>i</sub>(int)* are coded only on 8 bits, corresponding to a correction ranging from -11.25° to +11.25°. The format of *corr<sub>i</sub>(int)* is signed integer.

If  $corr_i(deg) \ge 0$ ,  $corr_i(int)$  can be calculated with Equation (14):

$$corr_i(int) = \frac{corr_i(deg)}{360^{\circ}} \cdot 32^{\circ} \cdot 128$$
 (14)

If  $corr_i(deg) < 0$ ,  $corr_i(int)$  can be calculated with Equation (15):

$$corr_i(int) = \frac{corr_i(deg)}{360^{\circ}} \cdot 32^{\circ} \cdot 128 + 256$$
 (15)

The user then stores the 32 correction values in decimal into block 1 (registers CORR0 to CORR31), which is reserved for calibration.

# Example

Before starting the calibration, registers CORR0 to CORR31 must be set to 0. As the first step, the 32 correction values are measured and calculated. Table 15 shows the correction values.

**Table 15: Calibration Table Example** 

| #  | out <sub>i</sub> (deg) | corr <sub>i</sub> (deg) | corr <sub>i</sub> (int) |
|----|------------------------|-------------------------|-------------------------|
| 0  | 0                      | 0.45                    | 5                       |
| 1  | 11.25                  | 0.33                    | 4                       |
| 2  | 22.5                   | 0.12                    | 1                       |
| 3  | 33.75                  | -0.07                   | 255                     |
|    |                        |                         |                         |
| 31 | 348.75                 | 0.53                    | 6                       |

Then store *corr<sub>i</sub>(int)* into the NVM on block 1.

If a high-accuracy reference is not available, the calibration can be done with a magnet rotating at constant speed. The maximum recommended magnet speed is 5krpm. The user calibration flow is described below, and the calculations need to be done outside of the MA600A:

 Use the product of the constant speed and time as the reference angle, calculate the error curve as a function of the MA600A output



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

- Extract the 1<sup>st</sup>, 2<sup>nd</sup>, 4<sup>th</sup>, and 8<sup>th</sup> harmonics of the error curve to rebuild an accurate error fitting curve to exclude potential effect of noise
- At every 11.25°, calculate err<sub>i</sub> using the fitting curve and convert the 32 obtained values from degrees to decimal.
- Write the 32 corr<sub>i</sub> values into corresponding registers and then store into the NVM

In principle, user digital calibration can be used instead of BCT adjustment for side-shaft configuration. When the k ratio is large though, the 11.25° range of the digital calibration is not sufficient, and BCT adjustment should be done first.

If multiple settings are used, the settings should be done in the following order:

- 1. BCT setting
- 2. User calibration
- 3. Zero setting

#### **Functional Test**

The functional test verifies the integrity of the sensor signal treatment. When setting FTM to 1, the signal from the TMR front end is replaced by a predetermined reference signal. The system reverts to normal operation as soon as FTM is set back to 0.

With the FTA bits, the reference signal can be virtually rotated by 90-degree steps (see Table 16).

**Table 16: Functional Test Mode** 

| FTM | FTA | Angle Output (deg) |  |  |  |  |
|-----|-----|--------------------|--|--|--|--|
| 1   | 00  | 0                  |  |  |  |  |
| 1   | 01  | 90                 |  |  |  |  |
| 1   | 10  | 180                |  |  |  |  |
| 1   | 11  | 270                |  |  |  |  |

### **ABZ Incremental Encoder Output**

The MA600A's ABZ output emulates an incremental encoder (e.g. an optical encoder) to provide logic pulses in quadrature (see Figure 35) Compared to signal A, signal B is shifted by a quarter of the pulse period.



Figure 35: ABZ Output Timing

Across one revolution, signal A pulses n times, where n is configurable between 1 pulse and 4096 pulses per revolution. The number of pulses per channel per revolution is configured by setting the PPT parameter, which consists of 12 bits split between registers ABZ0 and ABZ1 4 and register 5 (see Table 9 on page 23). The factory default is 512 pulses per turn. Table 17 shows how to configure PPT to set the required resolution.

Table 17: PPT

| PPT            | Pulses<br>per Turn | Edges<br>per Turn |     |
|----------------|--------------------|-------------------|-----|
| 0000 0000 0000 | 1                  | 4                 | Min |
| 0000 0000 0001 | 2                  | 8                 |     |
| 0000 0000 0010 | 3                  | 12                |     |
| 0000 0000 0011 | 4                  | 16                |     |
|                |                    |                   |     |
| 0111 1111 1110 | 2047               | 8188              |     |
| 0111 1111 1111 | 2048               | 8192              |     |
|                |                    |                   |     |
| 1111 1111 1101 | 4094               | 16376             |     |
| 1111 1111 1110 | 4095               | 16380             |     |
| 1111 1111 1111 | 4096               | 16384             | Max |

For example, to set 120 pulses per revolution (480 edges), set PPT to 120 - 1 = 119 (binary: 0000 0111 0111). Table 18 shows the required settings for registers ABZ0 and ABZ1.

Table 18: Registers ABZ0 and ABZ1 Setting

| Reg  | В7 | B6 | B5 | B4 | В3 | B2 | B1 | B0 |
|------|----|----|----|----|----|----|----|----|
| ABZ0 | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  |
| ABZ1 | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  |

Signal Z (zero or index) is raised only once per turn at the zero-angle position. The Z pulse's position and length is configurable via ILIP in register ABZ1 (see Figure 36).



### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE



Figure 36: ILIP Parameter Effect on Index Shape

By default, the ILIP parameter is 0000. The index rising edge is aligned with channel B's falling edge, and the index length is half of the A or B pulse length.

### **ABZ Hysteresis**

The hysteresis is set by the HYS parameter. The hysteresis (H) in degrees can be calculated with Equation (16):

H (deg)=
$$2.8 \times \frac{HYS}{256}$$
 (16)

Table 19 shows the HYS configuration.

Table 19: HYS

| HYS      | H (deg) |  |  |
|----------|---------|--|--|
| 00000000 | 0       |  |  |
| 00000001 | 0.011   |  |  |
| 00000010 | 0.022   |  |  |
|          | •••     |  |  |
| 11111110 | 2.778   |  |  |
| 11111111 | 2.789   |  |  |

Figure 37 shows the incremental output hysteresis.



Figure 37: Incremental Output Hysteresis

Table 20 shows the recommended settings of HYS and hysteresis to avoid spurious transitions.

| FW             | Resolution (Bit) | HYS<br>(decimal) | Hysteresis (deg) |
|----------------|------------------|------------------|------------------|
| 0              | 12.3             | 22               | 0.24             |
| 5<br>(default) | 12.5             | 16               | 0.18             |
| 6              | 12               | 11               | 0.12             |

**Table 20: Recommended Settings of HYS** 

| (default) | 12.5 | 16 | 0.18 |
|-----------|------|----|------|
| 6         | 13   | 11 | 0.12 |
| 7         | 13.5 | 7  | 0.08 |
| 8         | 14   | 5  | 0.05 |
| 9         | 14.3 | 4  | 0.04 |
| 10        | 14.6 | 3  | 0.03 |
| 11        | 14.8 | 3  | 0.03 |
| 12        | 15   | 3  | 0.03 |

#### **DAZ Interface**

For angular speed-related applications, the ABZ interface can be converted to DAZ (where D is the direction, A is the pulsing signal, and Z is the index) by configuring the DAZ bit to 1.

In this configuration, the D signal indicates CW (logic 0) or CCW (logic 1) magnetic field rotation. The A and Z signals remain unchanged compared to the ABZ interface.

# **UVW Incremental Encoder Output**

The UVW output emulates the three Hall switches that are typically used for the block commutation of a 3-phase brushless motor. The three logic signals have a duty cycle of 50% and are shifted by 60° relative to each other (see Figure 38).



Figure 38: UVW Output for 1 Pole Pair Rotor during Rotation

If the number of the rotor's pole pairs exceeds the number of pole pairs of the target magnet, then the MA600A generates more than one UVW cycle per revolution by dividing the digital angle into the required number of commutation steps per 360-degree revolution. The NPP parameter sets the number of emulated pole pairs and the corresponding commutation step angle for the UVW signals.

Table 21 shows the rotor pole pair options.



#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

**Table 21: Number of UVW Pole Pairs** 

| NPP              | Pairs Reve |    | State Width (deg) |
|------------------|------------|----|-------------------|
| 000<br>(default) | 1          | 6  | 60                |
| 001              | 2          | 12 | 30                |
| 010              | 3          | 18 | 20                |
| 011              | 4          | 24 | 15                |
| 100              | 5          | 30 | 12                |
| 101              | 6          | 36 | 10                |
| 110              | 7          | 42 | 8.6               |
| 111              | 8          | 48 | 7.5               |

Figure 39 shows an example of the 30° UVW commutation signal spacing for a 4-pole (2-pole pair) motor.



Figure 39: UVW Commutation Signals for a 4-Pole (2-Pole Pair) Motor

#### **UVW Hysteresis**

A hysteresis larger than the output noise is introduced on the UVW output to avoid any spurious transitions (see Figure 40).



Figure 40: Hysteresis of the UVW Signal PWM

The UVW hysteresis is also set by HYS and is subject to the same recommendations (see Table 19 on page 35).

# **ABSOLUTE OUTPUT**

This output provides a logic signal with a duty cycle corresponding to the magnetic field angle.

The signal frame consists of four different segments:

- Start band (always high)
- Error
- Data
- End band (always low)

Figure 41 shows one period of the PWM signal.



Figure 41: PWM Frame Composed of Four Bands (Start, Error, Data, End)

To display errors in the PWM frame, enable the PWMM parameter. Under normal conditions, the error band ( $w_{\text{ERR}}$ ) is 1.

w<sub>ERR</sub> is 0 if one of the following flags is raised to 1:

- ERRCRC
- ERRMEM
- ERRPAR

If PWMM is enabled and an error is detected, then the data remains at 0.

The frequency can be selected with the PWMF parameter.

Table 22 shows the PWM frequency selection.

**Table 22: PWM Frequency Selection** 

| PWMF | PWM Frequency |  |  |  |
|------|---------------|--|--|--|
| 0    | 1kHz          |  |  |  |
| 1    | 250Hz         |  |  |  |

Table 23 shows the PWM time durations in counts.

**Table 23: PWM Time Duration in Counts** 

|      | 1 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 |                  |        |                  |                   |                  |  |
|------|-----------------------------------------|------------------|--------|------------------|-------------------|------------------|--|
| PWMM | PWMF                                    | W <sub>PWM</sub> | WSTART | W <sub>ERR</sub> | W <sub>DATA</sub> | W <sub>END</sub> |  |
| 0    | 0                                       | 4119             | 16     | 0                | 4095              | 8                |  |
| 0    | 1                                       | 4119             | 16     | 0                | 4095              | 8                |  |
| 1    | 0                                       | 4119             | 12     | 4                | 4095              | 8                |  |
| 1    | 1                                       | 4119             | 12     | 4                | 4095              | 8                |  |



#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

## **Speed Output and Calculation**

When MTSP in register PRT is set to 1, the user can obtain the 16-bit speed output from SPI communication (see the SPI Read Multi-Turn or Speed section on page 14).

The speed is transmitted as a signed 16-bit number using two's complement representation. When calculating the signed decimal value, the user must multiply the MSB of the 16-bit speed value by -1 instead of 1.

The speed scale is 5.722rpm/LSB, which is based on a 100kHz inner clock. Therefore, the measured speed range is from -187498rpm to +187492rpm (see Table 24).

**Table 24: Speed Conversion** 

| 16-Bit Signed Value | Signed<br>Decimal<br>Value | Speed<br>(rpm) |
|---------------------|----------------------------|----------------|
| 0000 0000 0000 0000 | 0                          | 0              |
| 0000 0000 0000 0001 | 1                          | 5.722          |
| 1111 1111 1111 1111 | -1                         | -5.722         |
| 1000 0000 0000 0000 | -32768                     | -187498.50     |
| 0111 1111 1111 1111 | 32767                      | 187492.78      |

# Speed Output Example

If the readback 16-bit signed speed value is 1110 0100 1110 1010, then the decimal value can be calculated with Equation (17):

Speed(decimal) = 
$$-1 \cdot 2^{15} + 1 \cdot 2^{14} + 1 \cdot 2^{13} + 1 \cdot 2^{10} + 1 \cdot 2^{7} + 1 \cdot 2^{6}$$
 (17)  
+1\cdot 2^5 + 1\cdot 2^3 + 1\cdot 2 = -6934

The corresponding speed can be calculated with Equation (18):

Speed(rpm) = 
$$-6934 \cdot 5.722 = -39676.35$$
 (18)

Table 25 shows the speed output's resolution, time constant, and cutoff frequency.

**Table 25: Speed Output Typical Parameters** 

| Resolution at | Time         | Cutoff    |  |
|---------------|--------------|-----------|--|
| 5krpm         | Constant (T) | Frequency |  |
| (Bits)        | (µs)         | (Hz)      |  |
| 9.5           | 320          | 500       |  |

If the user wants to monitor the clock frequency and achieve a more precise speed calculation, the clock related to S<sub>SPEED</sub> can be output on pin CK100 by setting CK100 bit to 1 in register IF.

The relationship between  $S_{SPEED}$  and  $f_{CK100}$ , the CK100 frequency in kHz, can be calculated with Equation (19):

$$S_{SPEED}(rpm/LSB) = 5.722 \text{ x } \frac{f_{CK100}}{100}$$
 (19)

# **Multi-Turn Output**

If MTSP in register PRT is set to 0 (default setting), the user can obtain the 16-bit multi-turn output from SPI communication (see the SPI Read Multi-Turn or Speed section on page 14).

When the angle detected by the MA600A passes the zero position in a positive direction (CW), the multi-turn count increases by 1; when the detected angle passes the zero position in a negative direction (CCW), the multi-turn count decreases by 1.

It is possible to set a multi-turn offset by configuring MTOFFSET in registers MT0 and MT1. The multi-turn count (MT) returned by the sensor is computed by adding the offset to the measured multi-turn ( $MT_{MEAS}$ ).

MT can be calculated with Equation (20):

$$MT = MT_{MFAS} + MTOFFSET$$
 (20)

MT<sub>MEAS</sub> and MTOFFSET are set to 0 at system start-up. Consider that the MTOFFSET setting cannot be stored to the NVM. The user must set MTOFFSET after each start-up event if the offset is required.

Multi-turn is a signed 16-bit value. The user must multiply the MSB of the 16-bit multi-turn value by -1 instead of 1 (see Equation (17)).

The measured multi-turn range is from -32768 to 32767 (see Table 26).

**Table 26: Multi-Turn Conversion** 

| 16-Bit Signed Value | Signed Multi-Turn<br>Decimal Value |
|---------------------|------------------------------------|
| 0000 0000 0000 0000 | 0                                  |
| 0000 0000 0000 0001 | 1                                  |
| 1111 1111 1111 1111 | -1                                 |
| 1000 0000 0000 0000 | -32768                             |
| 0111 1111 1111 1111 | 32767                              |

#### **Status Byte**

Register 26 contains one status bit (NVMB) and three error bits (ERRPAR, ERRMEM, and ERRCRC) that trigger a flag when some errors are detected. These bits can be cleared by sending the Clear Error Flags command.



#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

#### **NVMB**

When the Store a Single Register Block to the NVM command or the Restore All Register Blocks from the NVM command is sent to the MA600A, the NVM is busy until the operation is executed. During this busy period, the NVMB status bit is temporarily set to 1 and then reset back to 0 after the operation is executed.

#### **ERRMEM**

If a command triggers NVM access (store or restore) while the NWM is busy, it is ignored and the ERRMEM bit is set to 1.

#### **ERRPAR**

When parity check is enabled by PRT, the controller must send a parity bit on the COPI line after the 16-bit command.

The MA600A checks the parity of this 17-bit long frame. If a parity error occurs, the command is discarded and the ERRPAR bit is set to 1. The angle data is returned in the next frame.

When parity check is enabled, if the user only sends a 16-bit command, ERRPAR is not asserted and the command is discarded.

#### **ERRCRC**

The restoration of register values from the NVM is secured by a CRC algorithm. A mismatch between the generated CRC result with the previously stored value is flagged by the ERRNVM bit being asserted (set to 1).

# Input/Output (I/O) Matrix

The function of the digital I/O pins (IO1 to IO6) can be set by INTF\_SEL (see Table 27).

Table 27: IO Matrix

| INTF_SEL      | 106  | IO1 | 105 | IO2 | 104  | 103 |
|---------------|------|-----|-----|-----|------|-----|
| 000 (default) | U    | V   | W   | Α   | В    | Z   |
| 001           | U    | V   | W   | SSD | SSCK | PWM |
| 010           | SSCK | SSD | PWM | А   | В    | Z   |
| 011           | U    | V   | W   | /V  | /U   | /W  |
| 100           | /B   | /A  | /Z  | А   | В    | Z   |
| 101           | U    | V   | W   | -   | -    | -   |
| 110           | -    | -   | -   | А   | В    | Z   |
| 111           | SSCK | SSD | PWM | -   | -    | -   |

#### **Digital I/O Pin Circuit**

The digital I/O pins (IO1 to IO6) are set to push-pull by default and can be changed to open drain to allow I/O voltages different than  $V_{DD}$  (up to 5.5V). If the I/O pin is set as SSCK by INTF\_SEL, it is affected by neither OD615 nor OD243.

Table 28 shows the internal circuit of the IO6, IO1, and IO5 pins.

Table 28: IO6, IO1, and IO5 Internal Circuit

| OD615       | Internal Circuit |
|-------------|------------------|
| 0 (default) | Push-pull        |
| 1           | Open drain       |

Table 29 shows the internal circuit of the IO2, IO4, and IO3 pins.

Table 29: IO2, IO4, and IO3 Internal Circuit

| OD243       | Internal Circuit |
|-------------|------------------|
| 0 (default) | Push-pull        |
| 1           | Open drain       |

Figure 42 shows the internal circuits of IO1 to IO6.



Figure 42: Output Circuits Inside IC for IO1 to IO6

The SPI input pins (/CS, SCLK, and COPI) are configured as pull-up or pull-down by default.

If required, the SPI inputs can be set to a high impedance (Hi-Z) state by the SPULLIN parameter (see Table 30 on page 39). When the



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

internal pin's impedance is high, it is recommended to pull SCLK and COPI to GND externally and pull /CS to DVDD to prevent any voltage buildup and inadvertent configuration when the SPI is idle (e.g. high /CS).

Table 30: SPI Input Pin Circuit

| SPULLIN     | SPI Input Pins |           |  |  |
|-------------|----------------|-----------|--|--|
| SFOLLIN     | /CS SCLK, COPI |           |  |  |
| 0           | Hi-Z Hi-Z      |           |  |  |
| 1 (default) | Pull-up        | Pull-down |  |  |

Figure 43 shows the inside circuit of the SPI inputs.



Figure 43: Circuit of the SPI Input Pins in the IC

The SPI output pin (CIPO) is configured as pushpull when the SPI is active. CIPO is configured as pull-down by default when the SPI is idle.

#### **Special Interfaces**

The MA600A supports special interfaces such as reduced wire mode and daisy chain, which provide more flexibility to communicate with the controller.

DAISY and RWM in register IO0 can disable the SPI communication permanently. A security mechanism is built in to avoid accidental configuration of register IO0.

The security mechanism process is described below:

- By default, register IO0 is locked, meaning the RWM and DAISY parameters cannot be written
- To unlock register IO0, the UR10 parameter in register UR10 must be enabled
- RWM or DAISY mode are effective only when UR10 is reset to zero

To enable the RWM or DAISY for temporary testing purposes, follow the steps below:

- 1. Set UR10 to 1.
- 2. Set RWM or DAISY to 1.
- Set UR10 to 0.

At this stage, RWM or DAISY mode is enabled. After shutting down and starting up, the MA600A returns to normal SPI mode.

To switch to RWM or DAISY permanently, follow the steps below:

- 1. Set UR10 to 1.
- 2. Set RWM or DAISY to 1.
- 3. Store register block 0 to the NVM.
- 4. Set UR10 to 0 or shut down and start up the MA600A.

#### **Reduced Wire Mode**

The MA600A supports reduced wire mode by setting RWM to 1.

Reduced wire mode enables the user to configure the chip during a set-up stage, and then transforms the SPI pin into outputs with other functionalities for normal operation to save three connections.

Table 31 shows the RWM and redirection of pin functionality.

Table 31: RWM and Redirection of Pin Functionality

| RWM         | Pin 4 | Pin 5 | Pin 7 | Pin 12 |
|-------------|-------|-------|-------|--------|
| 0 (default) | COPI  | /CS   | CIPO  | SCLK   |
| 1           | IO3   | IO4   | CIPO  | IO2    |

For example, if only the ABZ output is required, the user can configure the ABZ-related parameters first via SPI communication, then redirect the ABZ signal to the SPI pins. In this case, no additional wiring is needed at IO2, IO3, and IO4. A similar process applies if only UVW, SSI, or PWM is required. The functionality of IO2 to IO4 is determined by INTF\_SEL.

#### **Daisy Chain**

When connecting multiple sensors on the same bus, the daisy chain configuration enables saving the I/O pins. Daisy chain mode is enabled by setting DAISY to 1.



#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

In this mode, the CIPO data output of each peripheral sensor is chained to the COPI data input of the next peripheral sensor. The CIPO data output of the last peripheral sensors is connected back to the controller's CIPO input (see Figure 44).



Figure 44: Daisy Chain Mode Configuration

In daisy chain mode, data can be only read. If n is the number of connected devices, n x 16 clock counts are required to read the data of all sensors. The SPI bus chip select signal (/CS) should remain low during the n x 16 clock counts.

The first 16 bits are the angle data from the last peripheral (n) device in the chain, followed by the 16-bit angle data from the preceding (n - 1) device, and so on. Figure 45 shows an example of the SPI read angle for n daisy-chained MA600A devices.



Figure 45: SPI Read Angle for n Daisy Chained MA600A Devices



#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# APPLICATION INFORMATION ELECTRICAL MOUNTING AND POWER SUPPLY DECOUPLING

The two decoupling capacitors are connected to the supply lines (AVDD and DVDD) via a lowimpedance path (see Figure 46).



Figure 46: Power Supply Decoupling

If the decoupling capacitors are placed close to the sensor, the target magnetic field may be influenced and negatively impact the sensor's accuracy (INL) due to the MA600A's high accuracy. For example, an SMD capacitor (0603) placed 1.5mm from the MA600A's edge can create a second harmonic nonlinearity up to 0.2°. To avoid magnetic interference that affects sensor accuracy, it is recommended to place the capacitor at a distance of at least 5mm from the MAQ600. A larger distance helps avoiding even further the capacitor magnetic interference.

Keep the high current path and ground as far away from the MA600A as possible to prevent potential interference.

It is recommended to float the MA600A's exposed pad to minimize mechanical stress.

# SPI SIGNALS ROUTING ON PCB

Typically, a direct connection between the sensor and controller SPI pins is sufficient to ensure a proper data transfer over the SPI bus. However, in specific situations (e.g.: long signal traces, external EMI presence) it is possible to improve signal integrity by making special

considerations during the PCB design, in particular for SCLK line. A list of useful guidelines is shown below:

- Properly shield all SPI signals with a GND plane on both sides of each trace, as well as GND plane underneath the SPI signals.
- Place vias along these traces to connect the top and bottom GND planes.
- To avoid EMI issues, route the SCLK signal away from the other SPI signals and noise sources. The distance should be at least three times the SCLK trace width.
- Insert an RC low-pass filter on SCLK (see Figure 10). This RC filter must be located close to the sensor. It is recommended to use a 200Ω serial resistor with a 10pF shunt capacitor to obtain an 80MHz filter cutting frequency.
- Use a star topology for the GND connection and keep it as direct and short as possible to avoid ground loops.
- Insert RC low-pass filters on the CIPO and COPI signals (see Figure 47). The RC filter on COPI must be located close to the controller, while the filter on CIPO must be located close to the sensor. It is recommended to use a 200Ω resistor with a 10pF capacitor.
- Avoid a significant trace length mismatch between the SPI signals, especially between the CIPO, COPI, and SCLK signals. These signals should have similar propagation delays.
- If possible, avoid placing vias on the SCLK signal.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE



Figure 47: Example of RC Low Pass Filters on the SPI Signals



PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# TYPICAL APPLICATION CIRCUIT



Figure 48: Typical Application Circuit (Configuration Using the SPI)



PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# APPENDIX A: SPI COMMUNICATION CHEATSHEET

Read Angle (see the SPI Read Angle section on page 14)



# **32-Bit Frame Read Multi-Turn or Speed Operation** (see the SPI Read Multi-Turn or Speed section on page 14)



# Read Register (see the SPI Read Register section on page 15)



#### Write Register (see the SPI Write Register on page 15)





# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

Store a Single Register Block to the NVM (see the SPI Store a Single Register Block to the NVM section on page 16)



# Restore All Register Blocks from the NVM (see the SPI Restore All Register Blocks from the NVM section on page 17)



# Clear Error Flags (see the SPI Clear Error Flags section on page 17)



# Read Angle when SPI Parity Check Is Enabled (see the SPI Parity Check section on page 18)





(INL)

MA600A - HIGH-ACCURACY, <0.6° (<0.1°) INL, DIGITAL MAGNETIC SENSOR

#### PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **APPENDIX B: DEFINITIONS**

**Resolution** Smallest angle increment distinguishable from the noise. The resolution is  $(3\sigma \text{ noise level})$  measured by computing three times  $\sigma$  (the standard deviation in degrees)

taken over 1,000 data points at a constant position. The resolution in bits is

obtained with  $log2(360 / 6\sigma)$ .

**Refresh Rate** Rate at which new data points are stored in the output buffer.

ABZ Update Rate Rate at which a new ABZ state is computed. The inverse of this rate is the

minimum time between two ABZ edges.

**Latency** Time elapsed between the instant when the data is ready to be read and the

instant at which the shaft passes that position. The lag in degrees is

 $lag = latency \cdot v$ , where v is the angular velocity in deg/s.

**Start-Up Time** Time until the sensor delivers valid data, starting at power-up.

Integral Nonlinearity Maximum deviation between the average sensor output (at a fixed position)

and the true mechanical angle (see Figure B1).



Figure B1: Resolution, INL, Lag

INL can be obtained from the error curve  $err(\alpha) = out(\alpha) - \alpha$ , where  $out(\alpha)$  is the average sensor output calculated over many samples (e.g. 1000), and  $\alpha$  is the mechanical angle indicated by a high-precision (<0.001°) encoder. INL is then calculated with Equation (B1):

$$INL = \frac{\max(err(\alpha)) - \min(err(\alpha))}{2}$$
 (B1)

#### **INL Harmonics**

Since the error is a periodical function of period  $2\pi$ , it can be expressed as a Fourier Series. The formula is shown in Equation B2:

- err(α) is the error curve.
- α is the mechanical angle in radians.
- each n<sup>th</sup> element of the summation is referred to as the n<sup>th</sup> harmonic component of the error.
- $H_0$  is the offset between the sensor output and the mechanical angle, namely the mean value of  $err(\alpha)$  (see Equation B3).

MA600A Rev. 0.8 MonolithicPower.com 47



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

- H<sub>n</sub> is the amplitude of the n<sup>th</sup> harmonic component (see Equation B4).
- $\varphi_n$  is the phase in radians of the  $n^{th}$  harmonic component (see Equation B5).

$$err(\alpha) = H_0 + \sum_{n=1}^{N} H_n \cos(n\alpha - \phi_n)$$
 (B2)

$$H_0 = \frac{1}{2\pi} \int_0^{2\pi} err(\alpha) d\alpha$$
 (B3)

$$H_n = \sqrt{A_n^2 + B_n^2} \tag{B4}$$

$$\varphi_n = \tan^{-1}\left(\frac{B_n}{A_n}\right) \tag{B5}$$

$$A_{n} = \frac{1}{\pi} \int_{0}^{2\pi} err(\alpha) cos(n\alpha) d\alpha$$
 (B6)

$$B_{n} = \frac{1}{\pi} \int_{0}^{2\pi} err(\alpha) sin(n\alpha) d\alpha$$
 (B7)

Drift

Angle variation rate when one parameter is changed (e.g. temperature, VDD) and all the others, including the shaft angle, are kept constant.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# PACKAGE INFORMATION

# QFN-16 (3mmx3mm) Wettable Flank





#### **TOP VIEW**

**BOTTOM VIEW** 







# **SECTION A-A**



#### **RECOMMENDED LAND PATTERN**

# **NOTE:**

- 1) THE LEAD SIDE IS WETTABLE.
- 2) ALL DIMENSIONS ARE IN MILLIMETERS.
- 3) EXPOSED PADDLE SIZE DOES NOT INCLUDE MOLD FLASH.
- 4) LEAD COPLANARITY SHALL BE 0.08 MILLIMETERS MAX.
- 5) JEDEC REFERENCE IS MO-220.
- 6) DRAWING IS NOT TO SCALE.



# PRELIMINARY SPECIFICATION SUBJECT TO CHANGE

# **CARRIER INFORMATION**



| Part Number          | Package             | Quantity/ | Quantity/ | Quantity/ | Reel     | Carrier    | Carrier    |
|----------------------|---------------------|-----------|-----------|-----------|----------|------------|------------|
|                      | Description         | Reel      | Tube      | Tray      | Diameter | Tape Width | Tape Pitch |
| MA600AGQE-<br>xxxx-Z | QFN-16<br>(3mmx3mm) | 5000      | N/A       | N/A       | 13in     | 12mm       | 8mm        |

**NOTICE:** The information in this document is subject to change without notice. Please contact MPS for current specifications. Users should warrant and guarantee that third party Intellectual Property rights are not infringed upon when integrating MPS products into any application. MPS will not assume any legal responsibility for any said applications.

50