

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface

# **About this document**









## **Scope and purpose**

This document provides product information and descriptions regarding:

- I<sup>2</sup>C Registers
- I<sup>2</sup>C Interface
- Wake Up mode
- Diagnostic and Tests

#### **Intended audience**

This document is aimed at engineers and developers of hard and software using the sensor TLE493D-P2B6.

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# Table of contents

# **Table of contents**

|         | About this document                                                            | 1  |
|---------|--------------------------------------------------------------------------------|----|
|         | Table of contents                                                              | 2  |
| 1       | I <sup>2</sup> C Register                                                      | 4  |
| 1.1     | Register overview                                                              | 4  |
| 1.2     | Register description                                                           | 5  |
| 1.2.1   | Bit types                                                                      | 5  |
| 1.2.2   | Measurement data and registers combined in the I <sup>2</sup> C parity bit "P" | 5  |
| 1.2.3   | Wake Up and registers combined in the I <sup>2</sup> C parity flag "CF"        | 8  |
| 1.2.4   | Mode registers combined in the I <sup>2</sup> C parity flag "FF"               | 13 |
| 1.2.5   | Diagnostic, status and version registers                                       | 15 |
| 2       | I <sup>2</sup> C Interface                                                     | 18 |
| 2.1     | I <sup>2</sup> C protocol description                                          | 18 |
| 2.1.1   | General description                                                            | 18 |
| 2.1.2   | I <sup>2</sup> C write command                                                 | 18 |
| 2.1.3   | I <sup>2</sup> C read commands                                                 | 22 |
| 2.1.3.1 | 2-byte read command                                                            | 22 |
| 2.1.3.2 | 1-byte read command                                                            | 22 |
| 2.2     | Collision avoidance and clock stretching                                       | 24 |
| 2.2.1   | Collision avoidance (CA bit = 0 <sub>B</sub> and INT bit = 0 <sub>B</sub> )    | 24 |
| 2.2.2   | Clock stretching (CA bit = $0_B$ and INT bit = $1_B$ )                         | 25 |
| 2.3     | Sensor reset by I <sup>2</sup> C                                               | 26 |
| 2.4     | Sensor Initialization and Readout example                                      | 27 |
| 2.5     | Loss of V <sub>DD</sub> impact on I <sup>2</sup> C bus                         | 28 |
| 3       | Wake Up mode                                                                   | 29 |
| 3.1     | Wake Up activation                                                             | 30 |
| 3.2     | Wake Up constraints                                                            | 30 |
| 3.3     | Wake Up in combination with the angular mode                                   |    |
| 4       | Diagnostic and tests                                                           | 32 |
| 4.1     | Diagnostic functions                                                           | 32 |
| 4.1.1   | Parity bits and parity flags                                                   | 32 |
| 4.1.2   | Test mode                                                                      | 32 |
| 4.1.3   | Power-down flags                                                               | 32 |
| 4.1.4   | Frame counter                                                                  |    |
| 4.1.5   | Device address                                                                 | 32 |
| 4.2     | Test functions                                                                 | 32 |
| 4.2.1   | Vhall/Vext test mode                                                           | 33 |
| 4.2.1.1 | Test description                                                               | 33 |
| 4.2.1.2 | Test implementation                                                            |    |

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# Table of contents

|         | Disclaimer                          | 41 |
|---------|-------------------------------------|----|
| 6       | Revision history                    | 40 |
| 5       | Terminology                         | 39 |
| 4.3     | Magnetic measurement implementation | 38 |
| 4.2.3.2 | Test implementation                 | 37 |
| 4.2.3.1 | Test description                    |    |
| 4.2.3   | SAT-test mode                       | 37 |
| 4.2.2.3 | Test reference values               | 36 |
| 4.2.2.2 | Test implementation                 | 36 |
| 4.2.2.1 | Test description                    | 32 |
| 4.2.2   | Spintest mode                       | 32 |
| 4.2.1.3 | Test reference values               | 33 |

3

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



1 I<sup>2</sup>C Register

#### I<sup>2</sup>C Register 1

The TLE493D-P2B6 includes several registers that can be accessed via Inter-Integrated Circuit interface (I<sup>2</sup>C) to read data as well as to write and configure settings.

#### **Register overview** 1.1

A bitmap overview is presented in *Figure 1*. Basically the following sections are available:

- measurement data (green bits in registers 00<sub>H</sub> till 05<sub>H</sub>)
- sensor status and diagnostics (grey bits in registers 05<sub>H</sub>, 06<sub>H</sub>, 0E<sub>H</sub>, 0F<sub>H</sub>, 10<sub>H</sub> and 11<sub>H</sub>)
- configuration parameters such as the power mode (orange bits in registers 10<sub>H</sub>, 11<sub>H</sub> and 13<sub>H</sub>)
- Wake Up values in registers (blue bits in registers 07<sub>H</sub> till 0F<sub>H</sub>)



Figure 1 TLE493D-P2B6 Bitmap

The diagnostic register 06<sub>H</sub> contains parity information as a diagnostic mechanism. The bitmap illustrates this and marks the relationship of the sections to this flags with different colored lines/frames around the bit contents.

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 1 I<sup>2</sup>C Register

**Register overview** Table 1

| Register name | Register long name                               | Address                                             |
|---------------|--------------------------------------------------|-----------------------------------------------------|
| Bx, By and Bz | Magnetic values MSBs                             | 00 <sub>H</sub> , 01 <sub>H</sub> , 02 <sub>H</sub> |
| Temp          | Temperature value MSBs                           | 03 <sub>H</sub>                                     |
| Bx2           | Magnetic values LSBs                             | 04 <sub>H</sub>                                     |
| Temp2         | Temperature and magnetic LSBs and device address | 05 <sub>H</sub>                                     |
| Diag          | Sensor diagnostic and status register            | 06 <sub>H</sub>                                     |
| XL, YL and ZL | Wake Up lower threshold MSBs                     | 07 <sub>H</sub> , 09 <sub>H</sub> , 0B <sub>H</sub> |
| XH, YH and ZH | Wake Up upper threshold MSBs                     | 08 <sub>H</sub> , 0A <sub>H</sub> , 0C <sub>H</sub> |
| WU            | Wake Up enable and X thresholds LSBs             | 0D <sub>H</sub>                                     |
| TMode         | Test Mode and Wake Up Y thresholds LSBs          | 0E <sub>H</sub>                                     |
| TPhase        | Test Phase and Wake Up Z thresholds LSBs         | 0F <sub>H</sub>                                     |
| Config        | Configuration register                           | 10 <sub>H</sub>                                     |
| MOD1          | Power mode, interrupt, address, parity           | 11 <sub>H</sub>                                     |
| MOD2          | Low Power Mode update rate                       | 13 <sub>H</sub>                                     |
| Ver           | Version register                                 | 16 <sub>H</sub>                                     |

#### **Register description** 1.2

The I<sup>2</sup>C registers can be read or written at any time. It is recommended to read measurement data in a synchronized fashion, i.e. after an interrupt pulse (/INT). This avoids reading inconsistent sensor or diagnostic data, especially in fast mode. Additionally, several flags can be checked to ensure the register values are consistent and the ADC was not running at the time of readout.

#### 1.2.1 Bit types

The TLE493D-P2B6 contains read bits, write bits and reserved bits.

Table 2 Bit types

| Abbreviation | Function   | Description                                                           |
|--------------|------------|-----------------------------------------------------------------------|
| r            | Read       | Read-only bits                                                        |
| rw           | Read Write | Readable and writable bit                                             |
|              | Reserved   | Bits that must keep the default values (read prior to write required) |

#### Measurement data and registers combined in the I2C parity bit "P" 1.2.2

The I<sup>2</sup>C communication of the registers in this chapter is protected with the parity bit "P", described in the Diag register with the address 06<sub>H</sub>. See also *Figure 1* - parity bits and related registers.

To make sure all data is consistent, the registers from  $00_{H}$  to  $06_{H}$  should be read with the same  $I^{2}C$  command. Otherwise, the sampled data (X, Y, Z, Temperature) may correspond to different conversion cycles.

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



## 1 I<sup>2</sup>C Register

## **Magnetic values MSBs**



Back to TLE493D-P2B6 Bitmap.

#### **Temperature value MSBs**

| Register name |      |      | Address                                                                                                | Reset Value     |
|---------------|------|------|--------------------------------------------------------------------------------------------------------|-----------------|
| Temp          |      |      | 03 <sub>H</sub>                                                                                        | 80 <sub>H</sub> |
| 7             |      |      |                                                                                                        | 0               |
|               | 1    | 1    | Temp (114)                                                                                             |                 |
| Field         | Bits | Туре | Description                                                                                            | <u> </u>        |
| Temp          | 7:0  | r    | Temperature value                                                                                      |                 |
|               |      |      | Signed value as two's complement. If the temperation measurement is deactivated, the Temp value is the |                 |

Back to TLE493D-P2B6 Bitmap.

#### **Magnetic values LSBs**

| Register name |                | Address |                |                | Reset Value     |
|---------------|----------------|---------|----------------|----------------|-----------------|
| Bx2           |                | 04      | 4 <sub>H</sub> |                | 00 <sub>H</sub> |
| 7             |                | 4       | 3              |                | 0               |
|               | <b>Bx</b> (30) | 1       |                | <b>By</b> (30) |                 |

| Field | Bits | Туре | Description                                                                                                                               |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bx    | 7:4  | r    | Bx value                                                                                                                                  |
|       |      |      | Signed value as two's complement from the HALL probes in the x-direction of the magnetic field. Contains the four Least Significant Bits. |
| Ву    | 3:0  | r    | By value                                                                                                                                  |
|       |      |      | Signed value as two's complement from the HALL probes in the y-direction of the magnetic field. Contains the four Least Significant Bits. |

Back to TLE493D-P2B6 Bitmap.

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

## Temperature and magnetic LSBs and device address



| Field | Bits | Туре | Description                                                                                                                                                                                     |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Temp  | 7:6  | r    | Temperature value                                                                                                                                                                               |
|       |      |      | Signed value as two's complement. If the temperature measurement is deactivated, the Temp value is the reset value.                                                                             |
| ID    | 5:4  | r    | ID                                                                                                                                                                                              |
|       |      |      | Readback of the sensor ID, from <code>IICadr</code> . $\mu$ C shall verify the address sent by the sensor. See <code>Table 4</code> .                                                           |
| Bz    | 3:0  | r    | Bz value                                                                                                                                                                                        |
|       |      |      | Signed value as two's complement from the HALL probes in the z-direction of the magnetic field. Contains the four Least Significant Bits. If Bz is deactivated the Bz value is 0 <sub>H</sub> . |

Back to TLE493D-P2B6 Bitmap.

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



1 I<sup>2</sup>C Register

# 1.2.3 Wake Up and registers combined in the I<sup>2</sup>C parity flag "CF"

The I<sup>2</sup>C communication of the registers in this chapter is protected by the parity bit CF, which is described in the Diag register with the address  $06_{H}$ . See also *Figure 1* - parity bits and related registers.

## Wake Up lower threshold MSBs



Back to TLE493D-P2B6 Bitmap.

#### Wake Up upper threshold MSBs



Back to TLE493D-P2B6 Bitmap.

#### Wake Up enable and X thresholds LSBs



# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

| Field | Bits | Type | Description                                                                                                                                                                    |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WA    | 7    | r    | Wake Up mode active                                                                                                                                                            |
|       |      |      | Flag that reports whether the Wake Up mode is disabled or enabled.                                                                                                             |
|       |      |      | If 0 <sub>B</sub> the Wake Up mode is disabled.                                                                                                                                |
|       |      |      | If 1 <sub>B</sub> the Wake Up mode is enabled.                                                                                                                                 |
|       |      |      | This bit can be checked if the Wake Up function is disabled or enabled. As long as the $WA$ bit = $0_B$ , the /INT will be asserted according <i>Table 5</i> .                 |
| WU    | 6    | rw   | Enables Wake Up mode                                                                                                                                                           |
|       |      |      | If 0 <sub>B</sub> the Wake Up mode will be disabled.                                                                                                                           |
|       |      |      | If 1 <sub>B</sub> the Wake Up mode will be enabled.                                                                                                                            |
|       |      |      | The following conditions must be fulfilled:                                                                                                                                    |
|       |      |      | <ul> <li>Test modes must be disabled (T bit = 0<sub>B</sub>)</li> </ul>                                                                                                        |
|       |      |      | • <b>CP</b> parity bit (register 10 <sub>H</sub> ) must be odd                                                                                                                 |
|       |      |      | <ul> <li>Configuration parity must be flagged (CF bit = 1<sub>B</sub>)</li> </ul>                                                                                              |
|       |      |      | Interrupts /INT will be sent when the measurement data is ≥ upper or ≤ lower Wake Up threshold.                                                                                |
| XH    | 5:3  | rw   | Wake Up X upper threshold                                                                                                                                                      |
|       |      |      | Defines the upper threshold LSBs of the magnetic field in the x-direction at or above the sensor enables the /INT, if <i>INT</i> bit = $0_B$ . See <i>Equation 2</i> .         |
| XL    | 2:0  | rw   | Wake Up X lower threshold                                                                                                                                                      |
|       |      |      | Defines the lower threshold LSBs of the magnetic field density in the x-direction at or below the sensor enables the /INT, if <i>INT</i> bit = $0_B$ . See <i>Equation 2</i> . |

Back to TLE493D-P2B6 Bitmap.

# Test Mode and Wake Up Y thresholds LSBs

Register name Address **Reset Value** TMode 0E<sub>H</sub> 38<sub>H</sub> **YL** (3...1) **TST YH** (3...1)

| Field | Bits | Туре | Description                                                                                                                                                                            |
|-------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TST   | 7:6  | rw   | Test mode                                                                                                                                                                              |
|       |      |      | Different test modes can be enabled, see <i>Table 3</i> :                                                                                                                              |
|       |      |      | If $00_B$ no test active (normal sensor operation and $T$ bit = $0_B$ ). In the following test modes the $T$ bit = $1_B$ and the test result overwrites the measurement data register: |
|       |      |      | If 01 <sub>B</sub> Vhall/Vext test starts: measure the Hall bias voltage on all Hall plates and V <sub>DD</sub> .                                                                      |
|       |      |      | If 10 <sub>B</sub> Spintest starts: the <i>PH</i> bits select the channel to diagnose with the Spin-switch and Hall-offset test.                                                       |
|       |      |      | If 11 <sub>B</sub> SAT test starts: a test of the whole digital path, generates patterns, defined by the PH bits during conversion.                                                    |

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

| Field | Bits | Туре | Description                                                                                                                                                                     |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| YH    | 5:3  | rw   | Wake Up Y upper threshold                                                                                                                                                       |
|       |      |      | Defines the upper threshold LSBs of the magnetic field in the y-direction at or above which the sensor enables the /INT, if <i>INT</i> bit = $0_B$ .                            |
|       |      |      | See <b>Equation 2</b> .                                                                                                                                                         |
| YL    | 2:0  | rw   | Wake Up Y lower threshold                                                                                                                                                       |
|       |      |      | Defines the lower threshold LSBs of the magnetic field density in the y-direction at or below which the sensor enables the /INT, if $INT$ bit = $0_B$ . See <i>Equation 2</i> . |

Back to TLE493D-P2B6 Bitmap.

# Test Phase and Wake Up Z thresholds LSBs



| Field | Bits | Туре | Description                                                                                                                                                                     |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PH    | 7:6  | rw   | Test phase selection                                                                                                                                                            |
|       |      |      | In the Spintest these bits define the channel. In the digital test, specific patterns are defined. See Test phase selection <i>Table 3</i> .                                    |
|       |      |      | The PH bits have no effect in the voltage measurement test (Vext) and in normal operating mode <i>TST</i> bit=00 <sub>B</sub> and <i>T</i> bit=0 <sub>B</sub> ).                |
|       |      |      | See <b>Equation 2</b> .                                                                                                                                                         |
| ZH    | 5:3  | rw   | Wake Up Z upper threshold                                                                                                                                                       |
|       |      |      | Defines the upper threshold LSBs of the magnetic field in the z-direction at or above which the sensor enables the /INT, if $INT$ bit = $0_B$ .                                 |
|       |      |      | See <b>Equation 2</b> .                                                                                                                                                         |
| ZL    | 2:0  | rw   | Wake Up Z lower threshold                                                                                                                                                       |
|       |      |      | Defines the lower threshold LSBs of the magnetic field density in the z-direction at or below which the sensor enables the /INT, if $INT$ bit = $0_B$ . See <i>Equation 2</i> . |

Back to TLE493D-P2B6 Bitmap.

# **Configuration register**

| F | Register nam | es | Address           |   |    |     |     |    |          |
|---|--------------|----|-------------------|---|----|-----|-----|----|----------|
| ( | Config       |    | $10_{H}$ $01_{H}$ |   |    |     |     |    | $01_{H}$ |
| _ | 7            | 6  | 5                 | 4 | 3  | 2   | 1   | 0  | _        |
|   | DT           | АМ | TRIG              |   | X2 | TL_ | mag | СР |          |

# **Usermanual TLE493D-P2B6** High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

| Field  | Bits | Туре | Description                                                                                                                                                                                                                                                                                                   |
|--------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DT     | 7    | rw   | Disable Temperature                                                                                                                                                                                                                                                                                           |
|        |      |      | If 0 <sub>B</sub> temperature measurement is enabled.                                                                                                                                                                                                                                                         |
|        |      |      | If $1_{B}$ temperature measurement is disabled. This means the Bx, By and Bz channels are measured. The Temp channel is disabled and contains the reset value until a new conversion with Temp is done.                                                                                                       |
| AM     | 6    | rw   | X/Y Angular Measurement                                                                                                                                                                                                                                                                                       |
|        |      |      | If 0 <sub>B</sub> the Bz measurement is enabled.                                                                                                                                                                                                                                                              |
|        |      |      | If $1_B$ and DT bit = $1_B$ : the Bz measurement is disabled. This means the Bx and By channel is measured. The channels Bz and Temp contain the reset values until a new conversion with Bz and Temp is done                                                                                                 |
|        |      |      | If $1_B$ and DT bit = $0_B$ : must not be used.                                                                                                                                                                                                                                                               |
| TRIG   | 5:4  | rw   | Trigger options                                                                                                                                                                                                                                                                                               |
|        |      |      | If PR bit = $1_B$ (1-byte read protocol), the TRIG bits define the trigger mode of the device:                                                                                                                                                                                                                |
|        |      |      | If 00 <sub>B</sub> no ADC trigger on read                                                                                                                                                                                                                                                                     |
|        |      |      | If 01 <sub>B</sub> ADC trigger on read before first MSB.                                                                                                                                                                                                                                                      |
|        |      |      | If 1x <sub>B</sub> ADC trigger on read after register 05 <sub>H</sub> .                                                                                                                                                                                                                                       |
|        |      |      | If PR bit = $0_B$ these bits have no effect.                                                                                                                                                                                                                                                                  |
| X2     | 3    | rw   | Short range sensitivity                                                                                                                                                                                                                                                                                       |
|        |      |      | When this bit is set, the sensitivity of the Bx, By, and Bz ADC-conversion is doubled by a longer ADC integration time. The Temp result will not change, neither in sensitivity nor conversion time. See <i>Table 3</i> .                                                                                     |
| TL_mag | 2:1  | rw   | Magnetic temperature compensation                                                                                                                                                                                                                                                                             |
|        |      |      | There are two bits for setting the sensitivity over temperature of the sensor to compensate a magnet temperature coefficient. If $00_B \rightarrow TC_0$ (no compensation) If $01_B \rightarrow TC_1$ If $10_B \rightarrow TC_2$ If $11_B \rightarrow TC_3$                                                   |
| СР     | 0    | rw   | Wake Up and configuration parity                                                                                                                                                                                                                                                                              |
|        |      |      | The registers $07_H$ through $10_H$ (including $10_H$ ) without WA TST and PH bit are odd parity protected with this bit. On startup or reset, this parity is false and the <i>CF</i> bit in the status register $06_H$ is cleared. Thus the <i>CP</i> bit has to be corrected once after startup or a reset. |
|        |      |      | If this parity bit is incorrect during a write cycle, the Wake Up is disabled.                                                                                                                                                                                                                                |

# Usermanual TLE493D-P2B6 High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

Table 3 Test mode interaction of TST, PH and X2 bits

| TST bits        | PH bits         | X2 bit         | Bx (110)                        | By (110)                        | Bz (110)                        | T (112)                         |
|-----------------|-----------------|----------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|
| 00 <sub>B</sub> | don´t care      | 0 <sub>B</sub> | Bx full-range                   | By full-range                   | Bz full-range                   | T full-range                    |
| 00 <sub>B</sub> | don´t care      | 1 <sub>B</sub> | Bx short-range                  | By short-range                  | Bz short-range                  | T full-range                    |
| 01 <sub>B</sub> | don´t care      | don´t care     | Vhall X                         | Vhall Y                         | Vhall Z                         | Voltage V <sub>DD</sub>         |
| 10 <sub>B</sub> | 00 <sub>B</sub> | don´t care     | Spintest-Bx,<br>spin-0 disabled | Spintest-Bx,<br>spin-1 disabled | Spintest-Bx,<br>spin-2 disabled | Spintest-Bx,<br>spin-3 disabled |
| 10 <sub>B</sub> | 01 <sub>B</sub> | don´t care     | Spintest-By,<br>spin-0 disabled | Spintest-By, spin-1 disabled    | Spintest By, spin-2 disabled    | Spintest By, spin-3 disabled    |
| 10 <sub>B</sub> | 10 <sub>B</sub> | don´t care     | Spintest-Bz,<br>spin-0 disabled | Spintest-Bz,<br>spin-1 disabled | Spintest-Bz,<br>spin-2 disabled | Spintest-Bz,<br>spin-3 disabled |
| 10 <sub>B</sub> | 11 <sub>B</sub> | don´t care     | Spintest-T, setting1            | Spintest-T, setting2            | Spintest-T,<br>setting2         | Spintest-T, setting1            |
| 11 <sub>B</sub> | 00 <sub>B</sub> | 0 <sub>B</sub> | 7F9 <sub>H</sub>                | 806 <sub>H</sub>                | 7FF <sub>H</sub>                | 200 <sub>H</sub>                |
| 11 <sub>B</sub> | 01 <sub>B</sub> | 0 <sub>B</sub> | 806 <sub>H</sub>                | 7F9 <sub>H</sub>                | 800 <sub>H</sub>                | 1FF <sub>H</sub>                |
| 11 <sub>B</sub> | 10 <sub>B</sub> | 0 <sub>B</sub> | 7FF <sub>H</sub>                | 800 <sub>H</sub>                | 7F9 <sub>H</sub>                | 201 <sub>H</sub>                |
| 11 <sub>B</sub> | 11 <sub>B</sub> | 0 <sub>B</sub> | 800 <sub>H</sub>                | 7FF <sub>H</sub>                | 806 <sub>H</sub>                | 1FE <sub>H</sub>                |
| 11 <sub>B</sub> | 00 <sub>B</sub> | 1 <sub>B</sub> | 7FF <sub>H</sub>                | 800 <sub>H</sub>                | 7FF <sub>H</sub>                | 200 <sub>H</sub>                |
| 11 <sub>B</sub> | 01 <sub>B</sub> | 1 <sub>B</sub> | 800 <sub>H</sub>                | 7FF <sub>H</sub>                | 800 <sub>H</sub>                | 1FF <sub>H</sub>                |
| 11 <sub>B</sub> | 10 <sub>B</sub> | 1 <sub>B</sub> | 7FF <sub>H</sub>                | 800 <sub>H</sub>                | 7FF <sub>H</sub>                | 201 <sub>H</sub>                |
| 11 <sub>B</sub> | 11 <sub>B</sub> | 1 <sub>B</sub> | 800 <sub>H</sub>                | 7FF <sub>H</sub>                | 800 <sub>H</sub>                | 1FE <sub>H</sub>                |

Back to TLE493D-P2B6 Bitmap.

# **Usermanual TLE493D-P2B6** High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



1 I<sup>2</sup>C Register

#### Mode registers combined in the I<sup>2</sup>C parity flag "FF" 1.2.4

The I<sup>2</sup>C communication of the registers in this chapter is protected with the parity bit "FF", described in the Diag register with the address 06<sub>H</sub>. See also *Figure 1* - parity bits and related registers.

## Power mode, interrupt, address, parity

| Register name | e ,   | ,, , | Add                                                                                                  | Reset Value (Product Type A0) 80 <sub>H</sub>                                                                                          |                                                                                               |                                                                                                             |  |  |
|---------------|-------|------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|
|               |       |      |                                                                                                      |                                                                                                                                        |                                                                                               | (Product Type A1) 20 <sub>H</sub><br>(Product Type A2) 40 <sub>H</sub><br>(Product Type A3) E0 <sub>H</sub> |  |  |
| 7             | 6     | 5    | 4                                                                                                    | 3                                                                                                                                      | 2                                                                                             | 1 0                                                                                                         |  |  |
| FP            | IICad | dr   | PR                                                                                                   | CA                                                                                                                                     | INT                                                                                           | MODE                                                                                                        |  |  |
| Field         | Bits  | Type | Description                                                                                          | 1                                                                                                                                      |                                                                                               |                                                                                                             |  |  |
| FP            | 7     | rw   | Fuse parity                                                                                          | ,                                                                                                                                      |                                                                                               |                                                                                                             |  |  |
|               |       |      | The register this bit.                                                                               | s 11 <sub>H</sub> and 13 <sub>H</sub>                                                                                                  | (bits 7:5) are o                                                                              | dd parity protected with                                                                                    |  |  |
|               |       |      |                                                                                                      | bit is incorrec                                                                                                                        | =                                                                                             |                                                                                                             |  |  |
|               |       |      |                                                                                                      | state a sensor                                                                                                                         | reset is necess                                                                               | ary.                                                                                                        |  |  |
| IICadr        | 6:5   | rw   | I <sup>2</sup> C address                                                                             |                                                                                                                                        | 1011                                                                                          | dationalismos delicas in                                                                                    |  |  |
|               |       |      | bus configu                                                                                          |                                                                                                                                        | , 10 <sub>B</sub> or 11 <sub>B</sub> to                                                       | define the slave address in                                                                                 |  |  |
|               |       |      | See <i>Table 4</i> and data sheet.                                                                   |                                                                                                                                        |                                                                                               |                                                                                                             |  |  |
| PR            | 4     | rw   | I <sup>2</sup> C 1-byte o                                                                            | or 2-byte read                                                                                                                         | protocol                                                                                      |                                                                                                             |  |  |
|               |       |      | _                                                                                                    | he 2-byte read                                                                                                                         | •                                                                                             |                                                                                                             |  |  |
|               |       |      | <start> <i<sup>2C<br/> <stop></stop></i<sup></start>                                                 | adr.> <reg.adr.< td=""><th>&gt; <data of="" reg<="" th=""><td>.adr.&gt; <data of="" reg.adr.+1=""></data></td></data></th></reg.adr.<> | > <data of="" reg<="" th=""><td>.adr.&gt; <data of="" reg.adr.+1=""></data></td></data>       | .adr.> <data of="" reg.adr.+1=""></data>                                                                    |  |  |
|               |       |      |                                                                                                      | he 1-byte read                                                                                                                         | -                                                                                             | _                                                                                                           |  |  |
|               |       |      |                                                                                                      |                                                                                                                                        | reg.00 <sub>H</sub> > <data< th=""><td>a of reg.01<sub>H</sub>&gt; <stop></stop></td></data<> | a of reg.01 <sub>H</sub> > <stop></stop>                                                                    |  |  |
| <u> </u>      |       |      |                                                                                                      | See I <sup>2</sup> C read commands Callision avoidance                                                                                 |                                                                                               |                                                                                                             |  |  |
| CA            | 3     | rw   | Collision avoidance Clock stretching only in master-controlled and low-power mode, not in fast mode. |                                                                                                                                        |                                                                                               |                                                                                                             |  |  |
|               |       |      | The CA bit in                                                                                        |                                                                                                                                        |                                                                                               | Table 5 and Collision                                                                                       |  |  |
| INT           | 2     | rw   | Interrupt e                                                                                          | nabled                                                                                                                                 |                                                                                               |                                                                                                             |  |  |
|               |       |      | If 1 <sub>B</sub> /INT dis                                                                           |                                                                                                                                        |                                                                                               |                                                                                                             |  |  |
|               |       |      | conversion,                                                                                          | an /INT pulse                                                                                                                          | will be genera                                                                                |                                                                                                             |  |  |
|               |       |      | transfers an                                                                                         | d interrupt pu                                                                                                                         | lses must be n                                                                                | traints between I <sup>2</sup> C data<br>nonitored and aligned.                                             |  |  |
|               |       |      | $INT bit = 0_{B}$                                                                                    | may suppres                                                                                                                            | s the /INT puls                                                                               |                                                                                                             |  |  |
|               |       |      | The INT bit                                                                                          | interacts with                                                                                                                         | the <b>CA</b> bit, see                                                                        | Table 5 .                                                                                                   |  |  |

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

| Field | Bits | Туре | Description                                                                                                                                                          |
|-------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODE  | 1:0  | rw   | Power mode                                                                                                                                                           |
|       |      |      | If 00 <sub>B</sub> Low Power Mode:                                                                                                                                   |
|       |      |      | Cyclic measurements and ADC-conversions with a update rate, defined in the <i>PRD</i> registers. "No ADC trigger" must be used, see <i>Table 6</i> and <i>TRIG</i> . |
|       |      |      | If 01 <sub>B</sub> Master Controlled Mode (Power Down mode):                                                                                                         |
|       |      |      | Measurement triggering depends on the <i>PR</i> bit and is possible with I <sup>2</sup> C sub address byte (see <i>Table 6</i> ) or <i>TRIG</i> bits.                |
|       |      |      | If 10 <sub>B</sub> is reserved and must not be used.                                                                                                                 |
|       |      |      | If 11 <sub>B</sub> Fast Mode:                                                                                                                                        |
|       |      |      | The measurements and ADC-conversions are running continuously. It is recommended to set INT = $0_B$ and use a I <sup>2</sup> C clock speed $\geq$ 800 kHz.           |

Back to TLE493D-P2B6 Bitmap.

#### Table 4 Device address overview

The addresses are selected to ensure a minimum Hamming distance of 4 between them.

| Product<br>Type | Default address <sup>1)</sup> write | Default address <sup>1)</sup> read | IICadr (bit-6) | IICadr (bit-5) | <i>ID</i> (bit-5) | <i>ID</i> (bit-4) |
|-----------------|-------------------------------------|------------------------------------|----------------|----------------|-------------------|-------------------|
| A0              | 6A <sub>H</sub>                     | 6B <sub>H</sub>                    | 0 <sub>B</sub> | 0 <sub>B</sub> | 0 <sub>B</sub>    | 0 <sub>B</sub>    |
| A1              | 44 <sub>H</sub>                     | 45 <sub>H</sub>                    | 0 <sub>B</sub> | 1 <sub>B</sub> | 0 <sub>B</sub>    | 1 <sub>B</sub>    |
| A2              | F0 <sub>H</sub>                     | F1 <sub>H</sub>                    | 1 <sub>B</sub> | 0 <sub>B</sub> | 1 <sub>B</sub>    | 0 <sub>B</sub>    |
| A3              | 88 <sub>H</sub>                     | 89 <sub>H</sub>                    | 1 <sub>B</sub> | 1 <sub>B</sub> | 1 <sub>B</sub>    | 1 <sub>B</sub>    |

## Table 5 /INT (interrupt), collision avoidance and clock stretching configuration

| CA             | INT            | Configuration                                                                   |
|----------------|----------------|---------------------------------------------------------------------------------|
| 0 <sub>B</sub> | 0 <sub>B</sub> | /INT and collision avoidance enabled                                            |
|                |                | Clock stretching disabled                                                       |
| $0_{B}$        | 1 <sub>B</sub> | /INT and collision avoidance disabled                                           |
|                |                | Clock stretching enabled                                                        |
|                |                | This configuration must not be used:                                            |
|                |                | in fast mode                                                                    |
|                |                | • with the "read" trigger-bits $(7:5) = 010_B$ or $011_B$ (see <b>Table 6</b> ) |
|                |                | • with the trigger option <b>TRIG</b> bit = 01 <sub>B</sub> .                   |
| 1 <sub>B</sub> | 0 <sub>B</sub> | /INT enabled and collision avoidance disabled                                   |
|                |                | Clock stretching disabled                                                       |
| 1 <sub>B</sub> | 1 <sub>B</sub> | /INT and collision avoidance disabled                                           |
|                |                | Clock stretching disabled                                                       |

<sup>&</sup>lt;sup>1</sup> See data sheet ordering information

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



## 1 I<sup>2</sup>C Register

#### **Low Power Mode update rate**



If  $011_{\rm B}$  typ. update frequency  $f_{\rm Update} \approx 12$  Hz. If  $100_{\rm B}$  typ. update frequency  $f_{\rm Update} \approx 6$  Hz. If  $101_{\rm B}$  typ. update frequency  $f_{\rm Update} \approx 3$  Hz. If  $110_{\rm B}$  typ. update frequency  $f_{\rm Update} \approx 0.4$  Hz. If  $111_{\rm B}$  typ. update frequency  $f_{\rm Update} \approx 0.05$  Hz.

Do not modify, read before write required.

Back to TLE493D-P2B6 Bitmap.

Reserved

# 1.2.5 Diagnostic, status and version registers

rw

The device provides diagnostic and status information in register 06<sub>H</sub> and version information in register 16<sub>H</sub>.

**Factory settings** 

#### Sensor diagnostic and status register

4:0

| Register name | ġ.   |      | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                |                            |   | Reset Value     |
|---------------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------|---|-----------------|
| Diag          |      |      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6 <sub>H</sub> |                            |   | 60 <sub>H</sub> |
| 7             | 6    | 5    | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3              | 2                          | 1 | 0               |
| P             | FF   | CF   | т                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | PD3            | PD0                        | F | RM              |
| Field         | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                |                            |   | · · · ·         |
| P             | 7    | r    | Bus parity This bit adds up to an odd parity of the registers 00 <sub>H</sub> through 05 <sub>H</sub> (including 05 <sub>H</sub> ), described in <i>Measurement data and registe combined in the I<sup>2</sup>C parity bit "P"</i> .  The parity bit is generated during the I <sup>2</sup> C readout. The address byte, register byte and acknowledge bits are not included in the parity sum.  If the parity calculated by the microcontroller after I <sup>2</sup> C reads is |                |                            |   |                 |
|               |      |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                | the microconust be treated |   | C reads is      |

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                           |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FF    | 6    | r    | Fuse parity flag                                                                                                                                                                                                                                                                                      |
|       |      |      | Provides a flag from the internal fuse parity check of registers $11_H$ to $15_H$ . This parity check includes the $\emph{FP}$ bit.                                                                                                                                                                   |
|       |      |      | If 1 <sub>B</sub> parity is OK.                                                                                                                                                                                                                                                                       |
|       |      |      | If $0_B$ the parity is not correct. The sensor must be considered defective and must no longer be used. A sensor with an invalid fuse parity disconnects its SDA. It will automatically go to low-power mode and only uses the /INT signal to communicate the error (collision avoidance is enabled). |
| CF    | 5    | r    | Wake Up and configuration parity flag                                                                                                                                                                                                                                                                 |
|       |      |      | Provides a flag from the internal configuration and Wake Up parity check of registers $07_{\rm H}$ through $10_{\rm H}$ (including $10_{\rm H}$ ) without WA TST and PH bit. This parity check includes the $\it CP$ bit.                                                                             |
|       |      |      | If 1 <sub>B</sub> parity is OK.                                                                                                                                                                                                                                                                       |
|       |      |      | If 0 <sub>B</sub> parity is not OK, or after startup or after reset the <i>CP</i> bit is false to indicate a reset of all registers. Thus the <i>CP</i> bit has to be corrected once after startup or a reset.                                                                                        |
| T     | 4    | r    | Test mode                                                                                                                                                                                                                                                                                             |
|       |      |      | If $1_{\rm B}$ test mode is enabled. Data in registers $00_{\rm H}$ till $05_{\rm H}$ are either test results or - after a "ADC restart" - invalid measurement data.                                                                                                                                  |
|       |      |      | If 0 <sub>B</sub> test mode is disabled, valid measurement data available.                                                                                                                                                                                                                            |
| PD3   | 3    | r    | Power-down flag 3                                                                                                                                                                                                                                                                                     |
|       |      |      | If $1_B$ ADC-conversion of Temp is completed and valid measurement data can be read out. Thus it must be $1_B$ at readout.                                                                                                                                                                            |
|       |      |      | If $0_B$ ADC-conversion of Temp is running and read measurement data are invalid. Any readout with PD3 bit = $0_B$ should be considered invalid.                                                                                                                                                      |
|       |      |      | At startup, this is $0_{\rm B}$ until one ADC conversion has been performed. The value then changes to $1_{\rm B}$ .                                                                                                                                                                                  |
| PD0   | 2    | r    | Power-down flag 0                                                                                                                                                                                                                                                                                     |
|       |      |      | If $1_{B}$ the ADC conversion of Bx is completed and valid measurement data can be read out. Thus it must be $1_{B}$ at readout.                                                                                                                                                                      |
|       |      |      | If 0 <sub>B</sub> the ADC conversion of Bx is running and read measurement data are invalid. Any readout with PD0 bit = 0 <sub>B</sub> should be considered invalid.                                                                                                                                  |
|       |      |      | At startup, this is $0_{\rm B}$ until one ADC conversion has been performed. The value then changes to $1_{\rm B}$ .                                                                                                                                                                                  |
| FRM   | 1:0  | r    | Frame counter                                                                                                                                                                                                                                                                                         |
|       |      |      | Increments at every updated ADC-conversion, once a X/Y/Z/T or X/Y/Z or X/Y conversion is completed and the new measurement data have been stored in the registers $00_H$ till $05_H$ .                                                                                                                |
|       |      |      | The microcontroller shall check if bits change in consecutive conversion runs.                                                                                                                                                                                                                        |

Back to *TLE493D-P2B6 Bitmap*.

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



# 1 I<sup>2</sup>C Register

# **Version register**



| Field    | Bits | Туре | Description                                                 |
|----------|------|------|-------------------------------------------------------------|
| Reserved | 7:6  | r    | Factory settings                                            |
| TYPE     | 5:4  | r    | Chip feature                                                |
|          |      |      | If $00_B$ , $10_B$ or $01_B$ : device with Wake Up feature. |
| HWV      | 3:0  | r    | Hardware revision                                           |
|          |      |      | If 9 <sub>H</sub> it is the B21 design step.                |

Back to TLE493D-P2B6 Bitmap.

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 2 I<sup>2</sup>C Interface

# 2 I<sup>2</sup>C Interface

The TLE493D-P2B6 uses Inter-Integrated Circuit (I<sup>2</sup>C) as the communication interface with the microcontroller.

#### The I<sup>2</sup>C interface has three main functions:

- Sensor configuration
- · Transmit measurement data
- Interrupt handling

#### This sensor provides two I<sup>2</sup>C read protocols:

- 16-bit read frame (μC is driving data), so called **2-byte read command**.
- 8-bit read frame (μC is driving data), so called **1-byte read command**.

# 2.1 I<sup>2</sup>C protocol description

The TLE493D-P2B6 provides one I<sup>2</sup>C write protocol, based on 2 bytes and two I<sup>2</sup>C read protocols. Default is the 2-byte read protocol. With the **PR** bit it can be selected, if the 1-byte read protocol or the 2-byte read protocol is used.

## 2.1.1 General description

- The interface conforms to the I<sup>2</sup>C fast mode specification (400kBit/sec max.), but can be driven faster according to the data sheet.
- The TLE493D-P2B6 does not support "repeated starts". Each addressing requires a start condition.
- The interface can be accessed in any power mode.
- The data transmission order is Most Significant Bit (MSB) first, Least Significant Bit (LSB) last.
- A I<sup>2</sup>C communication is always initiated with a start condition and concluded with a stop condition by the master (microcontroller). During a start or stop condition the SCL line must stay "high" and the SDA line must change its state: SDA line falling = start condition and SDA line rising = stop condition.
- Bit transfer occur when the SCL line is "high".
- Each byte is followed by one ACK bit. The ACK bit is always generated by the recipient of each data byte.
  - If no error occurs during the data transfer, the ACK bit will be set to "low".
  - If an error occurs during the data transfer, the ACK bit will be set to "high".
  - If the communication is finished (before the Stop condition), the ACK bit must be set to "high".

#### 2.1.2 I<sup>2</sup>C write command

Write I<sup>2</sup>C communication description:

- The purpose of the sensor address is to identify the sensor with which communication should occur. The sensor address byte is required independently of the number of sensors connected to the microcontroller.
- The register address identifies the register in the bitmap (according to *Figure 1*) with which the first data byte will be written.
- Data bytes are transmitted as long as the SCL line generates pulses. Each additional data byte increments the register address until the stop condition occurs.
- Bytes transmitted beyond the register address frame are ignored and the corresponding ACK bit is sent "high", indicating an error.

The I<sup>2</sup>C write communication frame consists of:

- The start condition.
- The sensor address, according to Table 4.
- Write command bit = "low" (read = "high").

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 2 I<sup>2</sup>C Interface

- Acknowledge ACK.
- Trigger bits, according to *Table 6*.
- The register address, according to *Figure 1*.
- Acknowledge ACK.
- Writing of one or several bytes to the sensor, each byte followed by an acknowledge ACK.
- The stop condition.



Figure 2 General I<sup>2</sup>C write frame format: Write data from microcontroller to sensor

#### Trigger bits in the I<sup>2</sup>C protocol

The trigger bits are used in Power Down Mode. The Power Down Mode is used in the Master Controlled Mode, when no measurement is running. Thus the trigger bits are relevant for the Master Controlled Mode as well. For a more silent measurement environment it is recommended to separate the measurement and the communication as much as possible, by using the trigger bits =  $001_B$  or trigger bits =  $100_B$  and communicate between two measurements with reduced overlap of measurement and communication.

| Table 6 | I <sup>2</sup> C trigger | bits |
|---------|--------------------------|------|
|---------|--------------------------|------|

| Read/Write command | Trigger-bit 7  | Trigger-bit 6  | Trigger-bit 5  | Trigger command                                              |
|--------------------|----------------|----------------|----------------|--------------------------------------------------------------|
| 0 <sub>B</sub>     | 0 <sub>B</sub> | 0 <sub>B</sub> | 0 <sub>B</sub> | no ADC trigger                                               |
| 0 <sub>B</sub>     | 0 <sub>B</sub> | 0 <sub>B</sub> | 1 <sub>B</sub> | ADC trigger after write frame is finished, <i>Figure 4</i>   |
| 0 <sub>B</sub>     | 0 <sub>B</sub> | 1 <sub>B</sub> | 0 <sub>B</sub> | no ADC trigger                                               |
| 0 <sub>B</sub>     | 0 <sub>B</sub> | 1 <sub>B</sub> | 1 <sub>B</sub> | ADC trigger after write frame is finished, <i>Figure 4</i>   |
| 0 <sub>B</sub>     | 1 <sub>B</sub> | 0 <sub>B</sub> | 0 <sub>B</sub> | no ADC trigger                                               |
| 0 <sub>B</sub>     | 1 <sub>B</sub> | 0 <sub>B</sub> | 1 <sub>B</sub> | ADC trigger after write frame is finished, <i>Figure 4</i>   |
| 0 <sub>B</sub>     | 1 <sub>B</sub> | 1 <sub>B</sub> | 0 <sub>B</sub> | no ADC trigger                                               |
| 0 <sub>B</sub>     | 1 <sub>B</sub> | 1 <sub>B</sub> | 1 <sub>B</sub> | must not be used                                             |
| 1 <sub>B</sub>     | 0 <sub>B</sub> | 0 <sub>B</sub> | 0 <sub>B</sub> | no ADC trigger                                               |
| 1 <sub>B</sub>     | 0 <sub>B</sub> | 0 <sub>B</sub> | 1 <sub>B</sub> | no ADC trigger                                               |
| 1 <sub>B</sub>     | 0 <sub>B</sub> | 1 <sub>B</sub> | 0 <sub>B</sub> | ADC trigger before first MSB, <i>Figure 3</i>                |
| 1 <sub>B</sub>     | 0 <sub>B</sub> | 1 <sub>B</sub> | 1 <sub>B</sub> | ADC trigger before first MSB, <i>Figure 3</i>                |
| 1 <sub>B</sub>     | 1 <sub>B</sub> | 0 <sub>B</sub> | 0 <sub>B</sub> | ADC trigger after register 05 <sub>H</sub> , <i>Figure 5</i> |
| 1 <sub>B</sub>     | 1 <sub>B</sub> | 0 <sub>B</sub> | 1 <sub>B</sub> | ADC trigger after register 05 <sub>H</sub> , <i>Figure 5</i> |
| 1 <sub>B</sub>     | 1 <sub>B</sub> | 1 <sub>B</sub> | 0 <sub>B</sub> | ADC trigger after register 05 <sub>H</sub> , <i>Figure 5</i> |
| 1 <sub>B</sub>     | 1 <sub>B</sub> | 1 <sub>B</sub> | 1 <sub>B</sub> | must not be used                                             |

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 2 I<sup>2</sup>C Interface



Figure 3 ADC trigger before sending first MSB of data registers, I<sup>2</sup>C trigger bits 010<sub>B</sub>



Figure 4 ADC trigger after write frame is finished, I<sup>2</sup>C trigger bits 001<sub>B</sub>



Figure 5 ADC trigger after register 05<sub>H</sub>, I<sup>2</sup>C trigger bits 100<sub>B</sub>

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 2 I<sup>2</sup>C Interface

#### Example I<sup>2</sup>C write communication

An example of a write communication is provided in *Figure 6*.

In this example the sensor with the address  $6A_H$  /  $6B_H$  (see *Table 4*) should be configured for:

- Master Controlled Mode
- /INT disabled
- Clock stretching enabled
- No trigger of a measurement
- Other settings should be kept as is

## Implementation:

- The microcontroller generates a start condition
- Configuration changes can only be performed with a write command. The address for write operation of this sensor is  $6A_H = 01101010_R$
- If the sensor detects no error, the ACK = 0<sub>B</sub> is transmitted back to the microcontroller
- No measurement is performed if the trigger bits =  $000_{R}$
- The register to change the required settings is  $11_H$  according the bitmap **Figure 1** =  $10001_B$
- If the sensor detects no error, the ACK =  $0_B$  is transmitted back to the microcontroller
- The parity bit "FP" is the odd parity of the registers 11<sub>H</sub> and 13<sub>H</sub> (bits 7:5), see FP register, thus it is not possible to quantify it in this example
- The sensor address should not be changed, i.e. the sensor address  $6A_H / 6B_H$  should be kept. Thus the *IICadr* bits = 00<sub>B</sub>, see *IICadr* registers
- The 2-byte protocol should be kept as is. Thus the **PR** bit =  $0_{\rm R}$
- In order to enable clock stretching and disable /INT the CA bit must be set to 0<sub>B</sub> and the INT bit must be set to 1<sub>B</sub> (see *Table 5*)
- To use the Master Controlled Mode the MODE bits must be set to 01<sub>B</sub>
- If the sensor detects no error the ACK =  $0_B$  is transmitted back to the microcontroller
- The microcontroller generates the stop condition



Example I<sup>2</sup>C frame format 2-byte: Write data from microcontroller to sensor Figure 6



2 I<sup>2</sup>C Interface

#### I<sup>2</sup>C read commands 2.1.3

Read I<sup>2</sup>C communication description:

- The purpose of the sensor address is to identify the sensor with which communication should occur. The sensor address byte is required independently of the number of sensors connected to the microcontroller.
- Only available in the 2-byte read command: The register address identifies the register in the bitmap (according *Figure 1*) from which the first data byte will be read. In the 1-byte read command the read out starts always at the register address 00<sub>H</sub>.
- As many data bytes will be transferred as long as pulses are generated by the SCL line. Each additional data byte increments the register address. Until the stop condition occurs.
- If bytes are read beyond the register address frame the sensor keeps the SDA =  $1_B$ .
- If the microcontroller reads data and does not acknowledge the sensor data (ACK =  $1_B$ ) the sensor keeps the  $SDA = 1_B$  until the next stop condition.

#### 2-byte read command 2.1.3.1

The I<sup>2</sup>C read communication frame consists of:

- The start condition
- The sensor address, according to Table 4
- Read command bit = "high" (write = "low")
- Acknowledge ACK
- Trigger bits, according to Table 6
- The register address, according to Figure 1
- Acknowledge ACK
- Reading of one or several bytes from the sensor, each byte followed by an acknowledge ACK
- The stop condition



Figure 7 General I<sup>2</sup>C frame format 2-byte: Read data from sensor to microcontroller

#### 2.1.3.2 1-byte read command

The 1-byte read mode can be entered, by configuring the PR bit with an write communication. For example with the write cycle:

- start condition
- 6A<sub>H</sub> (sensor address)
- 11<sub>H</sub> (register address)
- $XXX1 XXXX_B (PR bit = 1_B)$
- stop condition

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 2 I<sup>2</sup>C Interface

The I<sup>2</sup>C communication frame consists of:

- The start condition
- The sensor address, according to Table 4
- Read command bit = "high" (write = "low")
- Acknowledge ACK
- Reading of one or several bytes from the sensor, each byte followed by an acknowledge ACK
- The stop condition



Figure 8 General I<sup>2</sup>C frame format 1-byte: Read data from sensor to microcontroller

## Example I<sup>2</sup>C 1-byte read communication

An example of a read communication is provided in *Figure 9*.

In this example, the sensor with the address  $F0_H/F1_H$  (see *Table 4*) should read out the measurement values, registers 00<sub>H</sub> - 05<sub>H</sub> and the diagnostic register 06<sub>H</sub>:

#### Implementation:

- The microcontroller generates a start condition
- The address for read operation of this sensor is  $F1_H = 11110001_B$ . This address value must be transmitted by the microcontroller to the sensor
- If the sensor detects no error, the ACK =  $0_B$  is transmitted back to the microcontroller
- The microcontroller must go on clocking the SCL line
- The sensor transmits 8 data bits of register 00<sub>H</sub> to the microcontroller
- If the microcontroller detects no error the ACK =  $0_B$  is transmitted back to the sensor
- The microcontroller must go on clocking the SCL line
- The sensor transmits 8 data bits of register 01<sub>H</sub> to the microcontroller
- After transmitting the register 06<sub>H</sub> the microcontroller transmits a NACK
- The microcontroller generates the stop condition



Figure 9 Example I<sup>2</sup>C frame format 1-byte: Read data from sensor to microcontroller

# infineon

2 I<sup>2</sup>C Interface

## 2.2 Collision avoidance and clock stretching

Using the configuration bits *CA* and *INT*, collision avoidance and clock stretching can be configured, see. An overview is given in *Table 5*. An example without collision avoidance and clock stretching is shown in *Figure 10*. In this example:

- The sensor interrupt disturbs the I<sup>2</sup>C clock, causing an additional SCL pulse which shifts the data read out by one bit
- The data read out starts when the ADC conversion is running



Figure 10 Example without collision avoidance CA bit =  $1_B$  and INT bit =  $0_B$ 

# 2.2.1 Collision avoidance (CA bit = $0_B$ and INT bit = $0_B$ )

In a bus configuration combined with an activated interrupt signal /INT it must be assured, that during any communication no interrupt /INT occurs. With collision avoidance enabled, the sensor monitors for any start/ stop condition, even if it does not detect a valid bus address. The interrupt signal /INT is omitted whenever a start condition is detected, as shown in *Figure 11*, in contrast to *Figure 10*. Only after a stop condition is detected, the interrupt signal /INT is generated by the sensor.

It is strongly recommended to use the collision avoidance feature whenever the interrupt signal /INT is used.



Figure 11 Example with collision avoidance CA bit = $0_B$  and INT bit = $0_B$ 



2 I<sup>2</sup>C Interface

# 2.2.2 Clock stretching (CA bit = $0_B$ and INT bit = $1_B$ )

With the clock stretching feature, the data read out starts after the ADC conversion is finished. Thus it can be avoided that during an ADC conversion old or corrupted measurement results are read out, which may occur when the ADC is writing to a register while this is being read out by the microcontroller. The clock stretching feature is shown in *Figure 12* in combination with a 1-byte read command. Clock stretching can also be used with a 2-byte read command.

The sensor pulls the SCL line to low during the following situation:

- An ADC conversion is in progress
- The sensor is addressed for register read (writes are never affected by clock stretching)
- The sensor is about to transmit the valid ACK in response to the I<sup>2</sup>C addressing of the microcontroller



Figure 12 Example with clock stretching CA bit  $=0_B$  and INT bit  $=1_B$ 

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 2 I<sup>2</sup>C Interface

# 2.3 Sensor reset by I<sup>2</sup>C

If the microcontroller is reset, the communication with the sensor may be corrupted, possibly causing the sensor to enter an incorrect state. The sensor can be reset via the I<sup>2</sup>C interface by sending the following command sequence from the microcontroller to the sensor:

- Start condition
- Sending FF<sub>H</sub>
- Stop condition
- Start condition
- Sending FF<sub>H</sub>
- Stop condition
- Start condition
- Sending 00<sub>H</sub>
- · Stop condition
- Start condition
- Sending 00<sub>H</sub>
- Stop condition
- 30 μs delay

After a reset, the sensor must be reconfigured to the desired settings. The reset sequence uses twice the identical data to assure a proper reset, even when an unexpected /INT pulse occurs.

Spikes can be interpreted as bus signals causing an action. For example when the collision avoidance feature is active and if the SDA line spikes together with SCL line this could be interpreted as start condition, blocking further /INT pulses until a stop condition appears on the bus. In such a case the sensor must be reset in order to initialize it. If the sensor does not respond after the reset, it must be considered defective.

Such spikes may occur as the sensor powers up. Because of this we recommend to using the reset sequence after each power up before configuring the sensor.

If the microcontroller resets during an ongoing I<sup>2</sup>C communication, the SDA line could get stuck low. This would block the I<sup>2</sup>C bus and is a well-known limitation of the I<sup>2</sup>C interface. To recover from this situation please use the reset sequence described in this chapter.



2 I<sup>2</sup>C Interface

# 2.4 Sensor Initialization and Readout example

To ensure that both the microcontroller and the sensor are synchronized and properly initialized, it is recommended to apply the I<sup>2</sup>C reset and upload the fuse register settings each time the microcontroller is reset, see *Figure 13*.



Figure 13 Microcontroller software flowchart for TLE493D-P2B6



2 I<sup>2</sup>C Interface

# 2.5 Loss of V<sub>DD</sub> impact on I<sup>2</sup>C bus

If the SDA or SCL line is pulled "low" and the sensor is disconnected from the  $V_{DD}$  supply line, the affected  $I^2C$  line will most likely get a stuck in the Low state and will interfere with the communication on the bus.



Figure 14 Example of I<sup>2</sup>C bus and a TLE493D-P2B6 with disconnected V<sub>DD</sub>

When V<sub>DD</sub> is pulled to GND the SDA and SCL line will not disturb the bus.



3 Wake Up mode

#### 3 Wake Up mode

The Wake Up mode (or short WU mode) is intended to be used together with the automated sensor modes (e.g. Low Power mode or Fast mode). In principle, it works with the Master Controlled mode as well, but it might not really be useful there because a controlled trigger usually implies the need to acquire a new measurement.

This WU mode can be used to allow the sensor to continue making magnetic field measurements while the uC is in the power-down state, which means the microcontroller will only consume power and access the sensor if relevant measurement data is available. This can be done either by using static thresholds (for example for applications where only movements of magnets away from a default position are relevant) or by using dynamic thresholds (where any movement over a specific uncertainty limit should be detected once). The figure below illustrates these two cases.



Figure 15 Static or Dynamic Wake Up Threshold Operation of the TLE493D-P2B6

This dynamic WU mode operation offers another option which is particularly useful in Fast mode with limited I<sup>2</sup>C bus capabilities and/or low bit rates. In this case, the WU mode can act as a "data filter" to reduce the bus load by preventing sensor data from being read that does not change significantly. So due to an interrupt, the new WU levels are adapted to the actual value read (for each X, Y, Z channel individually). This provides low latencies for detecting changes but reduces interrupts caused by similar values. If the collision avoidance feature is also used, the readout may take even longer than one conversion time (but this readout speed adds to the overall signal latency as well). As the thresholds also need to be set, a complete data read and set of new WU thresholds is not even feasible with the fastest specified bit rate within one sensor sample time in Fast mode.

The next figure illustrates this more clearly:



#### 3 Wake Up mode



Figure 16 Dynamic Wake Up Threshold Operation of the TLE493D-P2B6 for Bandwidth Reduction

To sum this up, we can state that this dynamic WU mode operation together with the Fast mode set allows detecting and reading significant value changes with low latency, even if the bit rate of the I<sup>2</sup>C cannot be set fast enough to read the data for each set of sensor data generated.

# 3.1 Wake Up activation

The Wake Up function can be activated with the **WU** bit and by modifying at least one of the Wake Up threshold registers of address 07<sub>H</sub> to 0F<sub>H</sub>, see **Configuration registers combined in the I<sup>2</sup>C parity flag "CF"**.

Please note that the Wake Up registers cover bit 11 to bit 1. Bit 0 is not accessible, but internally set with  $0_B$  to get a 12-bit value, for comparison with the 12-bit magnetic field value registers Bx, By and Bz.

## 3.2 Wake Up constraints

The Wake Up threshold range disabling /INT pulses between upper threshold and lower threshold is limited to a window of the half output range.

This window itself can be moved inside the full output range, as illustrated in *Figure 17*.

"Wake Up upper threshold" $_{D}$  > "Wake Up lower threshold" $_{D}$ 

#### **Equation 1**

"Wake Up upper threshold"<sub>D</sub> - "Wake Up lower threshold"<sub>D</sub> <  $2048_D$ LSB<sub>12</sub>

#### **Equation 2**



3 Wake Up mode



Figure 17 Wake Up enable and disable range examples

#### Wake Up in combination with the angular mode 3.3

In angular mode, see **DT** and **AM** bit, the

- "Wake Up Y upper threshold" must be written to the registers 0C<sub>H</sub> and 0F<sub>H</sub> (5 ... 3)(ZH in *Figure 1*)
- "Wake Up Y lower threshold" must be written to the registers 0B<sub>H</sub> and 0F<sub>H</sub> (3 ... 1)(ZL in *Figure 1*)

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 4 Diagnostic and tests

#### **Diagnostic and tests** 4

The sensor TLE493D-P2B6 provides diagnostic functions and test functions:

**Diagnostic functions:** 

These functions are running in the background, providing results, which can be checked by the microcontroller for the verification of the measurement results.

Test functions:

These functions are only executed by the sensor following a request by the microcontroller. The test functions provides test values instead of measurement values, which can be used to check if the sensor is working properly.

#### 4.1 **Diagnostic functions**

To ensure the integrity of received data the following diagnostic functions are available.

#### Parity bits and parity flags 4.1.1

Parity bits:

- **FP** (mode parity bit)
- **CP** (Wake Up and configuration parity bit)
- P (bus parity bit)

Parity flags:

- **FF** (mode parity flag)
- **CF** (Wake up and configuration parity flag)

#### 4.1.2 Test mode

The device is in test mode, this is indicated by the *T* register (Diag register 06<sub>H</sub> bit 4).

#### 4.1.3 **Power-down flags**

During measurements and during ADC conversion, the sensor monitors if the supply voltage is correct and if the conversion is finished. This is indicated by the PD3 and PD0 registers.

#### 4.1.4 Frame counter

The frame counter **FRM** register is incremented by one when a conversion is completed.

#### 4.1.5 **Device address**

The TLE493D-P2B6 can be ordered with different default addresses. This device address can be read out with the *IICadr* registers.

#### 4.2 **Test functions**

The TLE493D-P2B6 includes three test functions which can be activated by the microcontroller, using the TST registers in combination with the **PH** registers:

- Vhall/Vext test: checks the whole signal path from sensor to microcontroller
- Spintest: checks all Spin-switches, the Hall-offset and the ADC-offset
- SAT-test: checks the whole digital path from sensor to microcontroller

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### **4 Diagnostic and tests**

#### 4.2.1 Vhall/Vext test mode

This test checks the whole signal path, including the Hall plates, Hall biasing, multiplexer, ADC, data registers, oscillator, power management unit, interface, and the bandgap reference voltage. It also detects whether any Hall switch for the spinning (also known as chopping) is open or short.

#### 4.2.1.1 **Test description**

Instead of measuring the actual Hall voltages on the probe (which depend on the external magnetic field), a measurement cycle is performed where a voltage drop across the Hall probes is measured. For the temperature sensor, an external voltage (via the V<sub>DD</sub> pin) is connected.

As the voltage drop across the Hall probes and the external voltage is known, any unexpected output would detect a malfunctioning of the internal Hall biasing or the signal path.

This test should be executed in module production test first. The values generated in this first test should be compared, if inside the limits listed in *Table 7* and stored on module level. During module life time this stored values should be compared with additional life time tests and compared, if the values are inside the limits listed in Table 7.

#### 4.2.1.2 **Test implementation**

The test is performed as described below:

- Set the **TST** registers according to Vhall/Vext test
- Trigger a new measurement
- Read the value of Bx, By, Bz and Temp

#### Vhall test:

- Check that Bx, By, Bz and T have values inside the limits of Table 7
- Testing one voltage reference is sufficient to cover the Vhall test

#### Vext test:

- Make the microcontroller aware of the V<sub>DD</sub>-pin voltage
- Convert the Temp registers (11 ... 2) to Vext (11 ... 0) by multiplying the 10-bit Temp registers by 4<sub>D</sub>
- Check that the Vext value corresponds to the values listed in **Table 7**

#### After the test:

- Continue with another test or leave the test mode by setting the **TST** registers accordingly Timing:
- Typ. 0.5 ms are required for this implementation at an I<sup>2</sup>C interface baud rate of 400 kbit/s
- Typ. 0.3 ms are required for this implementation at an I<sup>2</sup>C interface baud rate of 1 Mbit/s

#### 4.2.1.3 **Test reference values**

The test limits are different for production and life time. Both is shown in *Table 7* and illustrated in *Figure 18*.

#### Table 7 Vhall/Vext diagnostic limits TLE493D-P2B6

| Diagnostic test                            | 1                 | productio | n test<br>ed for prod | Temperature and lieftime drift of stored product values |      |      |      |
|--------------------------------------------|-------------------|-----------|-----------------------|---------------------------------------------------------|------|------|------|
|                                            | Unit              | min.      | typ.                  | max.                                                    | Unit | min. | max. |
| Vhall X @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | 400       | 630                   | 900                                                     | %    | -20  | 20   |
| Vhall Y @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | 400       | 630                   | 900                                                     | %    | -20  | 20   |
| Vhall Z @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | 500       | 830                   | 1200                                                    | %    | -30  | 30   |
| Vext @ 3.3 V                               | LSB <sub>12</sub> | 1100      | 1370                  | 1650                                                    | %    | -5   | 5    |

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 4 Diagnostic and tests

Table 7 Vhall/Vext diagnostic limits TLE493D-P2B6 (continued)

| Diagnostic test                              | Module p             |      | n test<br>ed for prod | Temperature and lieftime drift of stored product values |      |      |      |
|----------------------------------------------|----------------------|------|-----------------------|---------------------------------------------------------|------|------|------|
|                                              | Unit                 | min. | typ.                  | max.                                                    | Unit | min. | max. |
| Vext gain @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> /V | 300  | 430                   | 500                                                     | %    | -10  | 10   |



Figure 18 Vhall/Vext diagnostic limits vs. lifetime

## 4.2.2 Spintest mode

This test checks the correct spinning (also known as chopping) of all four phases of a Hall probe for the three channels Bx, By and Bz of the sensor and that the Hall probes offset and the ADC offset is within specified limits. Also offers diagnostic coverage for the multiplexer, ADC, oscillator and power management unit. Limited coverage for the biasing, registers and interface as well.

## 4.2.2.1 Test description

$$4V_H + (2V_{Oh} - 2V_{Oh} + 2V_{Oa} - 2V_{Oa}) = 4V_H$$

#### **Equation 3**

In a magnetic measurement run, the result of the four spins is:

- V<sub>H</sub> is the voltage at the Hall probes
- V<sub>Oh</sub> is the voltage offset at the Hall probes
- V<sub>Oa</sub> is the voltage offset at the ADC

By spinning the measurement four times at the Hall probes, the Hall offset and the ADC offset are eliminated in magnetic measurements. The Spintest can be used to measure these offsets.

The PH register selects, which Hall probe is measured by the Spintest, see *Table 3*. This Hall probe is then measured four times, and every time another spinning phase is disregarded, see *Figure 19*. Thus, four results are stored in the registers Bx (11 ... 0), By (11 ... 0), Bz (11 ... 0) and T (11 ... 2).

The ADC offset can be measured with  $PH = 11_B$ . In this Spintest, the ADC compares the temperature sensor with an internal reference voltage. During the test, the temperature and the reference are swapped (setting1 and setting2). The offset of the ADC can be calculated according to **Equation 7**. The temperature, including the offset, can be calculated according to **Equation 6**.

Each Spintest Bx, By, Bz and T has the same duration as a measurement cycle consisting of a Bx, By, Bz and T measurement.

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### 4 Diagnostic and tests



Figure 19 Spintest concept of one Hall probe, please see also Table 3

Disabling the first or the forth phase leads to the following result:

$$3V_H + (1V_{Oh} - 2V_{Oh} + 1V_{Oa} - 2V_{Oa}) = 3V_H - 1V_{Oh} - 1V_{Oa}$$

#### **Equation 4**

Disabling the second or the third phase leads to the following result:

$$3V_H + (2V_{Oh} - 1V_{Oh} + 2V_{Oa} - 1V_{Oa}) = 3V_H + 1V_{Oh} + 1V_{Oa}$$

#### **Equation 5**

Spintest magnetic field calculation:

$$B_{X,Y,Z(Spin)} = \frac{B_X(11 \dots 0) \ + \ B_Y(11 \dots 0) \ + \ B_Z(11 \dots 0) \ + \ 4 \cdot Temp(11 \dots 2)}{3}$$

#### **Equation 6**

Spintest offset calculation:

$$V_{Oh} = \frac{B_X(11 \dots 0) + 4 \cdot Temp(11 \dots 2) - B_Y(11 \dots 0) - B_Z(11 \dots 0)}{4} + 512$$

#### **Equation 7**

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### **4 Diagnostic and tests**

#### 4.2.2.2 **Test implementation**

The test is performed as described below:

- Set the **TST** registers according "no test"
- Read and store the values of Bx, By and Bz of any magnetic measurement
- Set the **TST** registers according Spintest
- Set the **PH** registers to  $00_B$  to test the Bx Hall probe
- Trigger a new measurement
- Read the value of Bx, By, Bz and Temp. Please note: The Temp (11 ... 2) needs to be multiplied by 4<sub>D</sub> to get the 12-bit Temp-value
- Calculate the offset with **Equation 7** and check against the values listed in **Table 8**
- For a proper test result the magnetic field must be stable during the test. This can be checked by calculating the magnetic field from the Spintest with **Equation 6** and comparing the result with the latest "no test" measurement. If a difference in value is identified, the test can be run again to discard that the fault is due to a change of the magnetic field (instead of a chip fault)
- Repeat the last five steps (PH setting, measurement trigger, value read out, ...) with PH registers incrementing to 01<sub>B</sub>, 10<sub>B</sub> and 11<sub>B</sub>, according **Table 3**

#### After the test:

- Continue with another test or leave the test mode by setting the **TST** registers accordingly Timing:
- Typ. 2.3 ms are required for this implementation at an I<sup>2</sup>C interface baud rate of 400 kbits/s
- Typ. 1.4 ms are required for this implementation at an I<sup>2</sup>C interface baud rate of 1 Mbit/s

#### **Test reference values** 4.2.2.3

The test limits are different for production and life time. Both is shown in **Table 8** and illustrated in **Figure** 20. The spintest should be executed during the module production test first. The offset values (Equation 7) generated in the first test should be compared to make sure that they are inside the limits specified in *Table* 8, section "Module production test" and stored on module level. During module lifetime these stored values must be compared in an additional Spintest to check if the values are inside the limits listed in *Table 8*, section "Temperature and lifetime drift".

Spintest diagnostic limits TLE493D-P2B6 Table 8

| Diagnostic test                               | 1                 | production t<br>d stored for p | Temperature and lifetime drift of stored product V <sub>Oh</sub> values |                   |      |      |
|-----------------------------------------------|-------------------|--------------------------------|-------------------------------------------------------------------------|-------------------|------|------|
|                                               | Unit              | min.                           | max.                                                                    | Unit              | min. | max. |
| Spintest X @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | -200                           | 200                                                                     | LSB <sub>12</sub> | -130 | 130  |
| Spintest Y @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | -200                           | 200                                                                     | LSB <sub>12</sub> | -130 | 130  |
| Spintest Z @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | -160                           | 160                                                                     | LSB <sub>12</sub> | -60  | 60   |
| Spintest T @ V <sub>DD</sub> = 2.8 V to 3.5 V | LSB <sub>12</sub> | -160                           | 160                                                                     | LSB <sub>12</sub> | -60  | 60   |

#### High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



#### **4 Diagnostic and tests**



Figure 20 Spintest diagnostic limits vs. lifetime

#### 4.2.3 **SAT-test mode**

This test checks the whole digital signal path from sensor to microcontroller. This includes the ADC's digital core, the data register, the I<sup>2</sup>C interface and the I<sup>2</sup>C bus as well.

#### 4.2.3.1 **Test description**

This test checks the Successive Approximation and Tracking (SAT) mechanism used for the four spin phases of each data channel (Hall probes and temperature sensor).

The results, listed in *Table 3* are outside of the specified linear range for Hall values and temperature. Thus, it is possible to easily distinguish between values from the test mode and values from normal operation. An unintended enabling of the test can therefore be identified.

#### 4.2.3.2 **Test implementation**

The test is performed as described below:

- Set the test register **TST** accordingly
- Select one combination of PH and X2 register out of Table 3 Please note: One combination is sufficient for a valid SAT-test
- Trigger a new measurement
- Read the values of Bx, By, Bz and Temp and compare if they are inside the limits specified in Table 3 After the test:
- Continue with another test or leave the test mode by setting the **TST** registers accordingly Timing:

This test requires one write command with three data bytes and one readout with seven data bytes and the measurement run time. The readouts may take place immediately after a new diagnostic is set and the measurement is triggered.

- Typ. 0.5ms are required for this implementation at an I2C interface baud rate of 400kbit/s
- Typ. 0.3ms are required for this implementation at an I2C interface baud rate of 1Mbit/s

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



## **4 Diagnostic and tests**

# 4.3 Magnetic measurement implementation

A magnetic measurement can be performed as described below:

- Set the TST registers according "no test"
- Trigger a measurement
- Read the value of Bx, By, Bz and Temp Please note: The Temp (11 ... 2) needs to be multiplied by  $4_{\rm D}$  to get the 12-bit Temp-value Timing:
- Typ. 0.5 ms are required for this implementation at an I<sup>2</sup>C interface baud rate of 400 kbit/s
- Typ. 0.3 ms are required for this implementation at an I<sup>2</sup>C interface baud rate of 1 Mbit/s

## High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



## **5 Terminology**

#### **Terminology** 5

Α

ACK Acknowledge

Analog/Digital Converter ADC

adr address

Ε

**EMC Electromagnetic Compatibility** 

G

**GND** Ground

I

ID **IDentification** 

I<sup>2</sup>C (I2C) Inter - Integrated Circuit

/INT Interrupt pin, Interrupt signal

L

LSB Least Significant Bit

Magnetic field Magnetic flux density that the sensor measures

min minimum

MSB Most Significant Bit

maximum max

Ρ

**PCB Printed Circuit Board** 

R

register reg

S

SCL Clock pin **SDA** Data pin

Sensor Refers to the TLE493D-P2B6 product

Sensor module Refers to the TLE493D-P2B6 product and all the passive elements in the

customer's module

Supply Refers to the sensor supply pins V<sub>DD</sub> and GND (the unused pins are assumed to be

connected to GND as well)

٧

Supply voltage  $V_{DD}$ 

W

WU Wake Up

μ

Microcontoller μC

# High Accuracy Low Power 3D Hall Sensor with I<sup>2</sup>C Interface



6 Revision history

#### **Revision history** 6

| Revision  | Date       | Changes         |
|-----------|------------|-----------------|
| Ver. 1.00 | 2020-12-11 | Initial release |

#### Trademarks

All referenced product or service names and trademarks are the property of their respective owners.

Edition 2020-12-11 Published by Infineon Technologies AG 81726 Munich, Germany

© 2020 Infineon Technologies AG All Rights Reserved.

Do you have a question about any aspect of this document?

 ${\bf Email: erratum@infineon.com}$ 

Document reference IFX-shv1605257952928

#### IMPORTANT NOTICE

The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics ("Beschaffenheitsgarantie").

With respect to any examples, hints or any typical values stated herein and/or any information regarding the application of the product, Infineon Technologies hereby disclaims any and all warranties and liabilities of any kind, including without limitation warranties of non-infringement of intellectual property rights of any third party.

In addition, any information given in this document is subject to customer's compliance with its obligations stated in this document and any applicable legal requirements, norms and standards concerning customer's products and any use of the product of Infineon Technologies in customer's applications.

The data contained in this document is exclusively intended for technically trained staff. It is the responsibility of customer's technical departments to evaluate the suitability of the product for the intended application and the completeness of the product information given in this document with respect to such application.

#### WARNINGS

Due to technical requirements products may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies office.

Except as otherwise explicitly approved by Infineon Technologies in a written document signed by authorized representatives of Infineon Technologies, Infineon Technologies' products may not be used in any applications where a failure of the product or any consequences of the use thereof can reasonably be expected to result in personal injury.